微信小程序canvas画布不清晰解决方法

绘制的图片,文字等十分模糊

添加以下代码,通过设置分辨率来解决

typescript 复制代码
	const dpr = wx.getSystemInfoSync().pixelRatio
	canvas.width = res[0].width * dpr
	canvas.height = res[0].height * dpr
	ctx.scale(dpr, dpr)

完整代码:

xml 复制代码
<!-- canvas.wxml -->
<canvas type="2d" id="myCanvas"></canvas>
typescript 复制代码
// canvas.js
Page({
  onReady() {
    const query = wx.createSelectorQuery()
    query.select('#myCanvas')
      .fields({ node: true, size: true })
      .exec((res) => {
        const canvas = res[0].node
        const ctx = canvas.getContext('2d')
		//添加这些代码,通过分辨率重新设置
        const dpr = wx.getSystemInfoSync().pixelRatio
        canvas.width = res[0].width * dpr
        canvas.height = res[0].height * dpr
        ctx.scale(dpr, dpr)

        ctx.fillRect(0, 0, 100, 100)
      })
  }
})

按照以上方法即可实现

相关推荐
inksci6 分钟前
推荐动态群聊二维码制作工具
前端·javascript·微信小程序
郑州光合科技余经理2 小时前
海外O2O系统源码剖析:多语言、多货币架构设计与二次开发实践
java·开发语言·前端·小程序·系统架构·uni-app·php
CHU72903510 小时前
定制专属美丽时刻:美容预约商城小程序的贴心设计
前端·小程序
hnxaoli16 小时前
统信小程序(十)nutika打包elf格式程序
小程序
CHU72903516 小时前
家门口的邻里集市:社区团购小程序的功能探索
小程序
hnxaoli17 小时前
统信小程序(十一)快捷地址栏
linux·python·小程序
职豚求职小程序19 小时前
中国人保财险笔试如何通过?附刷题库小程序
小程序
chushiyunen20 小时前
python轻量级框架flask、做桌面小程序
python·小程序·flask
笨笨狗吞噬者21 小时前
【uniapp】小程序支持分包存放微信自定义组件 wxcomponents
前端·微信小程序·uni-app
蓝色心灵-海1 天前
小律书 技术架构详解:前后端分离的自律管理系统设计
java·http·小程序·架构·uni-app