可视化—gojs 超多超实用经验分享(二)
想了想序号还是接上一篇分享的的序号接着写,如果在本文中没有获取需要的答案,可以移步去看看上一篇的分享。gojs 超多超实用经验分享(一)
22. 指定线段连接到节点的某一个特定的接口上
如果不指定链接点的话,gojs会自动规划一条路径,具体算法还不是很清楚,总之大部分时候按默认的算法规划出来的路径,还是比较美观的,但是当节点比较多且关系复杂的时候,可能会出现几条线路并不是很美观,需要自己动态的调整一下,看下两种写法:
第一种:所有节点均指定相同的出入连接点,关键属性:fromSpot、toSpot
可选值 :Top、 Bottom、Right 、Left 是从节点对应方向的center开始连接, 也可以指定角: TopRight、 TopLeft、BottomRight、BottomLeft
myDiagram.linkTemplate = $(
go.Link,
{
// routing, corner, curve....等属性
fromSpot: go.Spot.Top, // 从上出
toSpot: go.Spot.Bottom // 从下入
},
);
第二种: 根据不同的属性,动态绑定,关键属性:fromSpot、toSpot,关键方法:go.Binding
myDiagram.linkTemplate = $(
go.Link,
{
// routing, corner, curve....等属性
},
new go.Binding("toSpot",'linkto',()=>go.Spot.Top), // 回调函数 返回具体连接点位置
);
var linkDataArray = [
{ from: "A", to: "B",linkto:'Top'}, // 属性名随便,值也随便,上边回调判断的是,linkto字段有没有值
{ from: "B", to: "C",,linkto:'Top'},
];
23. 给节点设置连线端口spot
myDiagram.nodeTemplate =$(
go.Node,
'Auto',
$(
go.Shape,
'RoundedRectangle',
{ fill: '#eee', parameter1: 5, opacity: 0.7, stroke: '#eee' },
),
// 其他Panel / Shape / TextBlock 零件配置
$(go.Panel, 'Vertical', { alignment: go.Spot.TopLeft }, makePort('1')),
$(go.Panel, 'Vertical', { alignment: go.Spot.TopRight }, makePort('2'))
)
nodeDataArray = [{ key: 'A' },{ key: 'B' }]
linkDataArray = [{ from: 'A', to: 'B', frompid: '1', topid: '2'}]
myDiagram.model = new go.GraphLinksModel(nodeDataArray, linkDataArray)
myDiagram.model.linkFromPortIdProperty = 'frompid' // 1
myDiagram.model.linkToPortIdProperty = 'topid' // 2
// 创建端口
function makePort(name) {
var port = $(go.Shape, 'Rectangle', {
fill: 'transparent',
stroke: null,
desiredSize: new go.Size(8, 8),
portId: name,
toMaxLinks: 3,
cursor: 'pointer'
},
new go.Binding('fromSpot', 'xxx', () => go.Spot.Right),
new go.Binding('toSpot', 'xxx', () => go.Spot.Left)
)
var panel = $(go.Panel, 'Horizontal', { margin: new go.Margin(8, 0) })
panel.add(port)
return panel
}
24. 设置折叠面板及部分默认样式
$('PanelExpanderButton', 'COLLAPSIBLE', {
alignment: go.Spot.Right,
_buttonExpandedFigure: 'M0 0 L8 0',
_buttonCollapsedFigure: 'M0 0 L8 0 M4 -4 L4 4',
'ButtonBorder.fill': '#fff',
'ButtonBorder.stroke': '#fff',
width: 15,
height: 15,
margin: 3,
})
25. itemArray 抽离封装引用,面板中设置表格,并给表格设置边框
// 表格数据,用于下方面板中
var fieldTemplate = $(
go.Panel,
'TableRow',
$(
go.TextBlock,
{
margin: new go.Margin(3, 5),
column: 1, // 表格第一列
font: '13px sans-serif',
alignment: go.Spot.Left
},
new go.Binding('text', 'name')
),
$(
go.TextBlock,
{
margin: new go.Margin(3, 5),
column: 2, // 表格第二列
font: 'bold 13px sans-serif',
alignment: go.Spot.Left
},
new go.Binding('text', 'age'),
)
);
// 表格面板
$(
go.Panel,
'Table',
{
name: 'COLLAPSIBLE',
stretch: go.GraphObject.Horizontal,
background: 'white',
defaultAlignment: go.Spot.Left,
itemTemplate: fieldTemplate,
defaultColumnSeparatorStroke: '#ccc', // 列边框
defaultRowSeparatorStroke: '#ccc' // 行边框
},
new go.Binding('itemArray', 'dataList')
)
26. 设置渐变色
const pinkbluegrad= $(go.Brush, 'Linear', { 0: '#F48FB1', 1: '#90CAF9' }) // 粉蓝渐变
$(go.Shape, "Rectangle",{ desiredSize: new go.Size(30, 30), fill: pinkbluegrad, margin: 5 }),
27. 与端口相邻的链路段的长度
myDiagram.linkTemplate = $(
go.Link,
{
// routing ,corner ,... ,
fromEndSegmentLength: 40,
toEndSegmentLength:40
})
28. 设置/关闭选中效果
选中效果,就是节点外层有一层蓝色的边框, 选中的样式也是可以自定义的,详细可以查看下文档,因为我没有用到,所以就没进行记录。
myDiagram.select(myDiagram.findNodeForKey(key)) // 设置选中节点
$( go.Node, 'auto', { selectionAdorned: false}) // 关闭选中节点
29. 画布垂直水平居中
尽量能够保证在画布init之后,在执行,可以在外层加一个定时器
myDiagram.alignDocument(go.Spot.Center, go.Spot.Center)
myDiagram.contentAlignment = go.Spot.Default
myDiagram.commandHandler.scrollToPart(diagram.findNodeForKey(key))
30. 将某一个节点聚焦至画布中心
myDiagram.commandHandler.scrollToPart(myDiagram.findNodeForKey(key))
31. button使用和修改默认样式
还有更多的自定义样式,可以去button.js源码中查看。
$(
'Button',
{
'ButtonBorder.fill': 'white',
'ButtonBorder.stroke': 'white',
_buttonFillOver: '#E0E0E0',
_buttonStrokeOver: '#E0E0E0',
cursor: 'pointer',
maxSize: new go.Size(100, NaN),
minSize: new go.Size(60, NaN),
click: ()=>{} // 建议单独抽离为一个函数
},
$(go.TextBlock, new go.Binding('text'))
),
可视化—gojs 超多超实用经验分享(二)的更多相关文章
- 关于写SpringBoot+Mybatisplus+Shiro项目的经验分享二:问题1
框架: SpringBoot+Mybatisplus+Shiro 简单介绍:关于写SpringBoot+Mybatisplus+Shiro项目的经验分享一:简单介绍 添加时,如果失败,不能正确跳转 c ...
- APICloud超实用经验分享——平台功能
从2016年开始使用APICloud进行app项目开发,到现在也有五六年了.在此过程中伴随着APICloud一起成长,踩过一些坑,自己的技术也提升不少.在APICloud 推出avm框架一年之后,ID ...
- 总结ThinkPHP使用技巧经验分享(二)
循环输出volist 还有别名 iterate 模版赋值:$User = D('User')$list = $User->findAll()$this->assign('list',$li ...
- MySQL 性能优化的最佳20多条经验分享(二)(转)
11. 尽可能的使用 NOT NULL 除非你有一个很特别的原因去使用 NULL 值,你应该总是让你的字段保持 NOT NULL.这看起来好像有点争议,请往下看. 首先,问问你自己"Empt ...
- 关于启用 HTTPS 的一些经验分享(二)
转载: 关于启用 HTTPS 的一些经验分享(二) 几天前,一位朋友问我:都说推荐用 Qualys SSL Labs 这个工具测试 SSL 安全性,为什么有些安全实力很强的大厂家评分也很低?我认为这个 ...
- 【老司机经验】CC2530&STM8S105二合一嵌入式学习板设计思路与经验分享
CC2530&STM8S105二合一嵌入式学习板设计思路与经验分享 1.缘起 这些年来一直在其他公司的实验箱和别人的开发板上进行教学与开发工作,总是觉得功能设计不那么合意.心里突然冒出个 ...
- 好文推荐:转载一篇别人kaggle的经验分享
转载:https://www.toutiao.com/i6435866304363627010/ 笔者参加了由Quora举办的Quora Question Pairs比赛,并且获得了前1%的成绩.这是 ...
- 使用latex撰写博士,硕士学位论文(浙大博士经验分享)
使用latex撰写博士,硕士学位论文(浙大博士经验分享) 浙大博士: 个人感觉,还是要用latex来写.因为之前发过几篇word排版的中文论文,在参考文献的引用.文字格式调整上,实在是难受.如果坚持 ...
- 【干货】Kaggle 数据挖掘比赛经验分享(mark 专业的数据建模过程)
简介 Kaggle 于 2010 年创立,专注数据科学,机器学习竞赛的举办,是全球最大的数据科学社区和数据竞赛平台.笔者从 2013 年开始,陆续参加了多场 Kaggle上面举办的比赛,相继获得了 C ...
- Splunk大数据分析经验分享
转自:http://www.freebuf.com/articles/database/123006.html Splunk大数据分析经验分享:从入门到夺门而逃 Porsche 2016-12-19 ...
随机推荐
- nginx 常见配置案例参考(优化)
在NGINX中,可以通过配置文件和特定的指令来实现权限控制.以下是一些常见的权限控制方法: 使用deny指令: 在NGINX配置文件中,可以使用deny指令来拒绝特定IP地址或IP地址范围的访问.可以 ...
- MySQL面试必备三之事务
本文首发于公众号:Hunter后端 原文链接:MySQL面试必备三之事务 这一篇笔记介绍一下 MySQL 的事务,面试中常被问到关于事务的几个问题如下: 事务是什么 为什么需要事务,事务有什么作用 事 ...
- 基于webapi的websocket聊天室(二)
上一篇 - 基于webapi的websocket聊天室(一) 消息超传缓冲区的问题 在上一篇中我们定义了一个聊天室WebSocketChatRoom.但是每个游客只分配了400个字节的发言缓冲区,大概 ...
- SpringBoot自定义注解失效原因(2022-10-3)
长话短说,我负责的是一个多模块项目,接手的时候没有注意 @ComponentScan 注解的扫描范围,所以打包的时候,没有扫到我新加包. 所以,重点检查下 @ComponentScan 注解的范围
- 使用 CompeletedFuture 实现异步调用
在我们平时写的项目中,异步调用是一个比较重要的优化手段,在 Java 中,提供了 CompletedFuture 供我们使用,具体实现如下: 例子 假如现在有一个需求,我需要去淘宝.天猫和京东去搜索某 ...
- WPF使用事件聚合器,实现任意页面跨页通信
前言:最近几天有好几个小伙伴玩WPF,遇到不同页面,不知道要怎么传递消息.于是,我今天就来演示一个事件聚合器的玩法,采用prism框架来实现.作为福利,内容附带了主页面打开对话框时候直接通过参数传递消 ...
- 011. jenkins 备份
Jenkins目录介绍 1. 主配置文件: /etc/sysconfig/jenkins 2. Jenkins主目录: /var/lib/jenkins/ [root@node1 plugins]# ...
- DevOps全面综述:从概念到实践
这篇文章详尽介绍了DevOps的背景.核心实践.工具和技术,探讨了团队协作.文化建设及组织变革,旨在帮助企业高效实现持续交付和创新. 关注作者,分享互联网架构.云服务技术的全维度知识.作者拥有10+年 ...
- 搭建高可用k8s
搭建k8s高可用 高可用只针对于api-server,需要用到nginx + keepalived,nginx提供4层负载,keepalived提供vip(虚拟IP) 系统采用openEuler 22 ...
- CF1838A-Blackboard-List
题意简述 在黑板上有两个数字,进行如下操作 \(n-2\) 次: 每次在黑板上选择任意两个数,将两个数的差的绝对值写在黑板上. 这样你会得到一个长度为 \(n (3 \le n \le 100)\) ...