Search
Loading...
Skip to content

Options

Exporting via the block.export endpoint allows fine-grained control of the target format. CE.SDK currently supports exporting scenes, pages, groups, or individual blocks in the MP4, PNG, TGA, JPEG, WEBP, BINARY and PDF formats. To specify the desired type, just pass in the corresponding mimeType. Pass additional options in a mime-type specific object.

Static Design Export Options#

FormatMimeTypeOptions (Default)
PNGimage/pngpngCompressionLevel (5) - The compression level is a trade-off between file size and encoding/decoding speed, but doesn’t affect quality. Valid values are [0-9] ranging from no to maximum compression.
JPEGimage/jpegjpegQuality (0.9) - Directly influences the resulting files visual quality. Smaller = worse quality, but lower file size. Valid values are (0-1]
WEBPimage/webpwebpQuality (1.0) - Controls the desired output quality. 1.0 results in a special lossless encoding that usually produces smaller file sizes than PNG. Valid values are (0-1], higher means better quality.
BINARYapplication/octet-streamNo additional options. This type returns the raw image data in RGBA8888 order in a blob.
PDFapplication/pdfexportPdfWithHighCompatibility (true) - Increase compatibility with different PDF viewers. Images and effects will be rasterized with regard to the scene’s DPI value instead of simply being embedded.
PDFapplication/pdfexportPdfWithUnderlayer (false) - An underlayer is generated by adding a graphics block behind the existing elements of the shape of the elements on the page.
PDFapplication/pdfunderlayerSpotColorName ("") - The name of the spot color to be used for the underlayer’s fill.
PDFapplication/pdfunderlayerOffset (0.0) - The adjustment in size of the shape of the underlayer.

Certain formats allow additional configuration, e.g., options.jpegQuality controls the output quality level when exporting to JPEG. These format-specific options are ignored when exporting to other formats. You can choose which part of the scene to export by passing in the respective block as the first parameter.

For all formats, an optional targetWidth and targetHeight in pixels can be specified. If used, the block will be rendered large enough, that it fills the target size entirely while maintaining its aspect ratio. The supported export size limit can be queried with editor.getMaxExportSize(), the width and height should not exceed this value.

PDF Export Performance#

The exportPdfWithHighCompatibility option controls how images and gradients are embedded in PDFs. When set to false, PDF exports can be 6-15x faster for high-DPI content by embedding images directly instead of rasterizing them. However, this may cause rendering issues in Safari and macOS Preview with gradients that use transparency. See the PDF conversion guide for detailed performance optimization guidance and testing recommendations.

Video Export Options#

  • mimeType
  • h264Profile
  • h264Level
  • videoBitrate
  • audioBitrate
  • timeOffset
  • duration
  • framerate
  • targetWidth
  • targetHeight
  • abortSignal

Audio Export Options#

  • mimeType
  • sampleRate
  • numberOfChannels
  • timeOffset
  • duration
  • skipEncoding
  • abortSignal

Export a Static Design#

Export a design block element, e.g., a scene, a page, a group, or a single block, as a file of the given mime type.

export(handle: DesignBlockId, options?: ExportOptions): Promise<Blob>

Exports a design block element as a file of the given mime type. Performs an internal update to resolve the final layout for the blocks.

  • handle: The design block element to export.
  • options: The options for exporting the block type
  • Returns A promise that resolves with the exported image or is rejected with an error.

Export details:

  • Exporting automatically performs an internal update to resolve the final layout for all blocks.
  • Only blocks that belong to the scene hierarchy can be exported.
  • The export will include the block and all child elements in the block hierarchy.
  • If the exported block itself is rotated it will be exported without rotation.
  • If a margin is set on the block it will be included.
  • If an outside stroke is set on the block it will be included except for pages.
  • Exporting a scene with more than one page may result in transparent areas between the pages, it is recommended to export the individual pages instead.
  • Exporting as JPEG drops any transparency on the final image and may lead to unexpected results.

Export with a Color Mask#

exportWithColorMask(handle: DesignBlockId, maskColorR: number, maskColorG: number, maskColorB: number, options?: ExportOptions): Promise<Blob[]>

