亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

canvas使用注意點總結

2024-08-26 00:16:27
字體:
來源:轉載
供稿:網友

點評:canvas默認寬高是300、150,為避免異常,最好使用顯示屬性添加而不通過css來添加寬高,下面簡單的為大家介紹下canvas使用注意事項,感興趣的朋友可以參考下哈,希望對大家有所幫助

1、canvas中文教程https://developer.mozilla.org/zh-CN/docs/Canvas_tutorial

2、canvas默認寬高是300、150,為避免異常,最好使用顯示屬性添加而不通過css來添加寬高

3、在canvas標簽內部添加不支持canvas標簽的瀏覽器的說明

4、通過下面的js代碼也能判斷瀏覽器是否支持canvas

復制代碼

代碼如下:


var canvas = document.getElementById('tutorial');
if (canvas.getContext){
var ctx = canvas.getContext('2d');
// drawing code here
} else {
// canvas-unsupported code here
}


5、canvas只支持一種基本形狀的繪制,即矩形,但是其它圖形都可以通過canvas路徑來繪制

6、繪制矩形有四個函數:rect、fillRect、strokeRect和clearRect

7、beginPath的作用用來開始一個新的路徑層,如果不加就表示在原來路徑層上繪制,下面兩段代碼效果是完全不一樣的,第一段代碼顯示兩條紅線,第二段代碼顯示一條黑線和一條紅線

復制代碼

代碼如下:


var ctx = document.getElementById('cvs').getContext('2d');
ctx.beginPath();
ctx.moveTo(100.5,20.5);
ctx.lineTo(200.5,20.5);
ctx.stroke();
ctx.moveTo(100.5,40.5);
ctx.lineTo(200.5,40.5)
ctx.strokeStyle = '#f00';
ctx.stroke();



復制代碼

代碼如下:


var ctx = document.getElementById('cvs').getContext('2d');
ctx.beginPath();
ctx.moveTo(100.5,20.5);
ctx.lineTo(200.5,20.5);
ctx.stroke();
ctx.beginPath();
ctx.moveTo(100.5,40.5);
ctx.lineTo(200.5,40.5)
ctx.strokeStyle = '#f00';
ctx.stroke();


8、如果不需要路徑閉合,closePath可以不用,如果使用了fill則路徑則會自動閉合,不需要再使用closePath了

9、只要有足夠的耐性是完全可以利用貝塞爾曲線繪制任何圖形的

10、二次方曲線在火狐下存在bug,因此可以利用三次方曲線代替二次方曲線使用

11、圖像(如 PNG,GIF,JPEG等)都可以引入到 canvas 中,而且其它的 canvas 元素也可以作為圖像的來源

12、下面是基本的canvas圖片繪制代碼,其中 image 是 image 或者 canvas 對象,x 和 y 是其在目標 canvas 里的起始坐標

drawImage(image, x, y)
下面一段代碼表示縮放圖片,width和height表示縮放的尺寸
drawImage(image, x, y, width, height)
下面一段代碼表示剪切圖片,第一個參數和其它的是相同的,都是一個圖像或者另一個 canvas 的引用。其它8個參數中分別表示圖片中裁減的起始x坐標,圖片中裁減的起始y坐標,裁減區域寬度,裁減區域高度,所畫位置x坐標,所畫位置y坐標,所畫圖形寬度,所畫圖形高度,裁剪區域的尺寸是可以和所畫圖形的尺寸不一樣的,此時會縮放到所畫圖片的尺寸

