最新文章專(zhuān)題視頻專(zhuān)題問(wèn)答1問(wèn)答10問(wèn)答100問(wèn)答1000問(wèn)答2000關(guān)鍵字專(zhuān)題1關(guān)鍵字專(zhuān)題50關(guān)鍵字專(zhuān)題500關(guān)鍵字專(zhuān)題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關(guān)鍵字專(zhuān)題關(guān)鍵字專(zhuān)題tag2tag3文章專(zhuān)題文章專(zhuān)題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專(zhuān)題3
問(wèn)答文章1 問(wèn)答文章501 問(wèn)答文章1001 問(wèn)答文章1501 問(wèn)答文章2001 問(wèn)答文章2501 問(wèn)答文章3001 問(wèn)答文章3501 問(wèn)答文章4001 問(wèn)答文章4501 問(wèn)答文章5001 問(wèn)答文章5501 問(wèn)答文章6001 問(wèn)答文章6501 問(wèn)答文章7001 問(wèn)答文章7501 問(wèn)答文章8001 問(wèn)答文章8501 問(wèn)答文章9001 問(wèn)答文章9501
當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

如何使用javascript獲取圖片主體背景色(代碼)

來(lái)源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 19:30:33
文檔

如何使用javascript獲取圖片主體背景色(代碼)

如何使用javascript獲取圖片主體背景色(代碼):本篇文章給大家?guī)?lái)的內(nèi)容是關(guān)于如何使用javascript獲取圖片主體背景色(代碼),有一定的參考價(jià)值,有需要的朋友可以參考一下,希望對(duì)你有所幫助。我們打開(kāi)谷歌訪問(wèn)的時(shí)候,發(fā)現(xiàn)谷歌圖片加載之前會(huì)先預(yù)加載出來(lái)圖片的主題顏色,當(dāng)時(shí)就覺(jué)得很有意思,效果是這
推薦度:
導(dǎo)讀如何使用javascript獲取圖片主體背景色(代碼):本篇文章給大家?guī)?lái)的內(nèi)容是關(guān)于如何使用javascript獲取圖片主體背景色(代碼),有一定的參考價(jià)值,有需要的朋友可以參考一下,希望對(duì)你有所幫助。我們打開(kāi)谷歌訪問(wèn)的時(shí)候,發(fā)現(xiàn)谷歌圖片加載之前會(huì)先預(yù)加載出來(lái)圖片的主題顏色,當(dāng)時(shí)就覺(jué)得很有意思,效果是這
本篇文章給大家?guī)?lái)的內(nèi)容是關(guān)于如何使用javascript獲取圖片主體背景色(代碼),有一定的參考價(jià)值,有需要的朋友可以參考一下,希望對(duì)你有所幫助。

我們打開(kāi)谷歌訪問(wèn)的時(shí)候,發(fā)現(xiàn)谷歌圖片加載之前會(huì)先預(yù)加載出來(lái)圖片的主題顏色,當(dāng)時(shí)就覺(jué)得很有意思,效果是這樣

1421271285-5b9f13f5ac14b_articlex.png

當(dāng)然他們這個(gè)是后端給json的時(shí)候給了個(gè)顏色代碼,暫且不提,但如果前端來(lái)做的話,也是有方法的,張?chǎng)涡翊笊竦牟┛屠锞陀涊d的有,是一個(gè)叫rgbaster.js的玩意兒,具體用法我先給貼下來(lái)了。
rgbaster.js的內(nèi)容是:

!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>獲取圖片主題色腳本擴(kuò)展的完整的示例</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 從調(diào)色板返回最多30個(gè)頂級(jí)顏色
 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>

剩下的,效果一出,大家一目了然,就是這么簡(jiǎn)單。

聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

如何使用javascript獲取圖片主體背景色(代碼)

如何使用javascript獲取圖片主體背景色(代碼):本篇文章給大家?guī)?lái)的內(nèi)容是關(guān)于如何使用javascript獲取圖片主體背景色(代碼),有一定的參考價(jià)值,有需要的朋友可以參考一下,希望對(duì)你有所幫助。我們打開(kāi)谷歌訪問(wèn)的時(shí)候,發(fā)現(xiàn)谷歌圖片加載之前會(huì)先預(yù)加載出來(lái)圖片的主題顏色,當(dāng)時(shí)就覺(jué)得很有意思,效果是這
推薦度:
標(biāo)簽: 圖片 獲取 js
  • 熱門(mén)焦點(diǎn)

最新推薦

猜你喜歡

熱門(mén)推薦

專(zhuān)題
Top