bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

CSS怎么創(chuàng)建一個(gè)透明圖片背景

這篇文章主要介紹“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)

h5響應(yīng)式網(wǎng)站建設(shè)