利用Jung API在eclipse中实现Graph可视化

2024-01-07 15:10

本文主要是介绍利用Jung API在eclipse中实现Graph可视化,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言:
    Jung有一套让Graph实现可视化的API,可是在网络上的使用文档少之又少。故在此记下几个使用方法,来源于http://jung.sourceforge.net/doc/index.html及网上部分使用博客。

一、下载jung api

    http://jung.sourceforge.net/download.html 
    至于如何将jar文件导入eclipse,及如何build path请读者自行Google

二、适配API接口
    
    http://jung.sourceforge.net/doc/api/index.html

    在这里有jung的一系列API描述的接口,总体上而言就是使用Graph<L,E>这样一个泛型的接口,其中L是点的泛型,E为边的泛型。
    

假使现在有一个图: Graph<Vertex,Edge> g  其中Vertex是点,Edge是边 ,那么我建立一个无向多重图如下:

    SparseMultigraph<Vertex, Edge> graph = new SparseMultigraph<Vertex, Edge>();

然后,将g中所有的点、边放入新建的graph图中

for(Vertex v: g.vertices()) {
           graph.addVertex(v);
     }
//无向边
for(Edge e: g.edges()) {
         graph.addEdge(e, e.vertices.get(0),e.vertices.get(1));
    }
//有向边
for(Edge e: g.edges()) {
         graph.addEdge(e, e.vertices.get(0), e.vertices.get(1), EdgeType.DIRECTED);
    }

这样,我们就将自己的图适配好了Jung中所用的图,于是就可以调用JUNG中API进行可视化操作了


三、具体实现

//设置布局 
Layout<Vertex, Edge> layout = new CircleLayout<Vertex, Edge>(graph);
//设置可视化的的观察器,节点、边的信息如何显示、节点和边的颜色、形态都可以在vv中更改 
   VisualizationViewer<Vertex, Edge> vv = new VisualizationViewer<Vertex, Edge>(layout);

//默认显示节点的label
// vv.getRenderContext().setVertexLabelTransformer(new ToStringLabeller<Vertex>());

//或者利用一个Transformer,将节点的类型也显示出来
vv.getRenderContext().setVertexLabelTransformer(new Transformer<>() {
        public String transform(Vertex v) {
         if(v instanceof Word) return "Word "+v.getLabel();
         else if(v instanceof Person) return "Person "+ v.getLabel();
         else if(v instanceof Computer) return "Computer "+ v.getLabel();
         else if(v instanceof Router) return "Router "+ v.getLabel();
         else if(v instanceof Server) return "Server "+ v.getLabel();
         else if(v instanceof WirelessRouter) return "WirelessRouter "+ v.getLabel();
         else if(v instanceof Movie) return "Movie "+ v.getLabel();
         else if(v instanceof Actor) return "Actor "+ v.getLabel();
         else if(v instanceof Director) return "Director "+ v.getLabel();
         else return null;
        }
   });

