4.14.4.4 颜色选择器
优质
小牛编辑
137浏览
2023-12-01
颜色字段存储一个字符串作为其值,并存储一个字符串作为其文本。 它的值是格式为#rrggbb的字符串,而其文本也可以是格式为#rgb的字符串。
颜色字段
打开编辑器的颜色字段
压缩的颜色字段
新建
{
"type": "example_colour",
"message0": "colour: %1",
"args0": [
{
"type": "field_colour",
"name": "FIELDNAME",
"colour": "#ff0000"
}
]
}
颜色字段构造函数采用一个可选值和一个可选验证器。 该值应该是格式为“ #rrggbb”的字符串。 如果未提供任何值或给定的值无效,则将使用默认颜色数组中的第一项。
可序列化和XML
颜色选自器对应的XML代码如下所示:
<field name="FIELDNAME">#ff0000</field>
字段节点的名称属性包含一个引用颜色字段的字符串,该节点的内部文本是要应用于该字段的值。 内部文本值遵循与构造函数值相同的规则。
请注意,在反序列化和重新序列化之后,所有内部文本值将采用#rrggbb格式。 在区分工作空间时,这有时很重要。
定制化
编辑器选项
setColours函数可用于设置颜色字段的颜色选项。 它采用一个颜色字符串数组(必须以#rrggbb格式定义)和一个可选的工具提示数组。 如果未提供工具提示数组,则将使用默认的工具提示数组。
工具提示和颜色是根据数组索引而不是值来匹配的。 如果colors数组比工具提示数组长,则额外颜色的工具提示将为其#rrggbb值。
setColumns函数设置颜色选择器中的列数。
{
"type": "example_colour",
"message0": "colour: %1",
"args0": [
{
"type": "field_colour",
"name": "COLOUR",
"colour": "#ff4040"
}
],
"extensions": ["set_colours_extension"]
这是使用JSON扩展名完成的。
}
Blockly.Extensions.register('set_colours_extension',
function() {
var field = this.getField("COLOUR");
field.setColours(
['#ff4040', '#ff8080', '#ffc0c0',
'#4040ff', '#8080ff', '#c0c0ff'],
['dark pink', 'pink', 'light pink',
'dark blue', 'blue', 'light blue']);
field.setColumns(3);
});
可选地,默认颜色,工具提示和列可以全局覆盖。 这意味着它们将影响所有颜色字段,而不是特定字段。
Blockly.FieldColour.COLOURS = [
'#ff4040', '#ff8080', '#ffc0c0',
'#4040ff', '#8080ff', '#c0c0ff'];
Blockly.FieldColour.TITLES = [
'dark pink', 'pink', 'light pink',
'dark blue', 'blue', 'light blue'];
Blockly.FieldColour.COLUMNS = 3;
新建一个颜色选择器
颜色字段的值是#rrggbb格式的字符串,因此任何验证器都必须接受#rrggbb格式的字符串,并返回#rrggbb格式的字符串,null或undefined。
这是一个验证器的示例,它更改块的颜色以匹配块的颜色。
function(newValue) {
this.getSourceBlock().setColour(newValue);
return newValue;
}
根据色域阻止更改颜色