Layout
In this example, we will show you how to use the CreativeEditor SDK's CreativeEngine to modify scenes layout through the block
API.
Setup#
This example uses the headless CreativeEngine. See the Setup article for a detailed guide.
To get started right away, you can also access the block
API within a running CE.SDK instance via cesdk.engine.block
.
Check out the APIs Overview to see that illustrated in more detail.
Layout of Blocks#
Note on layout and frame size#
The frame size is determined during the layout phase of the render process
inside the engine.
This means that calling getFrameSize()
immediately after modifying the scene
might return an inaccurate result.
The CreativeEngine supports three different modes for positioning blocks. These can be set for each block and both coordinates independently:
'Absolute'
: the position value is interpreted in the scene's current design unit.'Percent'
: the position value is interpreted as percentage of the block's parent's size, where 1.0 means 100%.'Auto'
: the position is automatically determined.
Likewise there are also three different modes for controlling a block's size. Again both dimensions can be set independently:
'Absolute'
: the size value is interpreted in the scene's current design unit.'Percent'
: the size value is interpreted as percentage of the block's parent's size, where 1.0 means 100%.'Auto'
: the block's size is automatically determined by the size of the block's content.
Positioning#
getPositionX(id: DesignBlockId): number
Query a block's x position.
id
: The block to query.- Returns The value of the x position.
getPositionY(id: DesignBlockId): number
Query a block's y position.
id
: The block to query.- Returns The value of the y position.
getPositionXMode(id: DesignBlockId): PositionMode
Query a block's mode for its x position.
id
: The block to query.- Returns The current mode for the x position: absolute, percent or undefined.
getPositionYMode(id: DesignBlockId): PositionMode
Query a block's mode for its y position.
id
: The block to query.- Returns The current mode for the y position: absolute, percent or undefined.
setPositionX(id: DesignBlockId, value: number): void
Update a block's x position. The position refers to the block's local space, relative to its parent with the origin at the top left. Required scope: 'layer/move'
id
: The block to update.value
: The value of the x position.
setPositionY(id: DesignBlockId, value: number): void
Update a block's y position. The position refers to the block's local space, relative to its parent with the origin at the top left. Required scope: 'layer/move'
id
: The block to update.value
: The value of the y position.
setPositionXMode(id: DesignBlockId, mode: PositionMode): void
Set a block's mode for its x position. Required scope: 'layer/move'
id
: The block to update.mode
: The x position mode: absolute, percent or undefined.
setPositionYMode(id: DesignBlockId, mode: PositionMode): void
Set a block's mode for its y position. Required scope: 'layer/move'
id
: The block to update.mode
: The y position mode: absolute, percent or undefined.
type PositionMode = 'Absolute' | 'Percent' | 'Auto'
- Absolute: Position in absolute design units. - Percent: Position in relation to the block's parent's size in percent, where 1.0 means 100%. - Auto: Position is automatically determined
Size#
getWidth(id: DesignBlockId): number
Query a block's width.
id
: The block to query.- Returns The value of the block's width.
getWidthMode(id: DesignBlockId): SizeMode
Query a block's mode for its width.
id
: The block to query.- Returns The current mode for the width: absolute, percent or auto.
getHeight(id: DesignBlockId): number
Query a block's height.
id
: The block to query.- Returns The value of the block's height.
getHeightMode(id: DesignBlockId): SizeMode
Query a block's mode for its height.
id
: The block to query.- Returns The current mode for the height: absolute, percent or auto.
setWidth(id: DesignBlockId, value: number, maintainCrop?: boolean): void
Update a block's width and optionally maintain the crop. If the crop is maintained, the crop values will be automatically adjusted. The content fill mode Cover
is only kept if the features/transformEditsRetainCoverMode
setting is enabled, otherwise it will change to Crop
. Required scope: 'layer/resize'
id
: The block to update.value
: The new width of the block.maintainCrop
: Whether or not the crop values, if available, should be automatically adjusted.
setWidthMode(id: DesignBlockId, mode: SizeMode): void
Set a block's mode for its width. Required scope: 'layer/resize'
id
: The block to update.mode
: The width mode: Absolute, Percent or Auto.
setHeight(id: DesignBlockId, value: number, maintainCrop?: boolean): void
Update a block's height and optionally maintain the crop. If the crop is maintained, the crop values will be automatically adjusted. The content fill mode Cover
is only kept if the features/transformEditsRetainCoverMode
setting is enabled, otherwise it will change to Crop
. Required scope: 'layer/resize'
id
: The block to update.value
: The new height of the block.maintainCrop
: Whether or not the crop values, if available, should be automatically adjusted.
setHeightMode(id: DesignBlockId, mode: SizeMode): void
Set a block's mode for its height. Required scope: 'layer/resize'
id
: The block to update.mode
: The height mode: Absolute, Percent or Auto.
type SizeMode = 'Absolute' | 'Percent' | 'Auto'
- Absolute: Size in absolute design units. - Percent: Size in relation to the block's parent's size in percent, where 1.0 means 100%. - Auto: Size is automatically determined
Layers#
setAlwaysOnTop(id: DesignBlockId, enabled: boolean): void
Update the block's always-on-top property. If true, this blocks's global sorting order is automatically adjusted to be higher than all other siblings without this property. If more than one block is set to be always-on-top, the child order decides which is on top.
id
: the block to update.enabled
: whether the block shall be always-on-top.
isAlwaysOnTop(id: DesignBlockId): boolean
Query a block's always-on-top property.
id
: the block to query.- Returns true if the block is set to be always-on-top, false otherwise.
setAlwaysOnBottom(id: DesignBlockId, enabled: boolean): void
Update the block's always-on-bottom property. If true, this blocks's global sorting order is automatically adjusted to be lower than all other siblings without this property. If more than one block is set to be always-on-bottom, the child order decides which is on bottom.
id
: the block to update.enabled
: whether the block shall always be below its siblings.
isAlwaysOnBottom(id: DesignBlockId): boolean
Query a block's always-on-bottom property.
id
: the block to query.- Returns true if the block is set to be always-on-bottom, false otherwise.
bringToFront(id: DesignBlockId): void
Updates the sorting order of this block and all of its manually created siblings so that the given block has the highest sorting order.
id
: The id of the block to be given the highest sorting order among its siblings.
sendToBack(id: DesignBlockId): void
Updates the sorting order of this block and all of its manually created siblings so that the given block has the lowest sorting order.
id
: The id of the block to be given the lowest sorting order among its siblings.
bringForward(id: DesignBlockId): void
Updates the sorting order of this block and all of its superjacent siblings so that the given block has a higher sorting order than the next superjacent sibling.
id
: The id of the block to be given a higher sorting than the next superjacent sibling.
sendBackward(id: DesignBlockId): void
Updates the sorting order of this block and all of its manually created and subjacent siblings so that the given block will have a lower sorting order than the next subjacent sibling.
id
: The id of the block to be given a lower sorting order than the next subjacent sibling.
Rotation#
getRotation(id: DesignBlockId): number
Query a block's rotation in radians.
id
: The block to query.- Returns The block's rotation around its center in radians.
setRotation(id: DesignBlockId, radians: number): void
Update a block's rotation. Required scope: 'layer/rotate'
id
: The block to update.radians
: The new rotation in radians. Rotation is applied around the block's center.
Flipping#
getFlipHorizontal(id: DesignBlockId): boolean
Query a block's horizontal flip state.
id
: The block to query.- Returns A boolean indicating for whether the block is flipped in the queried direction
getFlipVertical(id: DesignBlockId): boolean
Query a block's vertical flip state.
id
: The block to query.- Returns A boolean indicating for whether the block is flipped in the queried direction
setFlipHorizontal(id: DesignBlockId, flip: boolean): void
Update a block's horizontal flip. Required scope: 'layer/flip'
id
: The block to update.flip
: If the flip should be enabled.
setFlipVertical(id: DesignBlockId, flip: boolean): void
Update a block's vertical flip. Required scope: 'layer/flip'
id
: The block to update.flip
: If the flip should be enabled.
Scaling#
scale(id: DesignBlockId, scale: number, anchorX?: number, anchorY?: number): void
Scales the block and all of its children proportionally around the specified relative anchor point. This updates the position, size and style properties (e.g. stroke width) of the block and its children. Required scope: 'layer/resize'
id
: The block that should be scaled.scale
: The scale factor to be applied to the current properties of the block.anchorX
: The relative position along the width of the block around which the scaling should occur. (0 = left edge, 0.5 = center, 1 = right edge)anchorY
: The relative position along the height of the block around which the scaling should occur. (0 = top edge, 0.5 = center, 1 = bottom edge)
Fill a Block's Parent#
fillParent(id: DesignBlockId): void
Resize and position a block to entirely fill its parent block. Required scope: 'layer/move' - 'layer/resize'
id
: The block that should fill its parent.
Resize Blocks Content-aware#
resizeContentAware(ids: DesignBlockId[], width: number, height: number): void
Resize all blocks to the given size. The content of the blocks is automatically adjusted to fit the new dimensions. Required scope: 'layer/resize'
ids
: The blocks to resize.width
: The new width of the blocks.height
: The new height of the blocks.
Even Distribution#
Multiple blocks can be distributed horizontally or vertically within their bounding box. The blocks are moved to have the remaining space divided evenly between the blocks. Blocks without a position and blocks that are not allowed to be moved will not be distributed.
isDistributable(ids: DesignBlockId[]): boolean
Confirms that a given set of blocks can be distributed.
ids
: An array of block ids.- Returns Whether the blocks can be distributed.
distributeHorizontally(ids: DesignBlockId[]): void
Distribute multiple blocks horizontally within their bounding box so that the space between them is even. Required scope: 'layer/move'
ids
: A non-empty array of block ids.
distributeVertically(ids: DesignBlockId[]): void
Distribute multiple blocks vertically within their bounding box so that the space between them is even. Required scope: 'layer/move'
ids
: A non-empty array of block ids.
Alignment#
Multiple blocks can be aligned horizontally or vertically within their bounding box. When a group is given, the elements within the group are aligned. If a single block is given, it gets aligned within its parent. Blocks without a position and blocks that are not allowed to be moved will not be aligned.
isAlignable(ids: DesignBlockId[]): boolean
Confirms that a given set of blocks can be aligned.
ids
: An array of block ids.- Returns Whether the blocks can be aligned.
alignHorizontally(ids: DesignBlockId[], horizontalBlockAlignment: HorizontalBlockAlignment): void
Align multiple blocks horizontally within their bounding box or a single block to its parent. Required scope: 'layer/move'
ids
: A non-empty array of block ids.alignment
: How they should be aligned: left, right, or center
alignVertically(ids: DesignBlockId[], verticalBlockAlignment: VerticalBlockAlignment): void
Align multiple blocks vertically within their bounding box or a single block to its parent. Required scope: 'layer/move'
ids
: A non-empty array of block ids.alignment
: How they should be aligned: top, bottom, or center
Computed Dimensions#
getFrameX(id: DesignBlockId): number
Get a block's layout position on the x-axis. The position is only available after an internal update loop which only occurs if the features/implicitUpdatesEnabled
setting is set.
id
: The block to query.- Returns The layout position on the x-axis.
getFrameY(id: DesignBlockId): number
Get a block's layout position on the y-axis. The position is only available after an internal update loop which only occurs if the features/implicitUpdatesEnabled
setting is set.
id
: The block to query.- Returns The layout position on the y-axis.
getFrameWidth(id: DesignBlockId): number
Get a block's layout width. The width is only available after an internal update loop which only occurs if the features/implicitUpdatesEnabled
setting is set.
id
: The block to query.- Returns The layout width.
getFrameHeight(id: DesignBlockId): number
Get a block's layout height. The height is only available after an internal update loop which only occurs if the features/implicitUpdatesEnabled
setting is set.
id
: The block to query.- Returns The layout height.
getGlobalBoundingBoxX(id: DesignBlockId): number
Get the x position of the block's axis-aligned bounding box in the scene's global coordinate space. The scene's global coordinate space has its origin at the top left.
id
: The block whose bounding box should be calculated.- Returns float The x coordinate of the position of the axis-aligned bounding box.
getGlobalBoundingBoxY(id: DesignBlockId): number
Get the y position of the block's axis-aligned bounding box in the scene's global coordinate space. The scene's global coordinate space has its origin at the top left.
id
: The block whose bounding box should be calculated.- Returns float The y coordinate of the position of the axis-aligned bounding box.
getGlobalBoundingBoxWidth(id: DesignBlockId): number
Get the width of the block's axis-aligned bounding box in the scene's global coordinate space. The scene's global coordinate space has its origin at the top left.
id
: The block whose bounding box should be calculated.- Returns float The width of the axis-aligned bounding box.
getGlobalBoundingBoxHeight(id: DesignBlockId): number
Get the height of the block's axis-aligned bounding box in the scene's global coordinate space. The scene's global coordinate space has its origin at the top left.
id
: The block whose bounding box should be calculated.- Returns float The height of the axis-aligned bounding box.
getScreenSpaceBoundingBoxXYWH(ids: DesignBlockId[]): XYWH
Get the position and size of the axis-aligned bounding box for the given blocks in screen space.
ids
: The block to query.- Returns The position and size of the bounding box.
Transform Locking#
You can lock the transform of a block to prevent changes to any of its transformations. That is the block's position, rotation, scale, and sizing.
isTransformLocked(id: DesignBlockId): boolean
Query a block's transform locked state. If true, the block's transform can't be changed.
id
: The block to query.- Returns True if transform locked, false otherwise.
setTransformLocked(id: DesignBlockId, locked: boolean): void
Update a block's transform locked state.
id
: The block to update.locked
: Whether the block's transform should be locked.