小程序Canvas

<view class = "canvas-area">
    <canvas canvas-id = "myCanvas" class = "myCanvas" disable-scroll = "false" bindtouchstart = "touchStart" bindtouchmove = "touchMove" />
</view>
<view>
    <view class = "box box1" bindtap = "penSelect" data-param = "5"></view>
    <view class = "box box2" bindtap = "colorSelect" data-param = "#c03"></view>
</view>
let ctx;
Page({
    data:{
        pen:{
            color:'#000',
            lineWidth: 5
        }
    },
    onload:function (options) {
        ctx = wx.createCanvasContext('myCanvas')
        ctx.setStrokeStyle(this.data.pen.color)
        ctx.setLineWidth(this.data.pen.lineWidth)
        ctx.setLineCap('round')
        ctx.setLineJoin('round')
    },
    touchStart(e){
        ctx.moveTo(e.touches[0].x,e.touches[0].y)
    },
    touchMove(e){
        let x = e.touches[0].x
        let y = e.touches[0].y
        ctx.lineTo(x,y)
        ctx.stroke()
        ctx.draw(true)
        ctx.moveTo(x,y)
    },
    penSelect(e){
        console.log(e)
        this.setData({
            'pen.lineWith':e.target.dataset.param
        })
    },
    colorSelect(e){
        this.setData({
            'pen.color':e.target.dataset.param
        })
    }
})

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值