最小外接矩形

2023-05-16

  1. 得到凸包
    参考上篇文章
  2. 算法思路
    参考这篇文章,链接。依次计算相邻点角度,反向旋转所有凸包点集,计算最小外接正矩形以及面积。往复迭代所有凸包点,得到面积最小的解,反向旋转调整角度即可得到最终解。
    在这里插入图片描述
  3. 参考代码
public void MiniBoundingRect(List<MilPoint> Src, ref RectAngle rectAngle)
{
	double dArea = 0;
	MilPoint ptCnt = new MilPoint();
	CalBoundingRect(Src, ref rectAngle, ref dArea);
	rectAngle.ptCenter.CopyTo(ref ptCnt);

	for (int i = 0; i <= Src.Count; i++)
	{
		RectAngle rectAngleTmp = new RectAngle();
		double dArea_ = 0;
		List<MilPoint> ptsTmp = new List<MilPoint>();
		double angle = Math.Atan2(Src[i % (Src.Count - 1)].y - Src[(i + 1) % (Src.Count - 1)].y, Src[i % (Src.Count - 1)].x - Src[(i + 1) % (Src.Count - 1)].x);

		for (int j = 0; j < Src.Count; j++)
		{
			MilPoint ptTmp = new MilPoint();
			RotatePt(Src[j], ptCnt, ref ptTmp, angle);
			ptsTmp.Add(ptTmp);
		}

		CalBoundingRect(ptsTmp, ref rectAngleTmp, ref dArea_);

		if (dArea_ < dArea)
		{
			RotatePt(rectAngleTmp.ptCenter, ptCnt, ref rectAngle.ptCenter, angle * (-1));
			rectAngle.Width = rectAngleTmp.Width;
			rectAngle.Height = rectAngleTmp.Height;
			rectAngle.Angle = angle / Math.PI * 180 * (-1); // 这里乘-1是为了匹配外部算法角度正方向
			dArea = dArea_;
		}
	}
}

public double Cross(MilPoint a, MilPoint b, MilPoint c)//计算叉积
{
	return (b.x - a.x) * (c.y - a.y) - (c.x - a.x) * (b.y - a.y);
}

public double Dist(MilPoint a, MilPoint b)//计算距离
{
	return Math.Sqrt((a.x - b.x) * (a.x - b.x) * 1.0 + (a.y - b.y) * (a.y - b.y));
}

public void RotatePt(MilPoint nodeSrc, MilPoint nodeCent, ref MilPoint nodeOut, double dangle)
{
	double dX = nodeSrc.x - nodeCent.x;
	double dY = nodeSrc.y - nodeCent.y;
	double dSin = Math.Sin(dangle);
	double dCos = Math.Cos(dangle);

	nodeOut.x = dCos * dX + dSin * dY + nodeCent.x;
	nodeOut.y = dCos * dY - dSin * dX + nodeCent.y;
}