//设置节点的颜色,利用一个Vertex - Paint 的Transformer
Transformer<Vertex, Paint> vertexPaint = new Transformer<Vertex, Paint>() { 
             public Paint transform(Vertex v) { 
              if(v instanceof Word || v instanceof Person) return Color.RED;
              
     else if(v instanceof Computer) return Color.BLUE;
     else if(v instanceof Router) return Color.GREEN;
     else if(v instanceof Server) return Color.ORANGE;
     else if(v instanceof WirelessRouter) return Color.RED;
              
     else if(v instanceof Movie) return Color.BLUE;
     else if(v instanceof Actor) return Color.RED;
     else if(v instanceof Director) return Color.GREEN;
     else return null;
    }
// 设置顶点颜色
vv.getRenderContext().setVertexFillPaintTransformer(vertexPaint);

//设置边的文本
//vv.getRenderContext().setEdgeLabelTransformer(new ToStringLabeller<Edge>());    默认显示边的label
//利用Transformer,显示边的label 以及 权值
vv.getRenderContext().setEdgeLabelTransformer(new Transformer<>() {
             public String transform(Edge e) {
                 return (e.toString() + " " + e.getWeight());
             }
         });

//在这里edgeStrokeTransformer显示的是虚线
float dash[] = {10.0f};       
       final Stroke edgeStroke = new BasicStroke(1.0f, BasicStroke.CAP_BUTT,            
         BasicStroke.JOIN_MITER, 10.0f, dash, 0.0f);       

       Transformer<Edge, Stroke> edgeStrokeTransformer = new Transformer<Edge, Stroke>() {           
            public Stroke transform(Edge s) {
             if(s instanceof SameMovieHyperEdge) {
                  return edgeStroke;   
             }
                 return null;
                }      
       };
   // 设置边的线型 
         vv.getRenderContext().setEdgeStrokeTransformer(edgeStrokeTransformer); 

//设置模式,默认模式可以拖动节点

   DefaultModalGraphMouse<Vertex, Edge> gm = new DefaultModalGraphMouse<Vertex, Edge>();
   gm.setMode(Mode.PICKING);  
         vv.setGraphMouse(gm);

    //最后是套话,pack 、 visible  
  
         JFrame myframe = new JFrame();
         myframe.getContentPane().add(vv);
         myframe.setExtendedState(JFrame.MAXIMIZED_BOTH);
         myframe.pack();
         myframe.setVisible(true);

这篇关于利用Jung API在eclipse中实现Graph可视化的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/580328

相关文章

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

SpringBoot监控API请求耗时的6中解决解决方案

《SpringBoot监控API请求耗时的6中解决解决方案》本文介绍SpringBoot中记录API请求耗时的6种方案,包括手动埋点、AOP切面、拦截器、Filter、事件监听、Micrometer+... 目录1. 简介2.实战案例2.1 手动记录2.2 自定义AOP记录2.3 拦截器技术2.4 使用Fi

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

PyCharm中配置PyQt的实现步骤

《PyCharm中配置PyQt的实现步骤》PyCharm是JetBrains推出的一款强大的PythonIDE,结合PyQt可以进行pythion高效开发桌面GUI应用程序,本文就来介绍一下PyCha... 目录1. 安装China编程PyQt1.PyQt 核心组件2. 基础 PyQt 应用程序结构3. 使用 Q

Python实现批量提取BLF文件时间戳

《Python实现批量提取BLF文件时间戳》BLF(BinaryLoggingFormat)作为Vector公司推出的CAN总线数据记录格式,被广泛用于存储车辆通信数据,本文将使用Python轻松提取... 目录一、为什么需要批量处理 BLF 文件二、核心代码解析:从文件遍历到数据导出1. 环境准备与依赖库

linux下shell脚本启动jar包实现过程

《linux下shell脚本启动jar包实现过程》确保APP_NAME和LOG_FILE位于目录内,首次启动前需手动创建log文件夹,否则报错,此为个人经验,供参考,欢迎支持脚本之家... 目录linux下shell脚本启动jar包样例1样例2总结linux下shell脚本启动jar包样例1#!/bin

go动态限制并发数量的实现示例

《go动态限制并发数量的实现示例》本文主要介绍了Go并发控制方法,通过带缓冲通道和第三方库实现并发数量限制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录带有缓冲大小的通道使用第三方库其他控制并发的方法因为go从语言层面支持并发,所以面试百分百会问到

Go语言并发之通知退出机制的实现

《Go语言并发之通知退出机制的实现》本文主要介绍了Go语言并发之通知退出机制的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、通知退出机制1.1 进程/main函数退出1.2 通过channel退出1.3 通过cont

Python实现PDF按页分割的技术指南

《Python实现PDF按页分割的技术指南》PDF文件处理是日常工作中的常见需求,特别是当我们需要将大型PDF文档拆分为多个部分时,下面我们就来看看如何使用Python创建一个灵活的PDF分割工具吧... 目录需求分析技术方案工具选择安装依赖完整代码实现使用说明基本用法示例命令输出示例技术亮点实际应用场景扩