Files

293 lines
16 KiB
Markdown
Raw Permalink Normal View History

2022-06-22 12:12:33 +00:00
本画板在WPF-Diagram-Designer的基础上进行的开发界面框架使用Fluent.Ribbon的框架。
## AIStudio框架汇总[https://gitee.com/akwkevin/aistudio.-introduce](https://gitee.com/akwkevin/aistudio.-introduce)
## B站介绍https://space.bilibili.com/1945893528
## 写在前面
友情提示 很多朋友老问为什么编译不过去您需要安装对应的net版本或者修改工程的net版本如下图。
![输入图片说明](Images/help.png)
2022-06-22 12:12:33 +00:00
## 2023年5月17日更新内容(做一个画笔画板)
![输入图片说明](Images/66.gif)
### 更新内容如下
- [1] 画笔实现
- [2] 封闭画笔实现
- [3] 钢笔实现
- [4] 文字画笔
- [5] 直线,矩形,椭圆
- [6] Path形状
- [7] 取色器
- [8] 三种画笔可选
### 画笔示例入口
![输入图片说明](Images/drawingdemo1.png)
![输入图片说明](Images/drawing.png)
### 画笔示例截图
![输入图片说明](Images/drawingdemo2.png)
## 2023年4月5号更新内容本次更新主要仿照百度脑图
### 1.思维导图、目录组织图、鱼骨头图、逻辑结构图、组织结构图,入口在文件新建下。
![输入图片说明](Images/c022f4a4-f474-4a94-8730-22f7eadda2c4.png)
### 2.思维导图工具栏(只有思维导图模式下可见)
![输入图片说明](Images/a16723ba-2e88-4391-b9b0-5361ecc7741b.png)
#### 2.1插入链接
![输入图片说明](Images/3db9354c-3a9d-4c66-940a-cedb2d776022.png)
#### 2.2插入图片
![输入图片说明](Images/761b291d-472c-4883-8c17-6e6466df0d0b.png)
#### 2.3插入备注
![输入图片说明](Images/cab534e3-9230-47ce-b1aa-2471a3d7f6b2.png)
#### 2.4插入优先级
![输入图片说明](Images/c99448f6-2342-4a19-a263-3723df7bdda7.png)
#### 2.5插入进度
![输入图片说明](Images/47ccfe90-9156-43e5-8d19-fe8520979fba.png)
#### 2.6切换类型
![输入图片说明](Images/34506c6e-0318-4408-80f1-49a2f1bddf0d.png)
![输入图片说明](Images/2d05d1a4-752a-4789-a98c-a16bc8da0733.png)
![输入图片说明](Images/4d22ce80-0521-4bd7-85d9-eab8a442cc12.png)
![输入图片说明](Images/cefd98ca-3809-48f1-9e23-a8f408046f2d.png)
#### 2.7切换主题
![输入图片说明](Images/1cf93bdc-c9bb-4b59-b385-4bd87b6c9d8a.png)
![输入图片说明](Images/5341f7e9-4e13-4c16-a137-82502ee57483.png)
![输入图片说明](Images/7e7dc7b9-2bcf-4bf9-8411-87d0aec9596a.png)
![输入图片说明](Images/07137f85-c85d-4712-9f4b-ba0ec2358565.png)
![输入图片说明](Images/d2b38816-aae2-438d-b89c-ba86225c57b4.png)
![输入图片说明](Images/33ce6c3e-3840-439e-b713-c0278671ba9a.png)
#### 2.8还有展开节点,全选,居中,适应窗体大小等功能,不在介绍。
### 3 添加搜索功能(不仅仅思维导图可以使用)
![输入图片说明](Images/08a182af-6eaa-4291-9007-3017ec6b2995.png)
### 4 MindEditor最后为了方便大家使用我封装了一个思维脑图的控件MindEditor可以直接绑定json格式的数据数据改变可以直接加载应用。见[AIStudio.Wpf.DiagramDesigner.Demo](https://gitee.com/akwkevin/aistudio.-wpf.-diagram/tree/master/Demos/AIStudio.Wpf.DiagramDesigner.Demo)
![输入图片说明](Images/8a8d5ead-a780-4b06-92d4-09dd1677c2fb.png)
## 2023年2月5号更新内容
本次更新主要参照了一个Blazor的Diagram的画线算法链接地址:[https://github.com/Blazor-Diagrams/Blazor.Diagrams](https://github.com/Blazor-Diagrams/Blazor.Diagrams),感谢作者。
### 1.连线改进新增连线算法目前共4种连线Smooth曲线Straight直线Boundary网格边界连接模式Corner折线
### 2.序列化改进xml与json序列化新增自定义元素后无需更改根元素只需要在新增的元素上添加序列化的对象即可扩展性更灵活了。
### 3.箭头改进箭头按照连线的实际角度显示即0-360度还支持自定义的箭头path。
### 4.新增快捷键自定义扩展,用户可根据自己的习惯定义快捷键。
### 5.FlowchartEditor封装了一个标准的工作流控件FlowchartEditor具体使用可以参照开源权限管理框架种的用法 [https://gitee.com/akwkevin/aistudio.-wpf.-aclient](https://gitee.com/akwkevin/aistudio.-wpf.-aclient)
nuget地址![输入图片说明](Images/nuget.png)
### 6.连接上添加动画:路径动画效果和线条流动效果。
### 7.改变结构,使用户更容易自定义自己的样式,覆盖系统默认样式。
### 8.从Blazor.Diagrams种引入PortlessLinks直接连接两个node不需要port自动连接节点Snapping按距离最近连接ReconnectLinksToClosestPorts
### 9.新增Demo示例帮助用户快速上手见底部2023年2月5号更新附加说明。
## 2023年之前发布内容
2022-06-22 12:12:33 +00:00
界面图:
本画板在WPF-Diagram-Designer进行的开发界面框架使用Fluent.Ribbon的框架。
界面图:
![输入图片说明](https://images.gitee.com/uploads/images/2021/0723/095141_dbfbe652_4799126.png "4.png")
### 1.支持字体样式,字体颜色,字体阴影,对齐方向,行间距。
2022-06-22 12:12:33 +00:00
### 2.支持复制粘贴剪贴,格式化,撤销重做。
2022-06-22 12:12:33 +00:00
### 3.支持形状绘制。
2022-06-22 12:12:33 +00:00
### 4.连接线
2022-06-22 12:12:33 +00:00
### 5.位置,组合,对齐
2022-06-22 12:12:33 +00:00
### 6.元素翻转,旋转。
2022-06-22 12:12:33 +00:00
### 7.填充颜色,支持线性渐变色,径向渐变色等
2022-06-22 12:12:33 +00:00
### 8.支持箭头样式
2022-06-22 12:12:33 +00:00
### 9.锁定与解锁
2022-06-22 12:12:33 +00:00
### 10.快速样式
2022-06-22 12:12:33 +00:00
### 11.支持矢量文本,二维码
2022-06-22 12:12:33 +00:00
### 12.支持插入图片视频SVG
2022-06-22 12:12:33 +00:00
### 13.支持画板大小,方向,标尺,网格是否显示,画板背景色
2022-06-22 12:12:33 +00:00
### 14.支持流程图(在文件新建下-基本绘图-流程图)
2022-06-22 12:12:33 +00:00
![输入图片说明](https://images.gitee.com/uploads/images/2021/0723/095156_62819165_4799126.png "1.png")
![输入图片说明](https://images.gitee.com/uploads/images/2021/0723/095209_6cdce752_4799126.png "2.png")
### 15支持逻辑图在文件新建下-基本绘图-逻辑图)
2022-06-22 12:12:33 +00:00
![输入图片说明](https://images.gitee.com/uploads/images/2021/0723/095226_36478a7b_4799126.png "3.png")
### 16支持SFC顺序控制图在文件新建下-基本绘图-顺序控制图)
2022-06-22 12:12:33 +00:00
![输入图片说明](https://images.gitee.com/uploads/images/2021/0802/215025_4aa32824_4799126.png "2 (2).png")
### 示例项目说明([AIStudio.Wpf.DiagramDesigner.Demo](https://gitee.com/akwkevin/aistudio.-wpf.-diagram/tree/master/Demos/AIStudio.Wpf.DiagramDesigner.Demo))目录如下:
#### 1 Simple 简单示例
![输入图片说明](Images/image.png)
#### 2 Locked 锁定节点
#### 3 Events 事件(暂未完成,敬请期待)
#### 4 DynamicInsertions 动态插入(暂未完成,敬请期待)
#### 5 Performance 性能100个节点生成
#### 6 Zoom 放大缩小
#### 7 SnapToGrid 对齐到网格
![输入图片说明](Images/snaptogrid.png)
#### 8 DragAndDrop 拖拽
![输入图片说明](Images/draganddrop.png)
#### 9 Nodes 节点示例
##### 9.1 Svg svg样式
![输入图片说明](Images/svg.png)
##### 9.2 CustomDefinedNode 自定义节点
![输入图片说明](Images/customdefinednode.png)
##### 9.3 PortlessLinks 无Port的node连接
![输入图片说明](Images/portlesslink.png)
##### 9.4 GradientNode 渐变色node
![输入图片说明](Images/gradinetnode.png)
##### 9.5 Rotate 旋转node连接线还需要优化还算连接在旋转之前的位置上
![输入图片说明](Images/rotate.png)
#### 10 Links 连线示例
##### 10.1 Snapping 连接线靠近节点自动连接
##### 10.2 Labels 连接线上的文字(支持多处)
![输入图片说明](Images/labels.png)
##### 10.3 Vertices 连接线上的中间节点
![输入图片说明](Images/vertices.png)
##### 10.4 Markers 箭头,支持自定义
![输入图片说明](Images/markers.png)
##### 10.5 Routers 连线模式
![输入图片说明](Images/routers.png)
##### 10.6 PathGenerators 连线算法
![输入图片说明](Images/pathgenerators.png)
#### 11 Ports 连接点示例
##### 11.1 ColoredPort 彩色连接点,相同颜色的连接点才能连接
![输入图片说明](Images/coloredport.png)
##### 11.2 InnerPort 内部连接点
![输入图片说明](Images/innerport.png)
#### 12 Groups 分组示例
##### 12.1 Group 分组
##### 12.2 CustomDefinedGroup 自定义分组
##### 12.3 CustomShortcutGroup 自定义分组快捷键
#### 13 Texts 文本节点示例
##### 13.1 Text 文本
##### 13.2 Alignment 对齐方式
##### 13.3 FontSize 字体大小
##### 13.4 ColorText 彩色字体
![输入图片说明](Images/colortext.png)
##### 13.5 OutlineText 轮廓文本
#### 14 Customization 自定义
##### 14.1 CustomNode 覆盖默认节点样式
![输入图片说明](Images/customnode.png)
##### 14.2 CustomLink 设置线条连接样式
![输入图片说明](Images/customlink.png)
##### 14.3 CustomPort 覆盖默认连接点样式
![输入图片说明](Images/customport.png)
##### 14.4 CustomGroup 覆盖默认分组样式
![输入图片说明](Images/customgroup.png)
#### 15 Algorithms 算法
##### 14.6 ReconnectLinksToClosestPorts 重新计算,按最近的连接点连接。
#### 15 Animations
##### 15.1 PathAnimation 动画路径
![输入图片说明](Images/11.gif)
##### 15.2 LineAnimation 线条流动动画
![输入图片说明](Images/22.gif)
#### 16 Editor
##### 16.1 FlowchartEditor 工作流封装控件
采用兼容主流的diagram的序列化格式
![输入图片说明](Images/flowcharteditor.png)
`{"Nodes":[{"Kind":1,"UserIds":null,"RoleIds":null,"ActType":null,"Id":"e0f2c29c-2c89-4c0c-857e-35eb0b121d7e","ParentId":null,"Name":null,"Color":"#1890ff","Label":"开始","Width":100.0,"Height":80.0,"X":12.5,"Y":147.5,"Type":"FlowchartNode","ZIndex":0,"PortAlignmentList":["Top","Bottom","Left","Right","Top","Bottom","Left","Right"]},{"Kind":3,"UserIds":[],"RoleIds":[],"ActType":null,"Id":"716f64ec-bcdb-438c-9748-9546abf990cc","ParentId":null,"Name":null,"Color":"#1890ff","Label":"节点1","Width":100.0,"Height":80.0,"X":137.5,"Y":147.5,"Type":"FlowchartNode","ZIndex":2,"PortAlignmentList":["Top","Bottom","Left","Right","Top","Bottom","Left","Right"]},{"Kind":4,"UserIds":null,"RoleIds":null,"ActType":null,"Id":"3cd6c332-6b5b-44ef-96c4-c7aef66fd5dd","ParentId":null,"Name":null,"Color":"#1890ff","Label":"条件节点","Width":100.0,"Height":80.0,"X":262.5,"Y":147.5,"Type":"FlowchartNode","ZIndex":3,"PortAlignmentList":["Top","Bottom","Left","Right","Top","Bottom","Left","Right"]},{"Kind":3,"UserIds":[],"RoleIds":[],"ActType":null,"Id":"7d953234-ddff-4701-a52a-bf6460ffa7b9","ParentId":null,"Name":null,"Color":"#1890ff","Label":"节点2","Width":100.0,"Height":80.0,"X":387.5,"Y":22.5,"Type":"FlowchartNode","ZIndex":6,"PortAlignmentList":["Top","Bottom","Left","Right","Top","Bottom","Left","Right"]},{"Kind":3,"UserIds":[],"RoleIds":[],"ActType":null,"Id":"7dfd4102-2751-42c7-a386-adcfcca27ede","ParentId":null,"Name":null,"Color":"#1890ff","Label":"节点3","Width":100.0,"Height":80.0,"X":387.5,"Y":272.5,"Type":"FlowchartNode","ZIndex":7,"PortAlignmentList":["Top","Bottom","Left","Right","Top","Bottom","Left","Right"]},{"Kind":2,"UserIds":null,"RoleIds":null,"ActType":null,"Id":"ad57e53f-8860-4212-9afb-f67e14eecbc8","ParentId":null,"Name":null,"Color":"#1890ff","Label":"结束","Width":100.0,"Height":80.0,"X":512.5,"Y":147.5,"Type":"FlowchartNode","ZIndex":10,"PortAlignmentList":["Top","Bottom","Left","Right","Top","Bottom","Left","Right"]}],"Links":[{"Id":"65f6432f-2084-462d-93d8-a6b3ff889182","Color":"#FF808080","SelectedColor":"#FF000000","Width":2.0,"Label":null,"SourceId":"e0f2c29c-2c89-4c0c-857e-35eb0b121d7e","TargetId":"716f64ec-bcdb-438c-9748-9546abf990cc","SourcePortAlignment":"Right","TargetPortAlignment":"Left","Type":"DiagramLink","Router":null,"PathGenerator":null,"SourceMarkerPath":null,"SourceMarkerWidth":null,"TargetMarkerPath":null,"TargetMarkerWidth":null},{"Id":"7d1dcf2d-ee69-4c24-84ff-3a99b6555692","Color":"#FF808080","SelectedColor":"#FF000000","Width":2.0,"Label":null,"SourceId":"716f64ec-bcdb-438c-9748-9546abf990cc","TargetId":"3cd6c332-6b5b-44ef-96c4-c7aef66fd5dd","SourcePortAlignment":"Right","TargetPortAlignment":"Left","Type":"DiagramLink","Router":null,"PathGenerator":null,"SourceMarkerPath":null,"SourceMarkerWidth":null,"TargetMarkerPath":null,"TargetMarkerWidth":null},{"Id":"cd18c02f-0cdb-4eb5-9793-b9db87eeea09","Color":"#FF808080","SelectedColor":"#FF000000","Width":2.0,"Label":"条件1","SourceId":"3cd6c332-6b5b-44ef-96c4-c7aef66fd5dd","TargetId":"7d953234-ddff-4701-a52a-bf6460ffa7b9","SourcePortAlignment":"Top","TargetPortAlignment":"Left","Type":"DiagramLink","Router":null,"PathGenerator":null,"SourceMarkerPath":null,"SourceMarkerWidth":null,"TargetMarkerPath":null,"TargetMarkerWidth":null},{"Id":"69bbb083-8eb4-403b-937a-b0f0d3c80eb0","Color":"#FF808080","SelectedColor":"#FF000000","Width":2.0,"Label":"条件2","SourceId":"3cd6c332-6b5b-44ef-96c4-c7aef66fd5dd","TargetId":"7dfd4102-2751-42c7-a386-adcfcca27ede","SourcePortAlignment":"Bottom","TargetPortAlignment":"Left","Type":"DiagramLink","Router":null,"PathGenerator":null,"SourceMarkerPath":null,"SourceMarkerWidth":null,"TargetMarkerPath":null,"TargetMarkerWidth":null},{"Id":"d640c547-5ba8-428c-8d65-74874b1d28bd","Color":"#FF808080","SelectedColor":"#FF000000","Width":2.0,"Label":null,"SourceId":"7d953234-ddff-4701-a52a-bf6460ffa7b9","TargetId":"ad57e53f-8860-4212-9afb-f67e14eecbc8","SourcePortAlignment":"Right","TargetPortAlignment":"Top","Type":"DiagramLink","Router":null,"PathGenerator":null,"SourceMarkerPath":null,"SourceMarkerWidth":nul
近期会持续更新,欢迎大家光临。
##### 最后上一个动画流程图。
![输入图片说明](Images/33.gif)
## 特别说明
### 博客园文章地址 [https://www.cnblogs.com/akwkevin/p/15047453.html](https://www.cnblogs.com/akwkevin/p/15047453.html)
### 用Wpf做一个Diagram画板续2包含封装一个控件FlowchartEditor [https://www.cnblogs.com/akwkevin/p/17093865.html](https://www.cnblogs.com/akwkevin/p/17093865.html)
### 用Wpf做一个思维导图续3-Diagram画板[https://www.cnblogs.com/akwkevin/p/17288814.html](https://www.cnblogs.com/akwkevin/p/17288814.html)
### 用Wpf做一个可编程画板续4-Diagram画板[https://www.cnblogs.com/akwkevin/p/17367212.html](https://www.cnblogs.com/akwkevin/p/17367212.html)
### 用Wpf做一个画笔画板续5-Diagram画板[https://www.cnblogs.com/akwkevin/p/17417546.html](https://www.cnblogs.com/akwkevin/p/17417546.html)
## 捐助 如果您觉得我们的开源软件对你有所帮助,请扫下方二维码打赏我们一杯咖啡,开源不易,感谢您的支持。(可以联系我,在下面添加特别鸣谢,谢谢。)
<img src="Images/90d797c820ea33386617d32c148e1a9.jpg" width=30% >
<img src="Images/da3cc91baa07eb81acebf9fc1246a01.jpg" width=30% >
## 捐赠列表:
![输入图片说明](Images/%E5%BE%AE%E4%BF%A1%E5%9B%BE%E7%89%87_20230825164357.png)
![输入图片说明](Images/1701265907825.png)
![输入图片说明](Images/juan1.png)
![输入图片说明](Images/1731140269863.png)
相关链接地址:
Fluent.Ribbon: https://github.com/fluentribbon/Fluent.Ribbon
WPF-Diagram-Designer:https://github.com/LinRaise/WPF-Diagram-Designer
个人QQ:80267720
QQ技术交流群1:51286643(已满)QQ技术交流群2:51280970如果您还喜欢帮忙点个星谢谢
特别感谢https://dotnet9.com/ 的站长dotnet9。
有想加入开发的朋友可以联系我。