在Prefuse上摸打滚爬了一段时间,发现其和蔼可亲,容易上手。但是每每在打开gephi,导入数据再运行时,总还是在心里暗自赞叹 gephi的绚烂之极,无与匹敌,当然,gephi也有自己的缺陷,但是gephi是一个在发展的、进步的、不断壮大的开源软件。纵使她曾经那般伤我,我 仍是对其恋恋不舍,好吧,我已经病入膏肓。。。。。

言归正传,Gephi是一款开源免费跨平台基于JVM的复杂网络分析软件, 其主要用于各种网络和复杂系统,动态和分层图的交互可视化与探测开源工具。可用作:探索性数据分析,链接分析,社交网络分析,生物网络分析等。因为 Gephi是开源软件,所以可以获取其源码,允许开发者去扩展和重复使用。

Gephi开发平台:Netbeans平台(因为之前对于这句话理解不深,在eclipse环境下浪费了不少时间)

开发语言:Java

可视化引擎:OpenGL

贴上gephi做的两张图:

现在,我们就深入Gephi,好好了解下这个strong visual tool,这次我们不走源码,作为过来人,我还是想提醒下,如果java功底不是很扎实或是不太熟悉Netbeans开发平台以及Swing编程知识的可 以走曲线,接近Gephi,否则会让自己焦头烂额,越陷越深,不可自拔^_^。下面通过一个实例,讲解如果新建一个Gephi实例,进行可视化展示:

(1)创建一个project、一个workspace,这是必做的工作,是进行后续操作的前提:

//Init a project - and therefore a workspace

ProjectController pc = Lookup.getDefault().lookup(ProjectController.class);

pc.newProject();

Workspace workspace = pc.getCurrentWorkspace();

(2)得到该空间的各个模型以及控制器,方便后面使用:

//Get models and controllers for this new workspace - will be useful later

AttributeModel attributeModel = Lookup.getDefault().lookup(AttributeController.class).getModel();

GraphModel graphModel = Lookup.getDefault().lookup(GraphController.class).getModel();

PreviewModel model = Lookup.getDefault().lookup(PreviewController.class).getModel();

ImportController importController = Lookup.getDefault().lookup(ImportController.class);

FilterController filterController = Lookup.getDefault().lookup(FilterController.class);

RankingController rankingController = Lookup.getDefault().lookup(RankingController.class);

(3)导入数据,使用Container接收,并将数据导入到空间中:

//Import file

Container container;

try {

File file = new File(getClass().getResource("/org/gephi/toolkit/demos/resources/polblogs.gml").toURI());

container = importController.importFile(file);

container.getLoader().setEdgeDefault(EdgeDefault.DIRECTED); //Force DIRECTED

} catch (Exception ex) {

ex.printStackTrace();

return;

}

//Append imported data to GraphAPI

importController.process(container, new DefaultProcessor(), workspace);

(4)通过打印信息,验证图形数据是否导入成功:

//See if graph is well imported

DirectedGraph graph = graphModel.getDirectedGraph();

System.out.println("Nodes: " + graph.getNodeCount());

System.out.println("Edges: " + graph.getEdgeCount());

(5)对图形数据进行过滤操作:

//Filter

DegreeRangeFilter degreeFilter = new DegreeRangeFilter();

degreeFilter.init(graph);

degreeFilter.setRange(new Range(30, Integer.MAX_VALUE)); //Remove nodes with degree < 30

Query query = filterController.createQuery(degreeFilter);

GraphView view = filterController.filter(query);

graphModel.setVisibleView(view); //Set the filter result as the visible view

(6)通过打印信息,验证过滤操作是否起作用:

//See visible graph stats

UndirectedGraph graphVisible = graphModel.getUndirectedGraphVisible();

System.out.println("Nodes: " + graphVisible.getNodeCount());

System.out.println("Edges: " + graphVisible.getEdgeCount());

(7)执行YifanHuLayout布局算法:

//Run YifanHuLayout for 100 passes - The layout always takes the current visible view

YifanHuLayout layout = new YifanHuLayout(null, new StepDisplacement(1f));

