AutoJs6 文档 - 6.6.4


目录

Color (颜色类)#

颜色类 Color 是一个全局类, 用于生成一个颜色实例:

typeof global.Color; // "function"

let c = new Color('red');
Object.getPrototypeOf(c) === Color.prototype; // true
c.getRed(); // 255
c.getRedDouble(); // 1

Color 类是对 colors 模块的一种变式封装, 用于解决 colors 模块冗余嵌套的难题.

例如需要对颜色 hsv(174,100,59) 设置 80% 透明度然后返回其 Hex 代码:

colors.toHex(colors.setAlpha(colors.hsv(174, 100, 59), 0.8));

或使用变量拆写形式以增加可读性:

let color = colors.hsv(174, 100, 59);
let colorWithAlpha = colors.setAlpha(color, 0.8);
colors.toHex(colorWithAlpha);

使用 Color 实例进行链式调用, 可使代码更轻量且易读:

new Color().setHsv(174, 100, 59).setAlpha(0.8).toHex();

链式拆行形式:

new Color()
    .setHsv(174, 100, 59)
    .setAlpha(0.8)
    .toHex();

注: 上述示例仅用于演示, 实际可使用 colors.hsva 或 Color#setHsva 同时设置 HSV 分量与 A 分量.

Color 实例方法的使用方式与 colors 模块对应方法多数情况是类似的, 因此某些情况下可用于替代 colors 模块.

setremove 为前缀的方法, 通常都会返回 Color 自身类型, 从而支持链式调用, 如 setAlpha, removeAlpha, setRed, removeRed, setHsv, setRgba 等.

为便于使用, Color 类在使用 JavaScript 代码设计时, 支持省略 new 关键字的语法形式:

new Color('blue');
Color('blue'); /* 效果同上. */

new Color().setAlpha(0.5).summary();
Color().setAlpha(0.5).summary();  /* 结果同上. */

需额外留意, Color 类的 new 关键字省略, 是 AutoJs6 开发者在编写 Color 类时为便于使用而专门设计的, 并不适用于所有构造器, 详情参阅 JavaScript 语法规范.

参阅: MDN / Ecma 标准

colors.build 也可用于构造一个 Color 实例:

new Color();
Color(); /* 同上. */
colors.build(); /* 同上. */

new Color('green');
Color('green'); /* 同上 */
colors.build('green'); /* 同上 */

new Color(120, 24, 72, 0.5);
Color(120, 24, 72, 0.5); /* 同上. */
colors.build(120, 24, 72, 0.5); /* 同上. */

本章节后续内容将不再赘述 colors.build(...) 的替代语法, 且统一使用省略 new 关键字的 Color 实例构造语法, 即 Color(...).


Color


[C] Color#

[c] (color?)#

6.3.0 Global Overload [1-2]/5

