Compartilhar via


Designer de compostos personalizados - apresentador de item de fluxo de trabalho

O WorkflowItemPresenter é um tipo de chave no modelo de programação do designer WF que permite a criação de uma "zona de lançamento" onde uma atividade arbitrária pode ser colocada. Este exemplo mostra como criar um designer de atividade que apresenta uma "área para arrastar e soltar".

O exemplo WorkflowItemPresenter demonstra:

  • Criando um designer personalizado de atividade com WorkflowItemPresenter.

  • Registrando o designer personalizado que usa o armazenamento de metadados.

  • Programando a caixa de ferramentas rehosted declarativamente e imperativa.

Detalhes de exemplo

O código para esse exemplo mostra:

  • O designer personalizado de atividade é compilado para a classe de SimpleNativeActivity .

  • A criação de um designer personalizado de atividade com WorkflowItemPresenter.

<sap:ActivityDesigner x:Class="Microsoft.Samples.UsingWorkflowItemPresenter.SimpleNativeDesigner"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:sap="clr-namespace:System.Activities.Presentation;assembly=System.Activities.Presentation"
    xmlns:sapv="clr-namespace:System.Activities.Presentation.View;assembly=System.Activities.Presentation">
    <sap:ActivityDesigner.Resources>
        <DataTemplate x:Key="Collapsed">
            <StackPanel>
                <TextBlock>This is the collapsed view</TextBlock>
            </StackPanel>
        </DataTemplate>
        <DataTemplate x:Key="Expanded">
            <StackPanel>
                <TextBlock>Custom Text</TextBlock>
                <sap:WorkflowItemPresenter Item="{Binding Path=ModelItem.Body, Mode=TwoWay}"
                                        HintText="Please drop an activity here" />
            </StackPanel>
        </DataTemplate>
        <Style x:Key="ExpandOrCollapsedStyle" TargetType="{x:Type ContentPresenter}">
            <Setter Property="ContentTemplate" Value="{DynamicResource Collapsed}"/>
            <Style.Triggers>
                <DataTrigger Binding="{Binding Path=ShowExpanded}" Value="true">
                    <Setter Property="ContentTemplate" Value="{DynamicResource Expanded}"/>
                </DataTrigger>
            </Style.Triggers>
        </Style>
    </sap:ActivityDesigner.Resources>
    <Grid>
        <ContentPresenter Style="{DynamicResource ExpandOrCollapsedStyle}" Content="{Binding}" />
    </Grid>
</sap:ActivityDesigner>

Observe o uso de associação de dados de WPF associar a ModelItem.Body. ModelItem é a propriedade em ActivityDesigner que se refere ao objeto subjacente para o qual o designer está sendo usado, neste caso, SimpleNativeActivity.

Configurar, compilar e executar o exemplo

  1. Abra a solução no Visual Studio.

  2. Pressione F5 para compilar e executar o aplicativo.

Confira também