HTML5 canvas畫(huà)布

canvas用途

  • 游戲 小游戲
  • 圖表 報(bào)表 如 Charts插件
  • 炫酷效果 banner
  • 模擬器、圖形編輯器 等

兼容性

IE9以上和其他瀏覽器

canvas 標(biāo)簽

屬性

  • width
  • height

方法

  • getContext() 參數(shù) 2d/webgl

注意

css設(shè)置的寬高跟width/height設(shè)置的寬高 不同

Context環(huán)境

通過(guò) getContext方法獲取繪圖環(huán)境(繪圖上下文)(對(duì)象)
繪制圖形通過(guò)該對(duì)象提供的方法/屬性

基本繪圖

路徑

  • moveTo() 起始位置
  • lineTo() 直線 摧冀,如果沒(méi)有moveTo() 第一個(gè)lineTo()替代 moveTo()

路徑的開(kāi)始和關(guān)閉

  • beginPath() 開(kāi)啟路徑
  • closePath() 關(guān)閉路徑 結(jié)束當(dāng)前的路徑塘砸,自動(dòng)閉合
  • 注意: 復(fù)雜的圖形游桩,一定要開(kāi)啟和關(guān)閉路徑

描邊 stroke()

  • stroke() 方法
  • strokeStyle 設(shè)置描邊顏色
  • lineWidth 設(shè)置描邊的粗細(xì)

填充

  • fill() 填充
  • fillStyle 設(shè)置填充顏色

快速矩形工具

  • rect(x, y, width, height) 繪制矩形路徑
  • strokeRect(x, y, width, height) 描邊矩形
  • fillRect(x,y,width,height) 填充矩形
  • clearRect(x,y,w,h) 清除矩形 (矩形范圍內(nèi)的內(nèi)容會(huì)被擦除)

圓形(圓弧)

  • arc(x,y,r,start, end, wise) 繪制圓弧
  • start/end是起始位置 單位是 弧度 色迂, 360角度 = 2PI蚀狰, 180角度 = PI
  • 最后一個(gè)參數(shù) 順時(shí)針(false)/逆時(shí)針(true) 默認(rèn)false

內(nèi)容

文字方法

  • strokeText(text, x, y) 描邊寫(xiě)字
  • fillText(text, x, y) 填充寫(xiě)字
  • measureText(text) 返回對(duì)象 包換文本的寬度
  • font 屬性 設(shè)置 大小、字體 如 cxt.fon="100px MicrosoftYaHei";
  • textAlign 屬性 水平對(duì)齊方式 start(默認(rèn))/end/center/left/right
  • textBaseline 屬性 垂直對(duì)齊方式 alphabetic(默認(rèn))/top/bottom/middke/hanging/ideographic

繪制圖片(插入圖片)

插入圖片

drawImage(img, x, y)

  • img image的dom元素
  • x,y 插入到 畫(huà)布的位置 坐標(biāo)

插入圖片并改變大小

drawImage(img, x, y, width, height)

插入裁剪后的圖片

drawImage(img, sx,sy,swidth,sheight, x, y, width, height)

  • sx/sy: 圖片上開(kāi)始裁剪的位置
  • swidth/sheight : 裁剪圖片的大小

陰影

  • shadowColor 陰影顏色
  • shadowBlur 陰影的模糊值
  • shadowOffsetX 陰影的左偏移量
  • shadowOffsetY 陰影的右偏移量

漸變

線性漸變

var grd = cxt.createLinearGradien(x, y, x1, y1);
//參數(shù):x,y起始坐標(biāo),x1,y1結(jié)束坐標(biāo)
例如:
//創(chuàng)建線性漸變的對(duì)象,
var grd=ctx.createLinearGradient(0,0,170,0);
grd.addColorStop(0,"black"); //添加一個(gè)漸變顏色朽色,第一個(gè)參數(shù)介于 0.0 與 1.0 之間的值栖榨,表示漸變中開(kāi)始與結(jié)束之間的位置。
grd.addColorStop(1,"white"); //添加一個(gè)漸變顏色
ctx.fillStyle =grd; //關(guān)鍵點(diǎn)垒在,把漸變?cè)O(shè)置到 填充的樣式

徑向漸變

  • createRadiaGradient(x1, y1, r1, x2, y2, r2)
  • addColorStop()

把背景圖片作為填充

  • createPattern(imgDom, repeate)
  • 第二個(gè)參數(shù) repeate/ repeat-x / repeat-y / no-repeat

變換

縮放

  • sacle(x, y)

位移

  • translate(x, y)

旋轉(zhuǎn)

  • rotate(angle)

環(huán)境的保存和恢復(fù)

  • save()
  • restore()

