将旋转的图像转换为矩形左上角

Posted

技术标签:

【中文标题】将旋转的图像转换为矩形左上角【英文标题】:Translate a rotated image into a Rectangle Left Top Corner 【发布时间】:2015-12-18 18:35:41 【问题描述】:

我编写了一个应用程序来绘制 SMT 托盘和填充它们的组件。我成功导入了一个旋转程序,该程序以 alpha 旋转角度在中心坐标中旋转并绘制我的电子元件雕像(见下图)。我需要用 X,Y 偏移量平移小雕像的 00 坐标,以在矩形中绘制整个旋转的小雕像。

So I only know the:
figurine rotation angle: dbRotationAngle
figurine X,Y position: dbX, dbY
figurine Width, Height: dbWidth, dbHeight
Rectangle LeftTop corner Position:  (LeftTop.X, LeftTop.Y)

所以我的问题是:如何计算旋转雕像的偏移 X、Y 以便在从 (LeftTop.X, LeftTop.Y) 开始的矩形内绘制整个图像?

【问题讨论】:

【参考方案1】:

查找范围

你需要变换角,然后找到最小值和最大值

所以从一个将在其中心点渲染的框开始

var box = 
   top:0,
   left:0,
   bottom:100,
   right:200,
   centerX:100,  // the position in the box that the render coordinates are.
   centerY:50

您有一个以弧度为单位的旋转框。它的 X 和 Y 轴将旋转这个量。

var rotation = ?

你需要四个角的坐标。

首先锻炼沿对象旋转 x 轴的向量

var axisX_x = Math.cos(rotation);
var axisX_y = Math.sin(rotation);

这也为我们提供了沿对象 y 旋转轴的向量。从 x 轴顺时针旋转 90 度。

var axisY_x = -axisX_y;
var axisY_y = axisX_x;

现在到左上角。我们需要找到它与物体旋转中心的距离。

var x = box.left - box.centerX;
var y = box.top - box.centerY;

现在通过沿表示旋转轴的两个向量移动该点来变换该点。沿 X 轴移动 x,沿 y 轴移动 y。

var tx = x*axisX_x + y * axisY_x;
var ty = x*axisX_y + y * axisY_y;

现在因为我们想要盒子的范围,我们需要保存最小值和最大值;

var minX = tx;
var miny = ty;
var maxX = tx;
var maxy = ty;

下一个点是沿着对象的 x 轴的右上角,所以沿着它移动框的宽度

tx = tx + axisX_x * (box.right - box.left); // (box.right - box.left) is the
ty = ty + axisX_y * (box.right - box.left); // width of the box

现在我们需要检查最小最大值

minX = Math.min(minX, tx);
minY = Math.min(minY, ty);
maxX = Math.max(maxX, tx);
maxY = Math.max(maxY, ty);

现在将 Y 轴向下移动对象的高度,并获得旋转右下角的对象的最小最大值。

tx = tx + axisY_x * (box.bottom - box.top);
ty = ty + axisY_y * (box.bottom - box.top);
minX = Math.min(minX, tx);
minY = Math.min(minY, ty);
maxX = Math.max(maxX, tx);
maxY = Math.max(maxY, ty);

左下角只剩下一点,所以沿X轴向后移动对象的宽度,得到最小最大值

tx = tx - axisX_x * (box.right - box.left);
ty = ty - axisX_y * (box.right - box.left);
minX = Math.min(minX, tx);
minY = Math.min(minY, ty);
maxX = Math.max(maxX, tx);
maxY = Math.max(maxY, ty);

现在最小值和最大值保存了框相对于其中心的范围

绘制框,使其位于所需容器的左上角并带有一些填充

var pad = 2; // two pixels from the edge
var containerLeft = 100;
var containerTop = 100;

var boxX = containerLeft - minX + pad;
var boxY = containerTop - minY + pad;

现在boxXboxY 保存需要将盒子中心塞入容器左上角的位置。使用最小值和最大值,您可以将框放在包含区域内的任何位置。

这是详细的解释,可以用一两个函数来简化,如果你只需要适合右上角那么你只需要minXminY

【讨论】:

盒子是小雕像的一个感兴趣的区域?对吗? 盒子是你要移动的对象,容器是盒子最终要进入的区域。

以上是关于将旋转的图像转换为矩形左上角的主要内容,如果未能解决你的问题,请参考以下文章

如何将图像从不规则矩形更改为矩形?

图像旋转的原理

图像旋转算法与实现

如何裁剪带有旋转矩形的图像?

无法将 BMP 图像转换为矩形 OpenGL

从旋转的矩形计算边界框坐标