多邊形重心計算
- 三角形重心
頂點為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;
public class PolygonNodeTriangle {
private int NUM = 3;
private Set result_p = new HashSet();
public static void main(String[] args) {
double[] point1 = new double[]{0, 0};
double[] point2 = new double[]{10, 0};
double[] point3 = new double[]{20, 0};
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);
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))");
}
private double[] polygonGravityPoint(String wkt) {
if (!wkt.startsWith("POLYGON")) {
return null;
}
Operation operation = new Operation();
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;
}
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};
}
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;
}
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;
}
private Polygon waiwei(double[] point1, double[] point3, double[] point4) {
List<double[]> ceshimian = new ArrayList();
ceshimian.add(point1);
ceshimian.add(point4);
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;
}
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;
}
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;
}
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;
} catch (ParseException e) {
e.printStackTrace();
}
}
return null;
}
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;
}
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);
}
}
}