共用方式為


自訂複合設計工具 - 工作流程項目展示器

System.Activities.Presentation.WorkflowItemsPresenter 是 WF 設計工具程式撰寫模型中的關鍵類型,允許編輯包含的項目集合。 這個範例示範如何建置會呈現這類可編輯集合的活動設計工具。

WorkflowItemsPresenter 範例 (英文) 會示範:

設定、建置及執行範例

  1. 在 Visual Studio 中開啟適用於 C# 或 Visual Basic 的 UsingWorkflowItemsPresenter.sln 範例方案。

  2. 建置並執行方案。

    重新裝載的工作流程設計工具應用程式隨即開啟,您可以將活動拖曳至畫布上。

範例重點項目

這個範例的程式碼示範下列操作:

  • 設計工具建置的目標活動:Parallel

  • 建立具有 System.Activities.Presentation.WorkflowItemsPresenter 的自訂活動設計工具 請注意下列幾點事項:

    • 請注意繫結至 ModelItem.Branches 的 WPF 資料繫結用法。 ModelItemWorkflowElementDesigner 上的屬性,它會參考設計工具的目標基礎物件,在這個範例中為 Parallel

    • WorkflowItemsPresenter.SpacerTemplate 可用來放置視覺效果,在集合中的個別項目之間顯示。

    • WorkflowItemsPresenter.ItemsPanel 是範本,可供判斷集合中的項目配置。 在這個範例中,會使用水平堆疊面板。

    下列範例程式碼會示範這點。

    <sad:WorkflowItemsPresenter HintText="Drop Activities Here"
                                  Items="{Binding Path=ModelItem.Branches}">
        <sad:WorkflowItemsPresenter.SpacerTemplate>
          <DataTemplate>
            <Ellipse Width="10" Height="10" Fill="Black"/>
          </DataTemplate>
        </sad:WorkflowItemsPresenter.SpacerTemplate>
        <sad:WorkflowItemsPresenter.ItemsPanel>
          <ItemsPanelTemplate>
            <StackPanel Orientation="Horizontal"/>
          </ItemsPanelTemplate>
        </sad:WorkflowItemsPresenter.ItemsPanel>
      </sad:WorkflowItemsPresenter>
    
  • 執行 DesignerAttributeParallel 類型的關聯,然後輸出回報的屬性。

    • 首先,註冊所有預設設計工具。

      以下是程式碼範例。

      // register metadata
      (new DesignerMetadata()).Register();
      RegisterCustomMetadata();
      
      ' register metadata
      Dim metadata = New DesignerMetadata()
      metadata.Register()
      ' register custom metadata
      RegisterCustomMetadata()
      
    • 接著覆寫 RegisterCustomMetadata 方法中的 parallel。

      下列 C# 和 Visual Basic 程式碼會示範這點。

      void RegisterCustomMetadata()
      {
            AttributeTableBuilder builder = new AttributeTableBuilder();
            builder.AddCustomAttributes(typeof(Parallel), new DesignerAttribute(typeof(CustomParallelDesigner)));
            MetadataStore.AddAttributeTable(builder.CreateTable());
      }
      
      Sub RegisterCustomMetadata()
         Dim builder As New AttributeTableBuilder()
         builder.AddCustomAttributes(GetType(Parallel), New DesignerAttribute(GetType(CustomParallelDesigner)))
         MetadataStore.AddAttributeTable(builder.CreateTable())
      End Sub
      
  • 最後,請注意不同資料範本和觸發程序根據 IsRootDesigner 屬性來選取適當範本的用法。

    以下是程式碼範例。

    <sad:ActivityDesigner x:Class="Microsoft.Samples.CustomParallelDesigner"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:sad="clr-namespace:System.Activities.Design;assembly=System.Activities.Design"
        xmlns:sadv="clr-namespace:System.Activities.Design.View;assembly=System.Activities.Design">
      <sad:ActivityDesigner.Resources>
        <DataTemplate x:Key="Expanded">
          <StackPanel>
            <TextBlock>This is the Expanded View</TextBlock>
            <sad:WorkflowItemsPresenter HintText="Drop Activities Here"
                                        Items="{Binding Path=ModelItem.Branches}">
              <sad:WorkflowItemsPresenter.SpacerTemplate>
                <DataTemplate>
                  <Ellipse Width="10" Height="10" Fill="Black"/>
                </DataTemplate>
              </sad:WorkflowItemsPresenter.SpacerTemplate>
              <sad:WorkflowItemsPresenter.ItemsPanel>
                <ItemsPanelTemplate>
                  <StackPanel Orientation="Horizontal"/>
                </ItemsPanelTemplate>
              </sad:WorkflowItemsPresenter.ItemsPanel>
            </sad:WorkflowItemsPresenter>
          </StackPanel>
        </DataTemplate>
        <DataTemplate x:Key="Collapsed">
          <TextBlock>This is the Collapsed View</TextBlock>
        </DataTemplate>
        <Style x:Key="ExpandOrCollapsedStyle" TargetType="{x:Type ContentPresenter}">
          <Setter Property="ContentTemplate" Value="{DynamicResource Collapsed}"/>
          <Style.Triggers>
            <DataTrigger Binding="{Binding Path=IsRootDesigner}" Value="true">
              <Setter Property="ContentTemplate" Value="{DynamicResource Expanded}"/>
            </DataTrigger>
          </Style.Triggers>
        </Style>
      </sad: ActivityDesigner.Resources>
      <Grid>
        <ContentPresenter Style="{DynamicResource ExpandOrCollapsedStyle}" Content="{Binding}"/>
      </Grid>
    </sad: ActivityDesigner>
    

另請參閱