c语言求解三角形的重心,计算几个三角形的重心

该博客介绍如何使用Java的Area类和Path2D来计算两个相交三角形区域的重心。通过将三角形转换为Area对象,进行相交操作,并计算边界点的平均坐标来得到重心。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先,您必须确定您实际想要计算的重心。很明显,当三角形相交(并且重叠区域不应该被计数两次)时,则不计算三角形的重心,而是计算它们交叉区域的重心。

幸运的是,这样一个相交区域可以很容易地用Area类来计算。根据一条评论,你已经有一个描述这个区域的Area。

因此计算此区域重心的一种方法是计算Area所有边界点的平均值。

请注意,这只适用于Area没有孔。

否则,您必须计算Area的面积。

这里是一个可能的实现:

import java.awt.Shape;

import java.awt.geom.Area;

import java.awt.geom.Path2D;

import java.awt.geom.PathIterator;

import java.awt.geom.Point2D;

import java.util.ArrayList;

import java.util.Collection;

import java.util.List;

public class CenterOfGravity

{

public static void main(String[] args)

{

Path2D p0 = new Path2D.Double();

p0.moveTo(100, 100);

p0.lineTo(200, 100);

p0.lineTo(150, 50);

p0.closePath();

Path2D p1 = new Path2D.Double();

p1.moveTo(150, 100);

p1.lineTo(250, 100);

p1.lineTo(200, 50);

p1.closePath();

Area a = new Area();

a.add(new Area(p0));

a.intersect(new Area(p1));

Point2D cog = computeCenterOfGravity(a);

System.out.println(cog);

}

private static Point2D computeCenterOfGravity(Shape shape)

{

return computeAverage(computePoints(shape, 1.0));

}

private static Point2D computeAverage(

Collection extends Point2D> points)

{

double x = 0;

double y = 0;

for (Point2D point : points)

{

x += point.getX();

y += point.getY();

}

if (!points.isEmpty())

{

x /= points.size();

y /= points.size();

}

return new Point2D.Double(x, y);

}

public static List computePoints(

Shape shape, double flatness)

{

List result = new ArrayList();

PathIterator pi = shape.getPathIterator(null, flatness);

double[] coords = new double[6];

while (!pi.isDone())

{

int segment = pi.currentSegment(coords);

switch (segment)

{

case PathIterator.SEG_MOVETO:

case PathIterator.SEG_LINETO:

result.add(new Point2D.Double(coords[0], coords[1]));

break;

case PathIterator.SEG_CLOSE:

break;

case PathIterator.SEG_QUADTO:

case PathIterator.SEG_CUBICTO:

default:

throw new AssertionError(

"Invalid segment in flattened path!");

}

pi.next();

}

return result;

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值