From 999060b67a8fd1358fe9903738204f4b311ff105 Mon Sep 17 00:00:00 2001
From: fengjiayi <12821976+ning_xi@user.noreply.gitee.com>
Date: Mon, 2 Jun 2025 19:17:30 +0800
Subject: [PATCH] =?UTF-8?q?=E5=B0=86=E6=B5=81=E7=A8=8B=E4=BA=8B=E4=BB=B6?=
=?UTF-8?q?=E6=8E=A5=E5=8F=A3=E4=B8=8E=E6=B5=81=E7=A8=8B=E8=BF=90=E8=A1=8C?=
=?UTF-8?q?=E7=8E=AF=E5=A2=83=E8=A7=A3=E8=80=A6=E3=80=82?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
FlowStartTool/FlowEnv.cs | 2 +-
Library/Api/IFlowEnvironment.cs | 115 +++----
NodeFlow/Env/EnvMsgTheme.cs | 4 -
NodeFlow/Env/FlowEnvironment.cs | 132 ++++----
NodeFlow/Env/FlowEnvironmentEvent.cs | 121 +++++++
NodeFlow/Env/LocalFlowEnvironment.cs | 296 +++++++++---------
NodeFlow/Env/MsgControllerOfServer.cs | 12 +-
NodeFlow/Env/RemoteFlowEnvironment.cs | 104 ++----
NodeFlow/Model/Operation/OperationBase.cs | 92 ++++++
NodeFlow/Model/SingleScriptNode.cs | 4 +-
NodeFlow/Services/NodeService.cs | 12 +
.../ViewModel/FlowCallNodeControlViewModel.cs | 4 +-
Workbench/ServiceCollectionExtensions.cs | 2 +-
Workbench/Services/FlowEEForwardingService.cs | 255 +++++++++------
Workbench/Services/FlowNodeService.cs | 16 +-
Workbench/Services/WorkbenchEventService.cs | 6 +-
.../Themes/NodeTreeItemViewControl.xaml.cs | 2 +-
Workbench/ViewModels/FlowLibrarysViewModel.cs | 2 +-
Workbench/Views/FlowCanvasView.xaml.cs | 18 +-
Workbench/Views/ViewCanvasInfoView.xaml | 8 +
Workbench/Views/ViewCanvasInfoView.xaml.cs | 2 +-
Workbench/Views/ViewNodeInfoView.xaml | 8 +
22 files changed, 734 insertions(+), 483 deletions(-)
create mode 100644 NodeFlow/Env/FlowEnvironmentEvent.cs
create mode 100644 NodeFlow/Model/Operation/OperationBase.cs
create mode 100644 NodeFlow/Services/NodeService.cs
diff --git a/FlowStartTool/FlowEnv.cs b/FlowStartTool/FlowEnv.cs
index 822006a..9668d1d 100644
--- a/FlowStartTool/FlowEnv.cs
+++ b/FlowStartTool/FlowEnv.cs
@@ -22,7 +22,7 @@ namespace Serein.FlowStartTool
flowEnvironment.SetUIContextOperation(uIContextOperation);
flowEnvironment.LoadProject(new FlowEnvInfo { Project = flowProjectData }, fileDataPath); // 加载项目
- flowEnvironment.Event.OnEnvOut += (infoType, value) =>
+ flowEnvironment.Event.EnvOutput += (infoType, value) =>
{
Console.WriteLine($"{DateTime.Now} [{infoType}] : {value}{Environment.NewLine}");
};
diff --git a/Library/Api/IFlowEnvironment.cs b/Library/Api/IFlowEnvironment.cs
index bff243e..4e5cd93 100644
--- a/Library/Api/IFlowEnvironment.cs
+++ b/Library/Api/IFlowEnvironment.cs
@@ -120,11 +120,6 @@ namespace Serein.Library.Api
///
public delegate void NodeLocatedHandler(NodeLocatedEventArgs eventArgs);
- ///
- /// 节点移动了(远程插件)
- ///
- ///
- public delegate void NodeMovedHandler(NodeMovedEventArgs eventArgs);
///
/// 远程环境内容输出
@@ -608,30 +603,30 @@ namespace Serein.Library.Api
public string NodeGuid { get; private set; }
}
- ///
+/* ///
/// 节点移动了
///
public class NodeMovedEventArgs : FlowEventArgs
- {
- public NodeMovedEventArgs(string nodeGuid, double x, double y)
{
- this.NodeGuid = nodeGuid;
- this.X = x;
- this.Y = y;
- }
- ///
- /// 节点唯一标识
- ///
- public string NodeGuid { get; private set; }
- ///
- /// 画布上的x坐标
- ///
- public double X { get; private set; }
- ///
- /// 画布上的y坐标
- ///
- public double Y { get; private set; }
- }
+ public NodeMovedEventArgs(string nodeGuid, double x, double y)
+ {
+ this.NodeGuid = nodeGuid;
+ this.X = x;
+ this.Y = y;
+ }
+ ///
+ /// 节点唯一标识
+ ///
+ public string NodeGuid { get; private set; }
+ ///
+ /// 画布上的x坐标
+ ///
+ public double X { get; private set; }
+ ///
+ /// 画布上的y坐标
+ ///
+ public double Y { get; private set; }
+ }*/
#endregion
@@ -645,97 +640,112 @@ namespace Serein.Library.Api
///
/// 加载Dll
///
- event LoadDllHandler OnDllLoad;
+ event LoadDllHandler DllLoad;
///
/// 项目加载完成
///
- event ProjectLoadedHandler OnProjectLoaded;
+ event ProjectLoadedHandler ProjectLoaded;
///
/// 项目准备保存
///
- event ProjectSavingHandler OnProjectSaving;
+ event ProjectSavingHandler ProjectSaving;
///
/// 节点连接属性改变事件
///
- event NodeConnectChangeHandler OnNodeConnectChange;
+ event NodeConnectChangeHandler NodeConnectChanged;
///
/// 增加画布事件
///
- event CanvasCreateHandler OnCanvasCreate;
+ event CanvasCreateHandler CanvasCreated;
///
/// 删除画布事件
///
- event CanvasRemoveHandler OnCanvasRemove;
+ event CanvasRemoveHandler CanvasRemoved;
///
/// 节点创建事件
///
- event NodeCreateHandler OnNodeCreate;
+ event NodeCreateHandler NodeCreated;
///
/// 移除节点事件
///
- event NodeRemoveHandler OnNodeRemove;
+ event NodeRemoveHandler NodeRemoved;
///
/// 节点放置事件
///
- event NodePlaceHandler OnNodePlace;
+ event NodePlaceHandler NodePlace;
///
/// 节点取出事件
///
- event NodeTakeOutHandler OnNodeTakeOut;
+ event NodeTakeOutHandler NodeTakeOut;
///
/// 起始节点变化事件
///
- event StartNodeChangeHandler OnStartNodeChange;
+ event StartNodeChangeHandler StartNodeChanged;
///
/// 流程运行完成事件
///
- event FlowRunCompleteHandler OnFlowRunComplete;
+ event FlowRunCompleteHandler FlowRunComplete;
///
/// 被监视的对象改变事件
///
- event MonitorObjectChangeHandler OnMonitorObjectChange;
+ event MonitorObjectChangeHandler MonitorObjectChanged;
///
/// 节点中断状态变化事件
///
- event NodeInterruptStateChangeHandler OnNodeInterruptStateChange;
+ event NodeInterruptStateChangeHandler NodeInterruptStateChanged;
///
/// 触发中断
///
- event ExpInterruptTriggerHandler OnInterruptTrigger;
+ event ExpInterruptTriggerHandler InterruptTriggered;
///
/// IOC容器发生改变
///
- event IOCMembersChangedHandler OnIOCMembersChanged;
+ event IOCMembersChangedHandler IOCMembersChanged;
///
/// 节点需要定位
///
- event NodeLocatedHandler OnNodeLocated;
+ event NodeLocatedHandler NodeLocated;
- ///
- /// 节点移动了(远程环境)
- ///
- event NodeMovedHandler OnNodeMoved;
///
/// 运行环境输出
///
- event EnvOutHandler OnEnvOut;
+ event EnvOutHandler EnvOutput;
+
+ public void OnDllLoad(LoadDllEventArgs eventArgs);
+ public void OnProjectLoaded(ProjectLoadedEventArgs eventArgs);
+ public void OnProjectSaving(ProjectSavingEventArgs eventArgs);
+ public void OnNodeConnectChanged(NodeConnectChangeEventArgs eventArgs);
+ public void OnCanvasCreated(CanvasCreateEventArgs eventArgs);
+ public void OnCanvasRemoved(CanvasRemoveEventArgs eventArgs);
+ public void OnNodeCreated(NodeCreateEventArgs eventArgs);
+ public void OnNodeRemoved(NodeRemoveEventArgs eventArgs);
+ public void OnNodePlace(NodePlaceEventArgs eventArgs);
+ public void OnNodeTakeOut(NodeTakeOutEventArgs eventArgs);
+ public void OnStartNodeChanged(StartNodeChangeEventArgs eventArgs);
+ public void OnFlowRunComplete(FlowEventArgs eventArgs);
+ public void OnMonitorObjectChanged(MonitorObjectEventArgs eventArgs);
+ public void OnNodeInterruptStateChanged(NodeInterruptStateChangeEventArgs eventArgs);
+ public void OnInterruptTriggered(InterruptTriggerEventArgs eventArgs);
+ public void OnIOCMembersChanged(IOCMembersChangedEventArgs eventArgs);
+ public void OnNodeLocated(NodeLocatedEventArgs eventArgs);
+ public void OnEnvOutput(InfoType type, string value);
}
@@ -904,15 +914,6 @@ namespace Serein.Library.Api
Task RemoveCanvasAsync(string canvasGuid);
- ///
- /// 移动了某个节点(远程插件使用)
- ///
- /// 所在画布
- ///
- ///
- ///
- void MoveNode(string canvasGuid, string nodeGuid, double x, double y);
-
///
/// 设置流程起点节点
///
@@ -1202,7 +1203,7 @@ namespace Serein.Library.Api
/// 节点定位
///
///
- void NodeLocated(string nodeGuid);
+ void NodeLocate(string nodeGuid);
#endregion
}
diff --git a/NodeFlow/Env/EnvMsgTheme.cs b/NodeFlow/Env/EnvMsgTheme.cs
index 146645f..ae7121e 100644
--- a/NodeFlow/Env/EnvMsgTheme.cs
+++ b/NodeFlow/Env/EnvMsgTheme.cs
@@ -34,10 +34,6 @@
///
public const string RemoveCanvas = nameof(RemoveCanvas);
///
- /// 尝试移动某个节点
- ///
- public const string MoveNode = nameof(MoveNode);
- ///
/// 尝试设置流程起点
///
public const string SetStartNode = nameof(SetStartNode);
diff --git a/NodeFlow/Env/FlowEnvironment.cs b/NodeFlow/Env/FlowEnvironment.cs
index 6f6bc2b..1f6b34b 100644
--- a/NodeFlow/Env/FlowEnvironment.cs
+++ b/NodeFlow/Env/FlowEnvironment.cs
@@ -10,14 +10,15 @@ namespace Serein.NodeFlow.Env
///
/// 流程运行环境
///
- public class FlowEnvironment : IFlowEnvironment, IFlowEnvironmentEvent
+ public class FlowEnvironment : IFlowEnvironment
{
public FlowEnvironment()
{
- flowEnvironment = new LocalFlowEnvironment();
+ flowEnvironmentEvent = new FlowEnvironmentEvent();
+ flowEnvironment = new LocalFlowEnvironment(flowEnvironmentEvent);
// 默认使用本地环境
currentFlowEnvironment = flowEnvironment;
- currentFlowEnvironmentEvent = flowEnvironment;
+ currentFlowEnvironmentEvent = flowEnvironmentEvent;
SereinEnv.SetEnv(currentFlowEnvironment);
}
@@ -105,135 +106,128 @@ namespace Serein.NodeFlow.Env
public RunState FlowState { get => currentFlowEnvironment.FlowState; set => currentFlowEnvironment.FlowState = value; }
///
- public event LoadDllHandler OnDllLoad {
- add { currentFlowEnvironmentEvent.OnDllLoad += value; }
- remove { currentFlowEnvironmentEvent.OnDllLoad -= value; }
+ public event LoadDllHandler DllLoad {
+ add { currentFlowEnvironmentEvent.DllLoad += value; }
+ remove { currentFlowEnvironmentEvent.DllLoad -= value; }
}
///
- public event ProjectLoadedHandler OnProjectLoaded
+ public event ProjectLoadedHandler ProjectLoaded
{
- add { currentFlowEnvironmentEvent.OnProjectLoaded += value; }
- remove { currentFlowEnvironmentEvent.OnProjectLoaded -= value; }
+ add { currentFlowEnvironmentEvent.ProjectLoaded += value; }
+ remove { currentFlowEnvironmentEvent.ProjectLoaded -= value; }
}
///
- public event ProjectSavingHandler? OnProjectSaving
+ public event ProjectSavingHandler? ProjectSaving
{
- add { currentFlowEnvironmentEvent.OnProjectSaving += value; }
- remove { currentFlowEnvironmentEvent.OnProjectSaving -= value; }
+ add { currentFlowEnvironmentEvent.ProjectSaving += value; }
+ remove { currentFlowEnvironmentEvent.ProjectSaving -= value; }
}
///
- public event NodeConnectChangeHandler OnNodeConnectChange
+ public event NodeConnectChangeHandler NodeConnectChanged
{
- add { currentFlowEnvironmentEvent.OnNodeConnectChange += value; }
- remove { currentFlowEnvironmentEvent.OnNodeConnectChange -= value; }
+ add { currentFlowEnvironmentEvent.NodeConnectChanged += value; }
+ remove { currentFlowEnvironmentEvent.NodeConnectChanged -= value; }
}
///
- public event CanvasCreateHandler OnCanvasCreate
+ public event CanvasCreateHandler CanvasCreated
{
- add { currentFlowEnvironmentEvent.OnCanvasCreate += value; }
- remove { currentFlowEnvironmentEvent.OnCanvasCreate -= value; }
+ add { currentFlowEnvironmentEvent.CanvasCreated += value; }
+ remove { currentFlowEnvironmentEvent.CanvasCreated -= value; }
}
///
- public event CanvasRemoveHandler OnCanvasRemove
+ public event CanvasRemoveHandler CanvasRemoved
{
- add { currentFlowEnvironmentEvent.OnCanvasRemove += value; }
- remove { currentFlowEnvironmentEvent.OnCanvasRemove -= value; }
+ add { currentFlowEnvironmentEvent.CanvasRemoved += value; }
+ remove { currentFlowEnvironmentEvent.CanvasRemoved -= value; }
}
///
- public event NodeCreateHandler OnNodeCreate
+ public event NodeCreateHandler NodeCreated
{
- add { currentFlowEnvironmentEvent.OnNodeCreate += value; }
- remove { currentFlowEnvironmentEvent.OnNodeCreate -= value; }
+ add { currentFlowEnvironmentEvent.NodeCreated += value; }
+ remove { currentFlowEnvironmentEvent.NodeCreated -= value; }
}
///
- public event NodeRemoveHandler OnNodeRemove
+ public event NodeRemoveHandler NodeRemoved
{
- add { currentFlowEnvironmentEvent.OnNodeRemove += value; }
- remove { currentFlowEnvironmentEvent.OnNodeRemove -= value; }
+ add { currentFlowEnvironmentEvent.NodeRemoved += value; }
+ remove { currentFlowEnvironmentEvent.NodeRemoved -= value; }
}
///
- public event NodePlaceHandler OnNodePlace
+ public event NodePlaceHandler NodePlace
{
- add { currentFlowEnvironmentEvent.OnNodePlace += value; }
- remove { currentFlowEnvironmentEvent.OnNodePlace -= value; }
+ add { currentFlowEnvironmentEvent.NodePlace += value; }
+ remove { currentFlowEnvironmentEvent.NodePlace -= value; }
}
///
- public event NodeTakeOutHandler OnNodeTakeOut
+ public event NodeTakeOutHandler NodeTakeOut
{
- add { currentFlowEnvironmentEvent.OnNodeTakeOut += value; }
- remove { currentFlowEnvironmentEvent.OnNodeTakeOut -= value; }
+ add { currentFlowEnvironmentEvent.NodeTakeOut += value; }
+ remove { currentFlowEnvironmentEvent.NodeTakeOut -= value; }
}
///
- public event StartNodeChangeHandler OnStartNodeChange
+ public event StartNodeChangeHandler StartNodeChanged
{
- add { currentFlowEnvironmentEvent.OnStartNodeChange += value; }
- remove { currentFlowEnvironmentEvent.OnStartNodeChange -= value; }
+ add { currentFlowEnvironmentEvent.StartNodeChanged += value; }
+ remove { currentFlowEnvironmentEvent.StartNodeChanged -= value; }
}
///
- public event FlowRunCompleteHandler OnFlowRunComplete
+ public event FlowRunCompleteHandler FlowRunComplete
{
- add { currentFlowEnvironmentEvent.OnFlowRunComplete += value; }
- remove { currentFlowEnvironmentEvent.OnFlowRunComplete -= value; }
+ add { currentFlowEnvironmentEvent.FlowRunComplete += value; }
+ remove { currentFlowEnvironmentEvent.FlowRunComplete -= value; }
}
///
- public event MonitorObjectChangeHandler OnMonitorObjectChange
+ public event MonitorObjectChangeHandler MonitorObjectChanged
{
- add { currentFlowEnvironmentEvent.OnMonitorObjectChange += value; }
- remove { currentFlowEnvironmentEvent.OnMonitorObjectChange -= value; }
+ add { currentFlowEnvironmentEvent.MonitorObjectChanged += value; }
+ remove { currentFlowEnvironmentEvent.MonitorObjectChanged -= value; }
}
///
- public event NodeInterruptStateChangeHandler OnNodeInterruptStateChange
+ public event NodeInterruptStateChangeHandler NodeInterruptStateChanged
{
- add { currentFlowEnvironmentEvent.OnNodeInterruptStateChange += value; }
- remove { currentFlowEnvironmentEvent.OnNodeInterruptStateChange -= value; }
+ add { currentFlowEnvironmentEvent.NodeInterruptStateChanged += value; }
+ remove { currentFlowEnvironmentEvent.NodeInterruptStateChanged -= value; }
}
///
- public event ExpInterruptTriggerHandler OnInterruptTrigger
+ public event ExpInterruptTriggerHandler InterruptTriggered
{
- add { currentFlowEnvironmentEvent.OnInterruptTrigger += value; }
- remove { currentFlowEnvironmentEvent.OnInterruptTrigger -= value; }
+ add { currentFlowEnvironmentEvent.InterruptTriggered += value; }
+ remove { currentFlowEnvironmentEvent.InterruptTriggered -= value; }
}
///
- public event IOCMembersChangedHandler OnIOCMembersChanged
+ public event IOCMembersChangedHandler IOCMembersChanged
{
- add { currentFlowEnvironmentEvent.OnIOCMembersChanged += value; }
- remove { currentFlowEnvironmentEvent.OnIOCMembersChanged -= value; }
+ add { currentFlowEnvironmentEvent.IOCMembersChanged += value; }
+ remove { currentFlowEnvironmentEvent.IOCMembersChanged -= value; }
}
///
- public event NodeLocatedHandler OnNodeLocated
+ public event NodeLocatedHandler NodeLocated
{
- add { currentFlowEnvironmentEvent.OnNodeLocated += value; }
- remove { currentFlowEnvironmentEvent.OnNodeLocated -= value; }
+ add { currentFlowEnvironmentEvent.NodeLocated += value; }
+ remove { currentFlowEnvironmentEvent.NodeLocated -= value; }
}
///
- public event NodeMovedHandler OnNodeMoved
+ public event EnvOutHandler EnvOutput
{
- add { currentFlowEnvironmentEvent.OnNodeMoved += value; }
- remove { currentFlowEnvironmentEvent.OnNodeMoved -= value; }
- }
-
- ///
- public event EnvOutHandler OnEnvOut
- {
- add { currentFlowEnvironmentEvent.OnEnvOut += value; }
- remove { currentFlowEnvironmentEvent.OnEnvOut -= value; }
+ add { currentFlowEnvironmentEvent.EnvOutput += value; }
+ remove { currentFlowEnvironmentEvent.EnvOutput -= value; }
}
@@ -287,7 +281,7 @@ namespace Serein.NodeFlow.Env
if (isConnect)
{
- remoteFlowEnvironment ??= new RemoteFlowEnvironment(remoteMsgUtil, this.UIContextOperation);
+ remoteFlowEnvironment ??= new RemoteFlowEnvironment(remoteMsgUtil, this.Event, this.UIContextOperation);
currentFlowEnvironment = remoteFlowEnvironment;
}
return (isConnect, remoteMsgUtil);
@@ -380,16 +374,16 @@ namespace Serein.NodeFlow.Env
currentFlowEnvironment.MonitorObjectNotification(nodeGuid, monitorData, sourceType);
}
- ///
+ /*///
public void MoveNode(string canvasGuid, string nodeGuid, double x, double y)
{
currentFlowEnvironment.MoveNode(canvasGuid, nodeGuid, x, y);
}
-
+*/
///
- public void NodeLocated(string nodeGuid)
+ public void NodeLocate(string nodeGuid)
{
- currentFlowEnvironment.NodeLocated(nodeGuid);
+ currentFlowEnvironment.NodeLocate(nodeGuid);
}
///
diff --git a/NodeFlow/Env/FlowEnvironmentEvent.cs b/NodeFlow/Env/FlowEnvironmentEvent.cs
new file mode 100644
index 0000000..ba4f8f2
--- /dev/null
+++ b/NodeFlow/Env/FlowEnvironmentEvent.cs
@@ -0,0 +1,121 @@
+using Serein.Library;
+using Serein.Library.Api;
+
+namespace Serein.NodeFlow.Env
+{
+ public class FlowEnvironmentEvent : IFlowEnvironmentEvent
+ {
+ public event LoadDllHandler DllLoad;
+ public event ProjectLoadedHandler ProjectLoaded;
+ public event ProjectSavingHandler ProjectSaving;
+ public event NodeConnectChangeHandler NodeConnectChanged;
+ public event CanvasCreateHandler CanvasCreated;
+ public event CanvasRemoveHandler CanvasRemoved;
+ public event NodeCreateHandler NodeCreated;
+ public event NodeRemoveHandler NodeRemoved;
+ public event NodePlaceHandler NodePlace;
+ public event NodeTakeOutHandler NodeTakeOut;
+ public event StartNodeChangeHandler StartNodeChanged;
+ public event FlowRunCompleteHandler FlowRunComplete;
+ public event MonitorObjectChangeHandler MonitorObjectChanged;
+ public event NodeInterruptStateChangeHandler NodeInterruptStateChanged;
+ public event ExpInterruptTriggerHandler InterruptTriggered;
+ public event IOCMembersChangedHandler IOCMembersChanged;
+ public event NodeLocatedHandler NodeLocated;
+ public event EnvOutHandler EnvOutput;
+
+ public void OnDllLoad(LoadDllEventArgs eventArgs)
+ {
+ DllLoad.Invoke(eventArgs);
+ }
+
+ public void OnProjectLoaded(ProjectLoadedEventArgs eventArgs)
+ {
+ ProjectLoaded.Invoke(eventArgs);
+ }
+
+ public void OnProjectSaving(ProjectSavingEventArgs eventArgs)
+ {
+ ProjectSaving.Invoke(eventArgs);
+ }
+
+ public void OnNodeConnectChanged(NodeConnectChangeEventArgs eventArgs)
+ {
+ NodeConnectChanged.Invoke(eventArgs);
+ }
+
+ public void OnCanvasCreated(CanvasCreateEventArgs eventArgs)
+ {
+ CanvasCreated.Invoke(eventArgs);
+ }
+
+ public void OnCanvasRemoved(CanvasRemoveEventArgs eventArgs)
+ {
+ CanvasRemoved.Invoke(eventArgs);
+ }
+
+ public void OnNodeCreated(NodeCreateEventArgs eventArgs)
+ {
+ NodeCreated.Invoke(eventArgs);
+ }
+
+ public void OnNodeRemoved(NodeRemoveEventArgs eventArgs)
+ {
+ NodeRemoved.Invoke(eventArgs);
+ }
+
+ public void OnNodePlace(NodePlaceEventArgs eventArgs)
+ {
+ NodePlace.Invoke(eventArgs);
+ }
+
+ public void OnNodeTakeOut(NodeTakeOutEventArgs eventArgs)
+ {
+ NodeTakeOut.Invoke(eventArgs);
+ }
+
+ public void OnStartNodeChanged(StartNodeChangeEventArgs eventArgs)
+ {
+ StartNodeChanged.Invoke(eventArgs);
+ }
+
+ public void OnFlowRunComplete(FlowEventArgs eventArgs)
+ {
+ FlowRunComplete.Invoke(eventArgs);
+ }
+
+ public void OnMonitorObjectChanged(MonitorObjectEventArgs eventArgs)
+ {
+ MonitorObjectChanged.Invoke(eventArgs);
+ }
+
+ public void OnNodeInterruptStateChanged(NodeInterruptStateChangeEventArgs eventArgs)
+ {
+ NodeInterruptStateChanged.Invoke(eventArgs);
+ }
+
+ public void OnInterruptTriggered(InterruptTriggerEventArgs eventArgs)
+ {
+ InterruptTriggered.Invoke(eventArgs);
+ }
+
+ public void OnIOCMembersChanged(IOCMembersChangedEventArgs eventArgs)
+ {
+ IOCMembersChanged.Invoke(eventArgs);
+ }
+
+ public void OnNodeLocated(NodeLocatedEventArgs eventArgs)
+ {
+ NodeLocated.Invoke(eventArgs);
+ }
+
+ public void OnEnvOutput(InfoType type, string value)
+ {
+ EnvOutput.Invoke(type, value);
+ }
+
+
+ }
+
+
+}
diff --git a/NodeFlow/Env/LocalFlowEnvironment.cs b/NodeFlow/Env/LocalFlowEnvironment.cs
index 55e8eed..135bc66 100644
--- a/NodeFlow/Env/LocalFlowEnvironment.cs
+++ b/NodeFlow/Env/LocalFlowEnvironment.cs
@@ -16,12 +16,27 @@ using System.Text;
namespace Serein.NodeFlow.Env
{
+ public class ADmmm
+ {
+ private readonly IFlowEnvironment flowEnvironment;
+ private readonly IFlowEnvironmentEvent flowEnvironmentEvent;
+ public ADmmm(IFlowEnvironment flowEnvironment, IFlowEnvironmentEvent flowEnvironmentEvent)
+ {
+ this.flowEnvironment = flowEnvironment;
+ this.flowEnvironmentEvent = flowEnvironmentEvent;
+
+
+ }
+
+ }
+
+
///
/// 运行环境
///
- public class LocalFlowEnvironment : IFlowEnvironment, IFlowEnvironmentEvent
+ public class LocalFlowEnvironment : IFlowEnvironment/*, IFlowEnvironmentEvent*/
{
///
/// 节点的命名空间
@@ -34,18 +49,19 @@ namespace Serein.NodeFlow.Env
///
/// 流程运行环境
///
- public LocalFlowEnvironment()
+ public LocalFlowEnvironment(IFlowEnvironmentEvent flowEnvironmentEvent)
{
this.sereinIOC = new SereinIOC();
+ this.Event = flowEnvironmentEvent;
this.IsGlobalInterrupt = false;
this.flowTaskManagement = null;
this.sereinIOC.OnIOCMembersChanged += e =>
{
if (OperatingSystem.IsWindows())
{
- UIContextOperation?.Invoke(() => this?.OnIOCMembersChanged?.Invoke(e)); // 监听IOC容器的注册
+ UIContextOperation?.Invoke(() => Event.OnIOCMembersChanged(e)); // 监听IOC容器的注册
}
-
+
};
this.FlowLibraryManagement = new FlowLibraryManagement(this); // 实例化类库管理
this.NodeMVVMManagement = new NodeMVVMManagement();
@@ -68,8 +84,8 @@ namespace Serein.NodeFlow.Env
PersistennceInstance.Add(typeof(IFlowEnvironment), (LocalFlowEnvironment)this); // 缓存流程实例
PersistennceInstance.Add(typeof(ISereinIOC), this); // 缓存容器服务
- ReRegisterPersistennceInstance();
-
+ ReRegisterPersistennceInstance();
+
#endregion
}
@@ -115,10 +131,10 @@ namespace Serein.NodeFlow.Env
#endregion
#region 环境运行事件
- ///
+ /*///
/// 加载Dll
///
- public event LoadDllHandler? OnDllLoad;
+ public event LoadDllHandler? DllLoad;
///
/// 移除DLL
@@ -128,93 +144,88 @@ namespace Serein.NodeFlow.Env
///
/// 项目加载完成
///
- public event ProjectLoadedHandler? OnProjectLoaded;
+ public event ProjectLoadedHandler? ProjectLoaded;
///
/// 项目准备保存
///
- public event ProjectSavingHandler? OnProjectSaving;
+ public event ProjectSavingHandler? ProjectSaving;
///
/// 节点连接属性改变事件
///
- public event NodeConnectChangeHandler? OnNodeConnectChange;
+ public event NodeConnectChangeHandler? NodeConnectChanged;
///
/// 节点创建事件
///
- public event NodeCreateHandler? OnNodeCreate;
+ public event NodeCreateHandler? NodeCreated;
///
/// 移除节点事件
///
- public event NodeRemoveHandler? OnNodeRemove;
+ public event NodeRemoveHandler? NodeRemoved;
///
/// 节点放置事件
///
- public event NodePlaceHandler OnNodePlace;
+ public event NodePlaceHandler NodePlace;
///
/// 节点取出事件
///
- public event NodeTakeOutHandler OnNodeTakeOut;
+ public event NodeTakeOutHandler NodeTakeOut;
///
/// 起始节点变化事件
///
- public event StartNodeChangeHandler? OnStartNodeChange;
+ public event StartNodeChangeHandler? StartNodeChanged;
///
/// 流程运行完成事件
///
- public event FlowRunCompleteHandler? OnFlowRunComplete;
+ public event FlowRunCompleteHandler? FlowRunComplete;
///
/// 被监视的对象改变事件
///
- public event MonitorObjectChangeHandler? OnMonitorObjectChange;
+ public event MonitorObjectChangeHandler? MonitorObjectChanged;
///
/// 节点中断状态改变事件
///
- public event NodeInterruptStateChangeHandler? OnNodeInterruptStateChange;
+ public event NodeInterruptStateChangeHandler? NodeInterruptStateChanged;
///
/// 节点触发了中断
///
- public event ExpInterruptTriggerHandler? OnInterruptTrigger;
+ public event ExpInterruptTriggerHandler? InterruptTriggered;
///
/// 容器改变
///
- public event IOCMembersChangedHandler? OnIOCMembersChanged;
+ public event IOCMembersChangedHandler? IOCMembersChanged;
///
/// 节点需要定位
///
- public event NodeLocatedHandler? OnNodeLocated;
-
- ///
- /// 节点移动了(远程插件)
- ///
- public event NodeMovedHandler? OnNodeMoved;
+ public event NodeLocatedHandler? NodeLocated;
///
/// 运行环境输出
///
- public event EnvOutHandler? OnEnvOut;
+ public event EnvOutHandler? EnvOutput;
///
/// 本地环境添加了画布
///
- public event CanvasCreateHandler OnCanvasCreate;
+ public event CanvasCreateHandler CanvasCreated;
///
/// 本地环境移除了画布
///
- public event CanvasRemoveHandler OnCanvasRemove;
-
+ public event CanvasRemoveHandler CanvasRemoved;
+*/
#endregion
#region 属性
@@ -227,7 +238,7 @@ namespace Serein.NodeFlow.Env
///
/// 流程事件
///
- public IFlowEnvironmentEvent Event { get => this; }
+ public IFlowEnvironmentEvent Event { get; set; }
///
/// UI线程操作类
@@ -242,7 +253,7 @@ namespace Serein.NodeFlow.Env
///
/// 信息输出等级
///
- public InfoClass InfoClass { get ; set ; } = InfoClass.Trivial;
+ public InfoClass InfoClass { get; set; } = InfoClass.Trivial;
///
/// 如果没有全局触发器,且没有循环分支,流程执行完成后自动为 Completion 。
@@ -282,7 +293,7 @@ namespace Serein.NodeFlow.Env
{
get
{
- if(ioc is null)
+ if (ioc is null)
{
ioc = new SereinIOC();
}
@@ -350,10 +361,10 @@ namespace Serein.NodeFlow.Env
{
if (@class >= this.InfoClass)
{
- OnEnvOut?.Invoke(type, message);
+ Event.OnEnvOutput(type, message);
}
//Console.WriteLine($"{DateTime.UtcNow} [{type}] : {message}{Environment.NewLine}");
-
+
}
///
@@ -378,7 +389,7 @@ namespace Serein.NodeFlow.Env
isBreak = true;
}
var count = NodeModels.Values.Count(n => n.CanvasDetails.Guid.Equals(canvasGuid));
- if(count == 0)
+ if (count == 0)
{
SereinEnv.WriteLine(InfoType.WARN, $"画布没有节点,停止运行。{canvasGuid}");
isBreak = true;
@@ -417,7 +428,7 @@ namespace Serein.NodeFlow.Env
}
#endregion
-
+
IOC.Reset();
IOC.Register(); // 注册脚本接口
@@ -428,7 +439,7 @@ namespace Serein.NodeFlow.Env
Flows = flowTasks,
FlowContextPool = new ObjectPool(() => new DynamicContext(this)), // 上下文对象池
AutoRegisterTypes = this.FlowLibraryManagement.GetaAutoRegisterType(), // 需要自动实例化的类型
- InitMds = this.FlowLibraryManagement.GetMdsOnFlowStart(NodeType.Init),
+ InitMds = this.FlowLibraryManagement.GetMdsOnFlowStart(NodeType.Init),
LoadMds = this.FlowLibraryManagement.GetMdsOnFlowStart(NodeType.Loading),
ExitMds = this.FlowLibraryManagement.GetMdsOnFlowStart(NodeType.Exit),
};
@@ -447,16 +458,16 @@ namespace Serein.NodeFlow.Env
}
finally
{
-
+
SereinEnv.WriteLine(InfoType.INFO, $"流程运行完毕{Environment.NewLine}"); ;
}
flowTaskOptions = null;
return true;
-
-
+
+
}
-
+
///
/// 从选定节点开始运行
///
@@ -472,8 +483,8 @@ namespace Serein.NodeFlow.Env
}
if (true || FlowState == RunState.Running || FlipFlopState == RunState.Running)
{
-
- if (!TryGetNodeModel(startNodeGuid,out var nodeModel) || nodeModel is SingleFlipflopNode)
+
+ if (!TryGetNodeModel(startNodeGuid, out var nodeModel) || nodeModel is SingleFlipflopNode)
{
return false;
}
@@ -509,7 +520,7 @@ namespace Serein.NodeFlow.Env
public Task ExitFlowAsync()
{
flowTaskManagement?.Exit();
- UIContextOperation?.Invoke(() => OnFlowRunComplete?.Invoke(new FlowEventArgs()));
+ UIContextOperation?.Invoke(() => Event.OnFlowRunComplete(new FlowEventArgs()));
IOC.Reset();
flowTaskManagement = null;
GC.Collect();
@@ -522,7 +533,7 @@ namespace Serein.NodeFlow.Env
///
public void ActivateFlipflopNode(string nodeGuid)
{
- if(!TryGetNodeModel(nodeGuid, out var nodeModel))
+ if (!TryGetNodeModel(nodeGuid, out var nodeModel))
{
return;
}
@@ -544,7 +555,7 @@ namespace Serein.NodeFlow.Env
///
public void TerminateFlipflopNode(string nodeGuid)
{
- if(!TryGetNodeModel(nodeGuid, out var nodeModel))
+ if (!TryGetNodeModel(nodeGuid, out var nodeModel))
{
return;
}
@@ -579,8 +590,8 @@ namespace Serein.NodeFlow.Env
///
public void SaveProject()
{
- var project = GetProjectInfoAsync().GetAwaiter().GetResult();
- OnProjectSaving?.Invoke(new ProjectSavingEventArgs(project));
+ var project = GetProjectInfoAsync().GetAwaiter().GetResult();
+ Event.OnProjectSaving(new ProjectSavingEventArgs(project));
}
///
@@ -605,10 +616,10 @@ namespace Serein.NodeFlow.Env
LoadLibrary(dllFilePath); // 加载项目文件时加载对应的程序集
}
-
- _ = Task.Run( async () =>
- {
+
+ _ = Task.Run(async () =>
+ {
// 加载画布
foreach (var canvasInfo in projectData.Canvass)
{
@@ -695,7 +706,7 @@ namespace Serein.NodeFlow.Env
///
public void LoadLibrary(string dllPath)
{
-
+
try
{
#region 检查是否已经加载本地依赖
@@ -703,16 +714,16 @@ namespace Serein.NodeFlow.Env
var thisAssemblyName = thisAssembly.GetName().Name;
if (!string.IsNullOrEmpty(thisAssemblyName) && FlowLibraryManagement.GetLibraryMdsOfAssmbly(thisAssemblyName).Count == 0)
{
- var tmp = FlowLibraryManagement.LoadLibraryOfPath(thisAssembly.Location);
- UIContextOperation?.Invoke(() => OnDllLoad?.Invoke(new LoadDllEventArgs(tmp.Item1, tmp.Item2))); // 通知UI创建dll面板显示
+ var tmp = FlowLibraryManagement.LoadLibraryOfPath(thisAssembly.Location);
+ UIContextOperation?.Invoke(() => Event.OnDllLoad(new LoadDllEventArgs(tmp.Item1, tmp.Item2))); // 通知UI创建dll面板显示
}
-
+
#endregion
(var libraryInfo, var mdInfos) = FlowLibraryManagement.LoadLibraryOfPath(dllPath);
if (mdInfos.Count > 0)
{
- UIContextOperation?.Invoke(() => OnDllLoad?.Invoke(new LoadDllEventArgs(libraryInfo, mdInfos))); // 通知UI创建dll面板显示
+ UIContextOperation?.Invoke(() => Event.OnDllLoad(new LoadDllEventArgs(libraryInfo, mdInfos))); // 通知UI创建dll面板显示
}
}
catch (Exception ex)
@@ -732,7 +743,7 @@ namespace Serein.NodeFlow.Env
(var libraryInfo, var mdInfos) = FlowLibraryManagement.LoadLibraryOfPath(flowLibrary);
if (mdInfos.Count > 0)
{
- UIContextOperation?.Invoke(() => OnDllLoad?.Invoke(new LoadDllEventArgs(libraryInfo, mdInfos))); // 通知UI创建dll面板显示
+ UIContextOperation?.Invoke(() => Event.OnDllLoad(new LoadDllEventArgs(libraryInfo, mdInfos))); // 通知UI创建dll面板显示
}
}
catch (Exception ex)
@@ -774,14 +785,14 @@ namespace Serein.NodeFlow.Env
//var mds = FlowLibraryManagement.GetLibraryMdsOfAssmbly(assemblyName);
//if(mds.Count > 0)
//{
-
-
+
+
//}
//else
//{
// return true;
//}
-
+
//var library = LibraryInfos.Values.FirstOrDefault(nl => assemblyName.Equals(nl.AssemblyName));
//if (library is null)
//{
@@ -860,7 +871,7 @@ namespace Serein.NodeFlow.Env
FlowCanvass.Add(model.Guid, model);
UIContextOperation?.Invoke(() =>
{
- OnCanvasCreate.Invoke(new CanvasCreateEventArgs(model));
+ Event.OnCanvasCreated(new CanvasCreateEventArgs(model));
});
return model;
}
@@ -878,7 +889,7 @@ namespace Serein.NodeFlow.Env
return false;
}
var count = NodeModels.Values.Count(node => node.CanvasDetails.Guid.Equals(canvasGuid));
- if(count > 0)
+ if (count > 0)
{
SereinEnv.WriteLine(InfoType.WARN, "无法删除具有节点的画布");
return false;
@@ -887,11 +898,11 @@ namespace Serein.NodeFlow.Env
{
UIContextOperation?.Invoke(() =>
{
- OnCanvasRemove.Invoke(new CanvasRemoveEventArgs(canvasGuid));
+ Event.OnCanvasRemoved(new CanvasRemoveEventArgs(canvasGuid));
});
return true;
}
-
+
return false;
}
@@ -910,7 +921,7 @@ namespace Serein.NodeFlow.Env
List flowCallNodeInfos = [];
foreach (NodeInfo? nodeInfo in nodeInfos)
{
- if(nodeInfo.Type == nameof(NodeControlType.FlowCall))
+ if (nodeInfo.Type == nameof(NodeControlType.FlowCall))
{
flowCallNodeInfos.Add(nodeInfo);
}
@@ -956,10 +967,10 @@ namespace Serein.NodeFlow.Env
var result = nodeContainer.PlaceNode(nodeModel);
if (result)
{
- UIContextOperation?.Invoke(() => OnNodePlace?.Invoke(
- new NodePlaceEventArgs(nodeInfo.CanvasGuid, nodeModel.Guid, containerNode.Guid)));
+ UIContextOperation?.Invoke(() => Event.OnNodePlace(
+ new NodePlaceEventArgs(nodeInfo.CanvasGuid, nodeModel.Guid, containerNode.Guid)));
}
-
+
}
}
@@ -987,10 +998,12 @@ namespace Serein.NodeFlow.Env
{
return;
}
- if (toNodeModel is null) {
+ if (toNodeModel is null)
+ {
// 防御性代码,加载正常保存的项目文件不会进入这里
continue;
- };
+ }
+ ;
var isSuccessful = ConnectInvokeOfNode(canvasGuid, fromNodeModel, toNodeModel, item.connectionType); // 加载时确定节点间的连接关系
}
}
@@ -1042,7 +1055,7 @@ namespace Serein.NodeFlow.Env
UIContextOperation?.Invoke(() =>
{
- OnProjectLoaded?.Invoke(new ProjectLoadedEventArgs());
+ Event.OnProjectLoaded(new ProjectLoadedEventArgs());
});
return;
@@ -1055,17 +1068,17 @@ namespace Serein.NodeFlow.Env
/// 所属类型
/// 所处位置
/// 如果是表达式节点条件节点,该项为null
- public Task CreateNodeAsync(string canvasGuid,
- NodeControlType nodeControlType,
+ public Task CreateNodeAsync(string canvasGuid,
+ NodeControlType nodeControlType,
PositionOfUI position,
MethodDetailsInfo? methodDetailsInfo = null)
{
- if (!TryGetCanvasModel(canvasGuid,out var canvasModel))
+ if (!TryGetCanvasModel(canvasGuid, out var canvasModel))
{
return Task.FromResult(null);
}
IFlowNode? nodeModel;
- if (methodDetailsInfo is null
+ if (methodDetailsInfo is null
|| string.IsNullOrEmpty(methodDetailsInfo.AssemblyName)
|| string.IsNullOrEmpty(methodDetailsInfo.MethodName))
{
@@ -1074,7 +1087,7 @@ namespace Serein.NodeFlow.Env
else
{
if (FlowLibraryManagement.TryGetMethodDetails(methodDetailsInfo.AssemblyName, // 创建节点
- methodDetailsInfo.MethodName,
+ methodDetailsInfo.MethodName,
out var methodDetails))
{
nodeModel = FlowNodeExtension.CreateNode(this, nodeControlType, methodDetails); // 一般的加载节点方法
@@ -1090,12 +1103,12 @@ namespace Serein.NodeFlow.Env
nodeModel.Position = position; // 设置位置
// 通知UI更改
- UIContextOperation?.Invoke(() => OnNodeCreate?.Invoke(new NodeCreateEventArgs(canvasGuid, nodeModel, position)));
+ UIContextOperation?.Invoke(() => Event.OnNodeCreated(new NodeCreateEventArgs(canvasGuid, nodeModel, position)));
var nodeInfo = nodeModel.ToInfo();
return Task.FromResult(nodeInfo);
}
-
+
///
/// 将节点放置在容器中
///
@@ -1115,7 +1128,7 @@ namespace Serein.NodeFlow.Env
if (nodeModel.ContainerNode is INodeContainer tmpContainer)
{
SereinEnv.WriteLine(InfoType.WARN, $"节点放置失败,节点[{nodeGuid}]已经放置于容器节点[{((IFlowNode)tmpContainer).Guid}]");
- return Task.FromResult(false);
+ return Task.FromResult(false);
}
if (!TryGetNodeModel(containerNodeGuid, out var containerNode))
@@ -1129,7 +1142,7 @@ namespace Serein.NodeFlow.Env
{
UIContextOperation?.Invoke(() =>
{
- OnNodePlace?.Invoke(new NodePlaceEventArgs(canvasGuid, nodeGuid, containerNodeGuid)); // 通知UI更改节点放置位置
+ Event.OnNodePlace(new NodePlaceEventArgs(canvasGuid, nodeGuid, containerNodeGuid)); // 通知UI更改节点放置位置
});
}
return Task.FromResult(result);
@@ -1161,7 +1174,7 @@ namespace Serein.NodeFlow.Env
{
UIContextOperation?.Invoke(() =>
{
- OnNodeTakeOut?.Invoke(new NodeTakeOutEventArgs(canvasGuid, nodeGuid)); // 重新放置在画布上
+ Event.OnNodeTakeOut(new NodeTakeOutEventArgs(canvasGuid, nodeGuid)); // 重新放置在画布上
});
}
return Task.FromResult(result);
@@ -1178,7 +1191,7 @@ namespace Serein.NodeFlow.Env
///
public async Task RemoveNodeAsync(string canvasGuid, string nodeGuid)
{
- if (!TryGetCanvasModel(canvasGuid,out var canvasModel))
+ if (!TryGetCanvasModel(canvasGuid, out var canvasModel))
{
return false;
}
@@ -1203,7 +1216,7 @@ namespace Serein.NodeFlow.Env
IFlowNode? pNode = pnc.Value[i];
pNode.SuccessorNodes[pCType].Remove(remoteNode);
- UIContextOperation?.Invoke(() => OnNodeConnectChange?.Invoke(new NodeConnectChangeEventArgs(
+ UIContextOperation?.Invoke(() => Event.OnNodeConnectChanged(new NodeConnectChangeEventArgs(
canvasGuid,
pNode.Guid,
remoteNode.Guid,
@@ -1215,7 +1228,7 @@ namespace Serein.NodeFlow.Env
}
- if(remoteNode.ControlType == NodeControlType.FlowCall)
+ if (remoteNode.ControlType == NodeControlType.FlowCall)
{
}
@@ -1242,7 +1255,7 @@ namespace Serein.NodeFlow.Env
NodeModels.Remove(nodeGuid);
UIContextOperation?.Invoke(() => canvasModel.Nodes.Remove(remoteNode));
- UIContextOperation?.Invoke(() => OnNodeRemove?.Invoke(new NodeRemoveEventArgs(canvasGuid, nodeGuid)));
+ UIContextOperation?.Invoke(() => Event.OnNodeRemoved(new NodeRemoveEventArgs(canvasGuid, nodeGuid)));
return true;
}
@@ -1261,7 +1274,7 @@ namespace Serein.NodeFlow.Env
JunctionType toNodeJunctionType,
ConnectionInvokeType invokeType)
{
-
+
// 获取起始节点与目标节点
if (!FlowCanvass.ContainsKey(canvasGuid) || !TryGetNodeModel(fromNodeGuid, out var fromNode) || !TryGetNodeModel(toNodeGuid, out var toNode))
{
@@ -1276,9 +1289,9 @@ namespace Serein.NodeFlow.Env
return Task.FromResult(false); // 出现不符预期的连接行为,忽略此次连接行为
}
- if(type == JunctionOfConnectionType.Invoke)
+ if (type == JunctionOfConnectionType.Invoke)
{
- if (fromNodeJunctionType == JunctionType.Execute)
+ if (fromNodeJunctionType == JunctionType.Execute)
{
// 如果 起始控制点 是“方法调用”,需要反转 from to 节点
(fromNode, toNode) = (toNode, fromNode);
@@ -1286,7 +1299,7 @@ namespace Serein.NodeFlow.Env
// 从起始节点“下一个方法”控制点,连接到目标节点“方法调用”控制点
state = ConnectInvokeOfNode(canvasGuid, fromNode, toNode, invokeType); // 本地环境进行连接
}
- return Task.FromResult(state);
+ return Task.FromResult(state);
}
@@ -1306,7 +1319,7 @@ namespace Serein.NodeFlow.Env
return Task.FromResult(false);
}
if (fromNode is null || toNode is null) return Task.FromResult(false);
- if ( fromNode.SuccessorNodes.TryGetValue(connectionType, out var nodes))
+ if (fromNode.SuccessorNodes.TryGetValue(connectionType, out var nodes))
{
var idx = nodes.IndexOf(toNode);
if (idx > -1)
@@ -1349,7 +1362,7 @@ namespace Serein.NodeFlow.Env
/// 目标节点的第几个参数
/// 调用目标节点对应方法时,对应参数来源类型
///
- public async Task ConnectArgSourceNodeAsync(string canvasGuid,
+ public async Task ConnectArgSourceNodeAsync(string canvasGuid,
string fromNodeGuid,
string toNodeGuid,
JunctionType fromNodeJunctionType,
@@ -1447,12 +1460,12 @@ namespace Serein.NodeFlow.Env
///
public void SetUIContextOperation(UIContextOperation uiContextOperation)
{
- if(uiContextOperation is not null)
+ if (uiContextOperation is not null)
{
this.UIContextOperation = uiContextOperation;
PersistennceInstance[typeof(UIContextOperation)] = uiContextOperation; // 缓存封装好的UI线程上下文
}
-
+
}
@@ -1463,23 +1476,6 @@ namespace Serein.NodeFlow.Env
this.ioc = ioc; // 设置IOC容器
}
- ///
- /// 移动了某个节点(远程插件使用)
- ///
- ///
- ///
- ///
- public void MoveNode(string canvasGuid, string nodeGuid, double x, double y)
- {
- if (!FlowCanvass.ContainsKey(canvasGuid) || !TryGetNodeModel(nodeGuid, out var nodeModel))
- {
- return;
- }
- nodeModel.Position.X = x;
- nodeModel.Position.Y = y;
- UIContextOperation?.Invoke(() => OnNodeMoved?.Invoke(new NodeMovedEventArgs(nodeGuid, x, y)));
-
- }
///
/// 设置起点控件
@@ -1504,7 +1500,7 @@ namespace Serein.NodeFlow.Env
///
public void MonitorObjectNotification(string nodeGuid, object monitorData, MonitorObjectEventArgs.ObjSourceType sourceType)
{
- OnMonitorObjectChange?.Invoke(new MonitorObjectEventArgs(nodeGuid, monitorData, sourceType));
+ Event.OnMonitorObjectChanged(new MonitorObjectEventArgs(nodeGuid, monitorData, sourceType));
}
///
@@ -1515,7 +1511,7 @@ namespace Serein.NodeFlow.Env
/// 类型,0用户主动的中断,1表达式中断
public void TriggerInterrupt(string nodeGuid, string expression, InterruptTriggerEventArgs.InterruptTriggerType type)
{
- OnInterruptTrigger?.Invoke(new InterruptTriggerEventArgs(nodeGuid, expression, type));
+ Event.OnInterruptTriggered(new InterruptTriggerEventArgs(nodeGuid, expression, type));
}
@@ -1631,7 +1627,7 @@ namespace Serein.NodeFlow.Env
/// 节点Guid
/// 节点Model
/// 无法获取节点、Guid/节点为null时报错
- public bool TryGetNodeModel(string nodeGuid,out IFlowNode nodeModel)
+ public bool TryGetNodeModel(string nodeGuid, out IFlowNode nodeModel)
{
if (string.IsNullOrEmpty(nodeGuid))
{
@@ -1654,7 +1650,7 @@ namespace Serein.NodeFlow.Env
///
public bool LoadNativeLibraryOfRuning(string file)
{
-
+
return NativeDllHelper.LoadDll(file);
}
@@ -1773,7 +1769,7 @@ namespace Serein.NodeFlow.Env
{
// 加载基础节点
methodDetails = new MethodDetails();
-
+
}
else
{
@@ -1807,7 +1803,7 @@ namespace Serein.NodeFlow.Env
}
UIContextOperation?.Invoke(() =>
- OnNodeCreate?.Invoke(new NodeCreateEventArgs(nodeInfo.CanvasGuid, nodeModel, nodeInfo.Position))); // 添加到UI上
+ Event.OnNodeCreated(new NodeCreateEventArgs(nodeInfo.CanvasGuid, nodeModel, nodeInfo.Position))); // 添加到UI上
return true;
}
@@ -1831,7 +1827,7 @@ namespace Serein.NodeFlow.Env
if (OperatingSystem.IsWindows())
{
- UIContextOperation?.Invoke(() => OnNodeConnectChange?.Invoke(
+ UIContextOperation?.Invoke(() => Event.OnNodeConnectChanged(
new NodeConnectChangeEventArgs(
canvasGuid,
fromNode.Guid,
@@ -1839,10 +1835,10 @@ namespace Serein.NodeFlow.Env
JunctionOfConnectionType.Invoke,
connectionType,
NodeConnectChangeEventArgs.ConnectChangeType.Remove)));
- }
+ }
return true;
}
- ///
+ ///
/// 移除连接关系
///
/// 起始节点Model
@@ -1864,16 +1860,16 @@ namespace Serein.NodeFlow.Env
if (OperatingSystem.IsWindows())
{
- UIContextOperation?.Invoke(() => OnNodeConnectChange?.Invoke(
+ UIContextOperation?.Invoke(() => Event.OnNodeConnectChanged(
new NodeConnectChangeEventArgs(
- canvasGuid,
+ canvasGuid,
fromNode.Guid,
toNode.Guid,
JunctionOfConnectionType.Arg,
argIndex,
ConnectionArgSourceType.GetPreviousNodeData,
NodeConnectChangeEventArgs.ConnectChangeType.Remove)));
- }
+ }
return true;
}
@@ -1886,7 +1882,7 @@ namespace Serein.NodeFlow.Env
{
nodeModel.Guid ??= Guid.NewGuid().ToString();
NodeModels.TryAdd(nodeModel.Guid, nodeModel);
-
+
// 如果是触发器,则需要添加到专属集合中
if (nodeModel is SingleFlipflopNode flipflopNode)
@@ -1908,8 +1904,8 @@ namespace Serein.NodeFlow.Env
/// 发起连接节点的控制点类型
/// 被连接节点的控制点类型
///
- public static (JunctionOfConnectionType,bool) CheckConnect(IFlowNode fromNode,
- IFlowNode toNode,
+ public static (JunctionOfConnectionType, bool) CheckConnect(IFlowNode fromNode,
+ IFlowNode toNode,
JunctionType fromNodeJunctionType,
JunctionType toNodeJunctionType)
{
@@ -1947,7 +1943,7 @@ namespace Serein.NodeFlow.Env
// type = JunctionOfConnectionType.Arg;
// state = true;
//}
- if(toNodeJunctionType == JunctionType.ReturnData && !fromNode.Guid.Equals(toNode.Guid))
+ if (toNodeJunctionType == JunctionType.ReturnData && !fromNode.Guid.Equals(toNode.Guid))
{
// “”控制点拖拽到“方法返回值”控制点,且不是同一个节点,添加获取参数关系,生成参数时从目标节点获取flowdata
type = JunctionOfConnectionType.Arg;
@@ -1964,7 +1960,7 @@ namespace Serein.NodeFlow.Env
}
}
// 剩下的情况都是不符预期的连接行为,忽略。
- return (type,state);
+ return (type, state);
}
///
@@ -1975,7 +1971,7 @@ namespace Serein.NodeFlow.Env
/// 连接关系
private bool ConnectInvokeOfNode(string canvasGuid, IFlowNode fromNode, IFlowNode toNode, ConnectionInvokeType invokeType)
{
- if (fromNode.ControlType == NodeControlType.FlowCall)
+ if (fromNode.ControlType == NodeControlType.FlowCall)
{
SereinEnv.WriteLine(InfoType.ERROR, $"流程接口节点不可调用下一个节点。" +
$"{Environment.NewLine}流程节点:{fromNode.Guid}");
@@ -2012,7 +2008,7 @@ namespace Serein.NodeFlow.Env
FromExistInTo = ToOnF.Length > 0;
if (ToExistOnFrom && FromExistInTo)
{
- if(ctType == invokeType)
+ if (ctType == invokeType)
{
SereinEnv.WriteLine(InfoType.WARN, $"起始节点已与目标节点存在连接。" +
$"{Environment.NewLine}起始节点:{fromNode.Guid}" +
@@ -2039,7 +2035,7 @@ namespace Serein.NodeFlow.Env
$"{Environment.NewLine}起始节点:{fromNode.Guid}" +
$"{Environment.NewLine}目标节点:{toNode.Guid}" +
$"");
- isPass = false;
+ isPass = false;
}
else
{
@@ -2059,13 +2055,13 @@ namespace Serein.NodeFlow.Env
if (OperatingSystem.IsWindows())
{
- UIContextOperation?.Invoke(() =>
- OnNodeConnectChange?.Invoke(
+ UIContextOperation?.Invoke(() =>
+ Event.OnNodeConnectChanged(
new NodeConnectChangeEventArgs(
canvasGuid,
fromNode.Guid, // 从哪个节点开始
toNode.Guid, // 连接到那个节点
- JunctionOfConnectionType.Invoke,
+ JunctionOfConnectionType.Invoke,
invokeType, // 连接线的样式类型
NodeConnectChangeEventArgs.ConnectChangeType.Create // 是创建连接还是删除连接
))); // 通知UI
@@ -2103,7 +2099,7 @@ namespace Serein.NodeFlow.Env
var toNodeArgSourceGuid = toNode.MethodDetails.ParameterDetailss[argIndex].ArgDataSourceNodeGuid;
var toNodeArgSourceType = toNode.MethodDetails.ParameterDetailss[argIndex].ArgDataSourceType;
- if(fromNode.Guid == toNodeArgSourceGuid && toNodeArgSourceType == connectionArgSourceType)
+ if (fromNode.Guid == toNodeArgSourceGuid && toNodeArgSourceType == connectionArgSourceType)
{
SereinEnv.WriteLine(InfoType.INFO, $"节点之间已建立过连接关系,此次操作将不会执行" +
$"起始节点:{fromNode.Guid}" +
@@ -2111,7 +2107,7 @@ namespace Serein.NodeFlow.Env
$"参数索引:{argIndex}" +
$"参数类型:{connectionArgSourceType}");
UIContextOperation?.Invoke(() =>
- OnNodeConnectChange?.Invoke(
+ Event.OnNodeConnectChanged(
new NodeConnectChangeEventArgs(
canvasGuid,
fromNode.Guid, // 从哪个节点开始
@@ -2125,7 +2121,7 @@ namespace Serein.NodeFlow.Env
return true;
}
- if (!string.IsNullOrEmpty(toNodeArgSourceGuid) )
+ if (!string.IsNullOrEmpty(toNodeArgSourceGuid))
{
await RemoteConnectAsync(canvasGuid, fromNode, toNode, argIndex);
}
@@ -2134,7 +2130,7 @@ namespace Serein.NodeFlow.Env
toNode.MethodDetails.ParameterDetailss[argIndex].ArgDataSourceType = connectionArgSourceType;
UIContextOperation?.Invoke(() =>
- OnNodeConnectChange?.Invoke(
+ Event.OnNodeConnectChanged(
new NodeConnectChangeEventArgs(
canvasGuid,
fromNode.Guid, // 从哪个节点开始
@@ -2162,7 +2158,7 @@ namespace Serein.NodeFlow.Env
}*/
cavnasModel.StartNode = newStartNode;
//newStartNode.IsStart = true;
- UIContextOperation?.Invoke(() => OnStartNodeChange?.Invoke(new StartNodeChangeEventArgs(cavnasModel.Guid, oldNodeGuid, cavnasModel.StartNode.Guid)));
+ UIContextOperation?.Invoke(() => Event.OnStartNodeChanged(new StartNodeChangeEventArgs(cavnasModel.Guid, oldNodeGuid, cavnasModel.StartNode.Guid)));
}
@@ -2176,7 +2172,7 @@ namespace Serein.NodeFlow.Env
foreach (var kvp in PersistennceInstance)
{
IOC.Register(kvp.Key, () => kvp.Value);
- }
+ }
}
}
@@ -2188,31 +2184,19 @@ namespace Serein.NodeFlow.Env
/// 定位节点
///
///
- public void NodeLocated(string nodeGuid)
+ public void NodeLocate(string nodeGuid)
{
if (OperatingSystem.IsWindows())
{
- UIContextOperation?.Invoke(() => OnNodeLocated?.Invoke(new NodeLocatedEventArgs(nodeGuid)));
+ UIContextOperation?.Invoke(() => Event.OnNodeLocated(new NodeLocatedEventArgs(nodeGuid)));
}
-
+
}
#endregion
-
-
}
-
-
-
-
-
-
-
-
-
-
}
diff --git a/NodeFlow/Env/MsgControllerOfServer.cs b/NodeFlow/Env/MsgControllerOfServer.cs
index 9bad06d..f9fbdc6 100644
--- a/NodeFlow/Env/MsgControllerOfServer.cs
+++ b/NodeFlow/Env/MsgControllerOfServer.cs
@@ -554,17 +554,7 @@ namespace Serein.NodeFlow.Env
};
}
- ///
- /// 移动了某个节点(远程插件使用)
- ///
- ///
- ///
- ///
- [AutoSocketHandle(ThemeValue = EnvMsgTheme.MoveNode)]
- public void MoveNode(string canvasGuid, string nodeGuid, double x, double y)
- {
- environment.MoveNode(canvasGuid, nodeGuid, x, y);
- }
+
///
/// 设置起点控件
diff --git a/NodeFlow/Env/RemoteFlowEnvironment.cs b/NodeFlow/Env/RemoteFlowEnvironment.cs
index 5ec9e23..decee0f 100644
--- a/NodeFlow/Env/RemoteFlowEnvironment.cs
+++ b/NodeFlow/Env/RemoteFlowEnvironment.cs
@@ -15,16 +15,19 @@ namespace Serein.NodeFlow.Env
///
/// 远程流程环境
///
- public class RemoteFlowEnvironment : ChannelFlowTrigger, IFlowEnvironment , IFlowEnvironmentEvent
+ public class RemoteFlowEnvironment : ChannelFlowTrigger, IFlowEnvironment
{
///
/// 连接到远程环境后切换到的环境接口实现
///
/// 连接到远程环境后,本地环境自动切换到对应的环境实体
/// 远程环境下需要操作UI线程时,所提供的线程上下文封装工具
- public RemoteFlowEnvironment(RemoteMsgUtil remoteMsgUtil, UIContextOperation uIContextOperation)
+ public RemoteFlowEnvironment(RemoteMsgUtil remoteMsgUtil,
+ IFlowEnvironmentEvent flowEnvironmentEvent,
+ UIContextOperation uIContextOperation)
{
this.UIContextOperation = uIContextOperation;
+ this.Event = flowEnvironmentEvent;
RemoteMsgUtil = remoteMsgUtil;
msgClient = new MsgControllerOfClient(this, remoteMsgUtil.SendAsync); // 这里提供的是主动发送消息的方法
remoteMsgUtil.EnvClient.MsgHandleHelper.AddModule(msgClient, (ex, send) =>
@@ -43,32 +46,13 @@ namespace Serein.NodeFlow.Env
///
private Dictionary NodeModels { get; } = [];
- public event LoadDllHandler OnDllLoad;
- public event ProjectLoadedHandler OnProjectLoaded;
- public event ProjectSavingHandler OnProjectSaving;
- public event CanvasCreateHandler OnCanvasCreate;
- public event CanvasRemoveHandler OnCanvasRemove;
- public event NodeConnectChangeHandler OnNodeConnectChange;
- public event NodeCreateHandler OnNodeCreate;
- public event NodeRemoveHandler OnNodeRemove;
- public event NodePlaceHandler OnNodePlace;
- public event NodeTakeOutHandler OnNodeTakeOut;
- public event StartNodeChangeHandler OnStartNodeChange;
- public event FlowRunCompleteHandler OnFlowRunComplete;
- public event MonitorObjectChangeHandler OnMonitorObjectChange;
- public event NodeInterruptStateChangeHandler OnNodeInterruptStateChange;
- public event ExpInterruptTriggerHandler OnInterruptTrigger;
- public event IOCMembersChangedHandler OnIOCMembersChanged;
- public event NodeLocatedHandler OnNodeLocated;
- public event NodeMovedHandler OnNodeMoved;
- public event EnvOutHandler OnEnvOut;
public ISereinIOC IOC => throw new NotImplementedException();
///
/// 流程事件
///
- public IFlowEnvironmentEvent Event { get => this; }
+ public IFlowEnvironmentEvent Event { get; private set; }
public string EnvName => LocalFlowEnvironment.SpaceName;
///
@@ -116,7 +100,7 @@ namespace Serein.NodeFlow.Env
/// 日志级别
public void WriteLine(InfoType type, string message, InfoClass @class = InfoClass.Trivial)
{
- OnEnvOut?.Invoke(type, message);
+ Event.OnEnvOutput(type, message);
}
public async Task StartRemoteServerAsync(int port = 7525)
@@ -151,7 +135,7 @@ namespace Serein.NodeFlow.Env
var result = await msgClient.SendAndWaitDataAsync(EnvMsgTheme.SaveProject);
if (result is not null)
{
- OnProjectSaving?.Invoke(new ProjectSavingEventArgs(result));
+ Event.OnProjectSaving(new ProjectSavingEventArgs(result));
}
});
@@ -186,7 +170,7 @@ namespace Serein.NodeFlow.Env
FileName = "Remote",
};
var mdInfos = lib.Mds.ToList();
- UIContextOperation?.Invoke(() => OnDllLoad?.Invoke(new LoadDllEventArgs(nodeLibraryInfo, mdInfos))); // 通知UI创建dll面板显示
+ UIContextOperation?.Invoke(() => Event.OnDllLoad(new LoadDllEventArgs(nodeLibraryInfo, mdInfos))); // 通知UI创建dll面板显示
foreach (var mdInfo in mdInfos)
{
MethodDetailss.TryAdd(mdInfo.MethodName, new MethodDetails(mdInfo)); // 从DLL读取时生成元数据
@@ -200,7 +184,7 @@ namespace Serein.NodeFlow.Env
var canvasModel = new FlowCanvasDetails(this);
canvasModel.LoadInfo(info);
var e = new CanvasCreateEventArgs(canvasModel);
- OnCanvasCreate?.Invoke(e);
+ Event.OnCanvasCreated(e);
}
// 加载节点
@@ -216,7 +200,7 @@ namespace Serein.NodeFlow.Env
UIContextOperation?.Invoke(() =>
{
- OnProjectLoaded?.Invoke(new ProjectLoadedEventArgs()); // 加载完成
+ Event.OnProjectLoaded(new ProjectLoadedEventArgs()); // 加载完成
});
IsLoadingProject = false;
@@ -488,7 +472,7 @@ namespace Serein.NodeFlow.Env
Width = info.Width,
};
UIContextOperation?.Invoke(() =>
- OnCanvasCreate?.Invoke(new CanvasCreateEventArgs(model)));
+ Event.OnCanvasCreated(new CanvasCreateEventArgs(model)));
return info;
}
@@ -510,40 +494,14 @@ namespace Serein.NodeFlow.Env
if (result)
{
UIContextOperation?.Invoke(() =>
- OnCanvasRemove?.Invoke(new CanvasRemoveEventArgs(canvasGuid)));
+ Event.OnCanvasRemoved(new CanvasRemoveEventArgs(canvasGuid)));
}
return true;
}
- ///
- /// 移动节点,通知远程环境也一起移动,保持相对位置一致
- ///
- ///
- ///
- ///
- public void MoveNode(string cavnasGuid, string nodeGuid, double x, double y)
- {
- //UIContextOperation?.Invoke(() =>
- //{
- // OnNodeMoved?.Invoke(new NodeMovedEventArgs(nodeGuid, x, y));
- //});
- _ = msgClient.SendAsync(EnvMsgTheme.MoveNode,
- new
- {
- cavnasGuid,
- nodeGuid,
- x,
- y
- });
-
- if(NodeModels.TryGetValue(nodeGuid, out var nodeModel))
- {
- nodeModel.Position.X = x;
- nodeModel.Position.Y = y;
- }
- }
+
///
@@ -561,7 +519,7 @@ namespace Serein.NodeFlow.Env
});
if (NodeModels.TryGetValue(newNodeGuid, out var nodeModel)) // 存在节点
{
- UIContextOperation?.Invoke(() => OnStartNodeChange?.Invoke(new StartNodeChangeEventArgs(canvasGuid, nodeGuid, newNodeGuid)));
+ UIContextOperation?.Invoke(() => Event.OnStartNodeChanged(new StartNodeChangeEventArgs(canvasGuid, nodeGuid, newNodeGuid)));
}
return newNodeGuid;
}
@@ -622,7 +580,7 @@ namespace Serein.NodeFlow.Env
var result = await msgClient.SendAndWaitDataAsync(EnvMsgTheme.ConnectInvokeNode, sendObj);
if (result)
{
- OnNodeConnectChange?.Invoke(new NodeConnectChangeEventArgs(canvasGuid,
+ Event.OnNodeConnectChanged(new NodeConnectChangeEventArgs(canvasGuid,
fromNodeGuid,
toNodeGuid,
JunctionOfConnectionType.Invoke,
@@ -697,7 +655,7 @@ namespace Serein.NodeFlow.Env
var result = await msgClient.SendAndWaitDataAsync(EnvMsgTheme.ConnectArgSourceNode, sendObj);
if (result)
{
- OnNodeConnectChange?.Invoke(new NodeConnectChangeEventArgs(canvasGuid,
+ Event.OnNodeConnectChanged(new NodeConnectChangeEventArgs(canvasGuid,
fromNodeGuid,
toNodeGuid,
JunctionOfConnectionType.Arg,
@@ -739,7 +697,7 @@ namespace Serein.NodeFlow.Env
{
UIContextOperation.Invoke(() =>
{
- OnNodeConnectChange?.Invoke(new NodeConnectChangeEventArgs(canvasGuid,
+ Event.OnNodeConnectChanged(new NodeConnectChangeEventArgs(canvasGuid,
fromNodeGuid,
toNodeGuid,
JunctionOfConnectionType.Invoke,
@@ -768,7 +726,7 @@ namespace Serein.NodeFlow.Env
{
UIContextOperation.Invoke(() =>
{
- OnNodeConnectChange?.Invoke(new NodeConnectChangeEventArgs(canvasGuid,
+ Event.OnNodeConnectChanged(new NodeConnectChangeEventArgs(canvasGuid,
fromNodeGuid,
toNodeGuid,
JunctionOfConnectionType.Arg,
@@ -914,7 +872,7 @@ namespace Serein.NodeFlow.Env
// 通知UI更改
UIContextOperation.Invoke(() =>
{
- OnNodeCreate?.Invoke(new NodeCreateEventArgs(canvasGuid, nodeModel, position));
+ Event.OnNodeCreated(new NodeCreateEventArgs(canvasGuid, nodeModel, position));
});
return nodeInfo;
}
@@ -945,7 +903,7 @@ namespace Serein.NodeFlow.Env
// 通知UI更改
UIContextOperation.Invoke(() =>
{
- OnNodePlace?.Invoke(new NodePlaceEventArgs(canvasGuid, nodeGuid, containerNodeGuid)); // 通知UI更改节点放置位置
+ Event.OnNodePlace(new NodePlaceEventArgs(canvasGuid, nodeGuid, containerNodeGuid)); // 通知UI更改节点放置位置
});
}
return result;
@@ -977,7 +935,7 @@ namespace Serein.NodeFlow.Env
// 通知UI更改
UIContextOperation.Invoke(() =>
{
- OnNodeTakeOut?.Invoke(new NodeTakeOutEventArgs(canvasGuid, nodeGuid)); // 重新放置在画布上
+ Event.OnNodeTakeOut(new NodeTakeOutEventArgs(canvasGuid, nodeGuid)); // 重新放置在画布上
});
}
return result;
@@ -1002,7 +960,7 @@ namespace Serein.NodeFlow.Env
{
UIContextOperation.Invoke(() =>
{
- OnNodeRemove?.Invoke(new NodeRemoveEventArgs(canvasGuid, nodeGuid));
+ Event.OnNodeRemoved(new NodeRemoveEventArgs(canvasGuid, nodeGuid));
});
}
else
@@ -1102,9 +1060,9 @@ namespace Serein.NodeFlow.Env
/// 需要定位某个节点
///
///
- public void NodeLocated(string nodeGuid)
+ public void NodeLocate(string nodeGuid)
{
- UIContextOperation?.Invoke(() => OnNodeLocated?.Invoke(new NodeLocatedEventArgs(nodeGuid)));
+ UIContextOperation?.Invoke(() => Event.OnNodeLocated(new NodeLocatedEventArgs(nodeGuid)));
}
///
@@ -1236,7 +1194,7 @@ namespace Serein.NodeFlow.Env
TryAddNode(nodeModel); // 加载项目时将节点加载到环境中
UIContextOperation?.Invoke(() =>
- OnNodeCreate?.Invoke(new NodeCreateEventArgs(canvasGuid, nodeModel, nodeInfo.Position))); // 添加到UI上
+ Event.OnNodeCreated(new NodeCreateEventArgs(canvasGuid, nodeModel, nodeInfo.Position))); // 添加到UI上
}
#endregion
@@ -1258,8 +1216,8 @@ namespace Serein.NodeFlow.Env
var canvasGuid = nodeInfo.CanvasGuid;
childNode.ContainerNode = parentNode;
parentNode.ChildrenNode.Add(childNode);
- UIContextOperation?.Invoke(() =>
- OnNodePlace?.Invoke(new NodePlaceEventArgs(canvasGuid,nodeInfo.Guid, nodeInfo.ParentNodeGuid)) // 通知UI更改节点放置位置
+ UIContextOperation?.Invoke(() =>
+ Event.OnNodePlace(new NodePlaceEventArgs(canvasGuid,nodeInfo.Guid, nodeInfo.ParentNodeGuid)) // 通知UI更改节点放置位置
);
}
@@ -1294,7 +1252,7 @@ namespace Serein.NodeFlow.Env
// 遍历当前类型分支的节点(确认连接关系)
foreach (var toNode in item.toNodes)
{
- UIContextOperation?.Invoke(() => OnNodeConnectChange?.Invoke(new NodeConnectChangeEventArgs(canvasGuid,
+ UIContextOperation?.Invoke(() => Event.OnNodeConnectChanged(new NodeConnectChangeEventArgs(canvasGuid,
fromNode.Guid,
toNode.Guid,
JunctionOfConnectionType.Invoke,
@@ -1320,7 +1278,7 @@ namespace Serein.NodeFlow.Env
{
var canvasGuid = toNode.CanvasDetails.Guid;
UIContextOperation?.Invoke(() =>
- OnNodeConnectChange?.Invoke(
+ Event.OnNodeConnectChanged(
new NodeConnectChangeEventArgs(
canvasGuid,
fromNode.Guid, // 从哪个节点开始
@@ -1335,7 +1293,7 @@ namespace Serein.NodeFlow.Env
}
#endregion
});
- UIContextOperation?.Invoke(() => OnProjectLoaded?.Invoke(new ProjectLoadedEventArgs()));
+ UIContextOperation?.Invoke(() => Event.OnProjectLoaded(new ProjectLoadedEventArgs()));
}
diff --git a/NodeFlow/Model/Operation/OperationBase.cs b/NodeFlow/Model/Operation/OperationBase.cs
new file mode 100644
index 0000000..92ae550
--- /dev/null
+++ b/NodeFlow/Model/Operation/OperationBase.cs
@@ -0,0 +1,92 @@
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+
+namespace Serein.NodeFlow.Model.Operation
+{
+
+ class Test {
+
+ ///
+ /// 撤销栈
+ ///
+ private Stack undoStack = [];
+ ///
+ /// 重做栈
+ ///
+ private Stack redoStack = [];
+
+
+ /*
+ // 执行新命令时,将命令推入撤销栈,并清空重做栈
+ undoStack.Push(operation);
+ redoStack.Clear();
+ */
+
+
+ ///
+ /// 撤销
+ ///
+ public void Undo()
+ {
+ if (undoStack.Count > 0)
+ {
+ var command = undoStack.Pop();
+ command.Undo(); // 执行撤销
+ redoStack.Push(command); // 将撤销的命令推入重做栈
+ }
+ }
+
+ ///
+ /// 重做
+ ///
+ public void Redo()
+ {
+ if (redoStack.Count > 0)
+ {
+ var command = redoStack.Pop();
+ command.Execute();
+ undoStack.Push(command); // 将重做的命令推入撤销栈
+ }
+ }
+
+ }
+
+
+ internal class OperationInfo
+ {
+
+ }
+
+ internal abstract class OperationBase : IOperation
+ {
+ ///
+ /// 操作的主题
+ ///
+ public required string Theme { get; set; }
+
+ public abstract void Execute();
+ public abstract void Undo();
+ public abstract void ToInfo();
+
+ protected OperationBase()
+ {
+
+ }
+ protected OperationBase(OperationInfo info)
+ {
+
+ }
+
+ }
+
+ internal interface IOperation
+ {
+ void Execute(); // 执行操作
+ void Undo(); // 撤销操作
+
+
+ }
+}
diff --git a/NodeFlow/Model/SingleScriptNode.cs b/NodeFlow/Model/SingleScriptNode.cs
index 3a53cea..9927089 100644
--- a/NodeFlow/Model/SingleScriptNode.cs
+++ b/NodeFlow/Model/SingleScriptNode.cs
@@ -227,12 +227,12 @@ namespace Serein.NodeFlow.Model
};
var envEvent = (IFlowEnvironmentEvent)context.Env;
- envEvent.OnFlowRunComplete += onFlowStop; // 防止运行后台流程
+ envEvent.FlowRunComplete += onFlowStop; // 防止运行后台流程
if (token.IsCancellationRequested) return null;
var result = await ScriptInterpreter.InterpretAsync(scriptContext, mainNode); // 从入口节点执行
- envEvent.OnFlowRunComplete -= onFlowStop;
+ envEvent.FlowRunComplete -= onFlowStop;
return new FlowResult(this, context, result);
}
diff --git a/NodeFlow/Services/NodeService.cs b/NodeFlow/Services/NodeService.cs
new file mode 100644
index 0000000..a1f6391
--- /dev/null
+++ b/NodeFlow/Services/NodeService.cs
@@ -0,0 +1,12 @@
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+
+namespace Serein.NodeFlow.Services
+{
+ internal class NodeService
+ {
+ }
+}
diff --git a/Workbench/Node/ViewModel/FlowCallNodeControlViewModel.cs b/Workbench/Node/ViewModel/FlowCallNodeControlViewModel.cs
index 0370151..9543b92 100644
--- a/Workbench/Node/ViewModel/FlowCallNodeControlViewModel.cs
+++ b/Workbench/Node/ViewModel/FlowCallNodeControlViewModel.cs
@@ -78,8 +78,8 @@ namespace Serein.Workbench.Node.ViewModel
private void InitEvent()
{
- flowEEForwardingService.OnCanvasCreate += (e) => RershCanvass(); // 画布创建了
- flowEEForwardingService.OnCanvasRemove += (e) => RershCanvass(); // 画布移除了
+ flowEEForwardingService.CanvasCreated += (e) => RershCanvass(); // 画布创建了
+ flowEEForwardingService.CanvasRemoved += (e) => RershCanvass(); // 画布移除了
}
diff --git a/Workbench/ServiceCollectionExtensions.cs b/Workbench/ServiceCollectionExtensions.cs
index 36d29a0..013ac8a 100644
--- a/Workbench/ServiceCollectionExtensions.cs
+++ b/Workbench/ServiceCollectionExtensions.cs
@@ -69,7 +69,7 @@ namespace Serein.Workbench
flowEnvironment.SetUIContextOperation(uIContextOperation);
collection.AddSingleton(uIContextOperation); // 注册UI线程操作上下文
collection.AddSingleton(flowEnvironment); // 注册运行环境
- collection.AddSingleton(flowEnvironment); // 注册运行环境事件
+ collection.AddSingleton(flowEnvironment.Event); // 注册运行环境事件
#endregion
diff --git a/Workbench/Services/FlowEEForwardingService.cs b/Workbench/Services/FlowEEForwardingService.cs
index 6670986..131fa85 100644
--- a/Workbench/Services/FlowEEForwardingService.cs
+++ b/Workbench/Services/FlowEEForwardingService.cs
@@ -49,79 +49,75 @@ namespace Serein.Workbench.Services
///
/// 加载了依赖文件事件
///
- public event LoadDllHandler? OnDllLoad;
+ public event LoadDllHandler? DllLoad;
///
/// 项目加载完成事件
///
- public event ProjectLoadedHandler? OnProjectLoaded;
+ public event ProjectLoadedHandler? ProjectLoaded;
///
/// 项目保存中事件
///
- public event ProjectSavingHandler? OnProjectSaving;
+ public event ProjectSavingHandler? ProjectSaving;
///
/// 节点连接改变事件
///
- public event NodeConnectChangeHandler? OnNodeConnectChange;
+ public event NodeConnectChangeHandler? NodeConnectChanged;
///
/// 节点创建事件
///
- public event NodeCreateHandler? OnNodeCreate;
+ public event NodeCreateHandler? NodeCreated;
///
/// 节点移除事件
///
- public event NodeRemoveHandler? OnNodeRemove;
+ public event NodeRemoveHandler? NodeRemoved;
///
/// 节点放置容器事件
///
- public event NodePlaceHandler? OnNodePlace;
+ public event NodePlaceHandler? NodePlace;
///
/// 节点取出事件
///
- public event NodeTakeOutHandler? OnNodeTakeOut;
+ public event NodeTakeOutHandler? NodeTakeOut;
///
/// 流程起始节点改变事件
///
- public event StartNodeChangeHandler? OnStartNodeChange;
+ public event StartNodeChangeHandler? StartNodeChanged;
///
/// 流程运行完毕事件
///
- public event FlowRunCompleteHandler? OnFlowRunComplete;
+ public event FlowRunCompleteHandler? FlowRunComplete;
///
/// 被监视的对象数据改变事件
///
- public event MonitorObjectChangeHandler? OnMonitorObjectChange;
+ public event MonitorObjectChangeHandler? MonitorObjectChanged;
///
/// 节点中断状态改变事件
///
- public event NodeInterruptStateChangeHandler? OnNodeInterruptStateChange;
+ public event NodeInterruptStateChangeHandler? NodeInterruptStateChanged;
///
/// 表达式中断触发事件
///
- public event ExpInterruptTriggerHandler? OnInterruptTrigger;
+ public event ExpInterruptTriggerHandler? InterruptTriggered;
///
/// 容器对象改变事件
///
- public event IOCMembersChangedHandler? OnIOCMembersChanged;
+ public event IOCMembersChangedHandler? IOCMembersChanged;
///
/// 节点定位事件
///
- public event NodeLocatedHandler? OnNodeLocated;
- ///
- /// 节点移动事件
- ///
- public event NodeMovedHandler? OnNodeMoved;
+ public event NodeLocatedHandler? NodeLocated;
///
/// 运行环境输出事件
///
- public event EnvOutHandler? OnEnvOut;
+ public event EnvOutHandler? EnvOutput;
///
/// 添加画布事件
///
- public event CanvasCreateHandler OnCanvasCreate;
+ public event CanvasCreateHandler CanvasCreated;
///
/// 移除了画布事件
///
- public event CanvasRemoveHandler OnCanvasRemove;
+ public event CanvasRemoveHandler CanvasRemoved;
#endregion
@@ -129,55 +125,53 @@ namespace Serein.Workbench.Services
private void InitFlowEnvironmentEvent()
{
- flowEnvironmentEvent.OnDllLoad += FlowEnvironment_DllLoadEvent;
- flowEnvironmentEvent.OnProjectSaving += FlowEnvironment_OnProjectSaving;
- flowEnvironmentEvent.OnProjectLoaded += FlowEnvironment_OnProjectLoaded;
- flowEnvironmentEvent.OnCanvasCreate += FlowEnvironmentEvent_OnCanvasCreate;
- flowEnvironmentEvent.OnCanvasRemove += FlowEnvironmentEvent_OnCanvasRemove;
- flowEnvironmentEvent.OnStartNodeChange += FlowEnvironment_StartNodeChangeEvent;
- flowEnvironmentEvent.OnNodeConnectChange += FlowEnvironment_NodeConnectChangeEvemt;
- flowEnvironmentEvent.OnNodeCreate += FlowEnvironment_NodeCreateEvent;
- flowEnvironmentEvent.OnNodeRemove += FlowEnvironment_NodeRemoveEvent;
- flowEnvironmentEvent.OnNodePlace += FlowEnvironment_OnNodePlaceEvent;
- flowEnvironmentEvent.OnNodeTakeOut += FlowEnvironment_OnNodeTakeOutEvent;
- flowEnvironmentEvent.OnFlowRunComplete += FlowEnvironment_OnFlowRunCompleteEvent;
+ flowEnvironmentEvent.DllLoad += FlowEnvironment_DllLoadEvent;
+ flowEnvironmentEvent.ProjectSaving += FlowEnvironment_OnProjectSaving;
+ flowEnvironmentEvent.ProjectLoaded += FlowEnvironment_OnProjectLoaded;
+ flowEnvironmentEvent.CanvasCreated += FlowEnvironmentEvent_OnCanvasCreate;
+ flowEnvironmentEvent.CanvasRemoved += FlowEnvironmentEvent_OnCanvasRemove;
+ flowEnvironmentEvent.StartNodeChanged += FlowEnvironment_StartNodeChangeEvent;
+ flowEnvironmentEvent.NodeConnectChanged += FlowEnvironment_NodeConnectChangeEvemt;
+ flowEnvironmentEvent.NodeCreated += FlowEnvironment_NodeCreateEvent;
+ flowEnvironmentEvent.NodeRemoved += FlowEnvironment_NodeRemoveEvent;
+ flowEnvironmentEvent.NodePlace += FlowEnvironment_OnNodePlaceEvent;
+ flowEnvironmentEvent.NodeTakeOut += FlowEnvironment_OnNodeTakeOutEvent;
+ flowEnvironmentEvent.FlowRunComplete += FlowEnvironment_OnFlowRunCompleteEvent;
- flowEnvironmentEvent.OnMonitorObjectChange += FlowEnvironment_OnMonitorObjectChangeEvent;
- flowEnvironmentEvent.OnNodeInterruptStateChange += FlowEnvironment_OnNodeInterruptStateChangeEvent;
- flowEnvironmentEvent.OnInterruptTrigger += FlowEnvironment_OnInterruptTriggerEvent;
+ flowEnvironmentEvent.MonitorObjectChanged += FlowEnvironment_OnMonitorObjectChangeEvent;
+ flowEnvironmentEvent.NodeInterruptStateChanged += FlowEnvironment_OnNodeInterruptStateChangeEvent;
+ flowEnvironmentEvent.InterruptTriggered += FlowEnvironment_OnInterruptTriggerEvent;
- flowEnvironmentEvent.OnIOCMembersChanged += FlowEnvironment_OnIOCMembersChangedEvent;
+ flowEnvironmentEvent.IOCMembersChanged += FlowEnvironment_OnIOCMembersChangedEvent;
- flowEnvironmentEvent.OnNodeLocated += FlowEnvironment_OnNodeLocateEvent;
- flowEnvironmentEvent.OnNodeMoved += FlowEnvironment_OnNodeMovedEvent;
+ flowEnvironmentEvent.NodeLocated += FlowEnvironment_OnNodeLocateEvent;;
- flowEnvironmentEvent.OnEnvOut += FlowEnvironment_OnEnvOutEvent;
+ flowEnvironmentEvent.EnvOutput += FlowEnvironment_OnEnvOutEvent;
}
private void ResetFlowEnvironmentEvent()
{
- flowEnvironmentEvent.OnDllLoad -= FlowEnvironment_DllLoadEvent;
- flowEnvironmentEvent.OnProjectSaving -= FlowEnvironment_OnProjectSaving;
- flowEnvironmentEvent.OnProjectLoaded -= FlowEnvironment_OnProjectLoaded;
- flowEnvironmentEvent.OnStartNodeChange -= FlowEnvironment_StartNodeChangeEvent;
- flowEnvironmentEvent.OnNodeConnectChange -= FlowEnvironment_NodeConnectChangeEvemt;
- flowEnvironmentEvent.OnNodeCreate -= FlowEnvironment_NodeCreateEvent;
- flowEnvironmentEvent.OnNodeRemove -= FlowEnvironment_NodeRemoveEvent;
- flowEnvironmentEvent.OnNodePlace -= FlowEnvironment_OnNodePlaceEvent;
- flowEnvironmentEvent.OnNodeTakeOut -= FlowEnvironment_OnNodeTakeOutEvent;
- flowEnvironmentEvent.OnFlowRunComplete -= FlowEnvironment_OnFlowRunCompleteEvent;
+ flowEnvironmentEvent.DllLoad -= FlowEnvironment_DllLoadEvent;
+ flowEnvironmentEvent.ProjectSaving -= FlowEnvironment_OnProjectSaving;
+ flowEnvironmentEvent.ProjectLoaded -= FlowEnvironment_OnProjectLoaded;
+ flowEnvironmentEvent.StartNodeChanged -= FlowEnvironment_StartNodeChangeEvent;
+ flowEnvironmentEvent.NodeConnectChanged -= FlowEnvironment_NodeConnectChangeEvemt;
+ flowEnvironmentEvent.NodeCreated -= FlowEnvironment_NodeCreateEvent;
+ flowEnvironmentEvent.NodeRemoved -= FlowEnvironment_NodeRemoveEvent;
+ flowEnvironmentEvent.NodePlace -= FlowEnvironment_OnNodePlaceEvent;
+ flowEnvironmentEvent.NodeTakeOut -= FlowEnvironment_OnNodeTakeOutEvent;
+ flowEnvironmentEvent.FlowRunComplete -= FlowEnvironment_OnFlowRunCompleteEvent;
- flowEnvironmentEvent.OnMonitorObjectChange -= FlowEnvironment_OnMonitorObjectChangeEvent;
- flowEnvironmentEvent.OnNodeInterruptStateChange -= FlowEnvironment_OnNodeInterruptStateChangeEvent;
- flowEnvironmentEvent.OnInterruptTrigger -= FlowEnvironment_OnInterruptTriggerEvent;
+ flowEnvironmentEvent.MonitorObjectChanged -= FlowEnvironment_OnMonitorObjectChangeEvent;
+ flowEnvironmentEvent.NodeInterruptStateChanged -= FlowEnvironment_OnNodeInterruptStateChangeEvent;
+ flowEnvironmentEvent.InterruptTriggered -= FlowEnvironment_OnInterruptTriggerEvent;
- flowEnvironmentEvent.OnIOCMembersChanged -= FlowEnvironment_OnIOCMembersChangedEvent;
- flowEnvironmentEvent.OnNodeLocated -= FlowEnvironment_OnNodeLocateEvent;
- flowEnvironmentEvent.OnNodeMoved -= FlowEnvironment_OnNodeMovedEvent;
+ flowEnvironmentEvent.IOCMembersChanged -= FlowEnvironment_OnIOCMembersChangedEvent;
+ flowEnvironmentEvent.NodeLocated -= FlowEnvironment_OnNodeLocateEvent;
- flowEnvironmentEvent.OnEnvOut -= FlowEnvironment_OnEnvOutEvent;
+ flowEnvironmentEvent.EnvOutput -= FlowEnvironment_OnEnvOutEvent;
}
@@ -192,7 +186,7 @@ namespace Serein.Workbench.Services
{
uIContextOperation.Invoke(() =>
{
- OnEnvOut?.Invoke(type, value);
+ EnvOutput?.Invoke(type, value);
});
}
@@ -203,7 +197,7 @@ namespace Serein.Workbench.Services
///
private void FlowEnvironment_OnProjectSaving(ProjectSavingEventArgs eventArgs)
{
- OnProjectSaving?.Invoke(eventArgs);
+ ProjectSaving?.Invoke(eventArgs);
}
///
@@ -212,7 +206,7 @@ namespace Serein.Workbench.Services
///
private void FlowEnvironment_OnProjectLoaded(ProjectLoadedEventArgs eventArgs)
{
- OnProjectLoaded?.Invoke(eventArgs);
+ ProjectLoaded?.Invoke(eventArgs);
}
///
@@ -223,7 +217,7 @@ namespace Serein.Workbench.Services
private void FlowEnvironment_OnFlowRunCompleteEvent(FlowEventArgs eventArgs)
{
SereinEnv.WriteLine(InfoType.INFO, "-------运行完成---------\r\n");
- OnFlowRunComplete?.Invoke(eventArgs);
+ FlowRunComplete?.Invoke(eventArgs);
}
///
@@ -231,7 +225,7 @@ namespace Serein.Workbench.Services
///
private void FlowEnvironment_DllLoadEvent(LoadDllEventArgs eventArgs)
{
- OnDllLoad?.Invoke(eventArgs);
+ DllLoad?.Invoke(eventArgs);
}
///
@@ -240,7 +234,7 @@ namespace Serein.Workbench.Services
///
private void FlowEnvironment_NodeConnectChangeEvemt(NodeConnectChangeEventArgs eventArgs)
{
- OnNodeConnectChange?.Invoke(eventArgs);
+ NodeConnectChanged?.Invoke(eventArgs);
}
@@ -251,7 +245,7 @@ namespace Serein.Workbench.Services
///
private void FlowEnvironmentEvent_OnCanvasCreate(CanvasCreateEventArgs eventArgs)
{
- OnCanvasCreate?.Invoke(eventArgs);
+ CanvasCreated?.Invoke(eventArgs);
}
///
@@ -261,7 +255,7 @@ namespace Serein.Workbench.Services
///
private void FlowEnvironmentEvent_OnCanvasRemove(CanvasRemoveEventArgs eventArgs)
{
- OnCanvasRemove?.Invoke(eventArgs);
+ CanvasRemoved?.Invoke(eventArgs);
}
@@ -271,7 +265,7 @@ namespace Serein.Workbench.Services
///
private void FlowEnvironment_NodeRemoveEvent(NodeRemoveEventArgs eventArgs)
{
- OnNodeRemove?.Invoke(eventArgs);
+ NodeRemoved?.Invoke(eventArgs);
}
///
@@ -281,7 +275,7 @@ namespace Serein.Workbench.Services
///
private void FlowEnvironment_NodeCreateEvent(NodeCreateEventArgs eventArgs)
{
- OnNodeCreate?.Invoke(eventArgs);
+ NodeCreated?.Invoke(eventArgs);
}
///
@@ -291,7 +285,7 @@ namespace Serein.Workbench.Services
///
private void FlowEnvironment_OnNodePlaceEvent(NodePlaceEventArgs eventArgs)
{
- OnNodePlace?.Invoke(eventArgs);
+ NodePlace?.Invoke(eventArgs);
}
///
@@ -300,7 +294,7 @@ namespace Serein.Workbench.Services
///
private void FlowEnvironment_OnNodeTakeOutEvent(NodeTakeOutEventArgs eventArgs)
{
- OnNodeTakeOut?.Invoke(eventArgs);
+ NodeTakeOut?.Invoke(eventArgs);
}
@@ -312,7 +306,7 @@ namespace Serein.Workbench.Services
private void FlowEnvironment_StartNodeChangeEvent(StartNodeChangeEventArgs eventArgs)
{
- OnStartNodeChange?.Invoke(eventArgs);
+ StartNodeChanged?.Invoke(eventArgs);
}
///
@@ -321,7 +315,7 @@ namespace Serein.Workbench.Services
///
private void FlowEnvironment_OnMonitorObjectChangeEvent(MonitorObjectEventArgs eventArgs)
{
- OnMonitorObjectChange?.Invoke(eventArgs);
+ MonitorObjectChanged?.Invoke(eventArgs);
}
///
@@ -330,7 +324,7 @@ namespace Serein.Workbench.Services
///
private void FlowEnvironment_OnNodeInterruptStateChangeEvent(NodeInterruptStateChangeEventArgs eventArgs)
{
- OnNodeInterruptStateChange?.Invoke(eventArgs);
+ NodeInterruptStateChanged?.Invoke(eventArgs);
}
///
@@ -340,7 +334,7 @@ namespace Serein.Workbench.Services
///
private void FlowEnvironment_OnInterruptTriggerEvent(InterruptTriggerEventArgs eventArgs)
{
- OnInterruptTrigger?.Invoke(eventArgs);
+ InterruptTriggered?.Invoke(eventArgs);
}
///
@@ -350,7 +344,7 @@ namespace Serein.Workbench.Services
///
private void FlowEnvironment_OnIOCMembersChangedEvent(IOCMembersChangedEventArgs eventArgs)
{
- OnIOCMembersChanged?.Invoke(eventArgs);
+ IOCMembersChanged?.Invoke(eventArgs);
}
@@ -361,25 +355,110 @@ namespace Serein.Workbench.Services
///
private void FlowEnvironment_OnNodeLocateEvent(NodeLocatedEventArgs eventArgs)
{
- OnNodeLocated?.Invoke(eventArgs);
+ NodeLocated?.Invoke(eventArgs);
}
-
- ///
- /// 节点移动
- ///
- ///
- private void FlowEnvironment_OnNodeMovedEvent(NodeMovedEventArgs eventArgs)
+
+
+
+
+
+
+ #endregion
+
+
+ #endregion
+
+ #region 主动触发运行环境事件
+ public void OnDllLoad(LoadDllEventArgs eventArgs)
{
- OnNodeMoved?.Invoke(eventArgs);
+ throw new NotImplementedException();
}
+ public void OnProjectLoaded(ProjectLoadedEventArgs eventArgs)
+ {
+ throw new NotImplementedException();
+ }
+ public void OnProjectSaving(ProjectSavingEventArgs eventArgs)
+ {
+ throw new NotImplementedException();
+ }
+
+ public void OnNodeConnectChanged(NodeConnectChangeEventArgs eventArgs)
+ {
+ throw new NotImplementedException();
+ }
+
+ public void OnCanvasCreated(CanvasCreateEventArgs eventArgs)
+ {
+ throw new NotImplementedException();
+ }
+
+ public void OnCanvasRemoved(CanvasRemoveEventArgs eventArgs)
+ {
+ throw new NotImplementedException();
+ }
+
+ public void OnNodeCreated(NodeCreateEventArgs eventArgs)
+ {
+ throw new NotImplementedException();
+ }
+
+ public void OnNodeRemoved(NodeRemoveEventArgs eventArgs)
+ {
+ throw new NotImplementedException();
+ }
+
+ public void OnNodePlace(NodePlaceEventArgs eventArgs)
+ {
+ throw new NotImplementedException();
+ }
+
+ public void OnNodeTakeOut(NodeTakeOutEventArgs eventArgs)
+ {
+ throw new NotImplementedException();
+ }
+
+ public void OnStartNodeChanged(StartNodeChangeEventArgs eventArgs)
+ {
+ throw new NotImplementedException();
+ }
+
+ public void OnFlowRunComplete(FlowEventArgs eventArgs)
+ {
+ throw new NotImplementedException();
+ }
+
+ public void OnMonitorObjectChanged(MonitorObjectEventArgs eventArgs)
+ {
+ throw new NotImplementedException();
+ }
+
+ public void OnNodeInterruptStateChanged(NodeInterruptStateChangeEventArgs eventArgs)
+ {
+ throw new NotImplementedException();
+ }
+
+ public void OnInterruptTriggered(InterruptTriggerEventArgs eventArgs)
+ {
+ throw new NotImplementedException();
+ }
+
+ public void OnIOCMembersChanged(IOCMembersChangedEventArgs eventArgs)
+ {
+ throw new NotImplementedException();
+ }
+
+ public void OnNodeLocated(NodeLocatedEventArgs eventArgs)
+ {
+ throw new NotImplementedException();
+ }
+
+ public void OnEnvOutput(InfoType type, string value)
+ {
+ throw new NotImplementedException();
+ }
#endregion
-
-
- #endregion
-
-
}
}
diff --git a/Workbench/Services/FlowNodeService.cs b/Workbench/Services/FlowNodeService.cs
index 25841f1..ce75c20 100644
--- a/Workbench/Services/FlowNodeService.cs
+++ b/Workbench/Services/FlowNodeService.cs
@@ -190,17 +190,17 @@ namespace Serein.Workbench.Services
///
private void InitFlowEvent()
{
- flowEEForwardingService.OnCanvasCreate += FlowEEForwardingService_OnCanvasCreate; // 创建了画布
- flowEEForwardingService.OnCanvasRemove += FlowEEForwardingService_OnCanvasRemove; // 移除了画布
- flowEEForwardingService.OnNodeCreate += FlowEEForwardingService_OnNodeCreate; // 创建了节点
- flowEEForwardingService.OnNodeRemove += FlowEEForwardingService_OnNodeRemove; // 移除了节点
+ flowEEForwardingService.CanvasCreated += FlowEEForwardingService_OnCanvasCreate; // 创建了画布
+ flowEEForwardingService.CanvasRemoved += FlowEEForwardingService_OnCanvasRemove; // 移除了画布
+ flowEEForwardingService.NodeCreated += FlowEEForwardingService_OnNodeCreate; // 创建了节点
+ flowEEForwardingService.NodeRemoved += FlowEEForwardingService_OnNodeRemove; // 移除了节点
- flowEEForwardingService.OnNodePlace += FlowEEForwardingService_OnNodePlace; // 节点放置在容器中
- flowEEForwardingService.OnNodeTakeOut += FlowEEForwardingService_OnNodeTakeOut; ; // 节点从容器中取出
+ flowEEForwardingService.NodePlace += FlowEEForwardingService_OnNodePlace; // 节点放置在容器中
+ flowEEForwardingService.NodeTakeOut += FlowEEForwardingService_OnNodeTakeOut; ; // 节点从容器中取出
- flowEEForwardingService.OnNodeConnectChange += FlowEEForwardingService_OnNodeConnectChange; // 节点连接状态改变事件
+ flowEEForwardingService.NodeConnectChanged += FlowEEForwardingService_OnNodeConnectChange; // 节点连接状态改变事件
- flowEEForwardingService.OnStartNodeChange += FlowEEForwardingService_OnStartNodeChange; // 画布起始节点改变
+ flowEEForwardingService.StartNodeChanged += FlowEEForwardingService_OnStartNodeChange; // 画布起始节点改变
}
diff --git a/Workbench/Services/WorkbenchEventService.cs b/Workbench/Services/WorkbenchEventService.cs
index 0e25087..07f9b53 100644
--- a/Workbench/Services/WorkbenchEventService.cs
+++ b/Workbench/Services/WorkbenchEventService.cs
@@ -82,9 +82,9 @@ namespace Serein.Workbench.Services
private void InitEvents()
{
- flowEEForwardingService.OnProjectLoaded += FlowEEForwardingService_OnProjectLoaded;
- flowEEForwardingService.OnProjectSaving += SaveProjectToLocalFile;
- flowEEForwardingService.OnEnvOut += FlowEEForwardingService_OnEnvOut;
+ flowEEForwardingService.ProjectLoaded += FlowEEForwardingService_OnProjectLoaded;
+ flowEEForwardingService.ProjectSaving += SaveProjectToLocalFile;
+ flowEEForwardingService.EnvOutput += FlowEEForwardingService_OnEnvOut;
keyEventService.OnKeyDown += KeyEventService_OnKeyDown; ;
}
diff --git a/Workbench/Themes/NodeTreeItemViewControl.xaml.cs b/Workbench/Themes/NodeTreeItemViewControl.xaml.cs
index 54c9637..b348f88 100644
--- a/Workbench/Themes/NodeTreeItemViewControl.xaml.cs
+++ b/Workbench/Themes/NodeTreeItemViewControl.xaml.cs
@@ -150,7 +150,7 @@ namespace Serein.Workbench.Themes
return;
}
}));
- contextMenu.Items.Add(WpfFuncTool.CreateMenuItem("定位", (s, e) => flowEnvironment.NodeLocated(tmpNodeTreeModel.RootNode.Guid)));
+ contextMenu.Items.Add(WpfFuncTool.CreateMenuItem("定位", (s, e) => flowEnvironment.NodeLocate(tmpNodeTreeModel.RootNode.Guid)));
treeViewItem.ContextMenu = contextMenu;
treeViewItem.Margin = new Thickness(-20, 0, 0, 0);
diff --git a/Workbench/ViewModels/FlowLibrarysViewModel.cs b/Workbench/ViewModels/FlowLibrarysViewModel.cs
index 52a7bdf..805f9fc 100644
--- a/Workbench/ViewModels/FlowLibrarysViewModel.cs
+++ b/Workbench/ViewModels/FlowLibrarysViewModel.cs
@@ -26,7 +26,7 @@ namespace Serein.Workbench.ViewModels
this.flowEEForwardingService = flowEEForwardingService;
this.flowEnvironment = flowEnvironment;
FlowLibraryInfos = new ObservableCollection();
- flowEEForwardingService.OnDllLoad += FlowEEForwardingService_OnDllLoad;
+ flowEEForwardingService.DllLoad += FlowEEForwardingService_OnDllLoad;
}
///
/// 加载文件依赖
diff --git a/Workbench/Views/FlowCanvasView.xaml.cs b/Workbench/Views/FlowCanvasView.xaml.cs
index bfd61f2..2dc0fdf 100644
--- a/Workbench/Views/FlowCanvasView.xaml.cs
+++ b/Workbench/Views/FlowCanvasView.xaml.cs
@@ -41,6 +41,7 @@ using UserControl = System.Windows.Controls.UserControl;
using Clipboard = System.Windows.Clipboard;
using TextDataFormat = System.Windows.TextDataFormat;
using System.Windows.Media.Animation;
+using Serein.NodeFlow.Model;
namespace Serein.Workbench.Views
{
@@ -174,7 +175,7 @@ namespace Serein.Workbench.Views
private void InitEvent()
{
keyEventService.OnKeyDown += KeyEventService_OnKeyDown;
- flowEEForwardingService.OnNodeLocated += FlowEEForwardingService_OnNodeLocated;
+ flowEEForwardingService.NodeLocated += FlowEEForwardingService_OnNodeLocated;
}
///
@@ -1348,9 +1349,9 @@ namespace Serein.Workbench.Views
var actualDeltaX = newLeft - oldLeft;
var actualDeltaY = newTop - oldTop;
- List<(string Guid, double NewLeft, double NewTop, double MaxWidth, double MaxHeight)> moveSizes =
+ List<(IFlowNode Node, double NewLeft, double NewTop, double MaxWidth, double MaxHeight)> moveSizes =
selectNodeControls.Select(control =>
- (control.ViewModel.NodeModel.Guid,
+ (control.ViewModel.NodeModel,
Canvas.GetLeft(control) + actualDeltaX,
Canvas.GetTop(control) + actualDeltaY,
control.FlowCanvas.Model.Width - control.ActualWidth - 10,
@@ -1363,7 +1364,10 @@ namespace Serein.Workbench.Views
}
foreach (var item in moveSizes)
{
- this.flowEnvironment.MoveNode(this.Guid, item.Guid, item.NewLeft, item.NewTop); // 移动节点
+ item.Node.Position.X = item.NewLeft;
+ item.Node.Position.Y = item.NewTop;
+
+ //this.flowEnvironment.MoveNode(this.Guid, item.Guid, item.NewLeft, item.NewTop); // 移动节点
}
// 更新节点之间线的连接位置
@@ -1390,7 +1394,11 @@ namespace Serein.Workbench.Views
newLeft = newLeft < 5 ? 5 : newLeft > canvasWidth ? canvasWidth : newLeft;
newTop = newTop < 5 ? 5 : newTop > canvasHeight ? canvasHeight : newTop;
- this.flowEnvironment.MoveNode(Guid, nodeControl.ViewModel.NodeModel.Guid, newLeft, newTop); // 移动节点
+ var node = nodeControl.ViewModel.NodeModel;
+ node.Position.X = newLeft;
+ node.Position.Y = newTop;
+
+ //this.flowEnvironment.MoveNode(Guid, nodeControl.ViewModel.NodeModel.Guid, newLeft, newTop); // 移动节点
nodeControl.UpdateLocationConnections();
}
startControlDragPoint = currentPosition; // 更新起始点位置
diff --git a/Workbench/Views/ViewCanvasInfoView.xaml b/Workbench/Views/ViewCanvasInfoView.xaml
index 4171ad3..b03cc1f 100644
--- a/Workbench/Views/ViewCanvasInfoView.xaml
+++ b/Workbench/Views/ViewCanvasInfoView.xaml
@@ -109,6 +109,14 @@
+
+
+
+
+
+
+
+
diff --git a/Workbench/Views/ViewCanvasInfoView.xaml.cs b/Workbench/Views/ViewCanvasInfoView.xaml.cs
index eef6097..1016f8c 100644
--- a/Workbench/Views/ViewCanvasInfoView.xaml.cs
+++ b/Workbench/Views/ViewCanvasInfoView.xaml.cs
@@ -39,7 +39,7 @@ namespace Serein.Workbench.Views
if (sender is Grid grid && grid.DataContext is IFlowNode nodeModel)
{
NodeInfoViewModel.ViewNodeModel = nodeModel;
- App.GetService().NodeLocated(nodeModel.Guid);
+ App.GetService().NodeLocate(nodeModel.Guid);
}
// 定位节点
diff --git a/Workbench/Views/ViewNodeInfoView.xaml b/Workbench/Views/ViewNodeInfoView.xaml
index c34731e..cdb8bcf 100644
--- a/Workbench/Views/ViewNodeInfoView.xaml
+++ b/Workbench/Views/ViewNodeInfoView.xaml
@@ -41,6 +41,14 @@
+
+
+
+
+
+
+
+