Skip to content

Latest commit

 

History

History
88 lines (68 loc) · 3.11 KB

File metadata and controls

88 lines (68 loc) · 3.11 KB

@blockly/field-colour-hsv-sliders Built on Blockly

A Blockly colour field using HSV sliders for editing.

A Blockly workspace showing the HSV sliders.

Installation

Yarn

yarn add @blockly/field-colour-hsv-sliders

npm

npm install @blockly/field-colour-hsv-sliders --save

Usage

This plugin adds a field type FieldColourHsvSliders that is registered to the name 'field_colour_hsv_sliders'. This field is an extension of the Blockly.FieldColour field and outputs values in the same hexadecimal string format '#rrggbb' even though the UI represents the colour in the HSV colour space. See the Blockly.FieldColour documentation on what parameters and configurations this field supports, although unlike Blockly.FieldColour, this field does not use colour swatches and thus ignores options related to the swatches such as 'colourOptions'.

The UI also provides an eye dropper button that can be used to take a colour from anywhere on the screen on supported platforms. Chrome, Edge, and Opera support the eye dropper feature, except on Chromebooks and on mobile devices. There is also a known bug in Chrome on some versions of Linux where the eye dropper may be visible but does not work correctly.

To use it, you'll need to add this field to a block type definition, and add that block to your toolbox. See below for an example of defining a block type that uses this field.

JSON

import * as Blockly from 'blockly';
import '@blockly/field-colour-hsv-sliders';
import {javascriptGenerator, Order} from 'blockly/javascript';

Blockly.defineBlocksWithJsonArray([
  {
    type: 'colour_hsv_sliders',
    message0: 'hsv %1',
    args0: [
      {
        type: 'field_colour_hsv_sliders',
        name: 'COLOUR',
        colour: '#ff0000',
      },
    ],
    output: 'Colour',
    style: 'colour_blocks',
  },
]);

javascriptGenerator.forBlock['colour_hsv_sliders'] = function (
  block,
  generator,
) {
  const code = generator.quote_(block.getFieldValue('COLOUR'));
  return [code, Order.ATOMIC];
};

JavaScript

import * as Blockly from 'blockly';
import {FieldColourHsvSliders} from '@blockly/field-colour-hsv-sliders';
import {javascriptGenerator, Order} from 'blockly/javascript';

Blockly.Blocks['colour_hsv_sliders'] = {
  init: function () {
    this.appendDummyInput()
      .appendField('hsv ')
      .appendField(new FieldColourHsvSliders('#ff0000'), 'COLOUR');
    this.setOutput(true, 'Colour');
    this.setStyle('colour_blocks');
  },
};
javascriptGenerator.forBlock['colour_hsv_sliders'] = function (
  block,
  generator,
) {
  const code = generator.quote_(block.getFieldValue('COLOUR'));
  return [code, Order.ATOMIC];
};

License

Apache 2.0