css图片颜色提取(解析CSS 提取图片主题色功能小技巧)
css图片颜色提取
解析CSS 提取图片主题色功能小技巧背景起因是微信技术群里有个同学发问,有什么方法能够获取图片的主色呢?有一张图片,获取他的主色调:
利用获取到的这个颜色值,来实现类似这样的功能 -- 容器中有一张图片,希望背景色可以适配图片的主色,像是这样:
大家出谋划策,有说利用 Canvas 进行计算的,有推荐专门的开源库的,都挺好。
那么,利用 CSS,能不能实现这个功能呢?
听起来好像有点痴人说梦,CSS 还能实现这个效果?emm,利用 CSS 确实可以通过一种讨巧的方式,近似的获取到图片的主色调,在对主色的要求不是特别精确的情况下,不失为一种办法,下面一起来一探究竟。
利用 filter: blur() 及 transform: sacle() 获取图片主题色
这里,我们利用模糊滤镜以及放大效果,可以近似的拿到图片的主题色。
假定我们有这样一张图片:
<li></li>
利用模糊滤镜作用给图片:
li { background: url("https://i0.wp.com/airlinkalaska.com/wp-content/uploads//aurora-2.jpg" alt="css图片颜色提取(解析CSS 提取图片主题色功能小技巧)" border="0" />
看看效果,我们通过比较大的一个模糊滤镜,将图片 blur(50px)
,模糊之后的图片有点那感觉了,不过存在一些模糊边缘,尝试利用 overflow
进行裁剪。
接下来,我们需要去掉模糊的边边,以及通过 transform: scale()
放大效果,将颜色再聚焦下,稍微改造下代码:
li { position: relative; width: 320px; height: 200px; overflow: hidden; } li::before { content: ""; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: url("https://i0.wp.com/airlinkalaska.com/wp-content/uploads//aurora-2.jpg" alt="css图片颜色提取(解析CSS 提取图片主题色功能小技巧)" border="0" />
结果如下:
这样,我们就利用 CSS,拿到了图片的主色调,并且效果还是不错的!
完整的代码你可以戳这里:CodePen Demo -- Get the main color of the image by filter and scale
不足之处当然,该方案也是存在一定的小问题的:
只能是大致拿到图片的主色调,无法非常精确,并且 filter: blur(50px)
这个 50px
需要进行一定的调试模糊滤镜本身是比较消耗性能的,如果一个页面存在多个这种方法获取到的背景,可能对性能会造成一定的影响,实际使用的时候需要进行一定的取舍
好了,本文到此结束,介绍了一种利用 CSS 获取图片主题色的小技巧,希望对你有帮助 😃
感谢提出介绍这种方法的阅文的同学 -- XboxYan,iCSS 微信群非常活跃,聚集了一帮 CSS 大佬,想进群一起讨论技术的同学可以加我微信 coco1s(因为群超过了 200 人,不能扫码进群,只能邀请了)
更多精彩 CSS 技术文章汇总在我的 Github -- iCSS ,持续更新,欢迎点个 star 订阅收藏。
到此这篇关于解析CSS 提取图片主题色功能的文章就介绍到这了,更多相关CSS 提取图片主题色内容请搜索开心学习网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持开心学习网!
- css中最常用的选择符(CSS 类选择符和ID选择符的区别)
- css行框高度与lineheight(CSS中height和min-height的区别)
- css文字图片垂直居中对齐(CSS设置文字图片垂直居中的方法总结)
- div css实例列表(DIV+CSS实现电台列表设计的示例代码)
- css空白边叠加
- html5css3旋转特效效果(一款利用html5和css3实现的3D立方体旋转效果教程)
- css设置隐藏左右边框(CSS 实现元素较宽不能被完全展示时将其隐藏的方法)
- css3 图片样式处理(CSS3实现漂亮的照片墙效果的简单实例推荐)
- css怎么样让banner不动(CSS banner图响应式居中显示的方法)
- css3边框阴影的属性(css3 border-radius属性详解)
- css设置背景图片在角落(详解使用CSS固定页面背景图片位置的方法)
- CSS中margin和padding的区别
- css浮动边距加倍错误怎么办(详解CSS外边距折叠引发的问题)
- 简述css3动画与过渡效果(CSS3制作翻转效果_动力节点Java学院整理)
- css垂直居中16个方法(css实现元素垂直居中的常用方法总结)
- css3loading教程(详解纯CSS3制作的20种loading动效)
- 十二星座爱情支配欲指数(十二星座爱情支配欲指数)
- 虐待儿童是发泄支配欲的愚蠢行为(虐待儿童是发泄支配欲的愚蠢行为)
- 你或许不知道你隐藏的支配欲望(你或许不知道你隐藏的支配欲望)
- 把宽体丰田86卖了,换成7.5代高尔夫GTI玩起姿态与性能并存的改装(把宽体丰田86卖了)
- 大众推出了第五代高尔夫GT(大众推出了第五代高尔夫GT)
- 换代在即,现在是抄底 7.5代 高尔夫的最佳时机吗(换代在即现在是抄底)
热门推荐
- 云服务器搭建网站怎么选择合适(访问量过万的网站需要多大云服务器?)
- 百度免费翻译接口(基于python实现百度翻译功能)
- dede执行查询语句(dede搜索关键字/tag标签不能区分大写字母的临时解决方法)
- vmware 安装失败(安装使用Vmware出现的问题及解决方法)
- css3 图片样式处理(CSS3实现漂亮的照片墙效果的简单实例推荐)
- python多线程多进程运行场景(Python多线程同步---文件读写控制方法)
- python opencv图像表格处理(Opencv-Python图像透视变换cv2.warpPerspective的示例)
- python写一个二叉树(Python二叉搜索树与双向链表转换算法示例)
- 虚拟主机windows和linux啥区别(Linux虚拟主机的好处有哪些?)
- web服务器架构(常用的WEB服务器简介)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9