佳木斯湛栽影视文化发展公司

主頁 > 知識(shí)庫 > canvas使用注意點(diǎn)總結(jié)

canvas使用注意點(diǎn)總結(jié)

熱門標(biāo)簽:百度競價(jià)點(diǎn)擊價(jià)格的計(jì)算公式 硅谷的囚徒呼叫中心 網(wǎng)站建設(shè) 美圖手機(jī) 智能手機(jī) 檢查注冊表項(xiàng) 使用U盤裝系統(tǒng) 阿里云
1、canvas中文教程https://developer.mozilla.org/zh-CN/docs/Canvas_tutorial

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

3、在canvas標(biāo)簽內(nèi)部添加不支持canvas標(biāo)簽的瀏覽器的說明

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

復(fù)制代碼
代碼如下:

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、繪制矩形有四個(gè)函數(shù):rect、fillRect、strokeRect和clearRect

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

復(fù)制代碼
代碼如下:

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();


復(fù)制代碼
代碼如下:

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則路徑則會(huì)自動(dòng)閉合,不需要再使用closePath了

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

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

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

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

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

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

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

15、lineWidth 屬性設(shè)置當(dāng)前繪線的粗細(xì),為解決1px線寬bug問題,采用+0.5的方式來解決

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

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

18、save 和 restore 方法是用來保存和恢復(fù) canvas 狀態(tài)的,都沒有參數(shù)。Canvas 的狀態(tài)就是當(dāng)前畫面應(yīng)用的所有樣式和變形的一個(gè)快照。Canvas 狀態(tài)是以堆(stack)的方式保存的,每一次調(diào)用 save 方法,當(dāng)前的狀態(tài)就會(huì)被推入堆中保存起來。每一次調(diào)用 restore 方法,上一個(gè)保存的狀態(tài)就從堆中彈出,所有設(shè)定都恢復(fù)。

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

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

標(biāo)簽:賀州 湖北 黃山 懷化 煙臺(tái) 湘潭 山南 通遼

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《canvas使用注意點(diǎn)總結(jié)》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    大冶市| 白沙| 罗山县| 罗江县| 凤冈县| 南川市| 枣阳市| 浮梁县| 香河县| 布拖县| 安新县| 桃源县| 乌鲁木齐市| 北票市| 富宁县| 锡林浩特市| 乐山市| 吉隆县| 渭南市| 固原市| 搜索| 密山市| 平和县| 长海县| 昌平区| 绥江县| 湘潭县| 晋江市| 江永县| 海宁市| 柯坪县| 武陟县| 长兴县| 镇安县| 瑞安市| 卓尼县| 乳山市| 会东县| 阿图什市| 新泰市| 阜阳市|