<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
因為工作設計到gis相關的內容,需要計算採煤機工作面的中心點。如果套用數學的計算公式,用java去實現,太多麻煩還費時比較久,於是我找到java幾何計算的工具包,幾行程式碼就能求出多變形的中心,簡直yyds!!!
廢話不多說直接上程式碼,然後再慢慢講解
首先再maven專案的pom檔案中引入依賴
<properties> <java.version>1.8</java.version> <maven.plugin.version>3.8.1</maven.plugin.version> <spring.boot.version>2.1.16.RELEASE</spring.boot.version> <bladex.project.version>2.6.0.RELEASE</bladex.project.version> <spring.platform.version>Cairo-SR8</spring.platform.version> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <maven.build.timestamp.format>yyyyMMddHHmmss</maven.build.timestamp.format> <geotools.version>28-SNAPSHOT</geotools.version> </properties> <dependency> <groupId>org.geotools</groupId> <artifactId>gt-main</artifactId> <version>${geotools.version}</version> </dependency>
下面程式碼以四邊形為例,計算面積和中心點
demo1
public static void main(String[] args) { GeometryFactory geometryFactory = JTSFactoryFinder.getGeometryFactory(); CoordinateList coords=new CoordinateList(); coords.add(new Coordinate(3630789.1856605336, 3.943998533907477E7)); coords.add(new Coordinate(3630480.3613995733, 3.944116440724006E7)); coords.add(new Coordinate(3630128.8984496593, 3.944109300504929E7)); coords.add(new Coordinate(3630408.0016770884, 3.943992775038134E7)); //閉合 coords.closeRing(); Polygon polygon = geometryFactory.createPolygon(coords.toCoordinateArray()); //輸出中心點 System.out.println( polygon.getCentroid()); //輸出多邊形面積 System.out.println( polygon.getArea()); }
demo2
public static void main(String[] args) { GeometryFactory geometryFactory = JTSFactoryFinder.getGeometryFactory(); //最後一個點和第一個相同完成多邊形的線段閉合 Coordinate[] coords = new Coordinate[] {new Coordinate(1, 5),new Coordinate(1, 1), new Coordinate(5,1) , new Coordinate(5, 5),new Coordinate(1, 5)}; Polygon polygon = geometryFactory.createPolygon(coords); //輸出中心點 System.out.println( polygon.getCentroid()); //輸出多邊形面積 System.out.println( polygon.getArea()); }
以上程式碼值得注意的有兩點:
1.座標點的順序必須保證是幾何圖形的相鄰點,順時針相連或者逆時針都可以。
2.最後要完成閉合,閉合的方式即最後一個點必須和第一個點相同。
如圖所示,順序按照A->B>C>D,且最後閉合點為A點,即開始和最後輸入點為A點
除了四邊形形,五邊形,六邊形,不規則多邊形,都可以計算。方法和原理一樣。
輸出結果範例
demo1輸出
demo2輸出
到此這篇關於三行Java程式碼實現計算多邊形的幾何中心點的文章就介紹到這了,更多相關Java計算多邊形的幾何中心點內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45