• react做 canvas做签名(含清理画图,阻止手机滑动行为,为空判断等)


    import React, { Component } from 'react'
    import { Button, Divider, Row, Col } from 'antd'
    class Autograph extends Component {
      state = {
        base: '' // base64形式的图片
      }
      componentDidMount () {
        this.initCanvas()
      }
      initCanvas () {
        // 自适应设置画布大小
        const vWidth = document.body.clientWidth
        const can = document.getElementById('canvas')
        can.width = vWidth
        can.height = vWidth
        // 画布准备
        const context = can.getContext('2d')
        // 添加背景色
        context.fillStyle = '#ccc'
        context.fillRect(0, 0, can.width, can.height)
        // 笔尖设置
        context.strokeStyle = '#000' // 笔尖颜色
        context.lineWidth = 6 // 笔尖粗度
        // 监听触屏事件
        can.addEventListener('touchstart', (e) => {
          context.beginPath()
          context.moveTo(e.touches[0].pageX, e.touches[0].pageY)
        })
        can.addEventListener('touchmove', (e) => {
          e.preventDefault(); // 阻止页面拖动,如部分移动端,上下左右滑动手势,等
          context.lineTo(e.touches[0].pageX, e.touches[0].pageY)
          context.stroke()
        })
        can.addEventListener('touchend', () => {
          context.closePath()
        })
      }
      blankCanvas () {
        const blank = document.createElement('canvas')
        const canImg = document.getElementById('canvas')
        blank.width = canImg.width
        blank.height = canImg.height
        // 为使空画布与现有画图相同 (可根据实际需要修改)
        const context = blank.getContext('2d')
        context.fillStyle = '#ccc'
        context.fillRect(0, 0, blank.width, blank.height)
        // 为true 则为空画图
        // console.log(canImg.toDataURL() === blank.toDataURL());
        return canImg.toDataURL() === blank.toDataURL()
      }
      getCanvasImg () {
        const isFull = this.blankCanvas()
        if (isFull) {
          // 根据项目ui组件自行更改设置
          alert('请签名')
          return
        }
        // 获取到base64代码
        console.log(document.querySelector('canvas').toDataURL());
        this.setState({
          base: document.querySelector('canvas').toDataURL()
        })
      }
      clearCanvas () {
        this.initCanvas()
      }
      render () {
        return (
          <div>
            <canvas id='canvas' disable-scroll="true"></canvas>
            <Divider orientation="center">手写签名</Divider>
            <Row justify="space-around" align="middle">
              <Col>
              <Button onClick={this.getCanvasImg.bind(this)}>提交签名</Button>
              </Col>
              <Col>
              <Button onClick={this.clearCanvas.bind(this )}>清除签名</Button>
              </Col>
            </Row>
            <div style={{'wordBreak': 'break-all'}}>
              base64图片: <br/> {this.state.base}
            </div>
          </div>
        )
      }
    }
    export default Autograph
    
    /*
      https://www.w3school.com.cn/tags/html_ref_canvas.asp
      https://blog.csdn.net/Luckyzhoufangbing/article/details/87784843
      https://blog.csdn.net/weixin_30471561/article/details/97082558
    */ 

  • 相关阅读:
    关于WM_CTLCOLOREDIT的处理的一些问题
    Duilib非官方更新贴~
    一个非常简单的返回局部字符数组的C语言程序, 请问其输出结果?
    更改Windows控制台默认缓冲区行数和宽度
    最新版Duilib在VS2012下编译错误的解决方法
    记C语言浮点数运算处理 "坑" 一则
    修改stb_image.c以让Duilib直接支持Ico格式的图标显示
    一个通过网络转换Ico到Png图片的小小程序(Ico2Png)
    编程调节Win7/Win8系统音量的一种方法
    分享一个最近研究的手机QQ3.0的协议(版本1.4)
  • 原文地址:https://www.cnblogs.com/-roc/p/14558181.html
Copyright © 2020-2023  润新知