ctx.drawImage的canvas绘图不清晰解决方案,以及canvas高清导出

2024-02-25 00:04

本文主要是介绍ctx.drawImage的canvas绘图不清晰解决方案,以及canvas高清导出,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ctx.drawImage的canvas绘图不清晰

原因:
查资料是这么说的:canvas 绘图时,会从两个物理像素的中间位置开始绘制并向两边扩散 0.5 个物理像素。当设备像素比为 1 时,一个 1px 的线条实际上占据了两个物理像素(每个像素实际上只占一半),由于不存在 0.5 个像素,所以这两个像素本来不应该被绘制的部分也被绘制了,于是 1 物理像素的线条变成了 2 物理像素,视觉上就造成了模糊。

devicePixelRatiwebkitBackingStorePixelRatio区别

devicePixelRatiowebkitBackingStorePixelRatio 都与屏幕上的像素密度和绘图有关,但它们在实际用途和浏览器的兼容性方面有一些区别。

  1. devicePixelRatio:

    • devicePixelRatio 是一个用于表示设备上物理像素与 CSS 像素之间比率的属性。它告诉你在渲染页面时,一个 CSS 像素对应多少个物理像素。
    • 在标准的 JavaScript 中,你可以通过 window.devicePixelRatio 来获取这个值。
    • 例如,如果 devicePixelRatio 的值为 2,表示每个 CSS 像素对应设备上的 2 个物理像素,这通常出现在高密度屏幕(如Retina屏幕)上。
  2. webkitBackingStorePixelRatio:

    • webkitBackingStorePixelRatio 是一个 WebKit(现在在很多浏览器中也被支持)私有的属性,用于表示绘图表面(如Canvas)的缓冲区像素比率。
    • 这个属性通常用于在高分辨率设备上绘制图形时,确保图形质量和性能的平衡。在 Retina 屏幕上,使用这个属性可以绘制高清晰度的图形,而不会降低性能。
    • 你可以通过 context.webkitBackingStorePixelRatio 来获取这个值。

使用示例:

// 获取 devicePixelRatio
var devicePixelRatio = window.devicePixelRatio || 1;// 获取 webkitBackingStorePixelRatio
var backingStoreRatio = context.webkitBackingStorePixelRatio || 1;// 设置 Canvas 的缩放比例,确保在高密度屏幕上有更好的显示效果
var ratio = devicePixelRatio / backingStoreRatio;canvas.width = canvas.width * ratio;
canvas.height = canvas.height * ratio;// 缩放 Canvas 上下文,使得图形在高密度屏幕上有更好的显示效果
context.scale(ratio, ratio);

vue使用实例。解决canvas图片绘制模糊问题