layout.setGraphModel(graphModel);

layout.resetPropertiesValues();

layout.setOptimalDistance(200f);

layout.initAlgo();

for (int i = 0; i < 100 && layout.canAlgo(); i++) {

layout.goAlgo();

}

layout.endAlgo();

(8)根据节点度值分配节点颜色:

//Rank color by Degree

Ranking degreeRanking = rankingController.getModel().getRanking(Ranking.NODE_ELEMENT, Ranking.DEGREE_RANKING);

AbstractColorTransformer colorTransformer = (AbstractColorTransformer) rankingController.getModel().getTransformer(Ranking.NODE_ELEMENT, Transformer.RENDERABLE_COLOR);

colorTransformer.setColors(new Color[]{new Color(0xFEF0D9), new Color(0xB30000)});

rankingController.transform(degreeRanking,colorTransformer);

(9)分配节点大小:

//Rank size by centrality

AttributeColumn centralityColumn = attributeModel.getNodeTable().getColumn(GraphDistance.BETWEENNESS);

Ranking centralityRanking = rankingController.getModel().getRanking(Ranking.NODE_ELEMENT, centralityColumn.getId());

AbstractSizeTransformer sizeTransformer = (AbstractSizeTransformer) rankingController.getModel().getTransformer(Ranking.NODE_ELEMENT, Transformer.RENDERABLE_SIZE);

sizeTransformer.setMinSize(3);

sizeTransformer.setMaxSize(10);

rankingController.transform(centralityRanking,sizeTransformer);

(10)预览效果配置,并呈现到Display上,添加到JFrame,进行界面话展示:

//Preview

PreviewController previewController = Lookup.getDefault().lookup(PreviewController.class);

model.getProperties().putValue(PreviewProperty.SHOW_NODE_LABELS, Boolean.TRUE);

model.getProperties().putValue(PreviewProperty.EDGE_COLOR, new EdgeColor(Color.GRAY));

model.getProperties().putValue(PreviewProperty.EDGE_THICKNESS, new Float(0.1f));

model.getProperties().putValue(PreviewProperty.NODE_LABEL_FONT, model.getProperties().getFontValue(PreviewProperty.NODE_LABEL_FONT).deriveFont(8));

previewController.refreshPreview();

//New Processing target, get the PApplet

ProcessingTarget target = (ProcessingTarget) previewController.getRenderTarget(RenderTarget.PROCESSING_TARGET);

PApplet applet = target.getApplet();

applet.init();

//Refresh the preview and reset the zoom

previewController.render(target);

target.refresh();

target.resetZoom();

//Add the applet to a JFrame and display

JFrame frame = new JFrame("Test Preview");

frame.setLayout(new BorderLayout());

frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

frame.add(applet, BorderLayout.CENTER);

frame.pack();

frame.setVisible(true);

控制台打印信息为:

# Nodes loaded: 1490

# Edges loaded: 19025

Nodes: 1490

Edges: 19025

Nodes: 397

Edges: 10599

执行的结果如下图所示:

了解Prefuse的API以及创建一个Prefuse应用的思路详见《 漫谈可视化Prefuse(二)---一分钟学会Prefuse 》,再回首看Gephi Toolkit创建gephi应用的思路也是如出一辙,后续有时间将继续Gephi Toolkit之旅!

如果觉得有用,欢迎点赞^_^!也欢迎加入公告栏的可视化群。