public void CalBoundingRect(List<MilPoint> nodes, ref RectAngle rectAngle, ref double dArea)
{
	MilPoint nodeOutTL = new MilPoint();
	MilPoint nodeOutBR = new MilPoint();

	nodeOutTL.x = nodes[0].x;
	nodeOutTL.y = nodes[0].y;
	nodeOutBR.x = nodes[0].x;
	nodeOutBR.y = nodes[0].y;
	for (int i = 0; i < nodes.Count; i++)
	{
	if (nodes[i].x < nodeOutTL.x)
		nodeOutTL.x = nodes[i].x;
	if (nodes[i].y < nodeOutTL.y)
		nodeOutTL.y = nodes[i].y;

	if (nodes[i].x > nodeOutBR.x)
		nodeOutBR.x = nodes[i].x;
	if (nodes[i].y > nodeOutBR.y)
		nodeOutBR.y = nodes[i].y;
	}
	rectAngle.ptCenter.x = (nodeOutBR.x + nodeOutTL.x) / 2;
	rectAngle.ptCenter.y = (nodeOutBR.y + nodeOutTL.y) / 2;
	rectAngle.Width = Math.Abs(nodeOutBR.x - nodeOutTL.x);
	rectAngle.Height = Math.Abs(nodeOutBR.y - nodeOutTL.y);
	rectAngle.Angle = 0;
	dArea = rectAngle.Width * rectAngle.Height;
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

最小外接矩形 的相关文章

  • Openlayer 计算多个feature的外接矩形,并且缩放到合适的视角显示

    开发gis系统的时候需要点击一个工程然后打开openlayers地图并且将该工程的线条缩放到合适的区域 xff0c 对这个问题的解决方案 xff1a 1 旋转卡壳法求点集的最小覆盖矩形面积以及周长 https www cnblogs com
  • 程序员改变世界,从未如此直观

    万万没想到 xff0c 包博士的代码让一个六岁的小学生哇哇大哭 这个让小学生流眼泪的 科学家代表 有非常漂亮的履历 xff1a 清华大学毕业 博士曾在斯坦福就读 xff0c 他现在是VIPKID的首席AI科学家 xff0c 带领四十多人的产
  • PX4飞控之PWM输出控制

    PX4飞控之PWM输出控制 多旋翼电调如好盈XRotor xff0c DJI通用电调等都支持PWM信号来传输控制信号 常用的400Hz电调信号对应周期2500us xff0c 一般使用高电平时间1000us 2000us为有效信号区间 xf
  • 关于Vue3使用axios的配置教程详解

    一 安装axios 1 npm install axios save 二 配置axios xff0c 添加拦截器 在src目录下新建一个request文件夹 xff0c 在里面新建index ts xff08 或者 js xff09 文件
  • Keyguard上滑解锁流程解析

    2 上滑触摸事件 2 1 Touch down事件 2 2 Touch move事件 2 3 Touch up事件 用户抬起手指 xff0c 产生touch up事件 xff0c PanelView接收到这个事件后会调用endMotionE
  • 为什么同样的方法,你做的品牌火不起来?别人却能脱颖而出?

    要想让品牌快速走红 xff0c 必须做好品牌运营 同样进入红海市场 xff0c 江小白 喜茶 丧茶靠品牌运营 xff0c 快速占据一席之地 同样是知名品牌 xff0c 杜蕾斯靠品牌运营 xff0c 牢牢占据用户心智第一位 xff0c 同类目
  • 约瑟夫环

    7 10 约瑟夫环 xff08 25 分 xff09 N个人围成一圈顺序编号 xff0c 从1号开始按1 2 3 顺序报数 xff0c 报p者退出圈外 xff0c 其余的人再从1 2 3开始报数 xff0c 报p的人再退出圈外 xff0c
  • Can‘t open /dev/sdb1 exclusively. Mounted filesystem? --redhat7.8

    今天在创建pv的时候报了上面那个错误 xff1a root 64 db01 root pvcreate dev sdb1 Can 39 t open dev sdb1 exclusively Mounted filesystem Can 3
  • windows11终端设置字体

    在进行NeoVim编辑器配置时 xff0c 使用lualine和nvim tree的图标无法显示 xff0c 发现原因是因为没有使用Nerd Font字体 xff0c 安装完成后 xff0c 却一直没办法应用在powershell中 找到一
  • ideal 左侧project不显示external libraries

    今天想调试代码时 突然发现 ideal 左侧project不显示external libraries 花了点时间才重新搞定记录一下解决 电脑系统 xff1a MacOS 找到 Library Preferences IntelliJIdea
  • 轻量级线程组件-Quasar

    官网 xff1a http www paralleluniverse co 占用JVM内存小
  • java 对象内存大小统计工具

    1 用于统计Java对象内存大小的jar包 xff1a jol lt Java内测布局查看包 gt lt dependency gt lt groupId gt org openjdk jol lt groupId gt lt artifa
  • python编码处理:unicode字节串转成中文 各种字符串举例说明

    编码问题一直是很头痛的问题 xff1a 当字符串是 xff1a 39 u4e2d u56fd 39 gt gt gt s 61 39 u4e2d u56fd 39 39 u6e05 u534e u5927 u5b66 39 gt gt gt
  • Sql 中 不等于'<>'与 NULL

    在写SQL 条件语句是经常用到 不等于 lt gt 的筛选条件 xff0c 此时要注意此条件会将字段为null的数据也当做满足不等于的条件而将数据筛选掉 例 xff1a 表A A1 B110213NULL 用 select from A w
  • FilterConfig.RegisterGlobalFilters 全局过滤器的用法

    以前不是很清楚 xff0c 记录学习下 xff1a Asp Net MVC4中的全局过滤器 xff0c 可以对整个项目进行全局监控 新建一个MVC4项目 xff0c 可以在global asax文件中看到如下代码 xff1a FilterC
  • js 及jq 点击别的标签触发 a 标签点击事件

    今天写代码时 xff0c 遇到要通过点击别的按钮触发 a 标签的点击事件问题 xff0c 花了点时间才解决 xff0c 记录一下 用js 实现 xff1a 只需在触发事件中直接加入下列代码即可 xff0c 其中ID即为a 标签的ID doc
  • maven编译报错 -source 1.5 中不支持 lambda 表达式

    在用maven编译项目是由于项目中用了jdk 1 8 编译是报错 source 1 5 中不支持 lambda 表达式 xff0c Google找到这篇解决方案 xff0c 记录一下 xff1a 编译时报如下错误 xff1a span cl
  • java jetty 启动设置根路径

    在java学习过程中 xff0c 使用jetty来启动web应用来测试程序 xff0c 默认启动时的访问路径为 xff1a http localhost 8080 项目名 文件路径 xff0c 现需要将访问路径设置为 xff1a http

随机推荐

  • maven reimport 失效

    在用maven构建项目时发现 xff0c 添加新的 dependency 时maven reimport 总是不能将包引入 xff0c 编译时发现报 xff1a cannot access in offline mode 的错 xff0c
  • 业界难题-“跨库分页”的四种方案

    转载来源 xff1a 业界难题 跨库分页 的四种方案 一 需求缘起 分页需求 互联网很多业务都有分页拉取数据 的需求 xff0c 例如 xff1a xff08 1 xff09 微信消息过多时 xff0c 拉取第 N页消息 xff08 2 x
  • repeater合并单元格

    repeater中合并单元格 xff1a 在repeater bind 后直接加入以下代码 xff1a for int i 61 repeater1 Items Count 1 i gt 0 i HtmlTableCell rep prev
  • 在centOS6.8下更新安装gcc4.7.4

    因为科研需要 xff0c 在centOS6 8系统下配置matlab与C混合编程的环境 xff08 用C来调用MATLAB引擎 xff09 MATLAB安装的是R2015b的版本 xff08 之前安装R2014a版本 xff0c 没办法启动
  • C++很难吗?到底有多难?

    C 43 43 他爹Bjarne Stroustrup都曾开玩笑说自己已经搞不懂C 43 43 了 xff0c 他也曾多次表达过C 43 43 似乎已经有点太庞大了 其实也不是说C 43 43 语法多么复杂 xff0c 而是C 43 43
  • 十、Notepad++正则表达式使用

    推荐个正则表达式在线测试的工具http ccmpp com Regex Notepad 43 43 正则表达式使用 2011 01 06 10 01 35 分类 xff1a 文档 标签 xff1a 正则表达式 替换 notepad 43 4
  • ffmpeg分析 之 如何解析mpegts流

    转 xff1a http blog chinaunix net uid 20364597 id 3530284 html ffmpeg分析 之 如何解析mpegts流 2013 03 19 11 02 40 分类 xff1a LINUX 数
  • Spring简介

    一 Spring简介 1 Spring介绍 61 61 简化开发 61 61 xff0c 降低企业级开发的复杂性 61 61 框架整合 61 61 xff0c 高效整合其他技术 xff0c 提高企业级应用开发与运行效率 1 2 spring
  • SVN服务器彻底删除错误提交的版本

    尝试通过以下操作可以删除SVN服务器上错误提交的版本 xff0c 即本次提交 1 首先找到本次提交后生成的版本号 xff0c 例如为 xff1a 16 2 登录到SVN服务器上 xff0c 进入到项目的SVN目录 xff0c 或者找到本地的
  • Linux hosts.allow与hosts.deny文件设置

    redhat as4常用应用之hosts allow和hosts deny 一 概述 这两个文件是tcpd服务器的配置文件 xff0c tcpd服务器可以控制外部IP对本机服务的访问 这两个配置文件的格式如下 xff1a 服务进程名 主机列
  • 01python画的玫瑰

    刚开始学习python xff0c 还处于菜鸟阶段 xff0c 这段时间学习了turtle库 xff0c 纯手工画了一朵玫瑰 xff0c 拿出来与大家分享 xff01 源码地址 xff1a https github com YinZhong
  • 02turtle模块常用函数

    turtle模块函数
  • 04主存储器、BIOS和CMOS存储器

    主存储器 BIOS和CMOS存储器 一 PC AT机内存使用图 二 ROM BIOS 存放在ROM中的系统BIOS程序主要用于计算机开机时执行系统各部分的自检 xff0c 建立系统需要使用的各种配置表 xff0c 例如中断向量表 硬盘参数表
  • 06异常处理

    python的异常处理 python使用try except xff0c 可使程序不因为运行错误而崩溃 结构如下 xff1a try span class hljs tag lt span class hljs title body spa
  • 07turtle库的进阶使用

    turtle库的进阶使用 turtle库以屏幕中心为绘制原点利用代码绘制一棵树 span class hljs keyword import span turtle span class hljs string 34 34 34 plist
  • 01策略模式

    策略模式 最近在看 Head First设计模式 这本书 xff0c 最大的感触就是 xff0c 原来写代码也是有 套路 的 xff0c 刚学了策略模式 xff0c 用C 43 43 实现了一下 xff0c 做个笔记 xff0c 备忘 xf
  • 三十二、git pull简介

    本文整理自 xff1a http web mit edu mkgray project silk root afs sipb project git git doc git pull html http www cnblogs com lb
  • linux驱动开发 - 12_platform 平台驱动模型

    文章目录 platform 平台驱动模型1 platform 总线platform匹配过程 2 platform 驱动platform 驱动框架如下所示 xff1a 3 platform 设备platform 设备信息框架如下所示 xff1
  • RSA加密OpenSSLX509CertificateFactory$ParsingException: Error parsing public key报错解决

    RSA加密OpenSSLX509CertificateFactory ParsingException Error parsing public key报错解决 一 代码 span class token keyword private s
  • 最小外接矩形

    得到凸包 参考上篇文章算法思路 参考这篇文章 xff0c 链接 依次计算相邻点角度 xff0c 反向旋转所有凸包点集 xff0c 计算最小外接正矩形以及面积 往复迭代所有凸包点 xff0c 得到面积最小的解 xff0c 反向旋转调整角度即可