drawImage(image, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight)
13、strokeStyle 是用于設置圖形輪廓的顏色,而 fillStyle 用于設置填充顏色。color 可以是表示 CSS 顏色值的字符串,漸變對象或者圖案對象。默認情況下,線條和填充顏色都是黑色(CSS 顏色值 #000000)。

14、圖像透明度可以用globalAlpha = transparency value或者rgba顏色值來表示

15、lineWidth 屬性設置當前繪線的粗細,為解決1px線寬bug問題,采用+0.5的方式來解決

16、lineCap 屬性最左邊的線用了默認的 butt ??梢宰⒁獾剿桥c輔助線齊平的。中間的是 round 的效果,端點處加上了半徑為一半線寬的半圓。右邊的是 square 的效果,端點處加上了等寬且高度為一半線寬的方塊

17、lineJoin 屬性這里我同樣用三條折線來做例子,分別設置不同的 lineJoin 值。最上面一條是 round 的效果,邊角處被磨圓了,圓的半徑等于線寬。中間和最下面一條分別是 bevel 和 miter 的效果。當值是 miter 的時候,線段會在連接處外側延伸直至交于一點,延伸效果受到下面將要介紹的 miterLimit 屬性的制約

18、save 和 restore 方法是用來保存和恢復 canvas 狀態的,都沒有參數。Canvas 的狀態就是當前畫面應用的所有樣式和變形的一個快照。Canvas 狀態是以堆(stack)的方式保存的,每一次調用 save 方法,當前的狀態就會被推入堆中保存起來。每一次調用 restore 方法,上一個保存的狀態就從堆中彈出,所有設定都恢復。

19、transform(1, 0, 0, 1, 0, 0)參數分別表示水平方向縮放、水平方向旋轉(順時針)、垂直方向旋轉(逆時針)、垂直方向縮放、水平方向偏移量、垂直方向偏移量
  setTransform(1, 0, 0, 1, 0, 0)表示重置前一個變換矩陣然后構建新的矩陣,參數作用同上
  rotate(angle),(一個半徑等于1弧度,2πr/r=弧度即360=2π,即1=π/180)

20、動畫其實就是不斷清空畫板(clearRect()),然后重繪

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧美激情精品一区二区| 欧美丰满老妇厨房牲生活| 97婷婷涩涩精品一区| 日韩在线视频二区| 精品视频在线观看日韩| 亚洲第一中文字幕在线观看| 91免费精品国偷自产在线| 日韩禁在线播放| 精品国产乱码久久久久久天美| 日本一本a高清免费不卡| 91免费欧美精品| 亚洲第一偷拍网| 欧美精品在线观看91| 456亚洲影院| 亚洲a中文字幕| 91av福利视频| 久久99精品久久久久久噜噜| 中文字幕视频一区二区在线有码| 中文字幕视频在线免费欧美日韩综合在线看| 久久综合国产精品台湾中文娱乐网| 日韩的一区二区| 国产精品久久久久福利| 午夜伦理精品一区| 成人激情视频在线| 夜夜狂射影院欧美极品| 欧美激情视频网| 欧美高清视频一区二区| 久久中文精品视频| 亚洲福利在线观看| 成人免费高清完整版在线观看| 欧美在线视频在线播放完整版免费观看| 在线国产精品播放| 精品成人乱色一区二区| 久久99久久久久久久噜噜| 色老头一区二区三区| 欧美大全免费观看电视剧大泉洋| 欧美电影免费播放| 蜜月aⅴ免费一区二区三区| 国产日韩欧美日韩大片| 亚洲精品美女久久久久| 欧美性猛交丰臀xxxxx网站| 亚洲视频欧美视频| 亚洲欧美一区二区三区四区| 国产视频在线观看一区二区| 欧美激情精品久久久久久蜜臀| 91久久久在线| 亚洲高清免费观看高清完整版| 国产日韩欧美视频| 中文字幕精品一区久久久久| 欧美理论电影在线观看| 亚洲黄色有码视频| 欧美天天综合色影久久精品| 亚洲精品视频在线观看视频| 亚洲精品日产aⅴ| 欧洲午夜精品久久久| 8050国产精品久久久久久| 欧美日韩午夜视频在线观看| 美女久久久久久久| 久久久成人精品视频| 欧美日韩亚洲成人| 一区二区三区天堂av| 黑人巨大精品欧美一区二区免费| 欧美疯狂做受xxxx高潮| 日本人成精品视频在线| 国内精品视频在线| 日韩亚洲综合在线| 中文字幕一区二区精品| 国产午夜精品免费一区二区三区| 伊人久久免费视频| 懂色aⅴ精品一区二区三区蜜月| 国产精品视频99| 国产精品av在线| 国产在线视频一区| 91精品国产综合久久香蕉| 国产精品久久9| 亚洲一区二区精品| 久久久久国产一区二区三区| 欧美韩国理论所午夜片917电影| 97国产精品视频人人做人人爱| 色噜噜狠狠色综合网图区| 久久视频中文字幕| 78色国产精品| 在线性视频日韩欧美| 亚洲成人久久电影| 66m—66摸成人免费视频| 欧美精品一区在线播放| 日韩视频―中文字幕| 久久久免费av| 国产精品久久色| 欧美理论片在线观看| 日韩免费在线播放| 国产精品欧美一区二区三区奶水| 欧美在线观看日本一区| 欧美视频裸体精品| 亚洲第一区在线| 伊人伊成久久人综合网站| 欧美与欧洲交xxxx免费观看| 亚洲的天堂在线中文字幕| 成人免费直播live| 在线视频一区二区| 精品久久久久久| 第一福利永久视频精品| 91免费综合在线| 亚洲大胆人体在线| 精品香蕉在线观看视频一| 最近更新的2019中文字幕| 精品久久久久久久久久久| 98午夜经典影视| 日韩美女免费视频| 久久久国产精品x99av| 欧美激情亚洲国产| 欧美超级乱淫片喷水| 久久影视电视剧免费网站清宫辞电视| 91精品视频免费看| 亚洲va欧美va国产综合剧情| 国产精品久久精品| 日日狠狠久久偷偷四色综合免费| 青青草原一区二区| 欧美放荡办公室videos4k| 久久伊人精品一区二区三区| 日韩精品亚洲视频| 欧美性生交大片免费| 久久国产精品久久久久| 欧美午夜激情小视频| 亚洲视频国产视频| 国产精品久久久久久影视| 日韩中文字幕亚洲| 亚洲香蕉成人av网站在线观看| 欧美日韩免费看| 亚洲一区二区三区乱码aⅴ蜜桃女| 精品久久久免费| 日韩在线观看免费全| 91久久久久久国产精品| 欧美肥老妇视频| 国产精品久久久久aaaa九色| 精品福利樱桃av导航| 91免费在线视频网站| 亚洲综合色激情五月| 欧美成aaa人片免费看| 国产精品视频不卡| 性夜试看影院91社区| 91精品视频在线| 中文字幕在线国产精品| 成人精品久久一区二区三区| 欧美日韩高清区| 亚洲久久久久久久久久久| 在线国产精品视频| 日韩在线观看高清| 97视频网站入口| 亚洲午夜未满十八勿入免费观看全集| 91精品国产色综合久久不卡98口| 国产日韩精品在线播放| 亚洲毛茸茸少妇高潮呻吟| 欧美激情videoshd| 日韩精品一二三四区| 国产一区视频在线播放| 国产成人精品在线播放| 久久综合亚洲社区| 色樱桃影院亚洲精品影院| 亚洲电影成人av99爱色| 亚洲日韩第一页| 久久久精品视频在线观看| 成人午夜一级二级三级| 欧美激情一区二区三区在线视频观看|