V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
babyrjw
V2EX  ›  问与答

给定 RGB 值,能找到它或者相似的颜色名称么?

  •  
  •   babyrjw · 2019-11-19 12:51:40 +08:00 · 2235 次点击
    这是一个创建于 1591 天前的主题,其中的信息可能已经有所发展或是发生改变。

    比如 http://ylbook.com/cms/web/ISCC-NBS_COLOR.htm 可以根据颜色名称找到颜色的 RGB 值, 给定 RGB 值,例如:#BA474E,能找到相近的颜色名称么?

    14 条回复    2019-11-20 12:08:06 +08:00
    opengps
        1
    opengps  
       2019-11-19 13:12:19 +08:00
    这得依赖记忆啊
    解读下这 6 个 16 进制位:前 2 位是红,中间两位是绿,后两位是蓝色。利用光的三原色去调色(骗一波访问: https://www.opengps.cn/Blog/View.aspx?id=461
    不学美术或者光学物理的,恐怕很难根据记忆知道那个颜色跟靠近当前值
    pastgift
        2
    pastgift  
       2019-11-19 13:14:35 +08:00 via iPhone
    可以参考色环配合 hsv 处理
    h (色调)是 360 度表示,相近颜色很好计算
    rgb 转 hsv,计算相近颜色后转回 rgb 会比直接 rgb 计算要方便很多,还好控制相似度
    pastgift
        3
    pastgift  
       2019-11-19 13:16:14 +08:00 via iPhone
    接上一条
    如果只是明度、饱和度相似就改 s 和 v
    应该可以满足需求
    tyx1703
        4
    tyx1703  
       2019-11-19 14:37:32 +08:00
    https://jsfiddle.net/4yhmpu12/

    原理:计算两个颜色向量之间的距离,将距离最小的颜色取出来即可。
    tyx1703
        5
    tyx1703  
       2019-11-19 14:39:52 +08:00
    Vegetable
        6
    Vegetable  
       2019-11-19 14:43:00 +08:00
    rgb 就是三维坐标系吧,默认两个点的距离越近颜色越近,所以计算和预定坐标(已知颜色)的空间距离,找到最近的就行了。
    sanmaozhao
        7
    sanmaozhao  
       2019-11-19 14:45:41 +08:00
    以前讨论过类似的问题,可以参考一下
    https://www.v2ex.com/t/387187
    shintendo
        8
    shintendo  
       2019-11-19 14:49:51 +08:00
    babyrjw
        9
    babyrjw  
    OP
       2019-11-20 09:25:22 +08:00
    @tyx1703 直接计算向量的话,会不会出现比如边界问题,比如深深深红色距离某个黄色或者蓝色更近一些
    babyrjw
        10
    babyrjw  
    OP
       2019-11-20 09:26:01 +08:00
    @pastgift 转成 HSV 后,可以忽略 S 和 V,取 H 的相近值么
    babyrjw
        11
    babyrjw  
    OP
       2019-11-20 09:26:15 +08:00
    @sanmaozhao 学习一下
    babyrjw
        12
    babyrjw  
    OP
       2019-11-20 09:26:39 +08:00
    @shintendo 哟大佬这个工具给力,想要实现的就是这个效果
    babyrjw
        13
    babyrjw  
    OP
       2019-11-20 09:48:07 +08:00
    @tyx1703 多谢您,这个也是计算向量哈,我测试一下边界条件看看
    tyx1703
        14
    tyx1703  
       2019-11-20 12:08:06 +08:00 via iPhone
    @babyrjw 🌚并没有检测

    其实就是展示一下原理。要用,还有很多要做的地方
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   5329 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 28ms · UTC 09:17 · PVG 17:17 · LAX 02:17 · JFK 05:17
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.