設(shè)置透明

  • globalAlpha = number 設(shè)置不透明度
  • 全局設(shè)置是對(duì)整個(gè)畫(huà)布(繪圖環(huán)境) 進(jìn)行設(shè)置

限定繪圖區(qū)域

  • clip()

輸出base64編碼

  • canvas.toDataURL(type, encoder)
  • type為mime類(lèi)型 image/jpeg image/gif image/png image/webp

畫(huà)布渲染畫(huà)布

把一個(gè)畫(huà)布以圖片的形式用 drawImage() 插入到另一個(gè)畫(huà)布
這是一種canvas的優(yōu)化手段

設(shè)置線條

  • lineCap 屬性 設(shè)置線條兩端的形狀 butt/round/square
  • lineJoin 屬性 設(shè)置線條夾角 miter/bevel/round
  • miterLimit 屬性 設(shè)置夾角斜角的最大長(zhǎng)度 一般默認(rèn) 10
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子呈枉,更是在濱河造成了極大的恐慌,老刑警劉巖檐什,帶你破解...
    沈念sama閱讀 217,826評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件碴卧,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡乃正,警方通過(guò)查閱死者的電腦和手機(jī)住册,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,968評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)瓮具,“玉大人荧飞,你說(shuō)我怎么就攤上這事∶常” “怎么了叹阔?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,234評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)传睹。 經(jīng)常有香客問(wèn)我耳幢,道長(zhǎng),這世上最難降的妖魔是什么欧啤? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,562評(píng)論 1 293
  • 正文 為了忘掉前任睛藻,我火速辦了婚禮,結(jié)果婚禮上邢隧,老公的妹妹穿的比我還像新娘店印。我一直安慰自己,他們只是感情好倒慧,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,611評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布按摘。 她就那樣靜靜地躺著包券,像睡著了一般。 火紅的嫁衣襯著肌膚如雪炫贤。 梳的紋絲不亂的頭發(fā)上溅固,一...
    開(kāi)封第一講書(shū)人閱讀 51,482評(píng)論 1 302
  • 那天,我揣著相機(jī)與錄音照激,去河邊找鬼发魄。 笑死,一個(gè)胖子當(dāng)著我的面吹牛俩垃,可吹牛的內(nèi)容都是我干的励幼。 我是一名探鬼主播,決...
    沈念sama閱讀 40,271評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼口柳,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼苹粟!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起跃闹,我...
    開(kāi)封第一講書(shū)人閱讀 39,166評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤嵌削,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后望艺,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體苛秕,經(jīng)...
    沈念sama閱讀 45,608評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,814評(píng)論 3 336
  • 正文 我和宋清朗相戀三年找默,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了艇劫。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,926評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡惩激,死狀恐怖店煞,靈堂內(nèi)的尸體忽然破棺而出风钻,到底是詐尸還是另有隱情顷蟀,我是刑警寧澤,帶...
    沈念sama閱讀 35,644評(píng)論 5 346
  • 正文 年R本政府宣布骡技,位于F島的核電站鸣个,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏布朦。R本人自食惡果不足惜囤萤,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,249評(píng)論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望喝滞。 院中可真熱鬧,春花似錦膏秫、人聲如沸右遭。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,866評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)窘哈。三九已至吹榴,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間滚婉,已是汗流浹背图筹。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,991評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留让腹,地道東北人远剩。 一個(gè)月前我還...
    沈念sama閱讀 48,063評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像骇窍,于是被迫代替她去往敵國(guó)和親瓜晤。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,871評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 一、什么是 Canvas嘲恍? HTML5 的 canvas 元素使用 JavaScript 在網(wǎng)頁(yè)上繪制圖像 畫(huà)布是...
    EndEvent閱讀 695評(píng)論 0 1
  • 一:canvas簡(jiǎn)介 1.1什么是canvas足画? ①:canvas是HTML5提供的一種新標(biāo)簽 ②:HTML5 ...
    GreenHand1閱讀 4,683評(píng)論 2 32
  • 一、簡(jiǎn)介 HTML5 中的定義:“它是依賴分辨率的位圖畫(huà)布佃牛,你可以在 canvas 上面繪制任何圖形淹辞,甚至加載照片...
    destiny0904閱讀 10,541評(píng)論 1 4
  • 一、canvas簡(jiǎn)介 1.1 什么是canvas吁脱?(了解) 是HTML5提供的一種新標(biāo)簽 Canvas是一個(gè)矩形區(qū)...
    Looog閱讀 3,942評(píng)論 3 40
  • 一桑涎、canvas簡(jiǎn)介 1.1 什么是canvas?(了解) 是HTML5提供的一種新標(biāo)簽 Canvas是一個(gè)矩形區(qū)...
    J_L_L閱讀 1,516評(píng)論 0 4