CSS中颜色突变的实现方案

我所说的颜色突变是指:两个颜色之间没有渐变,直接过渡,如下图所示:


颜色突变示例.png

在CSS中,颜色突变的效果的应用还是很广泛的,比如:条纹背景(参考《CSS中条纹效果的实现方案》)、网格背景、多边形图案等等;

在CSS中实现颜色突变的效果有多种方案,如下:

方案1:多个元素组合

这个方案的思路比较直观,就是每个颜色块用一个元素显示;由于过于简单,在此就不再讲解;

此方案优点:

  1. 原型直观,易理解;
  2. 可以实现任意多的颜色突变;

此方案缺点:

  1. 添加了较冗余的元素;

方案2:插入颜色渐变辅助色标

这个方案是通过CSS中的渐变实现;但由于在CSS渐变中不支持实色块的长度,即:只能线性地过渡2个相邻的色标。所以若要实现颜色的突变,还需要一个技巧,些技巧的原理步骤如下:

以background的线性渐变为例;
假设我们需要实现从颜色1到颜色2的突变,如下图:

示例.png

具体的实现步骤如下:

  1. 定义从颜色1到颜色2的渐变;
    示例代码:

    background-image: linear-gradient(to right, red 0%, blue 100%);
    

    示例效果:

    步骤1.png
  1. 插入颜色1和颜色2的实色辅助色标;
    为了在渐变中实现实色(没有渐变的颜色)效果,我们需要在颜色1与颜色2之间再插入与颜色1具有相同颜色的色标1+ 和 与颜色2具有相同颜色的色标2+;如下图:
    示例效果:

    步骤2.png

    示例代码:

    background-image: linear-gradient(to right, red 0%,red 40%,blue 60%, blue 100%);
    
  2. 把实色辅助色标放在同一位置;
    在步骤2中已经实现了实色块(色标1--色标1+ 和 色标2+—色标2),但是色标1+—色标2+之间的色区仍是渐变的效果,为了实现突变的效果,我们可以让渐变区域的长度变为零;如下:
    示例效果:

    步骤3.png

    示例代码:

    background-image: linear-gradient(to right, red 0%, red 50%, blue 50%, blue 100%);
    

此方案的优点:

  1. 用单个元素实现,不用添加冗余元素;
  2. 可以实现任意多颜色的突变;

方案3:非重复的2色渐变

方案2可以实现任意多颜色的突变,如果只有2种颜色的突变,则使用非重复的渐变实现起来会更方便;原理步骤如下:

以background的线性渐变为例;
假设我们需要实现从颜色1到颜色2的突变,如下图:

示例.png

具体的实现步骤如下:

  1. 定义从颜色1到颜色2的渐变;
    示例代码:

    background-image: linear-gradient(to right, red 0%, blue 100%);
    

    示例效果:

    步骤1.png
  2. 把色标1与色标2向突然位置靠拢;
    根据《CSS中渐变函数的特性》 (见附录),可知:对于非重复渐变:如果把色标1往后移,则色标1之前的区域会用色标1的颜色填充,形成色标1的实色区域;如果把色标2的位置往前移,则色标2之后的区域会用色标2的颜色填充,形成色标2的实色区域;如下:
    示例效果:

    步骤2-非重复.png

    示例代码:

    background-image: linear-gradient(to right, red 40%,blue 60%);
    
  3. 把色标1和色标2放在同一位置;
    在步骤2中已经实现了实色块(色标1之前 和 色标2之后),但是色标1—色标2之间的色区仍是渐变的效果,为了实现突变的效果,我们可以让渐变区域的长度变为零;如下:
    示例效果:

    步骤3-非重复.png

    示例代码:

    background-image: linear-gradient(to right, red 50%, blue 50%);
    

此方案的优点:

  1. 用单个元素实现,不用添加冗余元素;
  2. 不用添加辅助色标;

此方案的缺点:

  1. 只能用非重复渐变实现;
  2. 只能实现2个颜色的突变;

附录

由于本文会用到渐变的知识,所以,为了帮助大家理解,就把我总结的关于渐变的特性贴出来(原文:《HTML和CSS的发现与理解》 /CSS中渐变函数的特性),如下:

CSS中渐变函数的特性

  1. 每个渐变至少需要指定2个色标color-stop;
  2. 对于任意2个相邻色标之间的颜色变化是:在前一个色标与后一个色标的位置之间,线性地把前一个色标的颜色过渡到后一个色标的颜色;
  3. 对于多个没指定位置的色标,它们的位置分别是:前面最近的有位置的色标的位置 与 后面最近有位置的色标的位置 之间的平分点;
  4. 如果第1个色标没有指定位置,则第1个色标的位置是渐变区域的起始位置;
  5. 如果最后1个色标没有指定位置,则最后1个色标的位置是渐变区域的结束位置;
  6. 对于非重复渐变,第1个色标位置之前的颜色是第1个色标的颜色;最后一个色标位置之后的颜色是最后一个色标的颜色;
  7. 对于重复渐变,会用渐变区域分别平铺第1个色标之前的区域 和 最后1个色标之后的区域 ,直到填满为止;
  8. 对于重复渐变,如果渐变渐变区域的长宽为零,则会用最后1个色标的颜色填充整个区域;
  9. 如果前面色标设置的位置大于后面色标设置的位置,则后面色标设置的位置无效,所有比前端色标的位置小的色标,都将用 大于自身位置的前面的色标中位置最大的那个色标的位置 作为自身的位置;

相关文章:CSS中特殊效果的实现方案

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • 在用CSS实现等效中,经常会用到渐变,所以,本篇就研究一下渐变的特性; 在CSS中,渐变并不是作为CSS中的一个属...
    科研者阅读 656评论 0 3
  • 条纹效果如下所示: 在CSS中,条纹效果的应用还是很广泛的,比如:条纹背景、网格效果、棋盘格效果等等; 条纹效果的...
    科研者阅读 1,788评论 0 1
  • 环形效果如下所示: 环形效果的特点就是:多个颜色条交替排列,相邻颜色条之间的过渡是突变的效果;所以,可以用颜色突变...
    科研者阅读 3,235评论 0 4
  • 小姐姐: 你好,这是分开后的第二封信,我在阳朔。 昨天从兴坪坐船游了漓江,码头满满当当都是...
    陌上宁秋阅读 268评论 0 0
  • 今天看到一道面试题,打印螺旋数组,具体打印结果如下图所示: 之后使用java代码实现了一下,具体代码如下所示。 p...
    he_321阅读 1,905评论 0 0