Merge several images into one image
🤖/image/merge merges several images into a single spritesheet.

The final result will be a spritesheet, with the images displayed horizontally or vertically.
It's recommended to use this Robot with 🤖/image/resize so your images are of a similar size before merging them.
Usage example
Merge uploaded images into one, with a 5px gap between them on the spritesheet:
{
"steps": {
"merged": {
"robot": "/image/merge",
"use": {
"steps": [
":original"
],
"bundle_steps": true
},
"border": 5
}
}
}Parameters
interpolateboolean | Record<string, boolean>Controls whether Assembly Variables are interpolated for individual instruction fields.
By default, most Robot instruction fields interpolate Assembly Variables. Set this to
falseto treat every instruction field as literal text, or set an individual field path tofalseto treat only that field as literal text. For Robot-specific fields that are literal by default, set this totrueor set that field path totrueto opt back into interpolation.Use field names such as
path, or dotted paths such asffmpeg.vffor nested objects.output_metaRecord<string, boolean> | boolean | Array<string>Allows you to specify a set of metadata that is more expensive on CPU power to calculate, and thus is disabled by default to keep your Assemblies processing fast.
For images, you can add
"has_transparency": truein this object to extract if the image contains transparent parts and"dominant_colors": trueto extract an array of hexadecimal color codes from the image.For images, you can also add
"blurhash": trueto extract a BlurHash string — a compact representation of a placeholder for the image, useful for showing a blurred preview while the full image loads.For videos, you can add the
"colorspace: true"parameter to extract the colorspace of the output video.For audio, you can add
"mean_volume": trueto get a single value representing the mean average volume of the audio file.You can also set this to
falseto skip metadata extraction and speed up transcoding.resultboolean(default:false)Whether the results of this Step should be present in the Assembly Status JSON
queuebatchSetting the queue to 'batch', manually downgrades the priority of jobs for this step to avoid consuming Priority job slots for jobs that don't need zero queue waiting times
force_acceptboolean(default:false)Force a Robot to accept a file type it would have ignored.
By default, Robots ignore files they are not familiar with. 🤖/video/encode, for example, will happily ignore input images.
With the
force_acceptparameter set totrue, you can force Robots to accept all files thrown at them. This will typically lead to errors and should only be used for debugging or combatting edge cases.ignore_errorsboolean | Array<meta | execute>(default:[])Ignore errors during specific phases of processing.
Setting this to
["meta"]will cause the Robot to ignore errors during metadata extraction.Setting this to
["execute"]will cause the Robot to ignore errors during the main execution phase.Setting this to
trueis equivalent to["meta", "execute"]and will ignore errors in both phases.usestring | Array<string> | Array<object> | objectSpecifies which Step(s) to use as input.
- You can pick any names for Steps except
":original"(reserved for user uploads handled by Transloadit) - You can provide several Steps as input with arrays:
{ "use": [ ":original", "encoded", "resized" ] } - You can also tag an input Step with
asto pass semantic intent to robots: - You can also tag input Steps with
asto pass semantic intent to robots:{ "use": [ { "name": ":original", "as": "image" }, { "name": ":original", "as": "mask" } ] }
Tip
That's likely all you need to know about
use, but you can view Advanced use cases.- You can pick any names for Steps except
formatjpg | png | webp(default:"png")The output format for the modified image.
directionhorizontal | vertical(default:"horizontal")Specifies the direction which the images are displayed.
Only applies to the default spritesheet layout. Ignored when
effectis set topolaroid-stackormosaic, as those effects use their own layout algorithms.effectmosaic | polaroid-stackApplies a styled collage layout instead of a plain horizontal or vertical spritesheet.
Currently supports
polaroid-stack, which renders the inputs as overlapping instant photos on a canvas, andmosaic, which builds a justified tiled collage.borderstring | number(default:0)An integer value which defines the gap between images on the spritesheet.
A value of
10would cause the images to have the largest gap between them, while a value of1would place the images side-by-side.When
effectispolaroid-stack, this value is instead used as canvas padding so the outermost photos keep that many pixels of distance from the edge.When
effectismosaic, this value is used both as the outer canvas padding and as the gutter width between neighbouring tiles.backgroundstring | transparent | none | black | white | red | green | blue |(default:"#fff")Either the hexadecimal code or name of the color used to fill the background (only shown with a border > 1).
By default, the background of transparent images is changed to white. Set to
noneortransparentfor a transparent canvas — requiresformatpngorwebpto preserve alpha.For details about how to preserve transparency across all image types, see this demo.
widthstring | numberThe output canvas width in pixels.
This is mainly used by styled effects such as
polaroid-stackandmosaic.heightstring | numberThe output canvas height in pixels.
This is mainly used by styled effects such as
polaroid-stackandmosaic.seedstring | numberOptional deterministic seed used by styled effects such as
polaroid-stackandmosaic.shuffleboolean(default:false)Whether styled effects such as
polaroid-stackandmosaicmay shuffle the input order before laying out the canvas.coveragestring | numberArea-coverage multiplier for the
polaroid-stackeffect. Controls how large each polaroid is relative to the canvas and consequently how much of the canvas is covered by photos.The default of
1.5leaves a subtle beige border along some edges. Use2.0–2.5for edge-to-edge coverage (photos overlap more). Values below1.0produce smaller, more widely spaced polaroids.Has no effect on the
mosaicstyle or on plain spritesheets.adaptive_filteringboolean(default:false)Controls the image compression for PNG images. Setting to
trueresults in smaller file size, while increasing processing time. It is encouraged to keep this option disabled.qualitystring | number(default:100)Controls the image compression for JPG, PNG, and WebP images. Please also take a look at 🤖/image/optimize.