构建一个颜色实例, 初始颜色由 color 参数指定, 参数省略时默认为 黑色 (#FF000000).

Color().toHex(); // #000000
Color('black').toHex(); /* 同上. */
Color(0).setAlpha(1).toHex(); /* 同上. */

Color('green').toHex(); // #00FF00
Color('#00FF00').toHex(); /* 同上. */
Color().setGreen(255).toHex(); /* 同上. */
Color('white').removeRed().removeBlue().toHex(); /* 同上. */ 

需特别留意, Color(0) 返回的不是默认的黑色, 而是 透明色 (#00000000):

Color(0).toFullHex(); // #00000000
Color().toFullHex(); // #FF000000

Color(0).setAlpha(1).toFullHex(); // #FF000000
Color().removeAlpha().toFullHex(); // #00000000

[c] (red, green, blue, alpha?)#

6.3.0 Global Overload [3-4]/5

构建一个颜色实例, 初始颜色由多个参数指定, 其中 alpha 参数省略时默认为 1 (100%).

Color(255, 255, 255); /* 白色. */
Color(0, 0, 255, 0.5); /* 半透明蓝色. */

需特别留意, 颜色分量值为 0 时不可省略, 如 Color(255, 0, 0) 不可省略为 Color(255).

[c] (themeColor)#

6.3.0 Global Overload 5/5

  • themeColor { ThemeColor } - 主题颜色实例
  • returns { Color } - Color 实例

构建一个颜色实例, 初始颜色为 AutoJs6 主题色的 主色 (Primary Color).

Color(autojs.themeColor).toHex(); /* AutoJs6 主题色主色的 Hex 代码. */

此构造方法相当于 Color(ThemeColor#getColorPrimary).

Color(autojs.themeColor.getColorPrimary()).toHex();
Color(autojs.themeColor).toHex(); /* 效果同上. */

[m#] toInt#

toInt()#

6.3.0

获取颜色实例的 颜色整数 (ColorInt).

/* ColorHex - 颜色代码. */
Color('#CC5500').toInt(); // -3386112
Color('#C50').toInt(); // -3386112
Color('#FFCC5500').toInt(); // -3386112

/* ColorInt - 颜色整数. */
Color(0xFFCC5500).toInt(); // -3386112
Color(colors.web.BURNT_ORANGE).toInt(); // -3386112

/* ColorName - 颜色名称. */
Color('BURNT_ORANGE').toInt(); // -3386112
Color('burnt-orange').toInt(); // -3386112

[m#] toHex#

toHex()#

6.3.0 Overload 1/3

获取颜色实例的 颜色代码 (ColorHex).

/* ColorHex - 颜色代码. */
Color('#CC5500').toHex(); // #CC5500
Color('#C50').toHex(); // #CC5500
Color('#DECC5500').toHex(); // #DECC5500
Color('#FFCC5500').toHex(); /* #CC5500, A (alpha) 分量被省略. */

/* ColorInt - 颜色整数. */
Color(0xFFCC5500).toHex(); // #CC5500
Color(colors.web.BURNT_ORANGE).toHex(); // #CC5500

/* ColorName - 颜色名称. */
Color('BURNT_ORANGE').toHex(); // #CC5500
Color('burnt-orange').toHex(); // #CC5500

A (alpha) 分量为 100% (255/255;100/100) 时, FF 会自动省略,
#FFC0C0C0 将自动转换为 #C0C0C0, 此方法相当于 toHex('auto').

toHex(alpha)#

6.3.0 Overload 2/3

  • [ alpha = 'auto' ] { boolean | 'keep' | 'none' | 'auto' } - A (alpha) 分量参数
  • returns { ColorHex } - 颜色代码

获取颜色实例的 颜色代码 (ColorHex), 并根据 alpha 参数决定颜色代码 A (alpha) 分量的显示状态.

A (alpha) 分量参数取值表:

取值 含义 默认
'keep' / true 强制显示 A 分量, 不论 A 分量是否为 0xFF
'none' / false 强制去除 A 分量, 只保留 R / G / B 分量
'auto' 根据 A 分量是否为 0xFF 自动决定显示状态
let cA = '#AAC0C0C0';
let cB = '#FFC0C0C0';
let cC = '#C0C0C0';

Color(cA).toHex('auto'); /* #AAC0C0C0, 'auto' 参数可省略. */
Color(cB).toHex('auto'); /* #C0C0C0, 'auto' 参数可省略. */
Color(cC).toHex('auto'); /* #C0C0C0, 'auto' 参数可省略. */

/* cA 舍弃 A 分量. */
Color(cA).toHex(false); // #C0C0C0
Color(cA).toHex('none'); /* 同上. */

/* cB 保留 A 分量. */
Color(cB).toHex(true); // #FFC0C0C0
Color(cB).toHex('keep'); /* 同上. */

/* cC 强制显示 A 分量. */
Color(cC).toHex(true); // #FFC0C0C0
Color(cC).toHex('keep'); /* 同上. */

toHex(length)#

6.3.0 Overload 3/3

  • length { 8 | 6 | 3 } - Hex 代码长度参数
  • returns { ColorHex } - 颜色代码

获取颜色实例的 颜色代码 (ColorHex), 并根据 length 参数决定颜色代码的显示状态.

Hex 代码长度参数取值表:

取值 含义
8 强制显示 A 分量, 结果格式为 #AARRGGBB
6 强制去除 A 分量, 结果格式为 #RRGGBB
3 强制去除 A 分量, 结果格式为 #RGB
let cA = '#AA9966CC';
let cB = '#FF9966CC';
let cC = '#9966CC';
let cD = '#FAEBD7';

/* 转换为 8 长度颜色代码, 强制保留 A 分量. */
Color(cA).toHex(8); // #AA9966CC
Color(cB).toHex(8); // #FF9966CC
Color(cC).toHex(8); // #FF9966CC
Color(cD).toHex(8); // #FFFAEBD7

/* 转换为 6 长度颜色代码, 强制去除 A 分量. */
Color(cA).toHex(6); // #9966CC
Color(cB).toHex(6); // #9966CC
Color(cC).toHex(6); // #9966CC
Color(cD).toHex(6); // #FAEBD7

/* 转换为 3 长度颜色代码, 强制去除 A 分量. */
Color(cA).toHex(3); // #96C
Color(cB).toHex(3); // #96C
Color(cC).toHex(3); // #96C
Color(cD).toHex(3); /* 抛出异常. */

[m#] toFullHex#

toFullHex()#

6.3.0

  • returns { ColorHex } - 颜色代码的完整形式

获取颜色实例 颜色代码 (ColorHex) 的完整形式 (#AARRGGBB).

此方法为 toHex(color, 8) 的别名方法.

Color('#CC5500').toHex(); // #CC5500
Color('#CC5500').toFullHex(); // #FFCC5500

[m#] summary#

summary()#

6.3.0

  • returns { string } - 颜色摘要

获取颜色实例的颜色摘要.

格式为 hex($HEX), rgba($R,$G,$B/$A), int($INT).

其中, A (alpha) 分量将显示为 0..1 范围, 至少一位小数, 至多两位小数:

分量值 显示值
0 0.0
1 1.0
0.64 0.64
128 0.5
255 1.0
100 0.39

示例:

// hex(#009688), rgba(0,150,136/1.0), int(-16738680)
Color('#009688').summary();

// hex(#BE009688), rgba(0,150,136/0.75), int(-1107257720)
Color('#BE009688').summary();

// hex(#FF0000), rgba(255,0,0/1.0), int(-65536)
Color('red').summary();

// hex(#6400008B), rgba(0,0,139/0.39), int(1677721739)
Color('dark-blue').setAlpha(100).summary();

[m#] alpha#

alpha()#

6.3.0 Overload 1/2

获取颜色实例的 A (alpha) 分量, 取值范围 [0..255].

Color('#663399').alpha(); // 255
Color(colors.TRANSPARENT).alpha(); // 0
Color('#05060708').alpha(); // 5

alpha(options)#

6.3.0 Overload 2/2

获取颜色实例的 A (alpha) 分量.

取值范围 [0..1] (options.max1) 或 [0..255] (options.max255 或不指定).

Color('#663399').alpha({ max: 1 }); // 1
Color('#663399').alpha({ max: 255 }); // 255
Color('#663399').alpha(); /* 同上. */

Color('#05060708').alpha({ max: 1 }); // 0.0196078431372549
Color('#05060708').alpha({ max: 255 }); // 5
Color('#05060708').alpha(); /* 同上. */

options.max1 时, 相当于 alphaDouble 方法.

[m#] alphaDouble#

alphaDouble()#

6.3.0

获取颜色实例的 A (alpha) 分量, 取值范围 [0..1].

相当于 alpha({ max: 1 }).

Color('#663399').alphaDouble(); // 1
Color(colors.TRANSPARENT).alphaDouble(); // 0

Color('#05060708').alphaDouble(); // 0.0196078431372549
Color('#05060708').alpha({ max: 1 }); /* 同上. */

[m#] getAlpha#

getAlpha()#

6.3.0 Overload 1/2

获取颜色实例的 A (alpha) 分量, 取值范围 [0..255].

Color#alpha() 的别名方法.

getAlpha(options)#

6.3.0 Overload 2/2

获取颜色实例的 A (alpha) 分量.

Color#alpha(options) 的别名方法.

[m#] getAlphaDouble#

getAlphaDouble()#

6.3.0

获取颜色实例的 A (alpha) 分量, 取值范围 [0..1].

Color#alphaDouble() 的别名方法.

[m#] setAlpha#

setAlpha(alpha)#

6.3.0

设置颜色实例的 A (alpha) 分量, 返回自身类型.

Color('#663399').setAlpha(0x80).toHex(); // #80663399
Color('#663399').setAlpha(0.5).toHex(); /* 同上, 0.5 解析为百分数分量, 即 50%. */

Color('#663399').setAlpha(255).toHex(); // #FF663399
Color('#663399').setAlpha(1).toHex(); /* 同上, 1 默认作为百分数分量, 即 100%. */

[m] setAlphaRelative#

setAlphaRelative(percentage)#

6.3.1

针对 A (alpha) 分量设置其相对百分比, 返回新颜色的颜色整数.

如当前颜色 A (alpha) 分量为 80, 希望设置 A 分量为 50% 相对量, 即 40:

Color(color).setAlphaRelative(0.5);
Color(color).setAlphaRelative('50%'); /* 效果同上. */

同样地, 如希望设置 A 分量为 1.5 倍相对量, 即 120:

Color(color).setAlphaRelative(1.5);
Color(color).setAlphaRelative('150%');

当设置的相对量超过 255 时, 将以 255 为最终值:

Color(color).setAlphaRelative(10); /* A 分量最终值为 255, 而非 800. */

特别地, 当原本颜色的 A 分量为 0 时, 无论如何设置相对量, A 分量均保持 0 值.

[m#] removeAlpha#

removeAlpha()#

6.3.0

去除颜色实例的 A (alpha) 分量, 返回自身类型.

Color('#BE663399').removeAlpha().toHex(); // #663399
Color('#CC5500').removeAlpha().toHex(); // #CC5500
`

相当于 setAlpha(0).

[m#] red#

red()#

6.3.0 Overload 1/2

获取颜色实例的 R (red) 分量, 取值范围 [0..255].

Color('#663399').red(); // 102
Color(colors.TRANSPARENT).red(); // 0
Color('#05060708').red(); // 6

red(options)#

6.3.0 Overload 2/2

获取颜色实例的 R (red) 分量.

取值范围 [0..1] (options.max1) 或 [0..255] (options.max255 或不指定).

Color('#663399').red({ max: 1 }); // 0.4
Color('#663399').red({ max: 255 }); // 102
Color('#663399').red(); /* 同上. */

options.max1 时, 相当于 redDouble 方法.

[m#] redDouble#

redDouble()#

6.3.0

获取颜色实例的 R (red) 分量, 取值范围 [0..1].

相当于 red({ max: 1 }).

Color('#663399').redDouble(); // 0.4

[m#] getRed#

getRed()#

6.3.0 Overload 1/2

获取颜色实例的 R (red) 分量, 取值范围 [0..255].

Color#red() 的别名方法.

getRed(options)#

6.3.0 Overload 2/2

获取颜色实例的 R (red) 分量.

Color#red(options) 的别名方法.

[m#] getRedDouble#

getRedDouble()#

6.3.0

获取颜色实例的 R (red) 分量, 取值范围 [0..1].

Color#redDouble() 的别名方法.

[m#] setRed#

setRed(red)#

6.3.0

设置颜色实例的 R (red) 分量, 返回自身类型.

Color('#663399').setRed(0x80).toHex(); // #803399
Color('#663399').setRed(0.5).toHex(); /* 同上, 0.5 解析为百分数分量, 即 50%. */

Color('#663399').setRed(255).toHex(); // #FF3399
Color('#663399').setRed(1).toHex(); /* #013399, 不同上. 1 默认作为整数分量, 而非 100%. */

[m] setRedRelative#

setRedRelative(percentage)#

6.3.1

针对 R (red) 分量设置其相对百分比, 返回新颜色的颜色整数.

如当前颜色 R (red) 分量为 80, 希望设置 R 分量为 50% 相对量, 即 40:

Color(color).setRedRelative(0.5);
Color(color).setRedRelative('50%'); /* 效果同上. */

同样地, 如希望设置 R 分量为 1.5 倍相对量, 即 120:

Color(color).setRedRelative(1.5);
Color(color).setRedRelative('150%');

当设置的相对量超过 255 时, 将以 255 为最终值:

Color(color).setRedRelative(10); /* R 分量最终值为 255, 而非 800. */

特别地, 当原本颜色的 R 分量为 0 时, 无论如何设置相对量, R 分量均保持 0 值.

[m#] removeRed#

removeRed()#

6.3.0

去除颜色实例的 R (red) 分量, 返回自身类型.

Color('#BE663399').removeRed().toHex(); // #BE003399
Color('#CC5500').removeRed().toHex(); // #005500
`

相当于 setRed(0).

[m#] green#

green()#

6.3.0 Overload 1/2

获取颜色实例的 G (green) 分量, 取值范围 [0..255].

Color('#663399').green(); // 51
Color(colors.TRANSPARENT).green(); // 0
Color('#05060708').green(); // 7

green(options)#

6.3.0 Overload 2/2

获取颜色实例的 G (green) 分量.

取值范围 [0..1] (options.max1) 或 [0..255] (options.max255 或不指定).

Color('#663399').green({ max: 1 }); // 0.2
Color('#663399').green({ max: 255 }); // 51
Color('#663399').green(); /* 同上. */

options.max1 时, 相当于 greenDouble 方法.

[m#] greenDouble#

greenDouble()#

6.3.0

获取颜色实例的 G (green) 分量, 取值范围 [0..1].

相当于 green({ max: 1 }).

Color('#663399').greenDouble(); // 0.2

[m#] getGreen#

getGreen()#

6.3.0 Overload 1/2

获取颜色实例的 G (green) 分量, 取值范围 [0..255].

Color#green() 的别名方法.

getGreen(options)#

6.3.0 Overload 2/2

获取颜色实例的 G (green) 分量.

Color#green(options) 的别名方法.

[m#] getGreenDouble#

getGreenDouble()#

6.3.0

获取颜色实例的 G (green) 分量, 取值范围 [0..1].

Color#greenDouble() 的别名方法.

[m#] setGreen#

setGreen(green)#

6.3.0

设置颜色实例的 G (green) 分量, 返回自身类型.

Color('#663399').setGreen(0x80).toHex(); // #668099
Color('#663399').setGreen(0.5).toHex(); /* 同上, 0.5 解析为百分数分量, 即 50%. */

Color('#663399').setGreen(255).toHex(); // #66FF99
Color('#663399').setGreen(1).toHex(); /* #660199, 不同上. 1 默认作为整数分量, 而非 100%. */

[m] setGreenRelative#

setGreenRelative(percentage)#

6.3.1

针对 G (green) 分量设置其相对百分比, 返回新颜色的颜色整数.

如当前颜色 G (green) 分量为 80, 希望设置 G 分量为 50% 相对量, 即 40:

Color(color).setGreenRelative(0.5);
Color(color).setGreenRelative('50%'); /* 效果同上. */

同样地, 如希望设置 G 分量为 1.5 倍相对量, 即 120:

Color(color).setGreenRelative(1.5);
Color(color).setGreenRelative('150%');

当设置的相对量超过 255 时, 将以 255 为最终值:

Color(color).setGreenRelative(10); /* G 分量最终值为 255, 而非 800. */

特别地, 当原本颜色的 G 分量为 0 时, 无论如何设置相对量, G 分量均保持 0 值.

[m#] removeGreen#

removeGreen()#

6.3.0

去除颜色实例的 G (green) 分量, 返回自身类型.

Color('#BE663399').removeGreen().toHex(); // #BE660099
Color('#CC5500').removeGreen().toHex(); // #CC0000
`

相当于 setGreen(0).

[m#] blue#

blue()#

6.3.0 Overload 1/2

获取颜色实例的 B (blue) 分量, 取值范围 [0..255].

Color('#663399').blue(); // 153
Color(colors.TRANSPARENT).blue(); // 0
Color('#05060708').blue(); // 8

blue(options)#

6.3.0 Overload 2/2

获取颜色实例的 B (blue) 分量.

取值范围 [0..1] (options.max1) 或 [0..255] (options.max255 或不指定).

Color('#663399').blue({ max: 1 }); // 0.6
Color('#663399').blue({ max: 255 }); // 153
Color('#663399').blue(); /* 同上. */

options.max1 时, 相当于 colors.blueDouble 方法.

[m#] blueDouble#

blueDouble()#

6.3.0

获取颜色实例的 A (blue) 分量, 取值范围 [0..1].

相当于 blue({ max: 1 }).

Color('#663399').blueDouble(); // 0.6

[m#] getBlue#

getBlue()#

6.3.0 Overload 1/2

获取颜色实例的 B (blue) 分量, 取值范围 [0..255].

Color#blue() 的别名方法.

getBlue(options)#

6.3.0 Overload 2/2

获取颜色实例的 B (blue) 分量.

Color#blue(options) 的别名方法.

[m#] getBlueDouble#

getBlueDouble()#

6.3.0

获取颜色实例的 A (blue) 分量, 取值范围 [0..1].

Color#blueDouble() 的别名方法.

[m#] setBlue#

setBlue(blue)#

6.3.0

设置颜色实例的 B (blue) 分量, 返回自身类型.

Color('#663399').setBlue(0x80).toHex(); // #663380
Color('#663399').setBlue(0.5).toHex(); /* 同上, 0.5 解析为百分数分量, 即 50%. */

Color('#663399').setBlue(255).toHex(); // #6633FF
Color('#663399').setBlue(1).toHex(); /* #663301, 不同上. 1 默认作为整数分量, 而非 100%. */

[m] setBlueRelative#

setBlueRelative(percentage)#

6.3.1

针对 B (blue) 分量设置其相对百分比, 返回新颜色的颜色整数.

如当前颜色 B (blue) 分量为 80, 希望设置 B 分量为 50% 相对量, 即 40:

Color(color).setBlueRelative(0.5);
Color(color).setBlueRelative('50%'); /* 效果同上. */

同样地, 如希望设置 B 分量为 1.5 倍相对量, 即 120:

Color(color).setBlueRelative(1.5);
Color(color).setBlueRelative('150%');

当设置的相对量超过 255 时, 将以 255 为最终值:

Color(color).setBlueRelative(10); /* B 分量最终值为 255, 而非 800. */

特别地, 当原本颜色的 B 分量为 0 时, 无论如何设置相对量, B 分量均保持 0 值.

[m#] removeBlue#

removeBlue()#

6.3.0

去除颜色实例的 B (blue) 分量, 返回自身类型.

Color('#BE663399').removeBlue().toHex(); // #BE663300
Color('#CC5500').removeBlue().toHex(); // #CC5500
`

相当于 setBlue(0).

[m#] setRgb#

setRgb(color)#

6.3.0 Overload 1/3

color 参数对应的 RGB 颜色应用到 Color 实例上.

color 参数为颜色代码时, 支持情况如下:

格式 备注
#RRGGBB 正常
#RGB 正常
#AARRGGBB A (alpha) 分量被忽略

方法调用结果的 A (alpha) 分量恒为 255, 意味着 color 参数中的 A 分量信息将被忽略.

Color().setRgb('#663399');
Color().setRgb('#DE663399'); /* 同上, A 分量被忽略. */

setRgb(red, green, blue)#

6.3.0 Overload 2/3

颜色分量 对应的 RGB 颜色应用到 Color 实例上.

Color().setRgb(255, 128, 9);
Color().setRgb(0xFF, 0x80, 0x09); /* 同上. */
Color().setRgb('#FF8009'); /* 同上. */
Color().setRgb(1, 0.5, '3.53%'); /* 同上. */

setRgb(components)#

6.3.0 Overload 3/3

颜色分量数组 对应的 RGB 颜色应用到 Color 实例上.

Color().setRgb([ 255, 128, 9 ]);
Color().setRgb([ 0xFF, 0x80, 0x09 ]); /* 同上. */
Color().setRgb([ 1, 0.5, '3.53%' ]); /* 同上. */

[m#] setArgb#

setArgb(colorHex)#

6.3.0 Overload 1/3

colorHex 颜色代码对应的 ARGB 颜色应用到 Color 实例上.

格式 备注
#RRGGBB A (alpha) 分量为 0xFF
#RGB A (alpha) 分量为 0xFF
#AARRGGBB -
Color().setArgb('#663399'); /* 相当于 setArgb('#FF663399') . */
Color().setArgb('#DE663399'); /* 结果不同上. */

setArgb(alpha, red, green, blue)#

6.3.0 Overload 2/3

颜色分量 对应的 ARGB 颜色应用到 Color 实例上.

Color().setArgb(64, 255, 128, 9);
Color().setArgb(0x40, 0xFF, 0x80, 0x09); /* 同上. */
Color().setArgb('#40FF8009'); /* 同上. */
Color().setArgb(0.25, 1, 0.5, '3.53%'); /* 同上. */

setArgb(components)#

6.3.0 Overload 3/3

颜色分量数组 对应的 ARGB 颜色应用到 Color 实例上.

Color().setArgb([ 64, 255, 128, 9 ]);
Color().setArgb([ 0x40, 0xFF, 0x80, 0x09 ]); /* 同上. */
Color().setArgb([ 0.25, 1, 0.5, '3.53%' ]); /* 同上. */

[m#] setRgba#

setRgba(colorHex)#

6.3.0 Overload 1/3

colorHex 颜色代码对应的 RGBA 颜色应用到 Color 实例上.

格式 备注
#RRGGBB A (alpha) 分量为 0xFF
#RGB A (alpha) 分量为 0xFF
#RRGGBBAA -
Color().setRgba('#663399'); /* 相当于 setRgba('#663399FF') . */
Color().setRgba('#663399FF'); /* 结果同上. */
Color().setRgba('#FF663399'); /* 结果不同上. */

注意区分 Color#setRgbaColor#setArgb:

Color().setRgba('#11335577'); /* A (alpha) 分量为 0x77 . */
Color().setArgb('#11335577'); /* A (alpha) 分量为 0x11 . */

setRgba(red, green, blue, alpha)#

6.3.0 Overload 2/3

颜色分量 对应的 RGBA 颜色应用到 Color 实例上.

Color().setRgba(255, 128, 9, 64);
Color().setRgba(0xFF, 0x80, 0x09, 0x40); /* 同上. */
Color().setRgba('#FF800940'); /* 同上. */
Color().setRgba(1, 0.5, '3.53%', 0.25); /* 同上. */

setRgba(components)#

6.3.0 Overload 3/3

颜色分量数组 对应的 RGBA 颜色应用到 Color 实例上.

Color().setRgba([ 255, 128, 9, 64 ]);
Color().setRgba([ 0xFF, 0x80, 0x09, 0x40 ]); /* 同上. */
Color().setRgba([ 1, 0.5, '3.53%', 0.25 ]); /* 同上. */

[m#] setHsv#

setHsv(hue, saturation, value)#

6.3.0 Overload 1/2

颜色分量 对应的 HSV 颜色应用到 Color 实例上.

Color().setHsv(90, 80, 64);
Color().setHsv(90, 0.8, 0.64); /* 同上. */
Color().setHsv(0.25, 0.8, 0.64); /* 同上. */
Color().setHsv('25%', '80%', '64%'); /* 同上. */

setHsv(components)#

6.3.0 Overload 2/2

颜色分量数组 对应的 HSV 颜色应用到 Color 实例上.

Color().setHsv([ 90, 80, 64 ]);
Color().setHsv([ 90, 0.8, 0.64 ]); /* 同上. */
Color().setHsv([ 0.25, 0.8, 0.64 ]); /* 同上. */
Color().setHsv([ '25%', '80%', '64%' ]); /* 同上. */

[m#] setHsva#

setHsva(hue, saturation, value, alpha)#

6.3.0 Overload 1/2

颜色分量 对应的 HSVA 颜色应用到 Color 实例上.

Color().setHsva(90, 80, 64, 64);
Color().setHsva(90, 0.8, 0.64, 0.25); /* 同上. */
Color().setHsva(0.25, 0.8, 0.64, 0.25); /* 同上. */
Color().setHsva('25%', '80%', '64%', '25%'); /* 同上. */

setHsva(components)#

6.3.0 Overload 2/2

颜色分量数组 对应的 HSVA 颜色应用到 Color 实例上.

Color().setHsva([ 90, 80, 64, 64 ]);
Color().setHsva([ 90, 0.8, 0.64, 0.25 ]); /* 同上. */
Color().setHsva([ 0.25, 0.8, 0.64, 0.25 ]); /* 同上. */
Color().setHsva([ '25%', '80%', '64%', '25%' ]); /* 同上. */

[m#] setHsl#

setHsl(hue, saturation, lightness)#

6.3.0 Overload 1/2

颜色分量 对应的 HSL 颜色应用到 Color 实例上.

Color().setHsl(90, 80, 64);
Color().setHsl(90, 0.8, 0.64); /* 同上. */
Color().setHsl(0.25, 0.8, 0.64); /* 同上. */
Color().setHsl('25%', '80%', '64%'); /* 同上. */

setHsl(components)#

6.3.0 Overload 2/2

颜色分量数组 对应的 HSL 颜色应用到 Color 实例上.

Color().setHsl([ 90, 80, 64 ]);
Color().setHsl([ 90, 0.8, 0.64 ]); /* 同上. */
Color().setHsl([ 0.25, 0.8, 0.64 ]); /* 同上. */
Color().setHsl([ '25%', '80%', '64%' ]); /* 同上. */

[m#] setHsla#

setHsla(hue, saturation, lightness, alpha)#

6.3.0 Overload 1/2

颜色分量 对应的 HSLA 颜色应用到 Color 实例上.

Color().setHsla(90, 80, 64, 64);
Color().setHsla(90, 0.8, 0.64, 0.25); /* 同上. */
Color().setHsla(0.25, 0.8, 0.64, 0.25); /* 同上. */
Color().setHsla('25%', '80%', '64%', '25%'); /* 同上. */

setHsla(components)#

6.3.0 Overload 2/2

颜色分量数组 对应的 HSLA 颜色应用到 Color 实例上.

Color().setHsla([ 90, 80, 64, 64 ]);
Color().setHsla([ 90, 0.8, 0.64, 0.25 ]); /* 同上. */
Color().setHsla([ 0.25, 0.8, 0.64, 0.25 ]); /* 同上. */
Color().setHsla([ '25%', '80%', '64%', '25%' ]); /* 同上. */

[m#] toRgb#

toRgb()#

6.3.0

获取颜色实例的 RGB 颜色分量数组.

let [ r, g, b ] = Color('#663399').toRgb();
console.log(`R: ${r}, G: ${g}, B: ${b}`);

[m#] toRgba#

toRgba()#

6.3.0 Overload 1/2

获取颜色实例的 RGBA 颜色分量数组.

let [ r, g, b, a ] = Color('#DE663399').toRgba();
console.log(`R: ${r}, G: ${g}, B: ${b}, A: ${a}`);

需留意上述示例的参数格式为 #AARRGGBB, 结果格式为 [RR, GG, BB, AA].

toRgba(options)#

6.3.0 Overload 2/2

  • options {{
    • [ maxAlpha = 255 ]?: 1 | 255 - A (alpha) 分量的范围最大值
  • }} - 选项参数
  • returns { ColorComponents } - 颜色分量数组

根据 options 选项参数获取颜色实例的 RGBA 颜色分量数组.

let [ r1, g1, b1, a1 ] = Color('#DE663399').toRgba();
console.log(`R: ${r1}, G: ${g1}, B: ${b1}, A: ${a1}`); /* A 分量范围为 [0..255] . */

let [ r2, g2, b2, a2 ] = Color('#DE663399').toRgba({ maxAlpha: 1 });
console.log(`R: ${r2}, G: ${g2}, B: ${b2}, A: ${a2}`); /* A 分量范围为 [0..1] . */

[m#] toArgb#

toArgb()#

6.3.0 Overload 1/2

获取颜色实例的 ARGB 颜色分量数组.

let [ a, r, g, b ] = Color('#DE663399').toArgb();
console.log(`A: ${a}, R: ${r}, G: ${g}, B: ${b}`);

toArgb(options)#

6.3.0 Overload 2/2

  • options {{
    • [ maxAlpha = 255 ]?: 1 | 255 - A (alpha) 分量的范围最大值
  • }} - 选项参数
  • returns { ColorComponents } - 颜色分量数组

根据 options 选项参数获取颜色实例的 ARGB 颜色分量数组.

let [ a1, r1, g1, b1 ] = Color('#DE663399').toArgb();
console.log(`A: ${a1}, R: ${r1}, G: ${g1}, B: ${b1}`); /* A 分量范围为 [0..255] . */

let [ a2, r2, g2, b2 ] = Color('#DE663399').toArgb({ maxAlpha: 1 });
console.log(`A: ${a2}, R: ${r2}, G: ${g2}, B: ${b2}`); /* A 分量范围为 [0..1] . */

[m#] toHsv#

toHsv()#

6.3.0

获取颜色实例的 HSV 颜色分量数组.

let [ h, s, v ] = Color('#663399').toHsv();
console.log(`H: ${h}, S: ${s}, V: ${v}`);

[m#] toHsva#

toHsva()#

6.3.0

获取颜色实例的 HSVA 颜色分量数组.

其中 A (alpha) 分量范围恒为 [0..1].

let [ h, s, v, a ] = Color('#BF663399').toHsva();
console.log(`H: ${h}, S: ${s}, V: ${v}, A: ${a}`);

[m#] toHsl#

toHsl()#

6.3.0

获取颜色实例的 HSL 颜色分量数组.

let [ h, s, l ] = Color('#663399').toHsl();
console.log(`H: ${h}, S: ${s}, L: ${l}`);

[m#] toHsla#

toHsla()#

6.3.0

获取颜色实例的 HSLA 颜色分量数组.

其中 A (alpha) 分量范围恒为 [0..1].

let [ h, s, l, a ] = Color('#BF663399').toHsla();
console.log(`H: ${h}, S: ${s}, L: ${l}, A: ${a}`);

[m#] isSimilar#

isSimilar(other, threshold?, algorithm?)#

6.3.0 Overload [1-3]/4

判断实例颜与于参数颜色是否相似.

不同阈值对结果的影响 (阈值越高, 条件越宽松, 阈值越低, 条件越严格):

Color('orange').isSimilar('dark-orange', 5); /* false, 阈值较小, 条件相对严格. */
Color('orange').isSimilar('dark-orange', 10); /* true, 阈值增大, 条件趋于宽松. */

不同 颜色检测算法 对结果的影响:

Color('orange').isSimilar('dark-orange', 9, 'rgb+'); // false
Color('orange').isSimilar('dark-orange', 9, 'diff'); // true
Color('orange').isSimilar('dark-orange', 9, 'hs'); // true

Color('orange').isSimilar('dark-orange', 8, 'rgb+'); // false
Color('orange').isSimilar('dark-orange', 8, 'diff'); // false
Color('orange').isSimilar('dark-orange', 8, 'hs'); // true

isSimilar(other, options)#

6.3.0 Overload 4/4

判断实例颜与于参数颜色是否相似.

此方法将非必要参数集中于 options 对象中.

Color('#010101').isSimilar('#020202', { similarity: 0.95 }); // true

[m#] isEqual#

isEqual(other, alphaMatters?)#

6.3.0 Overload[1-2]/2

判断实例颜色与参数颜色是否相等, 比较时由 alphaMatters 参数决定是否考虑 A (alpha) 分量:

/* Hex 代码. */
colors.isEqual('#FF0000', '#FF0000'); // true
colors.isEqual('#FF0000', '#F00'); /* 同上, 三位数简写形式. */
/* 颜色整数. */
colors.isEqual(-65536, 0xFF0000); // true
/* 颜色名称. */
colors.isEqual('red', 'RED'); /* true, 不区分大小写. */
colors.isEqual('orange', 'Orange'); /* true, 不区分大小写. */
colors.isEqual('dark-gray', 'DARK_GRAY'); /* true, 连字符与下划线均被支持. */
/* 不同类型比较. */
colors.isEqual('red', '#FF0000'); // true
colors.isEqual('orange', '#FFA500'); // true
/* A (alpha) 分量的不同情况. */
colors.isEqual('#A1FF0000', '#A2FF0000'); /* true, 默认忽略 A 分量. */
colors.isEqual('#A1FF0000', '#A2FF0000', true); /* false, 需考虑 A 分量. */

[m#] equals#

equals(other)#

6.3.0 DEPRECATED

  • other { number | string } - 颜色参数
  • returns { boolean } - 实例颜色与参数颜色是否相等 (忽略 A (alpha) 分量)

判断实例颜色与参数颜色是否相等, 比较时忽略 A (alpha) 分量:

/* Hex 代码. */
Color('#FF0000').equals('#FF0000'); // true
/* 颜色整数. */
Color(-65536).equals(0xFF0000); // true
/* 颜色名称. */
Color('red').equals('RED'); // true
/* 不同类型比较. */
Color('red').equals('#FF0000'); // true
/* A (alpha) 分量将被忽略. */
Color('#A1FF0000').equals('#A2FF0000'); // true

但以下示例将全部抛出异常:

Color('orange').equals('#FFA500'); /* 抛出异常. */
Color('dark-gray').equals('#444'); /* 抛出异常. */
Color('#FF0000').equals('#F00'); /* 抛出异常. */

上述示例对于 Color#isEqual 则全部返回 true.

除非需要考虑多版本兼容, 否则建议始终使用 Color#isEqual 替代 Color#equals.

[m#] luminance#

luminance()#

6.3.0

获取颜色的 亮度 (Luminance), 取值范围 [0..1].

Color(colors.WHITE).luminance(); // 1
Color(colors.BLACK).luminance(); // 0
Color(colors.RED).luminance(); // 0.2126
Color(colors.GREEN).luminance(); // 0.7152
Color(colors.BLUE).luminance(); // 0.0722
Color(colors.YELLOW).luminance(); // 0.9278

参阅: W3C Wiki

[m#] toColorStateList#

toColorStateList()#

6.3.0

将颜色实例转换为包含单一颜色的 ColorStateList 实例.

Color('red').toColorStateList(); /* 包含单一颜色的 ColorStateList. */

[m#] setPaintColor#

setPaintColor(paint)#

6.3.0

方法 setPaintColor 用于解决在 Android API 29 (10) [Q] 及以上系统中 Paint#setColor(color) 无法正常设置画笔颜色的问题.

let paint = new android.graphics.Paint();

/* 安卓 10 及以上系统无法正常设置颜色. */
// paint.setColor(colors.toInt('blue'));

/* 使用 Color 类实现原始功能. */
Color('blue').setPaintColor(paint);

更多 setPaintColor 相关内容, 参阅 colors.setPaintColor 小节.