Exports a design block element as a file of the given mime type. Performs an internal update to resolve the final layout for the blocks.

  • handle: The design block element to export.
  • maskColorR: The red component of the special color mask color.
  • maskColorG: The green component of the special color mask color.
  • maskColorB: The blue component of the special color mask color.
  • options: The options for exporting the block type
  • Returns A promise that resolves with an array of the exported image and mask or is rejected with an error.

Export details:

  • Removes all pixels that exactly match the given RGB color and replaces them with transparency.
  • The output includes two files: the masked image and the mask itself.

Export a Video#

Export a page as a video file of the given mime type.

exportVideo(handle: DesignBlockId, options?: VideoExportOptions): Promise<Blob>

Exports a design block as a video file of the given mime type. Note: The export will run across multiple iterations of the update loop. In each iteration a frame is scheduled for encoding.

  • handle: The design block element to export. Currently, only page blocks are supported.
  • options: The options for exporting the video.
  • Returns A promise that resolves with a video blob or is rejected with an error.
type VideoExportOptions = {
mimeType?: VideoMimeType;
onProgress?: (
numberOfRenderedFrames: number,
numberOfEncodedFrames: number,
totalNumberOfFrames: number,
) => void;
h264Profile?: number;
h264Level?: number;
videoBitrate?: number;
audioBitrate?: number;
timeOffset?: number;
duration?: number;
framerate?: number;
targetWidth?: number;
targetHeight?: number;
abortSignal?: AbortSignal;
};

Video export details:

  • Exporting automatically performs an internal update to resolve the final layout for all blocks and waits until all pending assets have been loaded.
  • Only blocks that belong to the scene hierarchy can be exported.
  • The given block determines the size, camera position, and rotation in the same manner as the static design export.
  • The given block does not influence the time offset and duration of the video. This can be controlled using the timeOffset and duration options.
  • The video resolution is determined by the largest page width and the largest page height. This can be overridden using the targetWidth and targetHeight options.
  • When using H.264, transparency info is lost and the video will be exported with a black background.

Export Audio#

Export a page, audio block, video block, or track as an audio file of the given mime type.

exportAudio(handle: DesignBlockId, options?: AudioExportOptions): Promise<Blob>

Exports a design block as an audio file of the given mime type. Note: The export runs in a background worker and will run across multiple iterations of the update loop.

  • handle: The design block element to export. Currently supports page blocks, audio blocks, video blocks, and track blocks.
  • options: The options for exporting the audio.
  • Returns A promise that resolves with an audio blob or is rejected with an error.
type AudioExportOptions = {
mimeType?: AudioMimeType;
onProgress?: (
numberOfRenderedFrames: number,
numberOfEncodedFrames: number,
totalNumberOfFrames: number
) => void;
sampleRate?: number;
numberOfChannels?: number;
timeOffset?: number;
duration?: number;
skipEncoding?: boolean;
abortSignal?: AbortSignal;
};

