广告
返回顶部
首页 > 资讯 > 精选 >如何使用CSS改变图片颜色
  • 753
分享到

如何使用CSS改变图片颜色

2023-06-08 07:06:25 753人浏览 薄情痞子
摘要

这篇文章将为大家详细讲解有关如何使用CSS改变图片颜色,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。前言“说到对图片进行处理,我们经常会想到PhotoShop这类的图像处理工具。作为前端开发者,我们经常会

这篇文章将为大家详细讲解有关如何使用CSS改变图片颜色,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

前言

“说到对图片进行处理,我们经常会想到PhotoShop这类的图像处理工具。作为前端开发者,我们经常会需要处理一些特效,例如根据不同的状态,让图标显示不同的颜色。或者是hover的时候,对图片的对比度,阴影进行处理。”

如何使用CSS改变图片颜色

你以为这些是经过PS软件处理出来的?不不不,纯粹的是用css写出来的,很神奇把。

强大的 CSS:filter

CSS滤镜(filter)属提供的图形特效,像模糊,锐化或元素变色。过滤器通常被用于调整图片,背景和边界的渲染。 MDN

CSS标准里包含了一些已实现预定义效果的函数。

filter: none            | blur()     | brightness()     | contrast()     | drop-shadow()     | grayscale()     | hue-rotate()     | invert()     | opacity()     | saturate()     | sepia()     | url();

如何使用CSS改变图片颜色

filter: none

没有任何效果,默认filter就为none

filter:blur( ) 高斯模糊

给图像一个高斯模糊效果,length值越大,图像越模糊

我们来尝试一下

img {    filter:blur(2px);;}

如何使用CSS改变图片颜色

brightness(%) 线性乘法

可以让图片看起来更亮或者更暗

img {filter:brightness(70%);}

如何使用CSS改变图片颜色

contrast(%) 对比度

调整图像的对比度。

img {    filter:contrast(50%);}

如何使用CSS改变图片颜色

drop-shadow(h-shadow v-shadow blur spread color)

给图像设置一个阴影效果。阴影是合成在图像下面,可以有模糊度的,可以以特定颜色画出的遮罩图的偏移版本。函数接受<shadow>(在css3背景中定义)类型的值,除了”inset”关键字是不允许的。该函数与已有的box-shadow box-shadow属性很相似;不同之处在于,通过滤镜,一些浏览器为了更好的性能会提供硬件加速

利用这个方案,我们其实改变类似于一些图标的颜色,比如黑色的图标变成蓝色的图标。

PNG格式小图标的CSS任意颜色赋色技术

