亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

Java多邊形重心計算

2024-07-14 08:43:24
字體:
來源:轉載
供稿:網友

多邊形重心計算

三角形重心

  • 頂點為a,b,c的三角形重心為x = (xa + xb + xc) / 3,y = (ya + yb + yc) / 3

多邊形重心

  • x = (x1w1 + x2w2 + … + xnwn)/W
  • y = (y1w1 + y2w2 + … + ynwn)/W
import org.locationtech.jts.geom.Coordinate;import org.locationtech.jts.geom.Polygon;import org.locationtech.jts.io.ParseException;import java.util.*;import java.util.stream.Collectors;/** * <p>Title : PolygonNodeTriangle </p> * <p>Description : 多邊形自身節點組成三角形</p> * @author huifer * @date 2018/10/15 */public class PolygonNodeTriangle {  private int NUM = 3;  private Set result_p = new HashSet();  public static void main(String[] args) {    //0    double[] point1 = new double[]{0, 0};    //1    double[] point2 = new double[]{10, 0};    //2    double[] point3 = new double[]{20, 0};    //3    double[] point4 = new double[]{10, 10};    List<double[]> allPoint = new ArrayList();    allPoint.add(point1);    allPoint.add(point3);    allPoint.add(point4);    PolygonNodeTriangle polygonCenterPoint = new PolygonNodeTriangle();    // 外圍    Polygon waiwei = polygonCenterPoint.waiwei(point1, point3, point4);    // 節點三角形    List<Polygon> sanjiaoxing = polygonCenterPoint.triangleMothed(allPoint);    // 外圍內所有三角形    List<Polygon> rangeTriangle = polygonCenterPoint.getRangeTriangle(waiwei, sanjiaoxing);    // 重心xy    double[] gravityCenterXY = polygonCenterPoint.getGravityCenterXY(rangeTriangle);    System.out.println(rangeTriangle.size());    System.out.println("================================================");    double[] doubles = polygonCenterPoint. polygonGravityPoint("POLYGON((0 0, 20 0, 10 10, 0 0))");  }  /***   * polygon wkt 計算重心   * @param wkt   * @return   */  private double[] polygonGravityPoint(String wkt) {    if (!wkt.startsWith("POLYGON")) {      return null;    }    Operation operation = new Operation();    // 外圍數據轉 list<double[]>    Polygon waiwei = null;    try {      waiwei = operation.createPolygonByWKT(wkt);    } catch (ParseException e) {      e.printStackTrace();    }    Coordinate[] coordinates = waiwei.getCoordinates();    List<double[]> allP = new ArrayList<>();    Arrays.stream(coordinates).forEach(        s -> {          double nowX = s.x;          double nowY = s.y;          allP.add(new double[]{nowX, nowY});        }    );    List<Polygon> polygons = triangleMothed(allP);    List<Polygon> rangeTriangle1 = getRangeTriangle(waiwei, polygons);    double area = waiwei.getArea();    double[] gravityCenterXY1 = getGravityCenterXY(rangeTriangle1);    return gravityCenterXY1;  }  /***   * 重心值   * @param rangeTriangle   * @return [x, y]   */  private double[] getGravityCenterXY(List<Polygon> rangeTriangle) {    double xArea = 0.0;    double yArea = 0.0;    double aArea = 0.0;    for (Polygon triangle : rangeTriangle) {      Coordinate[] coordinates = triangle.getCoordinates();      double area = triangle.getArea();      double[] oneGR = triangleCenterOfGravity(coordinates[0], coordinates[1], coordinates[2]);      xArea += oneGR[0] * area;      yArea += oneGR[1] * area;      aArea += area;    }    System.out.println("重心X " + xArea / aArea);    System.out.println("重心Y " + yArea / aArea);    return new double[]{xArea / aArea, yArea / aArea};  }  /***   * 范圍內三角形   * @param waiwei   * @param sanjiaoxing   * @return   */  private List<Polygon> getRangeTriangle(Polygon waiwei, List<Polygon> sanjiaoxing) {    List<Polygon> triangle = new ArrayList<>();    // 判斷三角形是否在面內    for (int i = 0; i < sanjiaoxing.size(); i++) {      Polygon polygon = sanjiaoxing.get(i);      boolean within = polygon.within(waiwei);      if (within) {        triangle.add(polygon);      }    }    return triangle;  }  /***   * 三角形重心計算   * @param a   * @param b   * @param c   * @return   */  private double[] triangleCenterOfGravity(Coordinate a, Coordinate b, Coordinate c) {    double gravityX = (a.x + b.x + c.x) / 3;    double gravityY = (a.y + b.y + c.y) / 3;    double[] result = new double[]{gravityX, gravityY};    return result;  }  /***   * 測試用外包圖形   * @return   */  private Polygon waiwei(double[] point1, double[] point3, double[] point4) {    List<double[]> ceshimian = new ArrayList();    ceshimian.add(point1);//    ceshimian.add(point2);//    ceshimian.add(point7);    ceshimian.add(point4);//    ceshimian.add(point6);//    ceshimian.add(point5);    ceshimian.add(point3);    String polygonForList = createPolygonForList(ceshimian);    Operation op = new Operation();    Polygon polygonByWKT = null;    try {      polygonByWKT = op.createPolygonByWKT(polygonForList);      return polygonByWKT;    } catch (ParseException e) {      e.printStackTrace();    }    return null;  }  /***   * 生成所有三角形   * @param allPoint   * @return   */  private List<Polygon> triangleMothed(List<double[]> allPoint) {    // 索引 -> 點坐標    Map<String, double[]> indexOfPoint = new HashMap();    for (int i = 0; i < allPoint.size(); i++) {      indexOfPoint.put(String.valueOf(i), allPoint.get(i));    }    // 排序結果    sort((List) indexOfPoint.keySet().stream().collect(Collectors.toList()), new HashSet());    // 刪除元素相同后的集合    // 所有三角形    List<Polygon> allTriangle = new ArrayList();    for (Object oneDataObj : result_p) {      //這一行數據      Set oneDataList = (Set) oneDataObj;      // 這一行數據的三角形數據      List<double[]> trianglePoint = new ArrayList();      oneDataList.forEach(          s -> trianglePoint.add(indexOfPoint.get(s)          ));      Polygon triangle = createTriangle(trianglePoint);      if (triangle != null) {        allTriangle.add(triangle);      }    }    // 所有三角形結束    return allTriangle;  }  /***   * 從點坐標集合中創建一個面   * @param points   * @return   */  private static String createPolygonForList(List<double[]> points) {    String end = "))";    String res = "POLYGON((";    Operation op = new Operation();    for (double[] point : points) {      String x = Double.toString(point[0]);      String y = Double.toString(point[1]);      res += x + " " + y + ", ";    }    res += Double.toString(points.get(0)[0]) + " " + Double.toString(points.get(0)[1]);    res += end;    try {      op.createPolygonByWKT(res);    } catch (ParseException e) {      e.printStackTrace();    }    return res;  }  /***   * 創建三角形   * @param trianglePoint   * @return polygon   */  private static Polygon createTriangle(List<double[]> trianglePoint) {    Operation op = new Operation();    String triangleWkt;    boolean isTri = isTriangle(trianglePoint);    if (isTri) {      triangleWkt = "POLYGON((" + trianglePoint.get(0)[0] + " " + trianglePoint.get(0)[1] + ", " + trianglePoint.get(1)[0] + " " + trianglePoint.get(1)[1] + ", " + trianglePoint.get(2)[0] + " " + trianglePoint.get(2)[1] + ", " + trianglePoint.get(0)[0] + " " + trianglePoint.get(0)[1] + "))";      try {        Polygon polygonByWKT = op.createPolygonByWKT(triangleWkt);        return polygonByWKT;//        return triangleWkt;      } catch (ParseException e) {        e.printStackTrace();      }    }    return null;  }  /***   * 判斷三角形   * @param trianglePoint   * @return   */  private static boolean isTriangle(List<double[]> trianglePoint) {    double[] doubles = trianglePoint.get(0);    double[] doubles1 = trianglePoint.get(1);    double[] doubles2 = trianglePoint.get(2);    double len = Math.sqrt(Math.pow(doubles[0] - doubles1[0], 2) + Math.pow(doubles[1] - doubles1[1], 2));    double len1 = Math.sqrt(Math.pow(doubles[0] - doubles2[0], 2) + Math.pow(doubles[1] - doubles2[1], 2));    double len2 = Math.sqrt(Math.pow(doubles1[0] - doubles2[0], 2) + Math.pow(doubles1[1] - doubles2[1], 2));    if ((len + len1 > len2) && (len + len2 > len1) && (len1 + len2 > len)) {      return true;    }    return false;  }  /***   * 不重復排列 (元素不相同)   * @param datas   * @param target   */  private void sort(List datas, Set target) {    if (target.size() == this.NUM) {      this.result_p.add(target);      return;    }    for (int i = 0; i < datas.size(); i++) {      List newDatas = new ArrayList(datas);      Set newTarget = new HashSet(target);      newTarget.add(newDatas.get(i));      newDatas.remove(i);      sort(newDatas, newTarget);    }  }}

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品自拍偷拍视频| 国产成人精品日本亚洲| 国产免费观看久久黄| 亚洲性视频网址| 久久免费高清视频| 国产精品视频999| 国产成人精品国内自产拍免费看| 久久久av电影| 51ⅴ精品国产91久久久久久| 久久乐国产精品| 久久久女人电视剧免费播放下载| 在线看欧美日韩| 成人妇女免费播放久久久| 福利视频第一区| 米奇精品一区二区三区在线观看| 国产视频精品一区二区三区| 一本大道香蕉久在线播放29| 日韩亚洲成人av在线| 日韩欧美国产黄色| 亚洲曰本av电影| 国产精品网站视频| 久久久久99精品久久久久| 成人黄色午夜影院| 亚洲午夜av久久乱码| 日韩性生活视频| 国产日韩中文在线| 黑人巨大精品欧美一区免费视频| 午夜免费在线观看精品视频| 日韩在线视频观看正片免费网站| 色狠狠久久aa北条麻妃| 91在线观看免费观看| 91国自产精品中文字幕亚洲| 亚洲国产毛片完整版| 国产欧美最新羞羞视频在线观看| 国产精品亚洲欧美导航| 亚洲第一精品自拍| 亚洲人成伊人成综合网久久久| 亚洲free性xxxx护士白浆| 国产一区二区黄| 7m第一福利500精品视频| 黑人极品videos精品欧美裸| 国产精品一区电影| 欧美大片在线影院| 成人av电影天堂| 国产日韩欧美一二三区| 色综合视频一区中文字幕| 日韩精品在线观看视频| 日本久久久久久久久久久| 久久青草精品视频免费观看| 日韩av在线影院| 欧美华人在线视频| 2018中文字幕一区二区三区| 国产精品欧美日韩久久| 亚洲九九九在线观看| 国产亚洲人成a一在线v站| 国产精品久久久久久久久久免费| 欧美日韩另类视频| 孩xxxx性bbbb欧美| 亚洲精品中文字| 57pao国产精品一区| 国产不卡av在线免费观看| 97免费视频在线| 欧美激情网站在线观看| 色哟哟亚洲精品一区二区| 国内精品视频在线| 亚洲一区二区在线| 欧美日韩国产123| 国产精品视频内| 欧美性生交大片免费| 久久亚洲春色中文字幕| 日韩美女免费视频| 亚洲人成啪啪网站| 久久精品成人一区二区三区| 亚洲视频欧洲视频| 91成人在线播放| 日本精品一区二区三区在线播放视频| 欧美日韩第一视频| 国产精品视频男人的天堂| 日韩禁在线播放| 18一19gay欧美视频网站| 国产精品吹潮在线观看| 欧美尤物巨大精品爽| 亚洲电影免费观看高清完整版在线观看| 欧美日韩第一视频| 8x海外华人永久免费日韩内陆视频| 国产精品视频yy9099| 精品久久久久久中文字幕一区奶水| 国产精品91视频| 亚洲欧美中文日韩在线| 亚洲缚视频在线观看| 中文一区二区视频| 日韩一区在线视频| 一本一本久久a久久精品综合小说| 亚洲精品网址在线观看| 久久精品一偷一偷国产| 亚洲一区二区少妇| 国产日韩一区在线| 国产色综合天天综合网| 亚洲91精品在线观看| 亚洲欧洲黄色网| 欧美精品一二区| 2019亚洲日韩新视频| 日韩成人网免费视频| 亚洲午夜小视频| 欧美激情aaaa| 九九热精品视频| 中文字幕在线精品| 国产精品电影在线观看| 国产精品网红直播| 久久99国产精品自在自在app| 国产亚洲精品va在线观看| 国产精品久久一区| 国产成人一区二| 国产精品久久久久秋霞鲁丝| 日韩中文字幕av| 国产精品视频精品| 亚洲精品美女网站| www.欧美精品| 久久福利视频网| 亚洲黄色免费三级| 久久久97精品| 国产精品美女久久久久av超清| 欧美性猛交99久久久久99按摩| 欧美精品videosex极品1| 色婷婷综合成人| 国产91网红主播在线观看| 亚洲男人的天堂在线播放| 日本欧美黄网站| 成人淫片在线看| 国产精品爽黄69天堂a| 91久久久久久久久久久久久| 日韩经典中文字幕在线观看| 欧美裸体视频网站| 亚洲精品日韩在线| 久久久精品999| 日韩欧美一区二区在线| 亚洲 日韩 国产第一| 久久人91精品久久久久久不卡| 97精品久久久中文字幕免费| www欧美xxxx| 亚洲最大的成人网| 2023亚洲男人天堂| xxx成人少妇69| 久久精品视频va| 伊人久久久久久久久久| 国产69精品久久久| 中文字幕在线视频日韩| 国产一区二区三区日韩欧美| 91久久综合亚洲鲁鲁五月天| 欧美猛男性生活免费| 亚洲欧美日韩第一区| 91夜夜揉人人捏人人添红杏| 亚洲2020天天堂在线观看| 国产亚洲欧美日韩美女| 精品久久久久久久中文字幕| 国产精品青青在线观看爽香蕉| 95av在线视频| 亚洲在线一区二区| 国产精品福利观看| 精品一区二区电影| 久久精品99久久久香蕉| 久久91亚洲精品中文字幕| 欧美精品手机在线| 亚洲男人天堂视频|