最新文章专题视频专题问答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
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

如何使用javascript获取图片主体背景色(代码)

来源:懂视网 责编:小采 时间:2020-11-27 19:30:33
文档

如何使用javascript获取图片主体背景色(代码)

如何使用javascript获取图片主体背景色(代码):本篇文章给大家带来的内容是关于如何使用javascript获取图片主体背景色(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。我们打开谷歌访问的时候,发现谷歌图片加载之前会先预加载出来图片的主题颜色,当时就觉得很有意思,效果是这
推荐度:
导读如何使用javascript获取图片主体背景色(代码):本篇文章给大家带来的内容是关于如何使用javascript获取图片主体背景色(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。我们打开谷歌访问的时候,发现谷歌图片加载之前会先预加载出来图片的主题颜色,当时就觉得很有意思,效果是这
本篇文章给大家带来的内容是关于如何使用javascript获取图片主体背景色(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

我们打开谷歌访问的时候,发现谷歌图片加载之前会先预加载出来图片的主题颜色,当时就觉得很有意思,效果是这样

1421271285-5b9f13f5ac14b_articlex.png

当然他们这个是后端给json的时候给了个颜色代码,暂且不提,但如果前端来做的话,也是有方法的,张鑫旭大神的博客里就记载的有,是一个叫rgbaster.js的玩意儿,具体用法我先给贴下来了。
rgbaster.js的内容是:

!function(n,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t():"function"==typeof define&&define.amd?define(t):n.RGBaster=t()}(this,function(){"use strict";var t=function(n,o){var u=new Image,t=n.src||n;"data:"!==t.substring(0,5)&&(u.crossOrigin="Anonymous"),u.onload=function(){var n,t,e,r=(n=u.width,t=u.height,(e=document.createElement("canvas")).setAttribute("width",n),e.setAttribute("height",t),e.getContext("2d"));r.drawImage(u,0,0);var i=r.getImageData(0,0,u.width,u.height);o&&o(i.data)},u.src=t},s=function(n){return["rgb(",n,")"].join("")},f=function(n,t){return{name:s(n),count:t}},n={};return n.colors=function(n,u){var a=(u=u||{}).exclude||[],c=u.paletteSize||10;t(n,function(n){for(var t={},e="",r=[],i=0;i<n.length;i+=4)r[0]=n[i],r[1]=n[i+1],r[2]=n[i+2],e=r.join(","),-1===r.indexOf(void 0)&&0!==n[i+3]&&-1===a.indexOf(s(e))&&(t[e]=e in t?t[e]+1:1);if(u.success){var o=function(n,t){if(n.length>t)return n.slice(0,t);for(var e=n.length-1;e<t-1;e++)n.push(f("0,0,0",0));return n}(function(n){var t=[];for(var e in n)t.push(f(e,n[e]));return t.sort(function(n,t){return t.count-n.count}),t}(t),c+1);u.success({dominant:o[0].name,secondary:o[1].name,palette:o.map(function(n){return n.name}).slice(1)})}})},n});

具体html和js的使用代码是:

<html>
<head>
 <meta charset="UTF-8">
 <title>获取图片主题色脚本扩展的完整的示例</title>
 <script src="./rgbaster.js"></script>
</head>

<body>
 <div id="box" style="width:500px;height: 500px;">
 <img src="mm4.jpg" alt="" id="image">
 </div>
 <script type="text/javascript">
 var img = document.getElementById('image');
 var box=document.getElementById('box');
 RGBaster.colors(img, {
 // return up to 30 top colors from the palette 从调色板返回最多30个顶级颜色
 paletteSize: 30,
 // don't count white
 //排除 白色
 exclude: ['rgb(255,255,255)'],
 // do something when done
 //获取成功之后
 success: function(payload) {
 box.style.background=payload.dominant;
 console.log('Dominant color:', payload.dominant);
 console.log('Secondary color:', payload.secondary);
 console.log('Palette:', payload.palette);
 }
 })
 </script>
</body>
</html>

剩下的,效果一出,大家一目了然,就是这么简单。

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

如何使用javascript获取图片主体背景色(代码)

如何使用javascript获取图片主体背景色(代码):本篇文章给大家带来的内容是关于如何使用javascript获取图片主体背景色(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。我们打开谷歌访问的时候,发现谷歌图片加载之前会先预加载出来图片的主题颜色,当时就觉得很有意思,效果是这
推荐度:
标签: 图片 获取 js
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top