由于我的应用程序中的一个奇怪的行为,我被迫在调用WorkflowInvoker.Invoke之前重新加载设计器。
wd.Flush();
SaveXamlFile(currentXamlPath, wd.Text);
我只是刷新内容,并将wd.Text写入文件。
//cleanup the previous designer
if (wd != null)
{
wd.ModelChanged -= new EventHandler(Designer_ModelChanged);
}
//designer
wd = new WorkflowDesigner();
designerArea.Child = wd.View;
this.DebuggerService = this.wd.DebugManagerView;
//property grid
propertiesArea.Child = wd.PropertyInspectorView;
//event handler
wd.ModelChanged += new EventHandler(Designer_ModelChanged);
//error service
wd.Context.Services.Publish<IValidationErrorService>(errorService);
wd.Context.Items.Subscribe<Selection>(OnItemSelected);
然后,我重新创建WorkflowDesigner的新实例并加载以前保存的文件。
wd.Load(currentXamlPath);
我调用WorkflowInvoker.Invoke并在我的自定义活动中从CodeActivity派生我正在使用它的名字:好的,直到现在,我有1.2 Id。
我想通过其ModelItem更新此Activity的一些字段,以便立即在GUI中显示它们。
IEnumerable<ModelItem> activityCollection = currentWorkflow.Find(currentWorkflow.Root, typeof(Activity));
但问题出现了:
我在那里找不到我的Activity id。现在从1.2变为2.为什么会发生这种情况?
我试图从我的Activity Execute方法发送这个引用并通过ref搜索它,但我得到的只是空值。
ModelItem temp = activityCollection.FirstOrDefault((m) => (m.GetCurrentValue() == a));
我相信我在这里遗漏了一些东西,但我无法弄清楚它是什么。
我发现了一个解决方法:
在我的自定义活动中,我添加了一个Guid属性,并覆盖了CacheMetadata:
public Guid unique { get; set; }
protected override void CacheMetadata(CodeActivityMetadata metadata)
{
if (unique.ToString() == "00000000-0000-0000-0000-000000000000")
unique = Guid.NewGuid();
}
当我在设计器上拖动活动时,会生成唯一ID。我确保只调用一部分代码。这是为什么?
因为在这样的电话之后,
IEnumerable<ModelItem> activityCollection = currentWorkflow.Find(currentWorkflow.Root, typeof(Activity));
activity列表中的每个模型都包含该属性(Guid类型的唯一属性),其中包含在CacheMetadata中进行的第一个赋值。我无法解释这种行为,我只是考虑到了这一点。
谁再次调用CacheMetadata?这样的事情:
Activity root = ActivityXamlServices.Load(currentXamlPath);
WorkflowInspectionServices.CacheMetadata(root);
因此,Guid已经改变,其实用性已经消失。
这样,我就能够为我的自定义活动获取ModelItem,并更新一些立即显示在GUI中的属性。