Design
Analyze a WebP/VP8 image with Sharp, generate a grayscale displacement map, and render it as an interactive Three.js 3D relief surface
Call this tool from your code in three languages.
# 1) Upload each file first → returns { filePath }
curl -X POST 'https://api.elysiatools.com/upload/vp8-image-analyzer' \
-F 'file=@/path/to/imageFile.ext'
# 2) Call the tool with the returned filePath values
curl -X POST 'https://api.elysiatools.com/en/api/tools/vp8-image-analyzer' \
-F 'imageFile=/public/samples/images/sample-landscape.webp' \
-F 'displacementScale=1.25' \
-F 'segments=192' \
-F 'maxTextureSize=1024' \
-F 'autoRotate=true' \
-F 'wireframe=false'Send a POST request with your inputs as JSON. File parameters require a separate upload first.
POST https://api.elysiatools.com/en/api/tools/vp8-image-analyzer| Name | Type | Required | Description |
|---|---|---|---|
| imageFile | fileupload required | Yes | — |
| displacementScale | range | No | — |
| segments | range | No | — |
| maxTextureSize | select | No | — |
| autoRotate | checkbox | No |
Add this tool to your Model Context Protocol server so AI agents can list and call it.
Add this block to your MCP client configuration:
{
"mcpServers": {
"elysiatools-vp8-image-analyzer": {
"name": "vp8-image-analyzer",
"description": "Analyze a WebP/VP8 image with Sharp, generate a grayscale displacement map, and render it as an interactive Three.js 3D relief surface",
"baseUrl": "https://api.elysiatools.com/mcp/sse?toolId=vp8-image-analyzer",
"command": "",
"args": [],
"env": {},
"isActive": true,
"type": "sse"
}
}
}After connecting to the SSE endpoint, list the exposed tools:
{
"jsonrpc": "2.0",
"id": 1,
"method": "tools/list"
}Invoke the tool by its id, passing arguments built from its parameters:
{
"jsonrpc": "2.0",
"id": 2,
"method": "tools/call",
"params": {
"name": "vp8-image-analyzer",
"arguments": {
"imageFile": "/public/samples/images/sample-landscape.webp",
"displacementScale": 1.25,
"segments": 192,
"maxTextureSize": "1024",
"autoRotate": true,
"wireframe": false
}
}
}| — |
| wireframe | checkbox | No | — |
HTML result
{
"result": "<div>Processed HTML content</div>",
"error": "Error message (optional)",
"message": "Notification message (optional)",
"metadata": {
"key": "value"
}
}Questions or issues? Contact [email protected]