999精品在线视频,手机成人午夜在线视频,久久不卡国产精品无码,中日无码在线观看,成人av手机在线观看,日韩精品亚洲一区中文字幕,亚洲av无码人妻,四虎国产在线观看 ?

網(wǎng)頁中基于HTML5 canvas的動(dòng)畫實(shí)現(xiàn)

2019-09-16 13:04:46龔麗
數(shù)碼世界 2019年7期

龔麗

摘要:canvas是HTML5新增的一個(gè)非常重要的元素,通過這個(gè)元素,我們可以在網(wǎng)頁上創(chuàng)建畫布,并在畫布上繪制任意圖形或圖像。canvas還有一個(gè)特性就是可以在其內(nèi)部創(chuàng)建動(dòng)畫,通過設(shè)置時(shí)間循環(huán),讓圖形或圖像動(dòng)起來。

關(guān)鍵詞:HTML5 canvas元素 繪制圖形 drawlmage() setlnterval()

引言

1基本圖形繪制

在網(wǎng)頁中繪制基本圖形,需要經(jīng)過以下3個(gè)步驟:

(1)在HTML頁面文檔中放置一個(gè)canvas元素,相當(dāng)于創(chuàng)建了一個(gè)矩形繪圖區(qū)域,并設(shè)置canvas元素的id。

(3)通過繪圖API在頁面中繪制各種圖形。

下面我們舉例來看矩形、圓形的繪制編程。

首先,在HTML文檔中放置元素,元素本身是不包含寬度、高度及內(nèi)容,也不會(huì)在屏幕上有任何顯示,所以大部分情況下在創(chuàng)建時(shí)注明寬度及高度,并設(shè)置id。

在瀏覽器運(yùn)行結(jié)果如下圖1。

2在canvas中繪制圖像

在HTML5中,除了可以繪制形狀,也可以通過canvas API繪制圖像文件,并對(duì)圖像進(jìn)行平鋪、裁剪、像素處理等操作。

繪制圖像時(shí),需要使用drawlmage()方法,該方法有3種調(diào)用格式:

ctx.drawlmage(image, x,y);

其中l(wèi)rnage為圖像對(duì)象,x、y為繪制時(shí)該圖像在畫布中的起始坐標(biāo)。

ctx.drawlmage(image, x,y.w, h);

前三個(gè)參數(shù)與第一種調(diào)用格式相同,w、h為圖像縮放至畫布中的寬度和高度。

ctx. drawlmage(image, sx.sy.sw.sh.dx. chr. dw, dh);

這種調(diào)用格式有9個(gè)參數(shù),主要實(shí)現(xiàn)對(duì)原圖的局部或全部顯示。其中image,dx,dy, dw,dh的用法與第二種格式相同,參數(shù)sx,sy,sw,sh表示源圖像需要裁剪的范圍。

繪制圖像時(shí)首先使用不帶參數(shù)的new方法創(chuàng)建Image對(duì)象,并設(shè)置Image對(duì)象的src屬性,即需要繪制的圖像文件路徑。再使用drawlmage0方法繪制。比如我們將一張風(fēng)車圖像繪制到canvas畫布中。代碼如下:

在瀏覽器運(yùn)行結(jié)果如下圖2。

3動(dòng)畫實(shí)現(xiàn)

(1)編寫繪制圖形或圖像的函數(shù);

(2)自定義一個(gè)函數(shù),用于圖形或圖像的移動(dòng)或其他動(dòng)作;

(3)使用setlnterval()方法設(shè)置動(dòng)畫執(zhí)行的間隔時(shí)間,反復(fù)執(zhí)行上面的自定義函數(shù)。

(4)當(dāng)需要停止循環(huán)時(shí),用clearlnterval()清空計(jì)時(shí)器。

setlnterval方法為HTML中固有的方法,setlnterval()每隔一段時(shí)間調(diào)用一次函數(shù),即設(shè)置循環(huán)的計(jì)時(shí)器。該方法接受兩個(gè)參數(shù),第一個(gè)參數(shù)表示執(zhí)行的函數(shù),第二個(gè)參數(shù)為時(shí)間間隔,單位為毫秒。編寫動(dòng)畫腳本時(shí)有一點(diǎn)需要特別注意,當(dāng)我們移動(dòng)繪制好的圖形或圖像時(shí),其實(shí)就是對(duì)圖形或圖像進(jìn)行重繪,這時(shí)要先清空,如果不清空,新畫的形狀就會(huì)重疊到原形狀上。

運(yùn)行結(jié)果是小球會(huì)在畫布框中上下左右來回移動(dòng)碰到墻(即邊框)則反彈。

圖像動(dòng)畫

我們?cè)賮砜匆粋€(gè)圖像動(dòng)畫的實(shí)現(xiàn),在canvas中繪制風(fēng)車圖像,并讓風(fēng)車旋轉(zhuǎn)起來。

