canvas手動簽名vue組件

<template>
    <div class="boardBox" ref="boardBox">
        <canvas ref="board"
                @mousedown="pcStart"
                @mousemove="pcMove"
                @mouseup="pcEnd">
        </canvas>
        <div class="sign-btn">
            <div class="clear" @click="clear">
                清空
            </div>
            <div class="save" @click="save">
                保存
            </div>
        </div>
    </div>
</template>

<script>
export default {
  name: "signatureLine",
  components: {},
  data() {
    return {
      ctx: null,
      point: {
        x: 0,
        y: 0
      },
      moving: false, // 是否正在繪制中且移動
      board: "",
      flg:false,//識別用戶是否畫了
    };
  },
  mounted() {
    this.board = this.$refs.board; // 獲取DOM
    this.board.width = this.$refs.boardBox.offsetWidth; // 設(shè)置畫布寬
    this.board.height = this.$refs.boardBox.offsetHeight; // 設(shè)置畫布高
    console.log(this.board.width,this.board.height)
    this.ctx = this.board.getContext("2d"); // 二維繪圖
    this.ctx.strokeStyle = "#000000"; // 顏色
    this.ctx.lineWidth = 3; // 線條寬度
  },
  methods: {
    // 鼠標(biāo)按下(開始)
    pcStart(e) {
      let x = e.offsetX,
          y = e.offsetY; // 獲取鼠標(biāo)在畫板(canvas)的坐標(biāo)
      this.point.x = x;
      this.point.y = y;
      this.ctx.beginPath();
      this.moving = true;
    },
    // 鼠標(biāo)移動(移動中...)
    pcMove(e) {
      this.flg  = true
      if (this.moving) {
        let x = e.offsetX,
          y = e.offsetY; // 獲取鼠標(biāo)在畫板(canvas)的坐標(biāo)
        this.ctx.moveTo(this.point.x, this.point.y); // 把路徑移動到畫布中的指定點歧寺,不創(chuàng)建線條(起始點)
        this.ctx.lineTo(x, y); // 添加一個新點部逮,然后創(chuàng)建從該點到畫布中最后指定點的線條哮幢,不創(chuàng)建線條
        this.ctx.stroke(); // 繪制
        (this.point.x = x), (this.point.y = y); // 重置點坐標(biāo)為上一個坐標(biāo)
      }
    },
    // 鼠標(biāo)松開(結(jié)束)
    pcEnd() {
      if (this.moving) {
        this.ctx.closePath(); // 停止繪制
        this.moving = false; // 關(guān)閉繪制開關(guān)
      }
    },
    clear() {
      this.flg=false
      this.ctx.clearRect(0, 0, this.board.width, this.board.height);
    },
    save() {
      if(this.flg){
        const imgBase64 = this.$refs.board.toDataURL();
        // console.log(imgBase64);
        console.log('畫了')
      }else{
        console.log('沒有畫')
      }
    }
  }
};
</script>

<style scoped lang="scss">
.boardBox {
  margin: 100px auto 20px;
  //   width: 80vw;
  //   height: 35vh;
  width: 200px;
  height: 80px;
  background: #eee;
  canvas {
    border: 1px solid #298cff;
  }
}

.sign-btn div {
  width: 175px;
  text-align: center;
  height: 70px;
  line-height: 70px;
  color: #ffffff;
}
.sign-btn div:active {
  background-color: #cccccc;
  color: #333333;
}
.sign-btn .clear {
  background-color: #ff8f58;
}
.sign-btn .save {
  background-color: #0599d7;
}
</style>

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末匈织,一起剝皮案震驚了整個濱河市镶殷,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌庭呜,老刑警劉巖懈贺,帶你破解...
    沈念sama閱讀 223,002評論 6 519
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異拣展,居然都是意外死亡彭沼,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,357評論 3 400
  • 文/潘曉璐 我一進店門备埃,熙熙樓的掌柜王于貴愁眉苦臉地迎上來姓惑,“玉大人,你說我怎么就攤上這事按脚∮诒校” “怎么了?”我有些...
    開封第一講書人閱讀 169,787評論 0 365
  • 文/不壞的土叔 我叫張陵乘寒,是天一觀的道長望众。 經(jīng)常有香客問我,道長伞辛,這世上最難降的妖魔是什么烂翰? 我笑而不...
    開封第一講書人閱讀 60,237評論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮蚤氏,結(jié)果婚禮上甘耿,老公的妹妹穿的比我還像新娘。我一直安慰自己竿滨,他們只是感情好佳恬,可當(dāng)我...
    茶點故事閱讀 69,237評論 6 398
  • 文/花漫 我一把揭開白布捏境。 她就那樣靜靜地躺著,像睡著了一般毁葱。 火紅的嫁衣襯著肌膚如雪垫言。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,821評論 1 314
  • 那天倾剿,我揣著相機與錄音筷频,去河邊找鬼。 笑死前痘,一個胖子當(dāng)著我的面吹牛凛捏,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播芹缔,決...
    沈念sama閱讀 41,236評論 3 424
  • 文/蒼蘭香墨 我猛地睜開眼坯癣,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了最欠?” 一聲冷哼從身側(cè)響起示罗,我...
    開封第一講書人閱讀 40,196評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎窒所,沒想到半個月后鹉勒,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體帆锋,經(jīng)...
    沈念sama閱讀 46,716評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡吵取,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,794評論 3 343
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了锯厢。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片皮官。...
    茶點故事閱讀 40,928評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖实辑,靈堂內(nèi)的尸體忽然破棺而出捺氢,到底是詐尸還是另有隱情,我是刑警寧澤剪撬,帶...
    沈念sama閱讀 36,583評論 5 351
  • 正文 年R本政府宣布摄乒,位于F島的核電站,受9級特大地震影響残黑,放射性物質(zhì)發(fā)生泄漏馍佑。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 42,264評論 3 336
  • 文/蒙蒙 一梨水、第九天 我趴在偏房一處隱蔽的房頂上張望拭荤。 院中可真熱鬧,春花似錦疫诽、人聲如沸舅世。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,755評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽雏亚。三九已至缨硝,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間罢低,已是汗流浹背追葡。 一陣腳步聲響...
    開封第一講書人閱讀 33,869評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留奕短,地道東北人宜肉。 一個月前我還...
    沈念sama閱讀 49,378評論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像翎碑,于是被迫代替她去往敵國和親谬返。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,937評論 2 361

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