numpy - 旋转后计算边界框
问题描述
我有一个图像和相应的 4 点边界框,看起来像这样[685,601,832,743]
,我想执行一些旋转,如 90、180、270 等。
我不知道如何获得图像的边界框让我说在我旋转图像 90 之后。我正在使用 imagemagick 执行旋转,我寻找任何可以在我旋转图像后给我边界框的函数,但是我找不到任何东西,我已经坚持了 3 个多小时。此时的任何建议都会非常有帮助。提前致谢。
解决方案
使用 ImageMagick 和一些 bash shell 脚本,这是计算它的方法。
使用基本点旋转方程。(见https://en.wikipedia.org/wiki/Rotation_of_axes)。但是,由于旋转是关于中心的,因此必须从点坐标中减去输入的中心坐标,进行旋转,然后将输出图像的中心加回去。
注意 ImageMagick 的旋转是顺时针的,而通常的坐标变换方程是逆时针的。所以我必须否定旋转角度。
另请注意,Y 在图像坐标中向下为正,而法线坐标旋转的 Y 向上。因此,图像和正常笛卡尔坐标系之间的方程中存在符号交换。
这是我创建的测试图像:
convert -size 300x300 xc:skyblue -size 100x100 xc:pink -geometry +50+50 -composite test.png
很明显(来自 ImageMagick 命令),4 个角是:
pt1=50,50
pt2=149,50
pt3=149,149
pt4=59,149
较大的值 (149) 比粉红色尺寸加上起始坐标 (100-1+50=149) 小 1,因为 ImageMagick 中的索引从 0 开始。偏移量相对于 0。
接下来我旋转图像:
convert test.png -background black -rotate 20 test2.png
因此,要计算输出中的 4 个点,我首先需要知道给定旋转角度的输出有多大。
angle=20
ww=300
hh=300
ang=-$angle
wwr=$(convert xc: -format "%[fx:($ww*cos(pi*abs($ang)/180)+$hh*sin(pi*abs($ang)/180))]" info:)
hhr=$(convert xc: -format "%[fx:($ww*sin(pi*abs($ang)/180)+$hh*cos(pi*abs($ang)/180))]" info:)
echo "$wwr x $hhr"
384.514 x 384.514
Rounding to whole numbers, it would be
wwr=385
hhr=385
Note for computing the new dimensions, I use the abs of the sin and cos and all positive signs
接下来,我将 4 个点重新格式化为 X 和 Y 数组,以便稍后处理。
pt1=50,50
pt2=149,50
pt3=149,149
pt4=59,149
list="$pt1 $pt2 $pt3 $pt4"
echo "$list"
i=0
for pt in $list; do
xArr[$i]=$(echo "$pt" | cut -d, -f1)
yArr[$i]=$(echo "$pt" | cut -d, -f2)
i=$((i+1))
done
echo "${xArr[*]}"
50 149 149 59
echo "${yArr[*]}"
50 50 149 149
现在,我计算旋转的 4 个角坐标:
angle=20
xlast=299
ylast=299
wwr=385
hhr=385
for ((i=0; i<4; i++)); do
xr=$(convert xc: -format "%[fx:((${xArr[$i]}-300/2)*cos(pi*$ang/180)+(${yArr[$i]}-300/2)*sin(pi*$ang/180)) + $wwr/2]" info:)
yr=$(convert xc: -format "%[fx:((${yArr[$i]}-300/2)*cos(pi*$ang/180)-(${xArr[$i]}-300/2)*sin(pi*$ang/180)) + $hhr/2]" info:)
echo "$xr,$yr"
done
132.733,64.3287
225.762,98.1887
191.902,191.218
107.33,160.436
您可以在输出图像中测量它们以查看它们是否正确。您可以根据需要四舍五入到整数。
如果您想要矩形边界框,则只需计算 minx、miny、maxx、maxy 值。
推荐阅读
- sharepoint - Sharepoint - 文档的外部存储
- c - char** 和结构的错误(null)
- php - 尝试在没有用户交互 PHP 的情况下从 Reddit 获取 OAuth2 身份验证令牌
- iis-8 - IIS8 通过 SNI 提供错误的证书
- r - 从数据框中提取两行 - r
- android - 在本机反应中同时使用双击和单击
- azure - 如何在 Azure Api 管理服务中管理用户帐户?
- r - 在半对数图上绘制二次方的置信区间
- javascript - Bootstrap datetimepicker 不工作,低于规范:
- java - 如何使用 spring-boot 和 JPA 持久化包含另一个未持久化实体的多个相同实例的新实体?