- Global - 全局对象
- Automator - 自动化
- AutoJs6 - 本体应用
- App - 通用应用
- Color - 颜色
- Image - 图像
- OCR - 光学字符识别
- Barcode - 条码
- QR Code - 二维码
- Keys - 按键
- Device - 设备
- Storage - 储存
- File - 文件
- Engine - 引擎
- Task - 任务
- Module - 模块
- Plugins - 插件
- Toast - 消息浮动框
- Notice - 消息通知
- Console - 控制台
- Shell
- Shizuku
- Media - 多媒体
- Sensor - 传感器
- Recorder - 记录器
- Timer - 定时器
- Thread - 线程
- Continuation - 协程
- Event - 事件监听
- Dialog - 对话框
- Floaty - 悬浮窗
- Canvas - 画布
- UI - 用户界面
- Web - 万维网
- HTTP
- Base64
- Crypto - 密文
- OpenCC - 中文转换
- Internationalization - 国际化
- Standardization - 标准化
- E4X
- UiSelector - 选择器
- UiObject - 控件节点
- UiObjectCollection - 控件集合
- UiObjectActions - 控件节点行为
- WebSocket
- EventEmitter - 事件发射器
- ImageWrapper - 包装图像类
- App - 应用枚举类
- Color - 颜色类
- Version - 版本工具类
- Polyfill - 代码填泥
- Arrayx - Array 扩展
- Numberx - Number 扩展
- Mathx - Math 扩展
- Glossaries - 术语
- HttpHeader - HTTP 标头
- HttpRequestMethods - HTTP 请求方法
- MimeType - MIME 类型
- NotificationChannel - 通知渠道
- Data Types - 数据类型
- Omnipotent Types - 全能类型
- Storage - 存储类
- AndroidBundle
- AndroidRect
- CryptoCipherOptions
- CryptoKey
- CryptoKeyPair
- ConsoleBuildOptions
- HttpRequestBuilderOptions
- HttpRequestHeaders
- HttpResponseBody
- HttpResponseHeaders
- HttpResponse
- InjectableWebClient
- InjectableWebView
- NoticeOptions
- NoticeChannelOptions
- NoticePresetConfiguration
- NoticeBuilder
- Okhttp3HttpUrl
- OcrOptions
- Okhttp3Request
- OpenCVPoint
- OpenCVRect
- OpenCVSize
- OpenCCConversion
AutoJs6 文档 - 6.6.4
目录
- Color (颜色类)
- [C] Color
- [m#] toInt
- [m#] toHex
- [m#] toFullHex
- [m#] summary
- [m#] alpha
- [m#] alphaDouble
- [m#] getAlpha
- [m#] getAlphaDouble
- [m#] setAlpha
- [m] setAlphaRelative
- [m#] removeAlpha
- [m#] red
- [m#] redDouble
- [m#] getRed
- [m#] getRedDouble
- [m#] setRed
- [m] setRedRelative
- [m#] removeRed
- [m#] green
- [m#] greenDouble
- [m#] getGreen
- [m#] getGreenDouble
- [m#] setGreen
- [m] setGreenRelative
- [m#] removeGreen
- [m#] blue
- [m#] blueDouble
- [m#] getBlue
- [m#] getBlueDouble
- [m#] setBlue
- [m] setBlueRelative
- [m#] removeBlue
- [m#] setRgb
- [m#] setArgb
- [m#] setRgba
- [m#] setHsv
- [m#] setHsva
- [m#] setHsl
- [m#] setHsla
- [m#] toRgb
- [m#] toRgba
- [m#] toArgb
- [m#] toHsv
- [m#] toHsva
- [m#] toHsl
- [m#] toHsla
- [m#] isSimilar
- [m#] isEqual
- [m#] equals
- [m#] luminance
- [m#] toColorStateList
- [m#] setPaintColor
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 模块.
以 set
或 remove
为前缀的方法, 通常都会返回 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 语法规范.
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
- red { ColorComponent } - 颜色分量 - R (red)
- green { ColorComponent } - 颜色分量 - G (green)
- blue { ColorComponent } - 颜色分量 - B (blue)
- [ alpha =
1
] { ColorComponent } - 颜色分量 - A (alpha) - returns { Color } - Color 实例
构建一个颜色实例, 初始颜色由多个参数指定, 其中 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
- returns { ColorInt } - 颜色整数
获取颜色实例的 颜色整数 (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
- returns { ColorHex } - 颜色代码
获取颜色实例的 颜色代码 (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
- returns { IntRange[0..255] }
获取颜色实例的 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
- options {{
- [ max =
255
]?:1
|255
- 范围最大值
- [ max =
- }} - 选项参数
- returns { IntRange[0..1] | IntRange[0..255] }
获取颜色实例的 A (alpha)
分量.
取值范围 [0..1]
(options.max
为 1
) 或 [0..255]
(options.max
为 255
或不指定).
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.max
为 1
时, 相当于 alphaDouble 方法.
[m#] alphaDouble#
alphaDouble()#
6.3.0
- returns { Range[0..1] }
获取颜色实例的 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
- returns { IntRange[0..255] }
获取颜色实例的 A (alpha)
分量, 取值范围 [0..255]
.
Color#alpha() 的别名方法.
getAlpha(options)#
6.3.0
Overload 2/2
- options {{
- [ max =
255
]?:1
|255
- 范围最大值
- [ max =
- }} - 选项参数
- returns { IntRange[0..1] | IntRange[0..255] }
获取颜色实例的 A (alpha)
分量.
Color#alpha(options) 的别名方法.
[m#] getAlphaDouble#
getAlphaDouble()#
6.3.0
- returns { Range[0..1] }
获取颜色实例的 A (alpha)
分量, 取值范围 [0..1]
.
Color#alphaDouble() 的别名方法.
[m#] setAlpha#
setAlpha(alpha)#
6.3.0
- alpha { ColorComponent } - 颜色分量 - A (alpha)
- returns { Color }
设置颜色实例的 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
- percentage { ColorComponent } - 相对百分数
- returns { Color }
针对 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
- returns { Color }
去除颜色实例的 A (alpha)
分量, 返回自身类型.
Color('#BE663399').removeAlpha().toHex(); // #663399
Color('#CC5500').removeAlpha().toHex(); // #CC5500
`
相当于 setAlpha(0)
.
[m#] red#
red()#
6.3.0
Overload 1/2
- returns { IntRange[0..255] }
获取颜色实例的 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
- options {{
- [ max =
255
]?:1
|255
- 范围最大值
- [ max =
- }} - 选项参数
- returns { IntRange[0..1] | IntRange[0..255] }
获取颜色实例的 R (red)
分量.
取值范围 [0..1]
(options.max
为 1
) 或 [0..255]
(options.max
为 255
或不指定).
Color('#663399').red({ max: 1 }); // 0.4
Color('#663399').red({ max: 255 }); // 102
Color('#663399').red(); /* 同上. */
当 options.max
为 1
时, 相当于 redDouble 方法.
[m#] redDouble#
redDouble()#
6.3.0
- returns { Range[0..1] }
获取颜色实例的 R (red)
分量, 取值范围 [0..1]
.
相当于 red({ max: 1 })
.
Color('#663399').redDouble(); // 0.4
[m#] getRed#
getRed()#
6.3.0
Overload 1/2
- returns { IntRange[0..255] }
获取颜色实例的 R (red)
分量, 取值范围 [0..255]
.
Color#red() 的别名方法.
getRed(options)#
6.3.0
Overload 2/2
- options {{
- [ max =
255
]?:1
|255
- 范围最大值
- [ max =
- }} - 选项参数
- returns { IntRange[0..1] | IntRange[0..255] }
获取颜色实例的 R (red)
分量.
Color#red(options) 的别名方法.
[m#] getRedDouble#
getRedDouble()#
6.3.0
- returns { Range[0..1] }
获取颜色实例的 R (red)
分量, 取值范围 [0..1]
.
Color#redDouble() 的别名方法.
[m#] setRed#
setRed(red)#
6.3.0
- red { ColorComponent } - 颜色分量 - R (red)
- returns { Color }
设置颜色实例的 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
- percentage { ColorComponent } - 相对百分数
- returns { Color }
针对 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
- returns { Color }
去除颜色实例的 R (red)
分量, 返回自身类型.
Color('#BE663399').removeRed().toHex(); // #BE003399
Color('#CC5500').removeRed().toHex(); // #005500
`
相当于 setRed(0)
.
[m#] green#
green()#
6.3.0
Overload 1/2
- returns { IntRange[0..255] }
获取颜色实例的 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
- options {{
- [ max =
255
]?:1
|255
- 范围最大值
- [ max =
- }} - 选项参数
- returns { IntRange[0..1] | IntRange[0..255] }
获取颜色实例的 G (green)
分量.
取值范围 [0..1]
(options.max
为 1
) 或 [0..255]
(options.max
为 255
或不指定).
Color('#663399').green({ max: 1 }); // 0.2
Color('#663399').green({ max: 255 }); // 51
Color('#663399').green(); /* 同上. */
当 options.max
为 1
时, 相当于 greenDouble 方法.
[m#] greenDouble#
greenDouble()#
6.3.0
- returns { Range[0..1] }
获取颜色实例的 G (green)
分量, 取值范围 [0..1]
.
相当于 green({ max: 1 })
.
Color('#663399').greenDouble(); // 0.2
[m#] getGreen#
getGreen()#
6.3.0
Overload 1/2
- returns { IntRange[0..255] }
获取颜色实例的 G (green)
分量, 取值范围 [0..255]
.
Color#green() 的别名方法.
getGreen(options)#
6.3.0
Overload 2/2
- options {{
- [ max =
255
]?:1
|255
- 范围最大值
- [ max =
- }} - 选项参数
- returns { IntRange[0..1] | IntRange[0..255] }
获取颜色实例的 G (green)
分量.
Color#green(options) 的别名方法.
[m#] getGreenDouble#
getGreenDouble()#
6.3.0
- returns { Range[0..1] }
获取颜色实例的 G (green)
分量, 取值范围 [0..1]
.
Color#greenDouble() 的别名方法.
[m#] setGreen#
setGreen(green)#
6.3.0
- green { ColorComponent } - 颜色分量 - G (green)
- returns { Color }
设置颜色实例的 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
- percentage { ColorComponent } - 相对百分数
- returns { Color }
针对 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
- returns { Color }
去除颜色实例的 G (green)
分量, 返回自身类型.
Color('#BE663399').removeGreen().toHex(); // #BE660099
Color('#CC5500').removeGreen().toHex(); // #CC0000
`
相当于 setGreen(0)
.
[m#] blue#
blue()#
6.3.0
Overload 1/2
- returns { IntRange[0..255] }
获取颜色实例的 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
- options {{
- [ max =
255
]?:1
|255
- 范围最大值
- [ max =
- }} - 选项参数
- returns { IntRange[0..1] | IntRange[0..255] }
获取颜色实例的 B (blue)
分量.
取值范围 [0..1]
(options.max
为 1
) 或 [0..255]
(options.max
为 255
或不指定).
Color('#663399').blue({ max: 1 }); // 0.6
Color('#663399').blue({ max: 255 }); // 153
Color('#663399').blue(); /* 同上. */
当 options.max
为 1
时, 相当于 colors.blueDouble 方法.
[m#] blueDouble#
blueDouble()#
6.3.0
- returns { Range[0..1] }
获取颜色实例的 A (blue)
分量, 取值范围 [0..1]
.
相当于 blue({ max: 1 })
.
Color('#663399').blueDouble(); // 0.6
[m#] getBlue#
getBlue()#
6.3.0
Overload 1/2
- returns { IntRange[0..255] }
获取颜色实例的 B (blue)
分量, 取值范围 [0..255]
.
Color#blue() 的别名方法.
getBlue(options)#
6.3.0
Overload 2/2
- options {{
- [ max =
255
]?:1
|255
- 范围最大值
- [ max =
- }} - 选项参数
- returns { IntRange[0..1] | IntRange[0..255] }
获取颜色实例的 B (blue)
分量.
Color#blue(options) 的别名方法.
[m#] getBlueDouble#
getBlueDouble()#
6.3.0
- returns { Range[0..1] }
获取颜色实例的 A (blue)
分量, 取值范围 [0..1]
.
Color#blueDouble() 的别名方法.
[m#] setBlue#
setBlue(blue)#
6.3.0
- blue { ColorComponent } - 颜色分量 - B (blue)
- returns { Color }
设置颜色实例的 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
- percentage { ColorComponent } - 相对百分数
- returns { Color }
针对 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
- returns { Color }
去除颜色实例的 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
- red { ColorComponent } - 颜色分量 - R (red)
- green { ColorComponent } - 颜色分量 - G (green)
- blue { ColorComponent } - 颜色分量 - B (blue)
- returns { Color }
将 颜色分量 对应的 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
- components { ColorComponents[] } - 颜色分量数组
- returns { Color }
将 颜色分量数组 对应的 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
- alpha { ColorComponent } - 颜色分量 - A (alpha)
- red { ColorComponent } - 颜色分量 - R (red)
- green { ColorComponent } - 颜色分量 - G (green)
- blue { ColorComponent } - 颜色分量 - B (blue)
- returns { Color }
将 颜色分量 对应的 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
- components { ColorComponents[] } - 颜色分量数组
- returns { Color }
将 颜色分量数组 对应的 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#setRgba
与 Color#setArgb
:
Color().setRgba('#11335577'); /* A (alpha) 分量为 0x77 . */
Color().setArgb('#11335577'); /* A (alpha) 分量为 0x11 . */
setRgba(red, green, blue, alpha)#
6.3.0
Overload 2/3
- red { ColorComponent } - 颜色分量 - R (red)
- green { ColorComponent } - 颜色分量 - G (green)
- blue { ColorComponent } - 颜色分量 - B (blue)
- alpha { ColorComponent } - 颜色分量 - A (alpha)
- returns { Color }
将 颜色分量 对应的 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
- components { ColorComponents[] } - 颜色分量数组
- returns { Color }
将 颜色分量数组 对应的 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
- hue { ColorComponent } - 颜色分量 - H (hue)
- saturation { ColorComponent } - 颜色分量 - S (saturation)
- value { ColorComponent } - 颜色分量 - V (value)
- returns { Color }
将 颜色分量 对应的 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
- components { ColorComponents[] } - 颜色分量数组
- returns { Color }
将 颜色分量数组 对应的 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
- hue { ColorComponent } - 颜色分量 - H (hue)
- saturation { ColorComponent } - 颜色分量 - S (saturation)
- value { ColorComponent } - 颜色分量 - V (value)
- alpha { ColorComponent } - 颜色分量 - A (alpha)
- returns { Color }
将 颜色分量 对应的 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
- components { ColorComponents[] } - 颜色分量数组
- returns { Color }
将 颜色分量数组 对应的 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
- hue { ColorComponent } - 颜色分量 - H (hue)
- saturation { ColorComponent } - 颜色分量 - S (saturation)
- lightness { ColorComponent } - 颜色分量 - L (lightness)
- returns { Color }
将 颜色分量 对应的 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
- components { ColorComponents[] } - 颜色分量数组
- returns { Color }
将 颜色分量数组 对应的 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
- hue { ColorComponent } - 颜色分量 - H (hue)
- saturation { ColorComponent } - 颜色分量 - S (saturation)
- lightness { ColorComponent } - 颜色分量 - L (lightness)
- alpha { ColorComponent } - 颜色分量 - A (alpha)
- returns { Color }
将 颜色分量 对应的 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
- components { ColorComponents[] } - 颜色分量数组
- returns { Color }
将 颜色分量数组 对应的 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
- returns { ColorComponents } - 颜色分量数组
获取颜色实例的 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
- returns { ColorComponents } - 颜色分量数组
获取颜色实例的 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) 分量的范围最大值
- [ maxAlpha =
- }} - 选项参数
- 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
- returns { ColorComponents } - 颜色分量数组
获取颜色实例的 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) 分量的范围最大值
- [ maxAlpha =
- }} - 选项参数
- 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
- returns { ColorComponents } - 颜色分量数组
获取颜色实例的 HSV 颜色分量数组.
let [ h, s, v ] = Color('#663399').toHsv();
console.log(`H: ${h}, S: ${s}, V: ${v}`);
[m#] toHsva#
toHsva()#
6.3.0
- returns { ColorComponents } - 颜色分量数组
获取颜色实例的 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
- returns { ColorComponents } - 颜色分量数组
获取颜色实例的 HSL 颜色分量数组.
let [ h, s, l ] = Color('#663399').toHsl();
console.log(`H: ${h}, S: ${s}, L: ${l}`);
[m#] toHsla#
toHsla()#
6.3.0
- returns { ColorComponents } - 颜色分量数组
获取颜色实例的 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
- other { ColorHex | ColorInt | ColorName } - 颜色参数
- [ threshold =
4
] { IntRange[0..255] } - 颜色匹配阈值 - [ algorithm =
'diff'
] { ColorDetectionAlgorithm } - 颜色检测算法 - returns { boolean } - 实例颜色与参数颜色是否相似
判断实例颜与于参数颜色是否相似.
不同阈值对结果的影响 (阈值越高, 条件越宽松, 阈值越低, 条件越严格):
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
- other { ColorHex | ColorInt | ColorName } - 颜色参数
- options {{
- [ similarity ≈
0.9843
]?: Range[0..1] - 颜色匹配相似度 - [ threshold =
4
]?: IntRange[0..255] - 颜色匹配阈值 - [ algorithm =
'diff'
]?: ColorDetectionAlgorithm - 颜色检测算法
- [ similarity ≈
- }} - 选项参数
- returns { boolean } - 实例颜色与参数颜色是否相似
判断实例颜与于参数颜色是否相似.
此方法将非必要参数集中于 options
对象中.
Color('#010101').isSimilar('#020202', { similarity: 0.95 }); // true
[m#] isEqual#
isEqual(other, alphaMatters?)#
6.3.0
Overload[1-2]/2
- other { ColorHex | ColorInt | ColorName } - 颜色参数
- [ alphaMatters =
false
] { boolean } - 是否考虑A (alpha)
分量 - returns { boolean } - 实例颜色与参数颜色是否相等
判断实例颜色与参数颜色是否相等, 比较时由 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
判断实例颜色与参数颜色是否相等, 比较时忽略 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
- returns { Range[0..1] } - 颜色亮度
获取颜色的 亮度 (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
- returns { android.content.res.ColorStateList }
将颜色实例转换为包含单一颜色的 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 小节.