Partilhar via


Designers compostos personalizados - Apresentador de item de fluxo de trabalho

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

O exemplo WorkflowItemPresenter demonstra:

  • Criando um designer de atividade personalizado com um WorkflowItemPresenterarquivo .

  • Registrando o designer personalizado usando o repositório de metadados.

  • Programar a caixa de ferramentas rehospedada declarativa e imperativamente.

Detalhes da amostra

O código para este exemplo mostra:

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

  • A criação de um designer de atividades personalizado com um WorkflowItemPresenterarquivo .

<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 da vinculação de dados WPF para vincular ao 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.

Consulte também