這篇文章主要介紹“CSS怎么創(chuàng)建一個(gè)透明圖片背景”,在日常操作中,相信很多人在CSS怎么創(chuàng)建一個(gè)透明圖片背景問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”CSS怎么創(chuàng)建一個(gè)透明圖片背景”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!
10年積累的網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站建設(shè)經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶(hù)對(duì)網(wǎng)站的新想法和需求。提供各種問(wèn)題對(duì)應(yīng)的解決方案。讓選擇我們的客戶(hù)得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站設(shè)計(jì)制作后付款的網(wǎng)站建設(shè)流程,更有工布江達(dá)免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
一、把Canvas圖片作為CSS背景圖片
CSSPaintAPI可以簡(jiǎn)單理解為(實(shí)際不能等同)把Canvas畫(huà)布作為普通元素的背景圖片。
也就是CSS的background-image就是一個(gè)Canvas,我們可以利用Canvas絕大多數(shù)API繪制各種復(fù)雜有趣的圖形效果,以一種更高效的方式豐富web頁(yè)面元素的視覺(jué)展現(xiàn)。例如,藍(lán)色按鈕不僅僅是個(gè)藍(lán)色背景,上面還有白云漂漂的效果,想想就很棒!
二、一個(gè)簡(jiǎn)單的案例了解CSSPaintAPI
例如,我們希望創(chuàng)建一個(gè)透明圖片背景。
則完整的CSS代碼和JS部分代碼如下:
.box{
width:180px;height:180px;
/*transparent-grid自己命名*/
background-image:paint(transparent-grid);
}
然后繪制圖形的JS務(wù)必作為模塊引入,例如,建一個(gè)名為paint-grid.js的文件,在頁(yè)面上引入:
if(window.CSS){
CSS.paintWorklet.addModule('paint-grid.js');
}
paint-grid.js文件代碼如下:
//transparent-grid命名和CSS中的對(duì)應(yīng)
registerPaint('transparent-grid',class{
paint(context,size){
//這里就是繪制的代碼了…
}
});
以上就是CSSPaintAPI使用的固定套路:
CSS中paint(abc);
JS添加模塊CSS.paintWorklet.addModule(‘xxx.js’);
xxx.js中代碼套路固定,在下面注釋位置寫(xiě)繪制代碼即可;
registerPaint('abc',class{
paint(context,size,properties){
//繪制代碼在這里…
}
});
其中paint(context,size)中的兩個(gè)參數(shù)可以稍微介紹下:
context
為繪制上下文,全稱(chēng)是PaintRenderingContext2D,和Canvas的CanvasRenderingContext2D是近親,API全部來(lái)自Canvas,一模一樣,不過(guò)由于安全限制,有些Canvas中的有些API是不能使用的,可用和不可用的API見(jiàn)下表:
微信截圖_20181127164151.png
size
size是一個(gè)包含了繪制尺寸的對(duì)象,數(shù)據(jù)結(jié)構(gòu)如下:
{
width:180,
height:180
}
size的大小受到background-size屬性大小的影響,因此,對(duì)于重復(fù)背景,可以借助background-repeat進(jìn)行平鋪循環(huán),不用非得在繪制的JS代碼中循環(huán)。例如,下面即將要展示的demo效果,也可以這么實(shí)現(xiàn),CSS部分:
.box{
width:180px;height:180px;
background-image:paint(transparent-grid);
background-size:16px16px;
}
然后,paint-grid.js中只需要填充白-灰-灰-白,4個(gè)格子就好了,無(wú)需循環(huán)。
properties
可以用來(lái)獲得get到的CSS屬性和屬性值,包括CSS變量值;以及其他一些參數(shù)。
眼見(jiàn)為實(shí),您可以狠狠地點(diǎn)擊這里:CSSPaintAPI繪制透明格子作為背景demo(目前僅Chrome有效果)
透明格子效果demo
paint-grid.js中的完整繪制代碼如下:
registerPaint('transparent-grid',class{
paint(context,size){
//兩個(gè)格子顏色
varcolor1='#fff',color2='#eee';
//格子尺寸
varunits=8;
//橫軸數(shù)軸循環(huán)遍歷下
for(varx=0;x<size.width;x+=units){
for(vary=0;y<size.height;y+=units){
context.fillStyle=(x+y)%(units*2)===0?color1:color2;
context.fillRect(x,y,units,units);
}
}
}
});
補(bǔ)充:
類(lèi)似格子這類(lèi)重復(fù)背景,可以借助background-repeat進(jìn)行平鋪循環(huán),不用非得在繪制的JS代碼中循環(huán),不過(guò)需要借助background-size屬性幫助,改變繪制的尺寸。例如,上面demo效果,也可以這么實(shí)現(xiàn),CSS部分:
.box{
width:180px;height:180px;
background-image:paint(transparent-grid);
background-size:16px16px;
}
然后,paint-grid.js中只需要填充白-灰-灰-白,4個(gè)格子就好了,無(wú)需循環(huán)。
registerPaint('transparent-grid',class{
paint(context,size){
//兩個(gè)格子顏色
varcolor1='#fff',color2='#eee';
//兩個(gè)白色格子
context.fillStyle=color1;
context.fillRect(0,0,8,8);
context.fillRect(8,8,8,8);
//兩個(gè)灰色格子
context.fillStyle=color1;
context.fillRect(0,4,8,8);
context.fillRect(4,0,8,8);
}
});
到此,關(guān)于“CSS怎么創(chuàng)建一個(gè)透明圖片背景”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!
網(wǎng)站欄目:CSS怎么創(chuàng)建一個(gè)透明圖片背景
標(biāo)題網(wǎng)址:http://vcdvsql.cn/article0/pdicio.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)建站、移動(dòng)網(wǎng)站建設(shè)、ChatGPT、用戶(hù)體驗(yàn)、營(yíng)銷(xiāo)型網(wǎng)站建設(shè)、定制開(kāi)發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)