java 调用gephi_Gephi可视化(一)——使用Gephi Toolkit创建Gephi应用相关推荐

  1. JAVA调用R语言之Rserve(二)

    之前,我写了一篇文章是java调用R语言之Rserve,但我发现那种方法比较麻烦.后来我发现了一个比较方便的方法,所以今天从又写了一篇博客,来简单说说. 这次我们需要写一个简单的R语言脚本,然后通过运 ...

  2. JAVA调用R语言之Rserve

    为什么要用java调用R? Java作为一个非常流行的编程语言,具有功能强大和简单易用两个特征.Java语言作为静态面向对象编程语言的代表,极好地实现了面向对象理论,允许程序员以优雅的思维方式进行复杂 ...

  3. R语言实战应用精讲50篇(十三)-如何使用JAVA调用R语言,两种语言的完美结合

    前言 为什么要用java调用R? Java作为一个非常流行的编程语言,具有功能强大和简单易用两个特征.Java语言作为静态面向对象编程语言的代表,极好地实现了面向对象理论,允许程序员以优雅的思维方式进 ...

  4. java调用ocr识别api_Java文字识别软件-调用百度ocr实现文字识别

    java_baidu_ocr Java调用百度OCR文字识别API实现图片文字识别软件 项目源代码在文末,放到了GitHub上 - https://github.com/Ymy214/java_bai ...

  5. Java调用百度OCR文字识别API实现图片文字识别软件

    java_baidu_ocr Java调用百度OCR文字识别API实现图片文字识别软件 这是一款小巧方便,强大的文字识别软件,由Java编写,配上了窗口界面 调用了百度ocr文字识别API 识别精度高 ...

  6. eclipse java调用c 代码吗_linux下通过eclipse开发用java调用c程序的方法

    linux下通过eclipse开发用java调用c程序的方法: 1.先建立好java工程并建立java文件如下: public class testso {     static {         ...

  7. Java调用C/C++编写的第三方dll动态链接库(zz)

    这里主要用的方法是JNI.在网上查资料时看到很多人说用JNI非常的复杂,不仅要看很多的文档,而且要非常熟悉C/C++编程.恐怕有很多人在看到诸如此类的评论时已经决定绕道用其他方法了.本文将做详细的介绍 ...

  8. 使用JNA,让java调用原生代码

    JNA定义: JNA:java Native Access,是SUN公司开发的基于JNI的框架.JNI使得Java可以调用原生的c或者c++代码. JNA与JNI(Java Native Interf ...

  9. java无阻塞执行脚本,JAVA调用Shell脚本-及阻塞的解决方法

    JAVA调用Shell脚本--及阻塞的解决办法 用java调用shell,使用 Process p=Runtime.getRuntime().exec(String[] cmd); Runtime.e ...

  10. Java 调用Oracle的存储过程

    2019独角兽企业重金招聘Python工程师标准>>> 1.创建存储过程的语句: 1.表结构:①:create table TESTA(A_ID VARCHAR2(10) not n ...

最新文章

  1. 那些做了多少次错了多少次的题目
  2. Win7如何设置多个IP地址
  3. P3952 时间复杂度(模拟)
  4. 算法竞赛入门经典(第二版) | 习题3-5 谜题 (UVa227,Puzzle)(World Finals 1993)
  5. 机器学习】LDA线性判别分析
  6. html清除视频缓存,html清除页面缓存
  7. 对Redis配置中bind的探索
  8. (转载)程序员文史综合题目一(附答案)
  9. Myeclipse.ini 配置
  10. Microsoft JScript提示‘DIRECT’未定义(2014-08-26记)
  11. TypeScript学习笔记(七):模块
  12. Appium Server
  13. eas账号是什么意思_请问帐号和账号有什么区别,具体怎么用?
  14. 会议一体机_多媒体会议系统方案
  15. UnityShader入门精要——运动模糊
  16. 祥云杯2020 Crypto wp
  17. 电磁波的达朗贝尔方程 工程电磁场P25
  18. 使用插入排序、归并排序对链表进行排序
  19. python生存分析入门
  20. Codeforces Global Round 8

热门文章

  1. css3 实现星空动画 -- 星星闪烁 - 流星划过 - 月亮上升
  2. macbook proa1708_Macbook pro2017 a1708转接卡更换大容量硬盘
  3. python exec 函数_Python之浅谈exec函数
  4. Vulkan_Ray Tracing 01_API基础
  5. 解决linux:docker-compose: Permission denied
  6. ie11 java_如何在IE11运行Java小程序(Applet)
  7. WannaCry 勒索软件
  8. 微博怎么批量取消所有的关注
  9. SPI配置高精度采集8通道24位ADS1256(卷一---datasheet阅读总结篇)
  10. IE浏览器闪退、自动打开Edge浏览器