微信小程序canvas

因為微信小程序暫時沒有分享到朋友圈的功能,所以只能生成分享圖,然后再發(fā)到朋友圈,這就用到了canvas!剛開始寫的時候是各種查各種百度,然后也算寫了出來,但是現(xiàn)在也覺得不是很明白,就先從用到的API開始整理吧!

canvas畫布組件

canvas 標(biāo)簽?zāi)J(rèn)寬度300px、高度225px
canvas 是在一個二維的網(wǎng)格當(dāng)中,左上角的坐標(biāo)為(0, 0)。


屬性名               類型               默認(rèn)值                  說明
canvas-id          String                                 canvas 組件的唯一標(biāo)識符
disable-scroll     Boolean              false             當(dāng)在 canvas 中移動時且有綁定手勢事件時,禁止屏幕滾動以及下拉刷新
bindtouchstart    EventHandle                             手指觸摸動作開始
bindtouchmove     EventHandle                             手指觸摸后移動
bindtouchend      EventHandle                             手指觸摸動作結(jié)束
bindtouchcancel   EventHandle                             手指觸摸動作被打斷,如來電提醒,彈窗
bindlongtap       EventHandle                             手指長按 500ms 之后觸發(fā),觸發(fā)了長按事件后進(jìn)行移動不會觸發(fā)屏幕的滾動
binderror         EventHandle                             當(dāng)發(fā)生錯誤時觸發(fā) error 事件,detail = {errMsg: 'something wrong'}

在.wxml文件中
<canvas canvas-id="firstCanvas"></canvas>
在.js文件中

Page({
  onReady: function (e) {
      // 使用 wx.createContext 獲取繪圖上下文 context
      var context = wx.createCanvasContext('firstCanvas')
  }
})

當(dāng)頁面過長的時候,畫出了canvas之后禁止canva滑動設(shè)置屬性disable-scroll='true'是能禁止canvas滑動,但是不能禁止頁面滑動,如果你的canvas大小沒有頁面大的話,還是會觸摸滑動頁面的。
<canvas canvas-id="firstCanvas" disable-scroll='true'></canvas>

繪圖API

有好多也就不一一列舉了就說一些常用的吧

  • setFontSize:設(shè)置字體的字號
    context.setFontSize(number)
    context.font = '40px Arial' // 基礎(chǔ)庫 1.9.90 起支持
  • fillText:在畫布上繪制被填充的文本
    context.fillText(string text, number x, number y, number maxWidth)
    text:在畫布上輸出的文本; x:繪制文本的左上角x坐標(biāo)位置; y:繪制文本的左上角 y 坐標(biāo)位置; maxWidth:需要繪制的最大寬度,可選.
  • setTextAlign:設(shè)置文字的對齊
    content.setTextAlign(string align)
    string align的值:left; center; right
運用:讓文字在畫布居中顯示
context.setFontSize(20)
context.setFillStyle('#fff')
context.setTextAlign('center');
context.fillText('Hello',mobileWidth / 2, 20)
context.draw()
  • setFillStyle:設(shè)置填充色
    context.setFillStyle(color)
    context.fillStyle = color // 基礎(chǔ)庫 1.9.90 起支持

  • fill:對當(dāng)前路徑中的內(nèi)容進(jìn)行填充。默認(rèn)的填充色為黑色
    context.fill()

  • rect:創(chuàng)建一個矩形
    context.rect(矩形路徑左上角的x坐標(biāo), 矩形路徑左上角的y坐標(biāo), width, height)

運用:
context.rect(10, 10, 150, 75)
context.setFillStyle('red')
context.fill()
context.draw()
  • fillRect:填充一個矩形
    context.fillRect(矩形路徑左上角的x坐標(biāo), 矩形路徑左上角的y坐標(biāo), width, height)
運用:
context.setFillStyle('red')
context.fillRect(10, 10, 150, 75)
context.draw()
  • setStrokeStyle:設(shè)置描邊顏色。
    context.setStrokeStyle(color) // 從基礎(chǔ)庫 1.9.90 開始,本接口停止維護(hù)
    context.setStrokeStyle='color' // 基礎(chǔ)庫 1.9.90 起支持
  • strokeRect:畫一個矩形(非填充)
    context.strokeRect(矩形路徑左上角的x坐標(biāo), 矩形路徑左上角的y坐標(biāo), width, height)
