找回密码
 立即注册
查看: 760|回复: 1

人工智能配色系列(一)方案与法则

[复制链接]

1

主题

0

回帖

23

积分

新手上路

积分
23
发表于 2023-5-8 09:36:15 | 显示全部楼层 |阅读模式
随着人工智能时代的到来,科技展开了与艺术的博弈。某宝的人工智能产物设计的Banner已然霸屏“双十一”。由机器智能设计Banner以应用在电商类项目中,确能大大减少人力资源的投入。同时机器自动设计并生成Banner将为其个性化提供了可能,能够实现千人千面的效果。
在人工智能生成Banner的诸多环节中,智能配色是难点之一。首先,配色对设计品的辨识度和表示力有着非常大的影响,配色成果是否符合审美尺度更是一目了然。其次,人工配色具有较强艺术性和必然程度的经验堆集,是Banner设计中相对耗时耗力的环节,使用机器还原设计思路,甚至对同一Banner提供多套配色方案尤为挑战。
本系列文章将讨论Banner智能配色的解决方案。本文重点介绍方案框架以及此中配色法则的设计过程。
方案:调色盘与法则
元素分层
分层是设计中的重要概念,对层次进行划分有利于清晰地展现和定位问题。以鹅漫优品商品中的 Banner 为例。通过对此中的元素进行分层措置,得到上图。如图所示从下至上,Banner 的层次为:





  • 布景层:指最底层的纯色布景,凡是与商品或IP主色不异或相似。
  • 布景纹理层:指修饰布景的纹理,该纹理凡是与布景较接近。
  • 布景修饰层:指活跃布景氛围的,凡是布景修饰层的颜色附近。
  • IP 层:指 IP 形象图。
  • 前景修饰层:由于 IP 形象面积较大,前景修饰用于分割区域,并部门遮挡 IP,以便突出的商品及文字。前景修饰层,不在本文讨论。
  • 商品修饰层:指背后的修饰图,用于突出商品。
  • 商品:指商品图。
  • 文字:指标题等文字。
基于分层,我们可以定位问题为:基于商品或IP图,为各层进行配色。本文重点探讨以布景层、布景纹理层和布景修饰层三层为例的配色方案。更多层次本色亦然。
在构建方案时,存在两种方案,即使用调色盘或使用配色法则。
调色盘
如今,互联网中存在着海量的调色盘。如在设计师的常用网站 Dribble 中,每个被上传的设计作品,城市被自动提取并生成调色盘(Color Palette)。将这些调色盘用于 Banner 配色或为简洁有效的解决方案:





  • 在提取商品代表色后,通过商品代表色与现有调色盘库(抓取自 Dribble)中的色彩比对,找到对应的色盘。
  • Dribble 中的调色盘会按照色彩的面积依次排序。在调色盘使用时,忽略白色和黑色(以及近似白色、黑色)后,依次使用颜色由下层至上层着色至 Banner 上。



上图为使用Dribble中某作品的调色盘,颠末上述过程得到的配色方案,配色的效果差强人意,如这幅作品搬透露着诡异与迷惑。其问题可以归结为以下两点:


  • 未梳理调色盘上的颜色间内在关系,仅通过面积排序。
  • 以面积大小作为调色盘颜色与 Banner 元素的映射关系过于简单粗暴。
机器学习的暴力计算或许是人类面对自我无法掌控的诡异关系时的一条救赎之路。虽然通过机器学习,或能拟合上述关系,但训练海量样本的成本却令人望而却步。“以暴制暴”并不适用于“文艺”的智能设计机器人。暴力解决只会因为对问题的不放在眼里使其更加复杂。问题的本质不仅仅是找到合适的色彩搭配,而是找到元素层之间的的搭配规律。
配色法则
使用成立于色彩搭配关系的配色法则,可以避免以上的问题。说到色彩搭配关系,不得不提到 Google 在 Android Material Design 中提供的 Palette 类库。该类库的感化是可以从图像中提取一组颜色,以用于界面元素中,营造沉浸感的界面。如下图音乐软件界面中面板色与其相似的控制条色及与其具有高对比的按钮色均通过专辑封面动态提取。




这组由 Palette类库提取的颜色分为鲜活(Vibrant)、深色鲜活、淡色鲜活、暗沉(Muted)、深色暗沉、淡色暗沉六种类型。可以按照规律来为界面设置颜色,如:深色暗沉作为面板色、暗沉作为控制条色、鲜活为按钮色。进而提供了合理搭配。同时深色与淡色提供了合理的对比度凡是用于布景和文字。该类库的JS实现为Vibrant.js。通过分析其源码,会发现此中对图像中颜色进行必然法则的分类及转换。这证明了通过法则转换颜色,而且应用于多种商品或IP图像具有可行性。
通过Vibrant.js中内置的一条法则,可以得到一组配色方案。如果有多条合理的法则,对每一种商品或IP图案则可以生成多条方案。通过成立法则库能够丰硕成果的多样性。
对比使用调色盘,可以得出以下结论:
调色板配色法则映射关系通过“面积”确定关系由各层次元素的关系分析得出获取来源网络中的调色板无法直接使用由专家(设计师)设计法则复用性调色板不成复用配色法则可以复用由此可见,使用配色法则:基于元素的层次关系,可以使成果不变安全;获取法则的来源除由专家创建外,亦可以通过层次关系于网络中转化;同时一条法则可以复用在各种商品或IP图案的情况下,较少的配色法则就可以撑持大部门Banner需求。
系统框架
基于上述分析,可成立基于配色法则的,具有较高拓展性的系统框架。如下图所示,横向为智能配色主流程,其他为辅助流程。




