微信小程序制作簡易畫板

微信小程序制作簡易畫板

效果圖

palette.gif

原理介紹

??利用官方組件canvas來實現(xiàn)畫板的制作椒功,通過不斷獲取手指觸摸的位置窗骑,將初始位置和移動位置進行連線凛忿,達到實現(xiàn)畫筆的功能。另外利用官方APIclearRect實現(xiàn)橡皮檫的功能樱衷,而不僅僅只是在畫布上涂白色達到表面上的消除效果棋嘲。

??官方文檔鏈接

廢話不多,上代碼

簡單布局一下

??整個布局沒有啥好說的矩桂,命個名沸移,綁定兩個事件。唯一需要提醒的一點就是如果希望畫畫的時候禁用屏幕滾動耍鬓,可以設(shè)置disable-scroll='{{true}}'阔籽。

<!-- wxml布局 -->

<canvas 
  class='canvas'
  canvas-id='my-canvas' 
  disable-scroll='{{true}}'
  bindtouchstart='touchStart' 
  bindtouchmove='touchMove'>
</canvas>

<view class='rubber' bindtap='clear' hover-class='change'>
  我是橡皮檫
</view>
/* wxss樣式 */

page {
  background: #f1f1f1;
}

.canvas {
  background: #fff;
  width: 600rpx;
  height: 900rpx;
  margin-top: 200rpx;
  margin-left: auto;
  margin-right: auto;
}

.rubber {
  display: flex;
  background: orange;
  width: 200rpx;
  height: 100rpx;
  margin-top: 40rpx;
  margin-left: auto;
  margin-right: auto;
  justify-content: center;
  align-items: center;
}

.change {
  background: #fff;
}

js邏輯

??這里我把要說的都寫進注釋了,相信大家不難理解牲蜀。當然這只是一個模型笆制,需要改進和完善的地方還有很多,如果大家有更好的方法推薦涣达,希望能夠在下方留言在辆。

// js代碼

Page({

  /**
   * 頁面的初始數(shù)據(jù)
   */
  data: {
    isClear: false
  },

  /**
   * 生命周期函數(shù)--監(jiān)聽頁面加載
   */
  onLoad: function (options) {
    // 獲取畫布上下文
    this.context = wx.createCanvasContext('my-canvas');  // 參數(shù)必須和canvas組件中canvas-id值相同
  },

  // 剛開始觸摸
  touchStart(e) {
    // 獲取觸摸點坐標
    this.startX = e.changedTouches[0].x
    this.startY = e.changedTouches[0].y

    // 畫筆配置
    this.context.setStrokeStyle('red');  // 顏色 
    this.context.setLineWidth(5);        // 粗細 
    this.context.setLineCap('round');    // 線頭形狀
    this.context.setLineJoin('round');   // 交叉處形狀
  },

  // 開始移動
  touchMove(e) {
    // 移動時坐標
    var moveX = e.changedTouches[0].x
    var moveY = e.changedTouches[0].y

    // 判斷是否是橡皮檫
    if (this.data.isClear) {
      // 是
      // 以當前坐標點為中心創(chuàng)建20*20像素的橡皮檫
      let rectOriX = this.startX - 10;
      let rectOriY = this.startY - 10;
      this.context.clearRect(rectOriX, rectOriY, 20, 20);
    } else {
      // 不是
      this.context.moveTo(this.startX, this.startY);  // 找到起點
      this.context.lineTo(moveX, moveY);              // 找到終點
      this.context.stroke();                          // 描繪路徑
    }

    // 改變起點坐標
    this.startX = moveX;
    this.startY = moveY;
    this.context.draw(true);  // 畫
  },

  // 橡皮檫
  clear() {
    // 每次點擊都變成相反的狀態(tài)
    this.setData({
      isClear: !this.data.isClear
    })
  }
})
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末证薇,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子匆篓,更是在濱河造成了極大的恐慌浑度,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,718評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件鸦概,死亡現(xiàn)場離奇詭異箩张,居然都是意外死亡,警方通過查閱死者的電腦和手機窗市,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評論 3 385
  • 文/潘曉璐 我一進店門先慷,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人咨察,你說我怎么就攤上這事论熙。” “怎么了摄狱?”我有些...
    開封第一講書人閱讀 158,207評論 0 348
  • 文/不壞的土叔 我叫張陵脓诡,是天一觀的道長。 經(jīng)常有香客問我媒役,道長祝谚,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,755評論 1 284
  • 正文 為了忘掉前任酣衷,我火速辦了婚禮踊跟,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘鸥诽。我一直安慰自己,他們只是感情好箕憾,可當我...
    茶點故事閱讀 65,862評論 6 386
  • 文/花漫 我一把揭開白布牡借。 她就那樣靜靜地躺著,像睡著了一般袭异。 火紅的嫁衣襯著肌膚如雪钠龙。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 50,050評論 1 291
  • 那天御铃,我揣著相機與錄音碴里,去河邊找鬼。 笑死上真,一個胖子當著我的面吹牛咬腋,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播睡互,決...
    沈念sama閱讀 39,136評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼根竿,長吁一口氣:“原來是場噩夢啊……” “哼陵像!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起寇壳,我...
    開封第一講書人閱讀 37,882評論 0 268
  • 序言:老撾萬榮一對情侶失蹤醒颖,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后壳炎,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體泞歉,經(jīng)...
    沈念sama閱讀 44,330評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,651評論 2 327
  • 正文 我和宋清朗相戀三年匿辩,在試婚紗的時候發(fā)現(xiàn)自己被綠了腰耙。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,789評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡撒汉,死狀恐怖沟优,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情睬辐,我是刑警寧澤挠阁,帶...
    沈念sama閱讀 34,477評論 4 333
  • 正文 年R本政府宣布,位于F島的核電站溯饵,受9級特大地震影響侵俗,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜丰刊,卻給世界環(huán)境...
    茶點故事閱讀 40,135評論 3 317
  • 文/蒙蒙 一隘谣、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧啄巧,春花似錦寻歧、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,864評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至澄耍,卻和暖如春噪珊,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背齐莲。 一陣腳步聲響...
    開封第一講書人閱讀 32,099評論 1 267
  • 我被黑心中介騙來泰國打工痢站, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人选酗。 一個月前我還...
    沈念sama閱讀 46,598評論 2 362
  • 正文 我出身青樓阵难,卻偏偏與公主長得像,于是被迫代替她去往敵國和親芒填。 傳聞我的和親對象是個殘疾皇子多望,可洞房花燭夜當晚...
    茶點故事閱讀 43,697評論 2 351

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