- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何裁剪图像,然后将其绘制在 Canvas 的中央?
目前我有一个放置 div,我可以在其中放置图像,然后由 JavaScript 拾取图像。然后我想让 JavaScript 检查哪个更高(高度或宽度)。如果高度最高,我希望它是 200px 并且宽度要根据纵横比进行调整。之后,我希望 JavaScript 在 Canvas 中绘制图像,图像的中心就是 Canvas 的中心。
我现有的代码无法正常工作(我不确定为什么):
(为简单起见,我只是将网络上的图像传递给函数)
render('http://www.aboveandbeyond.nu/sites/www.aboveandbeyond.nu/files/news/europe_above_beyond_tour.jpg');
function render(src){
var image = new Image();
var canvas = document.getElementById("artworkcanvas");
var ctx = canvas.getContext("2d");
ctx.clearRect(0, 0, canvas.width, canvas.height);
image.onload = function(){
var sourceX = 200;
var sourceY = 0;
var sourceWidth = 200;
var sourceHeight = 200;
var destWidth = sourceWidth;
var destHeight = sourceHeight;
var destX = canvas.width / 2 - destWidth / 2;
var destX = 0;
var destY = canvas.height / 2 - destHeight / 2;
var destY = 0;
var MAX_WIDTH = 200;
var MAX_HEIGHT = 200;
if (image.height == image.width) {
image.width = MAX_WIDTH;
image.height = MAX_HEIGHT;
} else {
if(image.height < image.width) {
console.log("height smaller");
image.width *= MAX_HEIGHT / image.height;
image.height = MAX_HEIGHT;
} else {
image.height *= MAX_WIDTH / image.width;
image.width = MAX_WIDTH;
}
}
ctx.clearRect(0, 0, canvas.width, canvas.height);
canvas.width = image.width;
canvas.height = image.height;
ctx.drawImage(image, sourceX, sourceY, sourceWidth, sourceHeight, destX, destY, destWidth, destHeight);
};
image.src = src;
最佳答案
这是在保持纵横比的同时使用缩放版本的 drawImage
的一种方法:
// calc scale that fits into 200x200 and also maintains aspect ratio
var scale=Math.min((MAX_WIDTH/img.width),(MAX_HEIGHT/img.height));
ctx.drawImage(img,
0,0,img.width,img.height,
(canvas.width-img.width*scale)/2, (canvas.height-img.height*scale)/2,
img.width*scale, img.height*scale
);
示例代码和演示:
var canvas=document.getElementById("canvas");
var ctx=canvas.getContext("2d");
var cw=canvas.width;
var ch=canvas.height;
var img=new Image();
img.onload=start;
img.src="http://www.aboveandbeyond.nu/sites/www.aboveandbeyond.nu/files/news/europe_above_beyond_tour.jpg";
function start(){
var MAX_WIDTH = 200;
var MAX_HEIGHT = 200;
var iw=img.width;
var ih=img.height;
// calc scale that fits into 200x200 and also maintains aspect ratio
var scale=Math.min((MAX_WIDTH/iw),(MAX_HEIGHT/ih));
var sw=iw*scale;
var sh=ih*scale;
ctx.drawImage(img,
0,0,iw,ih,
(canvas.width-sw)/2,(canvas.height-sh)/2,iw*scale,ih*scale
);
}
body{ background-color: ivory; padding:10px; }
#canvas{border:1px solid red;}
<canvas id="canvas" width=300 height=300></canvas>
关于javascript - 图像对象裁剪并在 Canvas 中心绘制,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26705803/
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: How to align a to the middle of the page 这是一个简单的问题,应该有一个简
我想知道如何在屏幕中央的ListView中生成2个itens。 class _CategoriesState extends State { List categories = ["Anterio
我需要修复 UICollectionView 的一个小问题,当在 6s 设备尺寸上时,我得到如下布局: 但是,我想知道将它们居中以使其成为两条线的最佳方法是什么,或者我应该将它们缩小一点以便可以放置其
我尝试在 UIImageView 中居中 CAShapeLayer 但没有成功,我找到了解决方案,将其(CAShapeLayer)添加到 UIVIew,然后将 UIVIew 添加到 ImageView
一直在从线性布局和相对布局切换,因为我想实现图像的居中。 显示图片:
* { margin:0; padding:0; } /** General Style Info **/ body { background: #003d4c; co
我目前正在尝试修改我在 Wordpress 上的 Royal Slider 插件 (http://dimsemenov.com/plugins/royal-slider/) 我的目标是将所有标题的文本
我已经坚持了一段时间,因此简化了我的要求。当您单击标记时,信息窗口将打开,当用户缩放时,我希望该标记位于 map 的中心。这不起作用,但我认为它很接近: function bindInfoWindow
/* Linked Styles */ body { padding: 0 !important;
这个问题在这里已经有了答案: How do I center floated elements? (12 个答案) 关闭 7 年前。
这个问题在这里已经有了答案: Is there an equivalent to background-size: cover and contain for image elements? (1
我试图让我的页眉停留在页面的中间,不管我在什么窗口大小。 我试过使用 Bootstrap。 StackOverflow 还有这个 CSS。 .section-t
我有一个 1600 像素宽的页面。主要区域虽然只有 900 像素宽。我有一个导航应该固定在页面的中心(它是)。我的问题是当我打开页面时,页面固定在左侧而不是在打开时居中。当用户访问该网站时,我需要做什
我正在尝试找到 View 的中心。对于非旋转 View ,该值是正确的,但对于旋转 View ,它不正确,因为中心 (0,0) 正在旋转。在缩放的情况下,即使缩放后宽度和高度也保持不变 我正在使用以下
预期效果是将 Kartennummer 和 Passwort 集中。 这怎么可能? 我为此使用了一个自定义类: import 'package:flutter/material.dart'; impo
我管理着许多 Maven 项目。他们中的大多数部署到我们的内部 maven 存储库。现在我想开始向 Maven Central 发布一个项目。到目前为止,我有一个父 POM,它指定了我们内部存储库的
我试图锚定两个进展,但我看不到获得预期结果的方法。 我希望左边的进度条固定在左边,右边的条固定在中心固定(如下图所示) (下图显示调整大小的表格) 我尝试将控件放在具有各种 anchor 的停靠面板上
我正在玩 Angular 模态 ui 对话框。我想知道有什么方法可以让它居中?我发现了一个类似的问题: Twitter Bootstrap - Center Modal Dialog 但无法使其工作,
是否可以将值标签放置在条形上,使它们位于条形的中心? 如果我设置条形 align: "center",则条形上的标签将关闭且不居中。 $(function() { var d
http://www.asp.net/signalr/overview/signalr-20/getting-started-with-signalr-20/tutorial-signalr-20-s
我是一名优秀的程序员,十分优秀!