该方案主要由四部门构成,即图像取色、法则选择、方案生成及颜色替换:


  • 图像取色:对 Banner 图主体图案(如:商品图、IP形象图等)量化并提代替表色。图像主题色提取有多种方式,如基于量化算法的中位切分法(Median Cut)、八叉树法(Octree)等;基于聚类的K-Means 方式等。上文中提到的Vibrant.js基于量化算法,亦可用于图像取色。
  • 法则选择:由AI按照代表色、风格自动挑选合适的法则。虽然配色法则具有必然的通用性,但针对分歧的色彩依然有优劣之分。分歧的配色法则更是发生分歧的配色风格。通过对商品代表色、风格和基于配色法则的成果进行评分与训练,得到分歧颜色、风格对应的最佳法则。该训练除了通过人工训练,亦可通过Banner在实际使用中的点击量作为反馈进行训练。
  • 方案生成:方案生成是该系统中的核心部门。成立有效的配色法则,并生成合理的配色方案将直接决定成果的效果。
  • 颜色替换:按照配色方案中的颜色与Banner中元素的对应关系,对Banner中的元素进行颜色替换,进而完成配色。颜色替换与素材有关,SVG等形式的素材,撑持色彩的直接替换。如为PNG等格式的素材,则需采用canvas遍历像素替换的方式。
法则库为该系统提供了良好的扩展性。下文主要讨论本方案系统架构中的关键部门:方案生成。
色彩:方案生成
方案生成是智能配色系统的核心。此中有两个重点,即颜色模型的选择和基于颜色模型的法则。
颜色模型
在日常的设计及UI开发中,十六进制色值(Hex)是我们常用的暗示颜色的方式。十六进制色值实则是RGB模型的一种表达形式。虽然使用Hex非常便利,但学术范的 RGB 模型在设计配色时却格格不入。RGB 基于色光混合道理设计,用红、绿、蓝光强弱的叠加描述颜色,虽然符合视锥细胞的感色道理和显示器的显色道理,是机器的最爱,却违背人类的知觉,让人无力使用。




对比 HSL 模型,则通过色相、饱和度及亮度为分量暗示颜色则易于描述,使按照感知调配颜色成为可能,挽回了人类的尊严。




值得一提的是,HSL 拥有一位双生兄弟 HSB(亦称为 HSV)并吞了 Photoshop 等主流设计软件的调色器,更为设计师熟悉,然而其性格变节。相较于HSL符合其确切定义,HSB中的饱和度为0%时,应为等深的灰色,却为白色;其亮度为100%时,应为纯白色,却为颜色本身。这种调整在设计软件中虽然简化了设计师选择颜色界面的面积,却不符合分量的定义,亦引起歧义,且不利于法则计算,故未被项目使用。
鉴于 HSL 定义尺度(受W3C尺度撑持)且以色相、饱和度、亮度为分量,易于构建配色法则。故选择以HSL为颜色模型构建法则。这样任何一个颜色C,可以转化为由(H,S,L)三个分量构成的数组。通过分量成立配色法则,以应用于其他颜色。
配色法则
通过 HSL 可以使用人类的直觉来描述颜色,并挖掘此中的配色规律,继而形成配色法则。
事实上在设计范围中,逐渐形成了一系列的配色方式,以及带有鲜明特色的配色规律。可以将这些方式和规律通过 HSL 模型,转化为法则,进而形成仓库。




以HSL模型中的H分量色相为例。基于色相,设计范围可以按照色相环(以环状暗示色相)进行配色,并拥有一系列规律。如常见的配色方式:


  • 单色配色:设计的时候只使用一种色彩,或者使用某一色调的深色和淡色。
  • 类似色配色:使用色轮中彼此相邻的三种色彩来作为配色方案。
  • 互补色配色:使用色轮上相对位置的两种色彩来进行搭配。
  • 三色配色:使用色轮上互呈120度角度的三种色彩搭配。
由此可见,设计师在配色时,是通过旋转色相环角度的方式找到合适的颜色,而且该旋转角度存在着既定的规律,并可以复用。鉴于此道理,我们可以构建以下的法则:




设计师在以黄色(C1)作为代表色时,通过对其分量(H1,S1,L1)进行旋转和变化,形成了适用于分歧层的一组颜色浅黄C11(H11,S11,L11),浅橙C12(H12,S12,L12),橙C13(H13,S13,L13)。
将之间的变化量记录下来形成法则:(ΔH11,ΔS11,ΔL11),(ΔH12,ΔS12,ΔL12),(ΔH13,ΔS13,ΔL13);此中:ΔH11=H11-H1,其他以此类推。
当新的商品或IP需要生成Banner配色时,如:遇到以绿色(C2)作为代表色的商品,则可以通过对其分量(H2,S2,L2)做不异的变化,以得到颜色:绿C21(H21,S21,L21),浅绿C22(H22,S22,L22),黄C23(H23,S23,L23)。此中:H21 = H2 + ΔH11,其他以此类推。
这样构成了基于分量变化的配色法则。
然而,在实践过程中发现,存在色值溢出的情况。即H的数值范围为0°~360°,S与L的数值范围为0°~100°。因同一法则使用在分歧颜色中,如使用亮度饱和度斗劲适中的色彩进行法则创建,却用于亮度与饱和度较高或较低的颜色,色值便会溢出,故溢呈现象斗劲常见。如下图所示,按照紫色成立的配色法则,当使用粉黄色时,其亮度与饱和度在分歧分层上均呈现了溢出的状况,以至于法则无法使用。




颠末实际效果的比对和与设计师的合作,针对溢出情况,对法则做如下措置:


  • 色相:由于色相是环状关系,故超出360°或少于0°的情况可以按照圆形计算其实际度数,如370°实为10°,-10°实为350°。
  • 饱和度与亮度:颠末实际比对与设计师经验发现,配色的色彩丰硕由色相决定,偏转色相符合设计规律。而饱和度与亮度,在设计时凡是用于调整分歧色相间发生的差异,或营造氛围。应记录饱和度与亮度的数值,直接调整至该数值,而非记录变化值。
颠末调整后,配色法则最终为:(ΔH11,S11,L11),(ΔH12,S12,L12),(ΔH13,S13,L13);当其他颜色如C2作为代表色时,通过计算H和将S、L直接调整至对应值,得出:C21(H21,S11,L11),C22(H22,S12,L12),C23(H23,S13,L13),此中:H21 = H2 + ΔH11,其他以此类推。
颠末调整,如上图所示,粉色可以通过法则形成较好的配色成果。由此构建了斗劲健全的配色法则。进而可以由设计师成立法则库。
模型调整
在实际实施过程中,颠末一系列对比,HSL模型中存在着的瑕疵逐渐浮现出来。




如左图所示,在固定色相与亮度的情况下,对等分的12个色相进行最佳相似色色相旋转角度偏移值的探索。经对比发现,其旋转角度呈现发抖,说明同一条旋转角度的法则,不能广泛应用于其他色相。
右图则为固定色相与饱和度,只调节亮度,找到最佳搭配的不异色相分歧深浅的两个颜色。如针对红色,当布景色亮度为60%时,纹理色为48%时,最为舒适。两种亮度的关系也呈现了发抖,并非固定为同一值。说明不异的亮度设置,亦不能广泛应用于其他色相。
追其原因,是因为HSL中的色值依然不够“人性化”。不雅观其色相,在肉眼的感知上,并非一致。如下图将色轮展开,不雅察看右侧HSL色轮,黄色区域非常敞亮,而蓝紫区域则非常暗。即便通过对亮度排序,依然存在其他的肉眼感知问题,导致规律难寻。这减少了法则的可复用性,同一风格,需成立多条法则以满足分歧状况。




通过对解决方案的探索,我们发现了L*C*h模型,该模型由光色科学范围的权威机构,国际照明委员会(CIE)提出。L*C*h 模型与肉眼如何感知色彩具有良好的相关性,整消除了肉眼感知的纷歧致。如上图左侧所示,L*C*h在饱和度为100%,亮度为60%的情况下,相较于HSL模型更加的融合一致。而且相较于不异出身的 L*a*b 模型有着与 HSL 模型不异的表达模式,即以修正过的色相、饱和度、亮度为分量。故可以通过使用L*C*h模型替代或补充HSL模型,以提高配色法则的广泛试用性。
其他
前文中法式,需要进行色值转化。色值转化部门需要撑持 HEX、RGB、HSL、L*C*h 之间的转化。采用Chroma.js可以便利的实现上述转换。
基于以上法则,由设计师生成少量的法则,存入法则库,即可实现对Banner配色的撑持。同时,丰硕更多的法则,形成更多风格的法则,将大大提升配色成果的多样性。

自动生成Banner,智能配色是此中不成或缺的部门。

转载:本文由成都同创合一科技有限公司引用自DeepOcean如有侵权,请联系我们删除。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×
回复

使用道具 举报

0

主题

1

回帖

10

积分

新手上路

积分
10
发表于 2023-5-8 09:37:10 | 显示全部楼层
"调色板配色规则映射关系通过“面积”确定关系由各层次元素的关系分析得出获取来源网络中的调色板无法直接使用由专家(设计师)设计规则复用性调色板不可复用配色规则可以复用由此可见"   没个标点符号的
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|T9AI - 深度人工智能平台 ( 沪ICP备2023010006号 )

GMT+8, 2025-1-8 11:15 , Processed in 0.065184 second(s), 23 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表