Zoom option

  • Blockly workspaces can be scaled dynamically by users or statically by developers.

  • Zoom settings are customizable using Blockly's configuration options, controlling aspects like zoom controls, mouse wheel zoom, and initial scale.

  • Zoom levels can be defined using startScale, maxScale, and minScale properties within the configuration object to manage the zoom extent.

  • scaleSpeed property determines the rate at which the workspace is zoomed in or out with each step.

  • Pinch-to-zoom functionality on touch devices can be enabled through the pinch option in the zoom settings.

Blockly's main workspace may be scalable, either dynamically by the user, or statically by the developer.

The zoom settings are defined by an object that is part of Blockly's configuration options. Here is an example:

var workspace = Blockly.inject('blocklyDiv',
    {toolbox: document.getElementById('toolbox'),
     zoom:
         {controls: true,
          wheel: true,
          startScale: 1.0,
          maxScale: 3,
          minScale: 0.3,
          scaleSpeed: 1.2,
          pinch: true},
     trashcan: true});

controls

Set to true to show zoom-centre, zoom-in, and zoom-out buttons. Defaults to false.

The zoom-centre, zoom-in, and zoom-out
buttons.

wheel

Set to true to allow the mouse wheel to zoom. Defaults to false.

startScale

Initial magnification factor. For applications with multiple levels, startScale is often set to a higher value on the first level, then incrementally decreased as subsequent levels become more complex. Defaults to 1.0.

maxScale

Maximum multiplication factor for how far one can zoom in. Defaults to 3.

minScale

Minimum multiplication factor for how far one can zoom out. Defaults to 0.3.

scaleSpeed

For each zooming in-out step the scale is multiplied or divided respectively by the scale speed, this means that: scale = scaleSpeed ^ steps. Note that in this formula steps of zoom-out are subtracted and zoom-in steps are added. Defaults to 1.2.

pinch

Set to true to enable pinch to zoom support on touch devices. Defaults to true if either the wheel or controls option is set to true.