uniapp小程序使用uqrcode

code封装组件

<script setup lang="ts">
import { isWx } from '@/system/data'
import UQRCode from 'uqrcodejs'
const props = defineProps<{
  size: string
  data: string
}>()

const pxSize = computed(() => uni.upx2px(Number(props.size.replace(/rpx/g, ''))))

const qrOptions = computed(() => {
  return {
    data: props.data,
    size: pxSize.value,
  }
})
const draw = async () => {
  try {
    const qr = new UQRCode()
    qr.setOptions(qrOptions.value)
    // 提升二维码美观度,如果关闭的话二维码中会有很明显的白色线条
    qr.useDynamicSize = true
    // 调用制作二维码方法
    qr.make()
    if (isWx) {
      const canvas = await getWxCanvas()
      const canvasContext = canvas.getContext('2d')
      const dpr = uni.getSystemInfoSync().pixelRatio
      canvas.width = qr.dynamicSize * dpr
      canvas.height = qr.dynamicSize * dpr
      canvasContext?.scale(dpr, dpr)
      qr.canvasContext = canvasContext
    } else {
      const canvasContext = uni.createCanvasContext(canvasId, this)
      qr.canvasContext = canvasContext
    }
    // 调用绘制方法将二维码图案绘制到canvas上
    await qr.drawCanvas()
  } catch (error) {
    console.log('渲染错误', error)
  }
}
const render = async () => {
  await resetCanvas()
  draw()
}
onMounted(render)
watch(props, render)
const canvasId = `qrcode`
const instance = getCurrentInstance()
const getWxCanvas = () => {
  return new Promise<HTMLCanvasElement>((resolve, reject) => {
    try {
      const query = uni.createSelectorQuery().in(instance)
      query
        .select(`#${canvasId}`)
        .fields({ node: true, size: true } as any, () => {})
        .exec((res) => {
          resolve(res[0].node)
        })
    } catch (error) {
      reject(error)
    }
  })
}

const canvasDisplay = ref(true)
const resetCanvas = () => {
  return new Promise<void>((resolve) => {
    canvasDisplay.value = false
    nextTick(() => {
      canvasDisplay.value = true
      resolve()
    })
  })
}
</script>

<template>
  <view class="qr-code-wrap" :style="{ width: props.size, height: props.size }">
    <image
      class="img"
      src=""
    >
    </image>
    <canvas class="canvas" id="qrcode" canvas-id="qrcode" ref="qrcode" type="2d" :style="{ display: canvasDisplay ? 'block' : 'none' }"></canvas>
  </view>
</template>

<style lang="scss" scoped>
.qr-code-wrap {
  position: relative;
  box-sizing: border-box;
  .img {
    position: absolute;
    left: 50%;
    top: 50%;
    width: 25%;
    height: 25%;
    transform: translate(-50%, -50%);
  }
  .canvas {
    position: absolute;
    left: 50%;
    top: 50%;
    width: 100%;
    height: 100%;
    transform: translate(-50%, -50%);
  }
}
</style>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值