<template><div class="wrapper"><img src="https://pic3.zhimg.com/80/v2-ab763f22d99ea793b55d57f2051ceac2_1440w.webp" alt="" id="zone" :style="{width:`${width}px`,height:`${height}px`}"><canvas id="one"></canvas></div>
</template><script>
export default {components: {},props: {},data:()=>({imgUrl:require('@/assets/tile.jpeg'),width:512,height:512}),watch: {},computed: {},methods: {init(){var img = document.getElementById("zone");var c = document.getElementById("one");var ctx = c.getContext("2d");var ratio = this.getPixelRatio(ctx);img.onload = ()=>{// 【重要】关闭抗锯齿ctx.mozImageSmoothingEnabled = false;ctx.webkitImageSmoothingEnabled = false;ctx.msImageSmoothingEnabled = false;ctx.imageSmoothingEnabled = false;c.width = 512*ratio;c.height = 512*ratio;//  c.width = 512;// c.height = 512;// ctx.drawImage(img,0,0,this.width,this.height);ctx.drawImage(img,0,0,this.width*ratio,this.height*ratio);ctx.scale(ratio, ratio);}},getPixelRatio(context){let backingStore = context.backingStorePixelRatio ||context.webkitBackingStorePixelRatio ||context.mozBackingStorePixelRatio ||context.msBackingStorePixelRatio ||context.oBackingStorePixelRatio ||context.backingStorePixelRatio || 1;return (window.devicePixelRatio || 1) / backingStore;}},created() {},mounted() {this.init()}
};
</script>
<style lang="less" scoped>
.wrapper{box-sizing: border-box;border: 1px solid rgb(8, 0, 0);position: relative;margin: 0 auto;#zone{}#one{transform: translateX(20px);}#two{cursor: crosshair;}
}
</style>

至此细节处理的比较好了
在这里插入图片描述

解决canvas导出图片模糊的方法

 // 解决导出图片模糊的方法toBeCanvas() {var copyDom = $("#canvasQR");var width = copyDom.offsetWidth; //dom宽var height = copyDom.offsetHeight; //dom高var scale = 2; //放大倍数html2canvas(this.$refs['order'], {dpi: window.devicePixelRatio * 2,scale: scale,width: width,heigth: height,}).then(canvas => {const context = canvas.getContext('2d');// 【重要】关闭抗锯齿context.mozImageSmoothingEnabled = false;context.webkitImageSmoothingEnabled = false;context.msImageSmoothingEnabled = false;context.imageSmoothingEnabled = false;var url = canvas.toDataURL();var triggerDownload = $("<a>").attr("href", url).attr("download", "详情.png").appendTo("body");triggerDownload[0].click();triggerDownload.remove();});},

这篇关于ctx.drawImage的canvas绘图不清晰解决方案,以及canvas高清导出的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/743811

相关文章

SpringBoot集成EasyExcel实现百万级别的数据导入导出实践指南

《SpringBoot集成EasyExcel实现百万级别的数据导入导出实践指南》本文将基于开源项目springboot-easyexcel-batch进行解析与扩展,手把手教大家如何在SpringBo... 目录项目结构概览核心依赖百万级导出实战场景核心代码效果百万级导入实战场景监听器和Service(核心

idea Maven Springboot多模块项目打包时90%的问题及解决方案

《ideaMavenSpringboot多模块项目打包时90%的问题及解决方案》:本文主要介绍ideaMavenSpringboot多模块项目打包时90%的问题及解决方案,具有很好的参考价值,... 目录1. 前言2. 问题3. 解决办法4. jar 包冲突总结1. 前言之所以写这篇文章是因为在使用Mav

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3

shell脚本批量导出redis key-value方式

《shell脚本批量导出rediskey-value方式》为避免keys全量扫描导致Redis卡顿,可先通过dump.rdb备份文件在本地恢复,再使用scan命令渐进导出key-value,通过CN... 目录1 背景2 详细步骤2.1 本地docker启动Redis2.2 shell批量导出脚本3 附录总

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

Java.lang.InterruptedException被中止异常的原因及解决方案

《Java.lang.InterruptedException被中止异常的原因及解决方案》Java.lang.InterruptedException是线程被中断时抛出的异常,用于协作停止执行,常见于... 目录报错问题报错原因解决方法Java.lang.InterruptedException 是 Jav

kkFileView在线预览office的常见问题以及解决方案

《kkFileView在线预览office的常见问题以及解决方案》kkFileView在线预览Office常见问题包括base64编码配置、Office组件安装、乱码处理及水印添加,解决方案涉及版本适... 目录kkFileView在线预览office的常见问题1.base642.提示找不到OFFICE组件

SpringBoot监控API请求耗时的6中解决解决方案

《SpringBoot监控API请求耗时的6中解决解决方案》本文介绍SpringBoot中记录API请求耗时的6种方案,包括手动埋点、AOP切面、拦截器、Filter、事件监听、Micrometer+... 目录1. 简介2.实战案例2.1 手动记录2.2 自定义AOP记录2.3 拦截器技术2.4 使用Fi

SpringBoot集成EasyPoi实现Excel模板导出成PDF文件

《SpringBoot集成EasyPoi实现Excel模板导出成PDF文件》在日常工作中,我们经常需要将数据导出成Excel表格或PDF文件,本文将介绍如何在SpringBoot项目中集成EasyPo... 目录前言摘要简介源代码解析应用场景案例优缺点分析类代码方法介绍测试用例小结前言在日常工作中,我们经

WinForm跨线程访问UI及UI卡死的解决方案

《WinForm跨线程访问UI及UI卡死的解决方案》在WinForm开发过程中,跨线程访问UI控件和界面卡死是常见的技术难题,由于Windows窗体应用程序的UI控件默认只能在主线程(UI线程)上操作... 目录前言正文案例1:直接线程操作(无UI访问)案例2:BeginInvoke访问UI(错误用法)案例