java - 在两个节点(圆)之间绘制一条边(线)
问题描述
我正在研究一个依赖图,该图由多个节点和从图中一个节点到另一个节点的多个有向边组成。
我试图通过将 n 个节点添加为圆圈和将这些节点之间的边添加为一条线来绘制图形的可视化。
我使用 Java 的图形库以及 JPanel 和 Jframe。
这是目前我所做的代码:
public class LoopUnrolling extends JPanel{
static int length = 5;
static String graph[][] = new String[length][length];
@Override
public void paintComponent(Graphics g){
super.paintComponent(g);
Random random = new Random();
int x1 = random.nextInt(500);
int y1 = random.nextInt(100);
int x2 = random.nextInt(500);
int y2 = random.nextInt(100);
g.setColor(Color.red);
g.drawOval(x1,y1,30,40);
g.drawOval(x2,y2,30,40);
g.drawLine(x1, y1, x2, y2);
}
public static void main(String[] args) {
LoopUnrolling paintObject = new LoopUnrolling();
JFrame jf = new JFrame();
jf.setTitle("Dependancy Graph");
jf.setSize(600,400);
jf.setVisible(true);
jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
jf.add(paintObject);
}
}
我能够画出两个圆圈和一条线,但 我遇到的问题是将这两个圆圈与边缘连接起来。
我在画布上的一个随机位置绘制了每个节点,并希望在这两个节点之间添加一条线。这条线有 Point1(x1,y1) 和 Point2(x2,y2)。这些点应该是两个不同节点(圆)轮廓上的点
解决方案
你有两个带中心的椭圆
cx1 = x1 + w1/2, cy1 = y1 + h1/2
and
cx2 = x2 + w2/2, cy2 = y2 + h2/2
其中 wxx 和 hxx 是椭圆的宽度和高度(的第三个和第四个参数drawOval
)
获取差异向量
dx = cx2 - cx1
dy = cy2 - cy1
规范化它
len = sqrt(dx*dx + dy*dy)
dx = dx / len
dy = dy / len
现在计算圆周上的点
r1 = 0.5 * w1 * h1 / sqrt(w1*w1*dy*dy+h1*h1*dx*dx)
px1 = cx1 + r1 * dx
py1 = cy1 + r1 * dy
r2 = 0.5 * w2 * h2 / sqrt(w2*w2*dy*dy+h2*h2*dx*dx)
px2 = cx2 - r2 * dx
py2 = cy2 - r2 * dy
并画线段(px1,py1)-(px2,py2)
示例Delphi 实现和结果:
推荐阅读
- angular - ngFor 中的 Angular 动态事件名称
- ios - 方括号 [ ] 在这个 swift ui 示例中如何工作?它会将其返回值传递给“i”吗?
- mysql - 无法使用 Unix 套接字从 GCP Cloud Run 连接到 Cloud MySQL
- mysql - 如何将用户 ID 连接到登录用户
- mongoid - 在 Mongoid 中,在查询中使用时如何获取每个元素的第一个文档?
- javascript - 使用带有剩余参数的回调方法类型
- python - 将 python 原始字符串/正则表达式转换为 ruby
- angular - 如何在 ngx-daterangepicker-material 中选择具有相同值的日期范围内的不同日期?
- base64 - URL 解码 - 这到底是什么?
- angular - NGRX - 具有动态子集的应用状态