> 웹 프론트엔드 > HTML 튜토리얼 > canvas、drawImage的问题,高手速进_html/css_WEB-ITnose

canvas、drawImage的问题,高手速进_html/css_WEB-ITnose

WBOY
풀어 주다: 2016-06-24 12:18:55
원래의
1207명이 탐색했습니다.

代码如下:

nbsp;html>




<script></script>
<script> <br /> jQuery(function ($) { <br /> $("img").load(function () { <br /> var w = $(this).width(), <br /> h = $(this).height(); <br /> $(this).after($("<canvas>").css({"width": w, "height": h, "backgroundColor": "blue"})); <br /> var ctx = $(this).next("canvas")[0].getContext("2d"); <br /> ctx.drawImage($(this)[0], 0, 0, w, h); <br /> }); <br /> }); <br /> </script>


canvas、drawImage的问题,高手速进_html/css_WEB-ITnose



drawImage出来的图片尺寸变形,不是原来图片的形状,会看到canvas背景蓝色。

回复讨论(解决方案)

请问你用的是什么浏览器呀???我用的chrome opera ie9貌似都没有你说的问题

.after($("")


canvas的实际宽高(canvas代码种实际参考的大小) 要这样设置  否则默认是 300-150
样式里面的 宽高 代表 渲染大小

实际宽高 和  样式 宽高 不一致  就会拉伸了

canvas画布的尺寸没问题,用drawImage画出来的图片与源img节点尺寸不一样

canvas里面的width和height跟css里面的width和height是不一样的,我以前就被坑过。。 统一用canvas.width比较好,画板的坐标神马的跟这个width是一样的,跟css里面的不一样

canvas画布的尺寸没问题,用drawImage画出来的图片与源img节点尺寸不一样
2楼已经和你说的很清楚了

谢了各位,解决了

怎么解决的呀,也碰到了同样的问题,望楼主告知下解决的方法哦!!

怎么解决的呀,也碰到了同样的问题,望楼主告知下解决的方法哦!!
canvas的width和height要设置成属性而不是样式
就是这种 
不是  和 canvas {width: 400px; height: 300px;}

原来如此。。。。 坑了我好久。。。。

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