日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

最小外接矩形思路以及实现

發布時間:2025/7/25 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 最小外接矩形思路以及实现 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

最小外接矩形

外接矩形計算

對一個凸多邊形進行外接矩形計算,需要知道當前面的最大xy 和最小xy值,即可獲得外接矩形

最小外接矩形計算

對凸多邊形的每一條邊都繪制一個外接矩形求最小面積。下圖展示了計算流程


計算流程

  • 旋轉基礎算法實現

    • 旋轉點基礎
    /*** 旋轉點** @param point 被旋轉的點* @param center 旋轉中心* @param angle 角度* @return 旋轉后坐標*/public static Coordinate get(Coordinate point, Coordinate center, double angle) {double cos = Math.cos(angle);double sin = Math.sin(angle);double x = point.x;double y = point.y;double centerX = center.x;double centerY = center.y;return new Coordinate(centerX + cos * (x - centerX) - sin * (y - centerY),centerY + sin * (x - centerX) + cos * (y - centerY));}
  • 凸包算法實現

    Geometry hull = (new ConvexHull(geom)).getConvexHull();
  • 獲得結果

    public static Polygon get(Geometry geom, GeometryFactory gf) {Geometry hull = (new ConvexHull(geom)).getConvexHull();if (!(hull instanceof Polygon)) {return null;}Polygon convexHull = (Polygon) hull;System.out.println(convexHull);// 直接使用中心值Coordinate c = geom.getCentroid().getCoordinate();System.out.println("==============旋轉基點==============");System.out.println(new GeometryFactory().createPoint(c));System.out.println("==============旋轉基點==============");Coordinate[] coords = convexHull.getExteriorRing().getCoordinates();double minArea = Double.MAX_VALUE;double minAngle = 0;Polygon ssr = null;Coordinate ci = coords[0];Coordinate cii;for (int i = 0; i < coords.length - 1; i++) {cii = coords[i + 1];double angle = Math.atan2(cii.y - ci.y, cii.x - ci.x);Polygon rect = (Polygon) Rotation.get(convexHull, c, -1 * angle, gf).getEnvelope();double area = rect.getArea(); // 此處可以將 rotationPolygon 放到list中求最小值 // Polygon rotationPolygon = Rotation.get(rect, c, angle, gf); // System.out.println(rotationPolygon);if (area < minArea) {minArea = area;ssr = rect;minAngle = angle;}ci = cii;}return Rotation.get(ssr, c, minAngle, gf);}
  • 測試類

    @Testpublic void test() throws Exception{GeometryFactory gf = new GeometryFactory();String wkt = "POLYGON ((87623.0828822501 73753.4143904365,87620.1073981973 73739.213216548,87629.1690996309 73730.4220136646,87641.882531493 73727.3112803367,87643.0997749692 73714.8683470248,87662.0346734872 73725.0120426595,87669.0676357939 73735.1557382941,87655.9484561064 73735.9672339449,87676.9120937514 73747.4634223308,87651.8909778525 73740.8362078495,87659.4649372597 73755.4431295634,87644.4522677204 73748.680665807,87645.5342619215 73760.7178512935,87635.2553170117 73750.9799034842,87630.5215923822 73760.3121034681,87623.0828822501 73753.4143904365))";Polygon read = (Polygon) new WKTReader().read(wkt);Polygon polygon = MinimumBoundingRectangle.get(read, gf);// System.out.println(polygon); // System.out.println(polygon.getArea());}
  • 本文代碼及可視化代碼均放在 gitee 碼云上 歡迎star & fork

    總結

    以上是生活随笔為你收集整理的最小外接矩形思路以及实现的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 国产婷婷久久 | 香蕉视频亚洲 | 国产视频1区2区3区 国产欧美一区二区精品性色99 | 亚洲乱码一区二区三区 | 喷水了…太爽了高h | 裸体黄色片 | 亚洲中文一区二区三区 | 黄色高清在线观看 | 91蜜桃臀久久一区二区 | 久久精品4| 九九综合 | 午夜精品久久久久久久久久 | 一级黄色片网址 | 中文字幕一区二区三区免费视频 | 蜜臀av免费在线观看 | 狠狠一区 | 国产精品边吃奶边做爽 | 天堂中文av在线 | 亚洲图片小说视频 | 三级亚洲 | 婷婷在线免费 | 玖玖在线资源 | 色综合a| 波多野结衣欲乱上班族 | 在线看一区二区 | 蜜桃av噜噜一区二区三区网址 | 色窝网 | 日韩精品视频网 | 日本免费一区二区三区四区 | www奇米影视com | 51福利视频| 日韩视频一二三 | 好吊操精品视频 | 国产免费av片在线 | 亚洲精品国产成人无码 | 国产午夜福利精品 | 午夜小视频网站 | 亚洲成人999 | 狠狠操天天操夜夜操 | 三级艳丽杨钰莹三级 | 熟女视频一区二区三区 | 成年人免费在线视频 | 麻豆精品在线视频 | 欧美福利视频一区二区 | 五月天看片 | 欧美日韩小说 | 青娱乐福利视频 | 国产一级二级三级在线 | 精品婷婷色一区二区三区蜜桃 | 亚洲一级Av无码毛片久久精品 | 欧美www | 黄色精品在线观看 | 天堂网一区| 操碰av| 青青艹在线观看 | 国产二区三区 | 伊人色网站| 日本免费看| 特级丰满少妇一级aaa爱毛片 | 毛片视频软件 | 一呦二呦三呦精品网站 | av天堂一区| 色悠悠在线视频 | 亚洲一级在线播放 | 成人深夜视频在线观看 | 男女操操操 | 91porn破解版| 91看片视频 | 欧美在线激情 | 免费黄色看片网站 | 国产免费a | 亚洲成人v| 人人做人人爱人人爽 | 日韩啪| 黄大色黄大片女爽一次 | 日本在线看 | 日韩国产在线一区 | 中日韩男男gay无套 人人草人人干 | 亚洲一区欧洲二区 | 日干夜干天天干 | 亚洲永久免费精品 | 黄色片网站国产 | 欧美中文字幕一区二区三区 | а√天堂资源官网在线资源 | 又粗又猛又爽又黄少妇视频网站 | 中文字幕亚洲乱码熟女1区2区 | 天天干天天操心 | 亚洲第一成人av | 欧美色啪 | 丰满熟妇人妻中文字幕 | 中国美女洗澡免费看网站 | 中文字幕一区二区av | 欧美日韩国产大片 | 91亚洲精品久久久蜜桃 | 最近中文字幕在线观看视频 | 国产一区二区三区四区五区 | 曰韩av | 99re7| 人妻少妇被粗大爽9797pw |