js根据坐标截取图片区域

let positionArr = []    
const img = new Image()
img.setAttribute('crossOrigin', 'anonymous')
img.src = '图片路径'
img.onload = () => {
    // 多边形区域data: [[[x1,y1], [x2,y2], [x3,y3], [x4,y4]], [], []]
    data.forEach((it, idx) => {
      const canvas = document.createElement('canvas')
      canvas.style.display = 'none'
      canvas.width = img.width
      canvas.height = img.height
      document.body.appendChild(canvas)

      const ctx = canvas.getContext('2d')
      let minLeft = it[0][0]
      let maxLeft = it[0][0]
      let minTop = it[0][1]
      let maxTop = it[0][1]
      for (let index = 1; index < it.length; index++) {
        const item = it[index]
        if (item[0] < minLeft) {
          minLeft = item[0]
        }
        if (item[0] > maxLeft) {
          maxLeft = item[0]
        }
        if (item[1] < minTop) {
          minTop = item[1]
        }
        if (item[1] > maxTop) {
          maxTop = item[1]
        }
      }
      // 过滤非矩形区域
      if ((maxLeft - minLeft === 0) || (maxTop - minTop === 0)) return         
      ctx.beginPath()
      ctx.moveTo(it[0][0], it[0][1])
      ctx.lineTo(it[1][0], it[1][1])
      ctx.lineTo(it[2][0], it[2][1])
      ctx.lineTo(it[3][0], it[3][1])
      ctx.clip()
      ctx.drawImage(img, 0, 0, img.width, img.height)
      // 区域外接矩形
      const canvas2 = document.createElement('canvas')
      canvas2.style.display = 'none'
      document.body.appendChild(canvas2)
      const cxt2 = canvas2.getContext('2d')

      const imgClipData = ctx.getImageData(minLeft, minTop, maxLeft - minLeft, maxTop - minTop)
      canvas2.width = imgClipData.width
      canvas2.height = imgClipData.height
      cxt2.putImageData(imgClipData, 0, 0, 0, 0, imgClipData.width, imgClipData.height)
      const dataURL = canvas2.toDataURL('image/png') // 截取的图片
     
      document.body.removeChild(canvas)
      document.body.removeChild(canvas2)
      // 框选的模板区域
      positionArr.push({
        x: minLeft,
        y: minTop,
        w: maxLeft - minLeft,
        h: maxTop - minTop
      })
    })     
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值