css3 - canvas画对角线很模糊
问题描述
使用canvas画一个p的对角线,先算p的width和height,再赋给canvas的width和height,然后建立一个2d画布开始画,为什么画出的斜线很模糊,改成直线就还好?感觉没有被因为p和画布的大小不同而放大或缩小
var canvasDom = document.querySelector('.canvas_line'); var w = parseInt($(canvasDom).css('width')); var h = parseInt($(canvasDom).css('height')); canvasDom.width = w; canvasDom.height = h; var context = canvasDom.getContext(’2d’);; context.beginPath(); context.moveTo(0,0); context.lineTo(w, h); context.lineWidth = '1'; context.strokeStyle = 'red'; context.stroke();
问题解答
回答1:如果你使用的设备太高清了,你可以尝试下这样的操作:
对canvas使用css样式(style属性)来确定在页面内的高宽
设置canvas的width和height属性的值为css样式的高宽的2倍
开始享受你的绘图
回答2:尝试 moveTo(0.5,0.5);
回答3:找到一篇文章,希望对你有帮助:HTML5 Canvas 如何取消反锯齿绘图
回答4:楼主你好,你需要在canvas元素里面给width和height属性。如果你在css里面定义canvas的width和height就会出现线条模糊的情况,因此你的更改JS
原:var w = parseInt($(canvasDom).css('width')); 改:var w = parseInt($(canvasDom).style('width'));
同理,height部分也需要这样改动
相关文章:
1. angular.js - 如何从AngularJS迁移到Vue?2. css - AngularJS如何判断不同情况设置不同背景色??3. javascript - 如何利用vue组件 动态生成router-link4. css - 求推荐几款好用的移动端页面布局调试工具呢?5. javascript - jquery ajax 用jsonp的方式跨域访问,为什么报错6. CSS3 中 transition-duration 对 display: none/block 属性无效?7. css3 - 根据效果,分析一下该动态是如何实现的?8. javascript - jQuery中live事件在移动微信端下没有效果;代码如下9. javascript - 微信小程序中设置头像 里面的图片路径是怎么解决的 我把接口生成的路径存到数据库中 2次访问时就显示不出来了10. javascript - 微信小程序的分享问题
