最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

PNG格式小图标的CSS任意颜色赋色技术_html/css_WEB-ITnose

来源:懂视网 责编:小采 时间:2020-11-27 16:29:47
文档

PNG格式小图标的CSS任意颜色赋色技术_html/css_WEB-ITnose

PNG格式小图标的CSS任意颜色赋色技术_html/css_WEB-ITnose:这篇文章发布于 2016年06月8日,星期三,01:17,归类于css相关。 阅读 3 次, 今日 2 次 byzhangxinxu from http://www.zhangxinxu.com 本文地址: http://www.zhangxinxu.com/wordpress/p=5429 一、眼见为实
推荐度:
导读PNG格式小图标的CSS任意颜色赋色技术_html/css_WEB-ITnose:这篇文章发布于 2016年06月8日,星期三,01:17,归类于css相关。 阅读 3 次, 今日 2 次 byzhangxinxu from http://www.zhangxinxu.com 本文地址: http://www.zhangxinxu.com/wordpress/p=5429 一、眼见为实

这篇文章发布于 2016年06月8日,星期三,01:17,归类于css相关。 阅读 3 次, 今日 2 次

byzhangxinxu from http://www.zhangxinxu.com

本文地址: http://www.zhangxinxu.com/wordpress/?p=5429

一、眼见为实

CSS可以修改图片的颜色,没错,可以,眼见为实!您可以狠狠地点击这里:png小图标CSS赋色demo

上面的不是很黑的是原始图标,是个PNG图片,下面这个是可以赋色的:

下面,我们随意选择一个颜色,例如紫色,然后:

是不是感觉很厉害!以后设计师就不需要在提供几套颜色的图片了。

SVG, icon fonts等技术似乎也不是那么耀眼了。

二、原理其实很简单

原理其实很简单,使用了CSS3滤镜 filter 中的 drop-shadow , drop-shadow 滤镜可以给元素或图片非透明区域添加投影。

如果对 drop-shadow 不是很了解,建议先看看前些时间写的“ CSS3 filter:drop-shadow滤镜与box-shadow区别应用 ”一文!

对于背景透明的png小图标而言,如果我们施加一个不带模糊的投影,不就等同于生成了另外一个颜色的小图标了吗?

然后,我们把原始图标隐藏在容器外面,投影图标在容器中间,不见给人感觉是赋色效果了?

比方说本文的demo,如果把icon父级的的 overflow:hidden 去掉,原始的图标就暴露出来啦!

三、实现的时候实际有难度

原理如上面,我一开始实现的时候,以为很简单,因为分分钟可以实现自己的想法,后来发现有些天真了,Chrome浏览器怎么都显示不出来;FireFox浏览器却可以!咦,究竟发生了什么。

在Chrome浏览器下, drop-shadow 有一个如下的呈现特性:

在Chrome浏览器下,如果一个元素的主体部分,无论以何种方式,只要在页面中不可见,其drop-shadow是不可见的;实体部分哪怕有1像素可见,则drop-shadow完全可见。

所以,我试过:

  • text-indent负值隐藏原始图,无投影,失败!
  • clip剪裁隐藏,无投影,失败!
  • margin负值隐藏原始图,无投影,失败!
  • left负值隐藏原始图,无投影,失败!
  • 通通不行,实现遇到了巨大的阻碍。

    后来,灵光一现,如果我实体部分也在可视区域内,但是是透明的,会怎样呢(反正不会有投影出来)?

    于是,我就试了下曾经立下无数战功的透明边框,卧槽,又立功了,成了!

    因此,下面这一个CSS声明是千万不能少的:

    border-right: 20px solid transparent;

    四、关于兼容性

    IE13+支持,Chrome和FireFox浏览器支持,移动端iOS支持,Android4.4+支持。也就是,基本上,移动端现在可以使用这种技术了。

    既节约了流量,也让我们的开发更简单,维护更方便了。

    五、结语碎碎念

    其实,本文的技术发明(主要是透明border的处理)在“ drop-shadow vs box-shaow ”这篇文章完成后就研究出来了。本来想写个小专利,蹭点早饭钱。结果,新厂子写专利没费用,而且周期要3年。

    3年我儿子都可以打酱油了。所以,罢了,直接分享出来。

    今天8号,本月已经6篇文章了,写文章暴走了下。就是为了腾出大段且连续的业余时间,要秘密进行其他大项目。

    时光机

    如果你是3~5年之后看到此文,而且你是2016年上大学的,那么,我在写这篇文章的时候,你可能正在翻来覆去睡不着,还在焦虑明天的考试。总之,不要担心,我给大家找了一个非常硬的后台,保证你们这次高考无忧,放心睡觉吧!哟,你在好奇是哪个后台。嘻嘻嘻嘻,说出来怕吓着你————观音菩萨!

    本文为原创文章,包含脚本行为,会经常更新知识点以及修正一些错误,因此转载请保留原出处,方便溯源,避免陈旧错误知识的误导,同时有更好的阅读体验。

    本文地址: http://www.zhangxinxu.com/wordpress/?p=5429

    (本篇完)

    文档

    PNG格式小图标的CSS任意颜色赋色技术_html/css_WEB-ITnose

    PNG格式小图标的CSS任意颜色赋色技术_html/css_WEB-ITnose:这篇文章发布于 2016年06月8日,星期三,01:17,归类于css相关。 阅读 3 次, 今日 2 次 byzhangxinxu from http://www.zhangxinxu.com 本文地址: http://www.zhangxinxu.com/wordpress/p=5429 一、眼见为实
    推荐度:
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top