评论

该死的颜色选择器!!

颜色选择器

目标

看到这个很酷的网站 所以也想看看怎么弄?

先来挑战入门版…

颜色坐标系

  1. 首先要解决一个 误解

    我们所看到的颜色面板, 其实就是一个固定的样式, 而我们获取的颜色其实是从 坐标模型中 计算出来的。

  2. 坐标模型有很多, 在此使用的是 HSV颜色模型

    Q: 为什么使用 HSV ?
    A: HSV色系对用户来说是一种直观的颜色模型, 主要由 色调(Hue, 简H)、饱和度(Saturation, 简S)、色明度(Value, 简V)

  3. 将 HSV六角锥体模型 转为 直观的数学坐标系

    需要注意, document中元素节点 坐标原点是右上角, 而数学坐标原点为右下角

    数学坐标系: y、x、h

    HSV坐标系: v、s、h

  4. 确认坐标系的范围

    色调H: 取值范围为0°~360°

    饱和度S:取值范围为0.0~1.0

    亮度V:取值范围为0.0(黑色)~1.0(白色)

    通过document节点上元素的宽高, 计算步长, 达到取值范围为 0~100(转为百分制)

颜色转换

通过 触摸 坐标系 获取 y(v)、x(s)、h 的值, 然后利用算法公式转换成 rgb 颜色

实例用法

详细注释在 代码中…

1. 将 colorPicker 组件 引入到项目中。

// index.json

{
  "usingComponents": {
    "color-picker": "../../components/colorPicker/colorPicker"
  }
}

// index.html

<view>

 <color-picker></color-picker>

</view>

2. Attributes

属性 类型 默认值 必填 说明
width number 35 宽度; 单位px
height number 35 高度; 单位px
predefined string #409EFF 预览颜色; 支持HEX和RGB; 只支持英文字符

3. Events

事件名称 回调参数 说明
change 当前颜色 当修改绑定值时触发

4. 示例

参考文献

MakerGYT 看了MakerGYT写的mini-color-picker源码, 非常强🤙🤙🤙

颜色公式转换

在线测试工具,校验计算是否正确

hsv百度百科

Element的color-picker

最后一次编辑于  2020-11-29  
点赞 3
收藏
评论

2 个评论

  • 一⃰步⃰一⃰脚⃰印⃰
    一⃰步⃰一⃰脚⃰印⃰
    2023-10-27

    换个颜色就报错,修改colorPicker里面的 deColor也报错,修改predefined也报错,就你代码片段里的两个值不报错

    2023-10-27
    赞同
    回复
  • 九歌^
    九歌^
    2020-11-26

    666,第一个动图我还以为是input的type等于color

    2020-11-26
    赞同
    回复
登录 后发表内容