Audio export details:

  • Exporting automatically performs an internal update to resolve the final layout for all blocks and waits until all pending assets have been loaded.
  • Only blocks that belong to the scene hierarchy can be exported.
  • Supported block types: Pages (//ly.img.ubq/page), audio blocks (//ly.img.ubq/audio), video fills (//ly.img.ubq/fill/video), and tracks (//ly.img.ubq/track).
  • When exporting a page, all audio from audio blocks, video fills, and other audio sources on the page will be mixed together.
  • When exporting an audio block, only that audio block’s audio will be exported, respecting its trim and duration settings.
  • When exporting a video block with audio, only the audio track from that video will be exported, respecting its trim and duration settings.
  • When exporting a track, all audio from blocks within that track will be mixed together.
  • The timeOffset option allows you to start the audio export from a specific time in seconds (default: 0).
  • The duration option allows you to specify the length of the exported audio in seconds. If not specified, the duration of the block is used.
  • The sampleRate option controls the sample rate of the exported audio in Hz (default: 48000).
  • The numberOfChannels option controls the number of audio channels (default: 2 for stereo).
  • The skipEncoding option allows exporting audio data directly without encoding (default: false).
  • Supported mime types: audio/wav for WAV format and audio/mp4 for M4A/AAC format.

Export Information#

Before exporting, the maximum export size and available memory can be queried.

getMaxExportSize(): number

Get the export size limit in pixels on the current device. An export is only possible when both the width and height of the output are below or equal this limit. However, this is only an upper limit as the export might also not be possible due to other reasons, e.g., memory constraints.

  • Returns The upper export size limit in pixels or an unlimited size, i.e, the maximum signed 32-bit integer value, if the limit is unknown.
getAvailableMemory(): number

Get the currently available memory in bytes.

  • Returns The currently available memory in bytes.

Exporting via the Export button#

When a user triggers an export by clicking the corresponding button in the navigation bar, the editor will call the exportDesign callback. By default, this exports the current page and downloads it to the user’s device. You can customize this behavior by registering your own callback implementation.

// Register custom export handler
cesdk.actions.register('exportDesign', async options => {
// Use the utils API to perform the export
const { blobs, options: exportOptions } = await cesdk.utils.export(options);
// Custom handling - e.g., upload to CDN instead of download
await uploadToYourCDN(blobs);
});

To enable the export button in the navigation bar, see the configuration of elements for further information.

Full Code#

Here’s the full code:

import CreativeEngine from 'https://cdn.img.ly/packages/imgly/cesdk-engine/1.62.0/index.js';
const config = {
license: 'mtLT-_GJwMhE7LDnO8KKEma7qSuzWuDxiKuQcxHKmz3fjaXWY2lT3o3Z2VdL5twm',
userId: 'guides-user',
baseURL:
'https://cdn.img.ly/packages/imgly/cesdk-engine/1.62.0/assets',
};
const exportButton = document.getElementById('export_button');
const scene = engine.scene.get();
const page = engine.scene.getCurrentPage();
const sceneBlob = await engine.block.export(scene, {
mimeType: 'application/pdf',
});
const pageBlob = await engine.block.export(page, { mimeType: 'image/png' });
const [image, mask] = await engine.block.exportWithColorMask(
page,
0.5,
0.5,
0.5,
{
mimeType: 'image/png',
},
);
if (groupable) {
const group = engine.block.group([member1, member2]);
const groupBlob = await engine.block.export(group, { mimeType: 'image/png' });
}
const blockBlob = await engine.block.export(block, {
/**
* The mime type of the output file.
*
* Supported values are:
* - `image/png`
* - `image/jpeg`
* - `image/webp`
* - `image/x-tga`
* - `application/octet-stream`
* - `application/pdf`
*/
mimeType: 'image/jpeg',
/**
* The JPEG quality to use when encoding to JPEG.
*
* Valid values are (0-1], higher means better quality.
* Ignored for other encodings.
*
* @defaultValue 0.9
*/
jpegQuality: 0.9,
/**
* The PNG compression level to use, when exporting to PNG.
*
* Valid values are 0 to 9, higher means smaller, but slower.
* Quality is not affected.
* Ignored for other encodings.
* @defaultValue 5.
*/
pngCompressionLevel: 5,
/**
* An optional target width used in conjunction with target height.
* If used, the block will be rendered large enough, that it fills the target
* size entirely while maintaining its aspect ratio.
*/
targetWidth: null,
/**
* An optional target height used in conjunction with target width.
* If used, the block will be rendered large enough, that it fills the target
* size entirely while maintaining its aspect ratio.
*/
targetHeight: null,
});
// Video Export
const videoOptions = {
/**
* The mime type of the output file.
*
* Supported values are:
* - `video/mp4`
* - `video/quicktime`
*/
mimeType: 'video/mp4',
/**
* A callback which reports on the progress of the export.
* It informs the receiver of the current frame index, which
* currently gets exported and the total frame count.
*/
onProgress: (renderedFrames, encodedFrames, totalFrames) => {
console.log(
'Rendered',
renderedFrames,
'frames and encoded',
encodedFrames,
'frames out of',
totalFrames,
);
},
/**
* Determines the encoder feature set and in turn the quality, size and speed of the encoding process.
*
* @defaultValue 77 (Main)
*/
h264Profile: 77,
/**
* Controls the H.264 encoding level. This relates to parameters used by the encoder such as bit rate,
* timings and motion vectors. Defined by the spec are levels 1.0 up to 6.2. To arrive at an integer value,
* the level is multiplied by ten. E.g. to get level 5.2, pass a value of 52.
*
* @defaultValue 52
*/
h264Level: 52,
/**
* The video bitrate in bits per second. The maximum bitrate is determined by h264Profile and h264Level.
* If the value is 0, the bitrate is automatically determined by the engine.
*/
videoBitrate: 0,
/**
* The audio bitrate in bits per second. If the value is 0, the bitrate is automatically determined by the engine (128kbps for stereo AAC stream).
*/
audioBitrate: 0,
/**
* The time offset in seconds of the scene's timeline from which the video will start.
*
* @defaultValue 0
*/
timeOffset: 0,
/**
* The duration in seconds of the final video.
*
* @defaultValue The duration of the given page.
*/
duration: 10,
/**
* The target framerate of the exported video in Hz.
*
* @defaultValue 30
*/
framerate: 30,
/**
* An optional target width used in conjunction with target height.
* If used, the block will be rendered large enough, that it fills the target
* size entirely while maintaining its aspect ratio.
*/
targetWidth: 1280,
/**
* An optional target height used in conjunction with target width.
* If used, the block will be rendered large enough, that it fills the target
* size entirely while maintaining its aspect ratio.
*/
targetHeight: 720,
};
const videoBlob = await engine.block.exportVideo(page, videoOptions);
// Audio Export
const audioOptions = {
/**
* The mime type of the output file.
*
* Supported values are:
* - `audio/wav`
* - `audio/mp4`
*/
mimeType: 'audio/mp4',
/**
* A callback which reports on the progress of the export.
* It informs the receiver of the number of rendered frames,
* the number of encoded frames, and the total frame count.
*/
onProgress: (renderedFrames, encodedFrames, totalFrames) => {
console.log(
'Rendered',
renderedFrames,
'frames and encoded',
encodedFrames,
'frames out of',
totalFrames,
);
},
/**
* The time offset in seconds from which the audio will start.
*
* @defaultValue 0
*/
timeOffset: 0,
/**
* The duration in seconds of the final audio.
*
* @defaultValue The duration of the given block.
*/
duration: 10,
/**
* The sample rate of the exported audio in Hz.
*
* @defaultValue 48000
*/
sampleRate: 48000,
/**
* The number of audio channels. 1 for mono, 2 for stereo.
*
* @defaultValue 2
*/
numberOfChannels: 2,
/**
* Export audio data from in-memory buffers without re-encoding.
*
* @defaultValue false
*/
skipEncoding: false,
};
const audioBlob = await engine.block.exportAudio(
page,
audioOptions,
);
const maxExportSizeInPixels = engine.editor.getMaxExportSize();
const availableMemoryInBytes = engine.editor.getAvailableMemory();
CreativeEngine.init(config).then(async engine => {
document.getElementById('cesdk_container').append(engine.element);
await engine.addDefaultAssetSources();
await engine.scene.loadFromURL(
'https://cdn.img.ly/assets/demo/v1/ly.img.template/templates/cesdk_postcard_1.scene',
);
exportButton.removeAttribute('disabled');
exportButton.onclick = async () => {
/* Export scene as PNG image. */
const scene = engine.scene.get();
/* Optionally, the maximum supported export size can be checked before exporting. */
const maxExportSizeInPixels = engine.editor.getMaxExportSize();
/* Optionally, the compression level and the target size can be specified. */
const options = {
mimeType: 'image/png',
pngCompressionLevel: 9,
targetWidth: null,
targetHeight: null,
};
const blob = await engine.block.export(scene, options);
/* Download blob. */
const anchor = document.createElement('a');
anchor.href = URL.createObjectURL(blob);
anchor.download = 'export.png';
anchor.click();
};
});