• Vue利用canvas实现移动端手写板


    <template>
      <div class="hello">
    <!--touchstart,touchmove,touchend,touchcancel 这-->
      <button type="" v-on:click="clear">清除</button>
      <button v-on:click="save">保存</button>
        <canvas id="canvas" width="300" height="600" style="border:1px solid black">Canvas画板</canvas>
       <img v-bind:src="url" alt="">
      </div>
     
    </template>
    
    <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(){
                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);
            //canvas.ontouchmove = canvas.ontouchend = null
        }
        clear(btn) {
            this.cxt.clearRect(0, 0, 300, 600)
        }
        save(){
           return canvas.toDataURL("image/png")
        }
    }
    
    export default {
      data () {
        return {
          msg: 'Welcome to Your Vue.js App',
          val:true,
          url:""
        }
      },
      mounted() {
          draw=new Draw('canvas');
          draw.init();
      },
      methods:{
        clear:function(){
            draw.clear();
        },
        save:function(){
            var data=draw.save();
            this.url = data;
            console.log(data)
        },
       mutate(word) {
             this.$emit("input", word);
         },
    } } </script> <!-- Add "scoped" attribute to limit CSS to this component only --> <style scoped> 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; } </style>
  • 相关阅读:
    解决asp.net丢失session的方法文件
    Asp.net 从客户端中检测到有潜在危险的Request.Form值
    解决 ORA-12154 TNS无法解析指定的连接标识符
    sys用户权限不足,本地登录失败 |ORA-01031 insufficient privileges|
    Android按钮单击事件处理的几种方法(Android学习笔记)
    百度地图自定义放大缩小按钮
    百度地图 JS API开发Demo01
    java微信授权登录传参给redirect_uri 接口,回到原页面,传递多个参数
    利用padding-top/padding-bottom百分比,进行占位和高度自适应
    Rotate Array 旋转数组 JS 版本解法
  • 原文地址:https://www.cnblogs.com/huanlei/p/7494457.html
Copyright © 2020-2023  润新知