img {    filter: drop-shadow(705px 0 0 #ccc);}

在这里,我们将图片投影形成一个同等大小的灰色区域。

如何使用CSS改变图片颜色

hue-rotate(deg) 色相旋转

img {    filter:hue-rotate(70deg);}

看,我的小姐姐变成了阿凡达!

如何使用CSS改变图片颜色

invert(%) 反转

这个函数的作用是反转输入图像,有点像曝光的效果

img {    filter:invert(100%)}

如何使用CSS改变图片颜色

grayscale(%) 将图像转换为灰度图像

这个效果可以将图片做旧,有一种时代沧桑感。喜欢古风的人一定会喜欢上这个效果的

img {    filter:grayscale(80%);}

如何使用CSS改变图片颜色

除了古风还有一种用法是有的时候需要将全站变成灰色,如大屠杀纪念日的时候。

如何使用CSS改变图片颜色

可以这样设置

*{    filter: grayscale(100%);    -WEBkit-filter: grayscale(100%);    -moz-filter: grayscale(100%);    -ms-filter: grayscale(100%);    -o-filter: grayscale(100%);}

  sepia(%) 将图像转换为深褐色

下面给我的小姐姐一个暖暖的色调。

img {    filter:sepia(50%)}

如何使用CSS改变图片颜色

大家是不是发现我并没有把url()方法写到这上面来

没错,因为我想把这个内容放到最后来说,filter:url()就是css滤镜改变图片的终极方法。CSS:filter可以导入一个svg滤镜,作为他自己的滤镜。

终极变色解决方案! filter:url();

为什么说filter:url()是图片变色的终极解决方案呢,请容我慢慢道来。

我们先科普一下PS的工作原理,我们都知道网页是有三原色的R(红) G(绿) B(蓝),常见的RGBA还包括一个opicity值,而opcity值是根据alpha通道计算出来的。也就是说,我们见到的网页的每一个像素点都是由红蓝绿再加alpha四个通道组成,每一个通道我们称之为色板,PS中的8位板的意思就是2的八次方256,意思就是每一个通道的取值范围都是(0-255) &ndash;SVG 研究之路 (11) &ndash; filter:feColORMatrix

如果我们可以改变每个通道的值是不是就能完美的得到我们想要的任意颜色了呢,原理上,我们可以像ps那样利用svg滤镜得到任何我们想要的图像,不仅仅是变色。我们甚至可以凭空生成一幅图像。

svg feColorMatrix大法好

<svg height="0" xmlns="Http://www.w3.org/2000/svg">    <defs>        <filter id="change">                <feColorMatrix type="matrix" values="                0 0 0 0 0.55                0 0 0 0 0.23                 0 0 0 0 0                 0 0 0 0 1" />        </filter>    </defs></svg><img src="https://note.youdao.com/yws/res/237/WEBRESOURCE7e77df2551fe1a1db1b9d91f4d518917" alt="">img {    filter:url(#change);}

通过单通道我们可以将图片变成单一的颜色

如何使用CSS改变图片颜色

<svg height="0" xmlns="http://www.w3.org/2000/svg">    <defs>        <filter id="change">               <feColorMatrix values="3 -1 -1 0 0                       -1 3 -1 0 0                       -1 -1 3 0 0                       0 0 0 1 0" />        </filter>    </defs></svg>

通过双通道我们可以的到一些非常炫酷的PS效果

如何使用CSS改变图片颜色

当然,在这里,只是举个例子,通过配置矩阵中的值,我们可以配置每一个像素点的值按照我们定义的规则显示

我们在这里详细讲一下feColorMatrix 矩阵的计算方式

如何使用CSS改变图片颜色

其中Rin Gi

n Bin a(alpha) 为原始图片中每个像素点的rgba值

通过矩阵计算,得到的Rout Gout Bout Aout就是最终显示出来的rgba值。

将图片转为单色 拿棕色rgba(140,59,0,1)作为例子

根据上面的公式,我们可以简化一些计算,同一行中,只设置一个通道的值,其他通道为0

不难得出矩阵

0 0 0 0 目标值R0 0 0 0 目标值G0 0 0 0 目标值B0 0 0 0 1

根据规则,只需要计算,255/想要显示的颜色对应通道 = 目标值

我们想要的棕色rgba(140,59,0,1) 换算成色板 rgba 为 140 59 0 255

可以算出目标值

0 0 0 0 0.550 0 0 0 0.230 0 0 0 0 0 0 0 0 1

多通道设置出炫酷的效果来

就如同之前我们看到的双通道形成的炫酷图片一般

我們今天要把圖片的飽和度提高,該怎麼做呢?首先當然是想想飽和度的成因,就是紅的越紅,藍的越藍,綠的越綠,由這個成因出發,我們的矩陣就可以寫成下面的樣子,看到矩陣當中出現了 3 和 -1,一定會很那悶這是怎麼來的,箇中原理其實很容易理解,讓我們假設某一個像素的 RGB 分別是 (200/255),(100/255),(50/255),呈現的應該是有點暗沉的橘色,經過矩陣的換算,R 變成了 200/255&times;3-100/255-50/255= 1.76, G 變成 200/255x(-1)+100/255*3-50/255=0.2,B 變成 200x(-1)+100x(-1)+50&times;3=-0.59,因此 RGB 轉換後就是:200&times;1.76,100&times;0.2,50x-0.5。SVG 研究之路 (11) &ndash; filter:feColorMatrix

<svg height="0" xmlns="http://www.w3.org/2000/svg">    <defs>        <filter id="change">               <feColorMatrix values="3 -1 -1 0 0                       -1 3 -1 0 0                       -1 -1 3 0 0                       0 0 0 1 0" />        </filter>    </defs></svg>

其他方案

除了feColorMatrix svg滤镜还有很多的方法可以定义滤镜,他们同样可以作用到图片上。由于篇幅限制,这里就不详细展开了

总结 css3提供了filter这个属性,使得通过前端技术实现更多炫酷的特效成为了可能 依赖于svg的滤镜,我们可以实现复杂的滤镜效果 注意 css:filter与ie上的filter并不是相同的概念 css:filter在不同的浏览器上兼容性不一样,您在使用的时候需要注意浏览器的兼容性

如何使用CSS改变图片颜色

关于“如何使用CSS改变图片颜色”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

--结束END--

本文标题: 如何使用CSS改变图片颜色

本文链接: https://www.lsjlt.com/news/252718.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何使用CSS改变图片颜色
    这篇文章将为大家详细讲解有关如何使用CSS改变图片颜色,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。前言“说到对图片进行处理,我们经常会想到PhotoShop这类的图像处理工具。作为前端开发者,我们经常会...
    99+
    2023-06-08
  • css如何改变图片颜色
    小编给大家分享一下css如何改变图片颜色,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!在css中,可以使用filter属性来改变图片颜色,例如:使用“filter...
    99+
    2023-06-08
  • css怎么改变图片颜色
    小编给大家分享一下css怎么改变图片颜色,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!什么是csscss是一种用来表现HTML或XML等文件样式的计算机语言,主要...
    99+
    2023-06-14
  • css怎么改变图片的颜色
    这篇文章给大家分享的是有关css怎么改变图片的颜色的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。css的基本语法是什么css的基本语法是:1、css规则由选择器和一条或多条声明两个部分构成;2、选择器通常是需要改...
    99+
    2023-06-14
  • css怎么改变png图片的颜色
    这篇文章将为大家详细讲解有关css怎么改变png图片的颜色,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。css中可使用filter属性配合invert()、grayscale()、sepia()或hue-...
    99+
    2023-06-14
  • 用CSS改变图片颜色的方法有哪些
    本文小编为大家详细介绍“用CSS改变图片颜色的方法有哪些”,内容详细,步骤清晰,细节处理妥当,希望这篇“用CSS改变图片颜色的方法有哪些”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识...
    99+
    2022-10-19
  • 怎么用CSS修改图片颜色
    小编给大家分享一下怎么用CSS修改图片颜色,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!   原理嘛,其实很简单的,用到的就是 CSS3 滤镜filter中的drop-shadow,该滤...
    99+
    2022-10-19
  • 纯css如何实现更改图片颜色
    这篇文章主要介绍纯css如何实现更改图片颜色,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!css是什么意思css是一种用来表现HTML或XML等文件样式的计算机语言,主要是用来设计网页的样式,使网页更加美化。它也是一...
    99+
    2023-06-08
  • css如何改变光标颜色
    小编给大家分享一下css如何改变光标颜色,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!css改变光标颜色的方法是,给光标添加caret-color属性,并设置合适...
    99+
    2023-06-15
  • css如何改变文字颜色
    这篇文章将为大家详细讲解有关css如何改变文字颜色,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。css改变文字颜色的方法是,通过设置color属性来实现,如【color:red;】或【color:#00f...
    99+
    2023-06-15
  • css图片的边框如何设置颜色为渐变色
    这篇文章主要介绍css图片的边框如何设置颜色为渐变色,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! 在css中,可以利用border-image属性和li...
    99+
    2022-10-19
  • css如何改变div字体颜色
    这篇“css如何改变div字体颜色”文章,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要参考一下,对于“css如何改变div字体颜色”,小编整理了以下知识点,请大家跟着小编的步伐一步一步的慢慢理解,接下来就让我们进入...
    99+
    2023-06-06
  • css如何改变html字体颜色
    这篇文章给大家分享的是有关css如何改变html字体颜色的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 字体色彩代码:color1、篡改div字体颜色 .divys{ col...
    99+
    2022-10-19
  • 怎么在Android中使用Drawable改变图片的颜色
    今天就跟大家聊聊有关怎么在Android中使用Drawable改变图片的颜色,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1.利用color资源对Drawable变色Drawable...
    99+
    2023-05-30
    android drawable
  • Android开发中如何使用颜色矩阵改变图片颜色,透明度及亮度
    小编给大家分享一下Android开发中如何使用颜色矩阵改变图片颜色,透明度及亮度,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!具体如下:一、如图二、代码实现pub...
    99+
    2023-05-30
    android
  • 怎么使用css改变按钮颜色
    本篇内容介绍了“怎么使用css改变按钮颜色”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、CSS颜色在CSS中,颜色可以用以下方式来表示:...
    99+
    2023-07-06
  • 如何通过css3的filter滤镜改变png图片颜色
    这篇文章将为大家详细讲解有关如何通过css3的filter滤镜改变png图片颜色,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。本方法是通过CSS3滤镜 filter 中的 drop-shadow 将png...
    99+
    2023-06-08
  • 如何用javascript改变颜色
    这篇文章给大家介绍如何用javascript改变颜色,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。使用javascript改变颜色的方法:1、使用“元素对象.style.color =...
    99+
    2022-10-19
  • css同一行字体如何改变不同颜色
    这篇文章主要讲解了“css同一行字体如何改变不同颜色”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“css同一行字体如何改变不同颜色”吧! ...
    99+
    2022-10-19
  • css如何实现点击div改变背景颜色
    这篇文章主要讲解了“css如何实现点击div改变背景颜色”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“css如何实现点击div改变背景颜色”吧!在css中,...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作