日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

vue使用canvas實現(xiàn)移動端手寫簽名

瀏覽:154日期:2022-11-18 18:17:18

基于vue使用canvas實現(xiàn)移動端手寫簽名!

之前自己開發(fā)有這么一個需求,需要實現(xiàn)手寫簽名,然后以圖片的形式保存生成圖片的base64數(shù)據(jù)流 。自己在網(wǎng)上找了一堆,都不是很完美。然后參考網(wǎng)上的加自己的優(yōu)化和修改做了一版。希望有需要的朋友可以拿來直接用。

HTML部分:

<template> <div > <div>請輸入您的簽名7:</div> <canvas ref='canvasW' >Canvas畫板</canvas> <img v-bind:src='http://m.b3g6.com/bcjs/url' alt=''> <div> <button type='' v-on:click='clear'>重寫</button> <button v-on:click='save'>保存簽名</button> </div> </div> </template>

為了節(jié)約時間,樣式寫的比較簡單。湊合看吧!

script部分

<script>var draw;var preHandler = function(e){e.preventDefault();}class Draw { constructor(el) { this.el = el this.canvas = document.getElementById(this.el) this.cxt = this.canvas.getContext(’2d’) this.stage_info = canvas.getBoundingClientRect() this.path = { beginX: 0, beginY: 0, endX: 0, endY: 0 } } init(btn) { var that = this; //初始化生成 this.canvas.addEventListener(’touchstart’, function(event) { document.addEventListener(’touchstart’, preHandler, false); that.drawBegin(event) }) this.canvas.addEventListener(’touchend’, function(event) { document.addEventListener(’touchend’, preHandler, false); that.drawEnd() }) this.clear(btn) } drawBegin(e) { var that = this; window.getSelection() ? window.getSelection().removeAllRanges() : document.selection.empty() this.cxt.strokeStyle = '#000' this.cxt.beginPath() this.cxt.moveTo( e.changedTouches[0].clientX - this.stage_info.left, e.changedTouches[0].clientY - this.stage_info.top ) this.path.beginX = e.changedTouches[0].clientX - this.stage_info.left this.path.beginY = e.changedTouches[0].clientY - this.stage_info.top canvas.addEventListener('touchmove',function(ev){ ev.preventDefault() that.drawing(event) }) } drawing(e) { this.cxt.lineTo( e.changedTouches[0].clientX - this.stage_info.left, e.changedTouches[0].clientY - this.stage_info.top ) this.path.endX = e.changedTouches[0].clientX - this.stage_info.left this.path.endY = e.changedTouches[0].clientY - this.stage_info.top this.cxt.stroke() } drawEnd() { document.removeEventListener(’touchstart’, preHandler, false); document.removeEventListener(’touchend’, preHandler, false); document.removeEventListener(’touchmove’, preHandler, false); } clear(btn) { this.cxt.clearRect(0, 0, this.stage_info.width, this.stage_info.height) // this.cxt.clearRect(0, 0, 373, 200) } save(){ return canvas.toDataURL('image/png') console.log(canvas.toDataURL('image/png')) }}export default { data () { return { msg: ’啦啦啦’, val:true, url:'' } }, mounted() { draw=new Draw(’canvas’); draw.init(); }, methods:{ clear:function(){ draw.clear(); // 用于點擊清除畫布時,同時清除上次保存的圖片 this.save() }, save:function(){ var data=draw.save(); this.url = data; // 生成圖片的base64數(shù)據(jù)流 },mutate(word){ this.$emit('input', word); }, }}</script>

css部分

<style scoped lang='less'> .hello{ height: 100%; width: 100%; background: #ccc; h1, h2 { font-weight: normal; } ul { list-style-type: none; padding: 0; } li { display: inline-block; margin: 0 10px; } a { color: #42b983; } #canvas { background: pink; cursor: default; } #keyword-box { margin: 10px 0; } button{font-size: 0.2rem;color: blue;} }

效果圖:

vue使用canvas實現(xiàn)移動端手寫簽名

就到這里吧!

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Vue
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲综合精品| 亚洲国产一区二区在线观看| 欧美午夜精品一区二区三区电影| 久久久久久久久成人| 国产激情一区| 精品一区二区三区在线观看视频| 国产亚洲一区| 久久三级毛片| 成人久久久久| 午夜一级久久| 日韩欧美激情电影| 欧美a级一区二区| 肉色欧美久久久久久久免费看| 欧美手机在线| 999在线观看精品免费不卡网站| 日韩视频一区| 欧美在线不卡| 日韩伦理在线一区| 国产农村妇女精品一二区| 亚洲日本在线观看视频| 国产精品免费99久久久| 国产一区二区三区四区五区传媒| 高清一区二区三区av| 亚洲网站视频| 亚洲精品乱码日韩| 欧美激情99| 一区二区亚洲视频| 欧美激情国产在线| 99热精品在线观看| 日欧美一区二区| 97精品视频在线看| 日韩一区精品| 欧美天堂视频| 国产精品一区二区99| 欧美一区三区| 麻豆久久久久久| 伊人久久亚洲| 亚洲特级毛片| 国产精品99久久精品| 热久久久久久久| 亚洲h色精品| 精品视频网站| 视频一区二区三区中文字幕| 国产成人精品亚洲线观看| 精品一区欧美| 精品国产欧美日韩| 欧美在线不卡| 色狠狠一区二区三区| 亚洲国产日韩欧美在线| 亚洲伊人av| 久久亚洲黄色| 久久精品免视看国产成人| 午夜电影一区| 亚洲欧美专区| 亚洲一区二区小说| 国产免费成人| 伊人久久大香线蕉av超碰演员| а√天堂8资源中文在线| 精品日本视频| 国产精品亚洲人成在99www| 蜜臀av一区二区在线免费观看| 99视频一区| 免费视频最近日韩| 亚洲精品国模| 国产精品一级| 日本欧美国产| 99久久亚洲精品蜜臀| 久久久久国产精品一区二区| 日韩欧美中文| 国产一区二区中文| 蜜芽一区二区三区| 久久精品99国产国产精| 九九九精品视频| 久久久久国产精品一区二区| 国产麻豆久久| 电影亚洲精品噜噜在线观看| 久久69成人| 中文字幕色婷婷在线视频| 国产+成+人+亚洲欧洲在线| 日韩精品欧美激情一区二区| 亚洲国产一区二区在线观看| 中文字幕一区二区三区在线视频| 日韩高清二区| 欧美sm一区| 午夜电影一区| 五月天av在线| 日韩在线网址| 中文在线资源| 日韩高清电影免费| 98精品久久久久久久| 欧美日韩精品免费观看视频完整 | 亚洲精品欧洲| 韩国一区二区三区视频| 首页国产精品| 香蕉久久国产| 91福利精品在线观看| 国产成人精品三级高清久久91 | 日本不卡高清| 最新日韩av| 久久中文字幕一区二区| 99日韩精品| 日韩一区二区三区精品| 亚洲永久精品唐人导航网址| 久久99性xxx老妇胖精品| 国产高清一区二区| 日韩精品一区二区三区中文在线 | 免费视频最近日韩| 日韩一区二区在线免费| 日韩黄色av| 午夜电影亚洲| 日本高清不卡一区二区三区视频| 人人爽香蕉精品| 99精品一区| 精品久久97| 亚洲午夜91| 麻豆精品一区二区综合av| 久久精品国产68国产精品亚洲| 国产精品亚洲一区二区在线观看| 狠狠久久婷婷| 日本精品不卡| 国产精品白浆| 日韩精品一区二区三区中文字幕| 少妇久久久久| 高清精品久久| 福利在线免费视频| 国产欧美69| 国产欧美日韩| 中日韩男男gay无套| 麻豆精品蜜桃| 日韩一区二区三区精品视频第3页| 日韩不卡免费高清视频| 国产精品tv| 亚洲精品大全| 国产精品试看| 久久国产亚洲| 美女网站一区| 麻豆亚洲精品| 日本成人在线一区| 欧美一区=区三区| 国产激情欧美| 日韩在线短视频| 亚洲第一精品影视| 亚洲人妖在线| 精品视频一区二区三区四区五区| 四虎成人精品一区二区免费网站 | 久久精品高清| 四虎国产精品免费久久| 国产高清亚洲| 久久久久午夜电影| 亚洲三级观看| 激情久久99| 亚洲在线一区| 国产精品永久| 欧美精选一区二区三区| 日本综合视频| 国产91精品对白在线播放| 最新国产精品久久久| 国产视频一区二| 久久精品播放| 欧美激情五月| 免费日韩精品中文字幕视频在线| 欧美欧美黄在线二区| av亚洲一区二区三区| 日本v片在线高清不卡在线观看| 欧美1区二区| 麻豆成人在线| 日韩精品诱惑一区?区三区| 久久亚洲精品中文字幕蜜潮电影| 另类国产ts人妖高潮视频| 荡女精品导航| 日韩一区免费| 国产精品婷婷| 美女免费视频一区| 亚洲精品乱码日韩| 极品裸体白嫩激情啪啪国产精品| 国产精品久久久久久妇女| 视频一区中文| 韩国精品主播一区二区在线观看| 亚洲精品大片| 欧美日韩中文字幕一区二区三区| 国产高清亚洲| 涩涩涩久久久成人精品| 久久高清免费| 欧美亚洲日本精品| 国产亚洲精aa在线看| 中文无码日韩欧| 久久国产精品成人免费观看的软件| 欧美一区二区三区久久精品| 夜久久久久久| 久久亚洲国产| 欧美日韩中文一区二区| 成人羞羞视频播放网站| 精品久久精品| 国产福利片在线观看| 精品三区视频| 天堂√中文最新版在线| 国产一区丝袜| 国产传媒在线观看| 欧美91福利在线观看| 91精品国产福利在线观看麻豆|