A Blockly colour field using HSV sliders for editing.
yarn add @blockly/field-colour-hsv-sliders
npm install @blockly/field-colour-hsv-sliders --save
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.
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];
};
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];
};
Apache 2.0