我有一个图像,它是1836x3264,我想drawImage()
到画布,并调整到739x1162。
在阅读了文档后,我认为这可以通过以下几点来实现:
ctx.drawImage(image, 0, 0, 739, 1162);
我也尝试过:
ctx.drawImage(image, 0, 0, 1836, 3264, 0, 0, 739, 1162);
两者都只显示完整图像的一小部分,而不是缩小它。
如何传递要从1836 x 3264 -> 739 x 1162调整大小的值?
发布于 2013-03-04 10:30:02
你得到的看起来是正确的,所以你可能会仔细检查某个地方的打字错误。
额外的思考:你的图像真的是1836x3264而不是3264x1836吗?
下面是可用的代码和一个提琴:http://jsfiddle.net/m1erickson/MLGr4/
<!doctype html>
<html>
<head>
<link rel="stylesheet" type="text/css" media="all" href="css/reset.css" /> <!-- reset css -->
<script type="text/javascript" src="http://code.jquery.com/jquery.min.js"></script>
<style>
body{ background-color: ivory; }
canvas{border:1px solid red;}
</style>
<script>
$(function(){
var canvas=document.getElementById("canvas");
var ctx=canvas.getContext("2d");
img=new Image();
img.onload=function(){
canvas.width=400;
canvas.height=300;
ctx.drawImage(img,0,0,img.width,img.height,0,0,400,300);
}
img.src="http://www.onestopwebmasters.com/wp-content/uploads/2011/06/eitai-bridge.jpg";
}); // end $(function(){});
</script>
</head>
<body>
<canvas id="canvas" width=100 height=100></canvas>
</body>
</html>
https://stackoverflow.com/questions/15192343
复制相似问题