EyeDropper API

EyeDropper API 提供了吸管工具,允许用户选择屏幕上的某个特定位置的颜色

该 API 仅在严格上下文环境下允许使用

使用

EyeDropper() 构造函数用于创建一个 eyedropper 工具

调用 EyeDropper 接口的 open() 方法以选择颜色

方法接受一个可选的配置项,其唯一可选属性 signal 是一个 AbortSignal,可用于编程式退出选择过程

方法返回一个 Promise 的对象,其唯一属性 sRGBHex 代表一个相应的十六进制的颜色字符串

方法可能抛出 NotAllowedError,若方法不是因为用户交互触发的

方法可能抛出 InvalidStateError,若当前已存在其他打开的 EyeDropper

方法可能抛出 AbortError,若用户退出选择颜色或因调用 AbortSignal.abort() 方法退出

方法可能抛出 OperationError,若因为除用户主动退出之外的原因导致获取颜色信息失败

1
2
3
4
5
6
7
8
9
10
11
12
13
try {
const eyeDropper = new EyeDropper()

const controller = new AbortController()

const { sRGBHex } = await eyeDropper.open({
signal: controller.signal,
})

console.log(sRGBHex)
} catch (err) {
console.error(err)
}

示例

选择的颜色为:

类型

1
2
3
4
5
6
7
8
9
10
11
12
interface ColorSelectionResult {
sRGBHex: string
}

interface ColorSelectionOptions {
signal: AbortSignal
}

interface EyeDropper {
constructor()
open(options: ColorSelectionOptions): Promise<ColorSelectionResult>
}

链接

发布于

2023-10-27

更新于

2025-01-05

许可协议

评论

:D 一言句子获取中...

加载中,最新评论有1分钟缓存...