记录:基于mapbox自定义canvas实现canvas叠加图片icon实现icon动画旋转(gif效果)

const gifImage= {
   width: 40,
   height: 40,
   data: new Uint8Array(size * size * 4),
   onAdd: function () {
     const canvas = document.createElement('canvas')
     canvas.width = this.width
     canvas.height = this.height
     this.context = canvas.getContext('2d')
   },
   render: function () {
     const context = this.context
     context.clearRect(0, 0, this.width, this.height)
     const img = new Image()
     img.src = require('../img.png') // 图片路径
     context.drawImage(img, 0, 0)
     img.onload = function () {
       context.clearRect(0, 0, 40, 40)
       context.translate(20, 20)
       context.rotate(Math.PI / 45)
       context.translate(-20, -20)
       context.drawImage(img, 0, 0)
     }
     this.data = context.getImageData(
       0,
       0,
       this.width,
       this.height
     ).data
     mapObject.triggerRepaint()
     return true
   }
 }
 mapObject.addImage('gifImage', gifImage) // 可作为icon-image使用

:类比mapbox官网提供的动画点案例简单改造实现添加的icon像gif图一样有动画效果(记录以备后续使用)

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值