運用:
context.setStrokeStyle('red')
context.strokeRect(10, 10, 150, 75)
context.draw()
  • clearRect:清除畫布上該矩形區(qū)域內(nèi)的內(nèi)容
    context.clearRect(矩形路徑左上角的x坐標(biāo), 矩形路徑左上角的y坐標(biāo), width, height)
  • stroke:畫出當(dāng)前路徑的邊框。默認(rèn)顏色為黑色
    context.stroke()
  • beginPath:開始創(chuàng)建一個路徑,需要調(diào)用fill或者sroke才會使用路徑進(jìn)行填充或描邊
    context.beginPath()
  • closePath:關(guān)閉一個路徑,關(guān)閉路徑會鏈接起點和終點
    context.closePath()
  • moveTo:把路徑移動到畫布的指定點,不創(chuàng)建線條
    context.moveTo(目標(biāo)位置的x坐標(biāo),目標(biāo)位置的y坐標(biāo))
  • lineTo:方法增加一個新點,然后創(chuàng)建一條從上次指定點到目標(biāo)點的線
    context.lineTo(目標(biāo)位置的x坐標(biāo),目標(biāo)位置的y坐標(biāo))
運用:
context.moveTo(10,10)
context.rect(10,10,100,50)
context.lineTo(110,60)
context.stroke()
context.draw()

moveTo和lineTo用stroke()方法來畫線條

  • translate 對當(dāng)前坐標(biāo)系的原點(0, 0)進(jìn)行變換,默認(rèn)的坐標(biāo)系原點為頁面左上角
    context.translate(水平坐標(biāo)平移量,豎直坐標(biāo)平移量)
  • arc: 畫一條弧線,創(chuàng)建一個圓可以用arc()方法指定起始弧度為0,終止弧度為2*Math.PI
    context.arc(x,y,r,sAngle,eAngle,counterclockwise)
    x:圓的x坐標(biāo);y:圓的y坐標(biāo);r:圓的半徑;sAngle:起始弧度,單位弧度(在3點鐘方向)
    eAngle:終止弧度;counterclockwise:指定弧度的方向是逆時針還是順時針。Boolean類型,默認(rèn)是false即是順時針
  • clip:從原始畫布中剪切任意形狀和尺寸
    context.clip()
  • drawImage:繪制圖像到畫布
三種寫法:

context.drawImage(imageResource, dx, dy)
context.drawImage(imageResource, dx, dy, dWidth, dHeight)
context.drawImage(imageResource, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight) 從 1.9.0 起支持

imageResource:圖片資源(不能是本地圖片,需要wx.downloadFile(Object object)下載的路徑); dx:圖像的左上角在目標(biāo) canvas 上 x 軸的位置; dy:圖像的左上角在目標(biāo) canvas 上 y 軸的位置; dWidth:繪制圖像的寬度; dHeight:繪制圖像的高度; sx:源圖像的矩形選擇框的左上角 x 坐標(biāo); sy:源圖像的矩形選擇框的左上角 y 坐標(biāo); sWidth:源圖像的矩形選擇框的寬度; sHeight:源圖像的矩形選擇框的高度;

  • save:保存繪圖上下文
    content.save()
  • restore:恢復(fù)之前保存的繪圖上下文
    content.restore()

save和restore方法必須是配對使用的,restore方法前必須有save方法,不然會報Underflow in restore錯誤。
save表示保存sava函數(shù)之前的狀態(tài),restore表示獲取save保存的狀態(tài)

  • draw:將之前在繪圖上下文中的描述(路徑、變形、樣式)畫到 canvas 中
    content.draw()
運用:繪制一個圓的圖片
content.save()
content.beginPath()
content.arc(50, 50, 25, 0, 2 * Math.PI)
content.clip()
content.drawImage(url, 25, 25)
content.restore()
content.draw()

用clip方法一旦剪切了某個區(qū)域,則所有之后的繪圖都會被限制在被剪切的區(qū)域內(nèi)(不能訪問畫布上的其他區(qū)域)??梢栽谑褂?clip 方法前通過使用 save 方法對當(dāng)前畫布區(qū)域進(jìn)行保存,并在以后的任意時間通過restore方法對其進(jìn)行恢復(fù)。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,182評論 6 543
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,489評論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 178,290評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,776評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 72,510評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,866評論 1 328
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,860評論 3 447
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 43,036評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,585評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 41,331評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,536評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,058評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,754評論 3 349
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,154評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,469評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,273評論 3 399
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 48,505評論 2 379

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