实现流程编排设计器的心路历程

文章讲述了尝试使用AntVX6和低代码引擎构建流程编排设计器的过程,遇到的事件通信和兼容性问题,以及通过定制低代码引擎插件来注册X6画布面板的解决方案,强调了从失败中学习和寻找替代策略的重要性。

接上回《「AntV」使用AntV X6实现流程编排设计器》一文说到,流程编排设计器的实现方案是将低代码引擎和AntV X6作为画布相结合。

为什么会有这样的想法?

可行性

起因是业务中有用到低代码引擎的场景,它的交互形式、页面结构正好符合流程编排设计器的诉求。同时,在阅读低代码引擎文档时,发现设计原理->渲染模块设计->模拟器介绍中有如下介绍:

基于以上思考,我们通过基于沙箱隔离的模拟器技术来实现了多运行时环境(如 React、Rax、小程序、Vue)、多模式(如流式布局、自由布局)、多场景(如页面编排、关系图编排)的 UI 编排。通过注册不同的运行时环境的渲染模块,能够实现编辑器从 React 页面搭建到 Rax 页面搭建的迁移。通过注册不同的模拟器画布,你可以基于 G6 或者 mxgraph 来做关系图编排。你可以定制一个流式布局的画布,也可以定制一个自由布局的画布。

综上可见,使用AntV X6作为画布和低代码引擎结合方案的可行性是没有问题。

那么接下来就是实践了,因为
在这里插入图片描述

于是乎走上了阅读源码,自己探索的道路。

埋头苦干

通过阅读源码,并借鉴Lowcode Engine Vue 渲染器及适配器实现的实现思路,期望也能够基于BuiltinSimulatorRenderer这个桥梁,通过结合Antv X6, 实现Lowcode Engine BPMN(X6)的伟大构想。

不过在近一个月的大量研究、实践、测试后,仅仅是完成了画布的渲染,正常编排交互无法得以解决。

React和Vue的画布(渲染器)是运行在iframe中,存在事件通信等一系列机制。而AntV X6如果也运行在iframe中,本身的拖拽等事件和宿主拖拽等事件存在着各种各样的冲突,即使在尝试修改了低代码引擎的部分源码后,也没有能够完全解决。

在实践过程中,也提过相关的issue,寻求官方解决方案。当时得到的回答是内部方案还在打磨中,并未开源。(PS: 不过在自己项目发布没多久,官方方案图编排扩展就开源了)

虽然失败了,但是也充分学习了画布相关的源代码,了解了其实现原理。

贴一张官方的模拟器架构图,「模拟器Host进程」和iframe中的「模拟器Renderer进程」通信

image.png

睡醒再干

俗话说,在哪里跌倒,就在哪里睡一觉。

睡醒之后,再次寻求解决方案。既然基于底层API搞不了,去上层瞅瞅呢?

低代码引擎本身只包含了最小的内核,而我们所能看到的设计器上的按钮、面板等都是插件提供的。插件是组成设计器的必要部分。通过定制插件,在和低代码引擎解耦的基础上,我们可以和引擎核心模块进行交互,从而满足多样化的功能。

显然画布也不例外。如果把原画布移除,添加自己实现的X6画布,是否可行呢?你还真别说,有一种重见天日,恍然大明白的感觉。

注册默认画布

如下是低代码引擎中注册画布面板的源码实现:

import {
   
    IPublicModelPluginContext } from '@alilc/lowcode-types';
import DesignerPlugin from '@alilc/lowcode-plugin-designer';

// 注册默认的面板
export
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

青菜小王子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值