gpt4 book ai didi

java - 计算两个矩形之间的交点

转载 作者:行者123 更新时间:2023-11-30 08:11:38 24 4
gpt4 key购买 nike

我遇到一个问题,我需要找到两个矩形的交点。我知道这个问题已经被问过here ,但解决方案总是返回一个矩形,而我只需要 2 或 4 个交点

最佳答案

也许这种方法可以满足您的需求

public List<Point> getIntersects(Rectangle2D a, Rectangle2D b) {
if (!a.intersects(b)) return null;
List<Point> points = new ArrayList<Point>();
double ax = a.getX();
double ay = a.getY();
double aw = a.getWidth();
double ah = a.getHeight();
double bx = b.getX();
double by = b.getY();
double bw = b.getWidth();
double bh = b.getHeight();
if (ax <= bx) {
if (ay < by) {
points.add(new Point((int) (ax + aw), (int) by));
points.add(new Point((int) (bx), (int) (ay + ah)));
} else {
points.add(new Point((int) (ax + aw), (int) (by + bw)));
points.add(new Point((int) (bx), (int) (ay)));
}
} else return getIntersects(b, a);
return points;
}

关于java - 计算两个矩形之间的交点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30314665/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com