translate0方法能平移坐標(biāo)原點(diǎn),在此例中我們把坐標(biāo)原點(diǎn)從畫布左上角的默認(rèn)位置移動(dòng)到畫布中心,這樣圖形圍繞原點(diǎn)旋轉(zhuǎn),就會(huì)在畫布中間。它的兩個(gè)參數(shù)分別是x方向移動(dòng)的值及y方向移動(dòng)的值。rotate0方法能將原點(diǎn)坐標(biāo)進(jìn)行旋轉(zhuǎn),從而實(shí)現(xiàn)圖形的旋轉(zhuǎn)。它只有一個(gè)參數(shù),即旋轉(zhuǎn)的角度。旋轉(zhuǎn)默認(rèn)以順時(shí)針方向進(jìn)行,要想逆時(shí)針旋轉(zhuǎn),則將角度設(shè)定為負(fù)數(shù)就可以了。

4結(jié)束語

在中創(chuàng)建動(dòng)畫雖然實(shí)現(xiàn)起來比較簡單,但不斷的圖形重繪非常消耗CPU資源,若需要在移動(dòng)設(shè)備的瀏覽器中使用,必須考慮動(dòng)畫(或者游戲)的優(yōu)化。比如上例中的風(fēng)車旋轉(zhuǎn)動(dòng)畫,由于要不斷重繪風(fēng)車圖像,該過程中,當(dāng)擦除整個(gè)canvas后,瀏覽器到達(dá)重繪點(diǎn),會(huì)繪制空白的canvas,從而造成視覺上的閃爍問題。可以采用雙緩沖方法來解決,即獲取到頁面中的canvas對(duì)象之后,創(chuàng)建一個(gè)與頁面canvas同樣大小的緩沖canvas對(duì)象。繪圖時(shí)先將圖像繪制到緩沖canvas中,等到圖像繪制完全后再把整個(gè)緩沖canvas繪制到頁面canvas中。

參考文獻(xiàn)

[1]《HTML5從入門到精通》明日科技編著.北京:清華大學(xué)出版社,2012: 347-348

[2]《HTML5與CSS3權(quán)威指南》陸凌牛著,北京:機(jī)械工業(yè)出版社,2012: 107-111

[3]《HTML5實(shí)戰(zhàn)》 陶國榮著,北京:機(jī)械工業(yè)出版社,2012: 185-188

主站蜘蛛池模板: 国产性爱网站| 国产精品亚洲专区一区| 午夜影院a级片| av在线人妻熟妇| 韩国v欧美v亚洲v日本v| 午夜a级毛片| 丰满人妻久久中文字幕| 操操操综合网| 欧美亚洲欧美| 好吊色妇女免费视频免费| 97在线免费| 欧美人人干| 亚洲中文字幕在线精品一区| 欧类av怡春院| 日本尹人综合香蕉在线观看| 色悠久久综合| 亚洲一区二区三区香蕉| 日本黄色不卡视频| 欧美视频在线不卡| 免费全部高H视频无码无遮掩| 亚洲男人天堂2018| 国产美女丝袜高潮| 又黄又湿又爽的视频| 国产精品免费电影| 最新亚洲人成无码网站欣赏网| 精品色综合| 日本不卡视频在线| 99视频全部免费| 精品久久高清| 综合久久五月天| 久久人搡人人玩人妻精品| 亚洲综合片| 亚洲成人网在线观看| 亚洲无码高清一区二区| 欧美成a人片在线观看| 日韩黄色精品| 麻豆精品国产自产在线| 中文字幕调教一区二区视频| 色亚洲成人| 欧美色图第一页| 就去吻亚洲精品国产欧美| 91久久偷偷做嫩草影院免费看 | 久久激情影院| 中文字幕佐山爱一区二区免费| 制服丝袜无码每日更新| 国产精品久久久久久久久久久久| 免费A∨中文乱码专区| 国产性精品| 亚洲av无码成人专区| 国产日韩欧美一区二区三区在线| 日本高清在线看免费观看| 高清欧美性猛交XXXX黑人猛交| 精品视频一区在线观看| 日本一区二区三区精品视频| 夜夜爽免费视频| 欧美另类图片视频无弹跳第一页| 亚洲—日韩aV在线| 亚洲欧美在线综合一区二区三区| 噜噜噜久久| 韩日无码在线不卡| 国产av无码日韩av无码网站| 日韩欧美国产另类| 色综合狠狠操| 青青青国产精品国产精品美女| 色综合久久久久8天国| 2021国产精品自产拍在线| 亚洲无线国产观看| 四虎精品国产AV二区| 人人看人人鲁狠狠高清| 尤物午夜福利视频| 欧美日韩第三页| 亚洲成年网站在线观看| 乱系列中文字幕在线视频| 久久精品嫩草研究院| 欧美日韩国产综合视频在线观看| 一级毛片免费观看不卡视频| 亚洲电影天堂在线国语对白| 草草影院国产第一页| 制服丝袜无码每日更新| 色成人综合| 国产h视频免费观看| 久久这里只有精品66|