Procedura: Creare un modello di attività personalizzato
I modelli di attività personalizzati vengono usati per personalizzare la configurazione delle attività, incluse CompositeActivity personalizzate, in modo che gli utenti non debbano creare individualmente ciascuna attività e configurare manualmente le relative proprietà e altre impostazioni. Questi modelli personalizzati possono essere resi disponibili nella Casella degli strumenti in Windows Workflow Designer o da una finestra di progettazione riallocata dalla quale gli utenti possono trascinarli nell'area di progettazione preconfigurata. In Progettazione flussi di lavoro sono disponibili validi esempi di questi modelli: Finestra di progettazione del modello SendAndReceiveReply e Finestra di progettazione del modello ReceiveAndSendReply nella categoria ActivityDesigner di messaggistica.
Nella prima procedura di questo argomento viene descritto come creare un modello di attività personalizzato per un'attività Delay, mentre nella seconda procedura viene descritto brevemente come renderlo disponibile in Workflow Designer per verificare che il modello personalizzato funzioni.
I modelli di attività personalizzati devono implementare l'oggetto IActivityTemplateFactory. L'interfaccia dispone di un singolo metodo Create con il quale è possibile creare e configurare le istanze dell'attività usate nel modello.
Per creare un modello per l'attività Delay
Avviare Visual Studio 2010.
Scegliere Nuovo dal menu Filee quindi selezionare Progetto.
Verrà visualizzata la finestra di dialogo Nuovo progetto .
Nel riquadro Tipi progetto selezionare Flusso di lavoro dal gruppo di progetti Visual C# o Visual Basic a seconda del linguaggio preferito.
Nel riquadro Modelli selezionare Libreria attività.
Nella casella Nome immettere
DelayActivityTemplate
.Accettare le impostazioni predefinite nelle caselle di testo Percorso e Nome soluzione, quindi fare clic su OK.
Fare clic con il pulsante destro del mouse sulla directory Riferimenti del progetto DelayActivityTemplate in Esplora soluzioni e scegliere Aggiungi riferimento per aprire la finestra di dialogo corrispondente.
Andare alla scheda .NET e selezionare PresentationFramework dalla colonna Nome componente a sinistra e fare clic su OK per aggiungere un riferimento al file PresentationFramework.dll.
Ripetere questa procedura per aggiungere riferimenti ai file System.Activities.Presentation.dll e WindowsBase.dll.
Fare clic con il pulsante destro del mouse sul progetto DelayActivityTemplate in Esplora soluzioni, scegliere Aggiungi, quindi fare clic su Nuovo elemento per aprire la finestra di dialogo Aggiungi nuovo elemento.
Selezionare il modello Class, denominarlo MyDelayTemplate e quindi fare clic su OK.
Aprire il file MyDelayTemplate.cs e aggiungere le istruzioni seguenti.
//Namespaces added using System.Activities; using System.Activities.Statements; using System.Activities.Presentation; using System.Windows;
Implementare IActivityTemplateFactory con la classe
MyDelayActivity
con il codice seguente. In questo modo viene configurata una durata del ritardo di 10 secondi.public sealed class MyDelayActivity : IActivityTemplateFactory { public Activity Create(System.Windows.DependencyObject target) { return new System.Activities.Statements.Delay { DisplayName = "DelayActivityTemplate", Duration = new TimeSpan(0, 0, 10) }; } }
Selezionare Compila soluzione dal menu Compila per generare il file DelayActivityTemplate.dll.
Per rendere disponibile il modello in Progettazione flussi di lavoro
Fare clic con il pulsante destro del mouse sulla soluzione DelayActivityTemplate in Esplora soluzioni, scegliere Aggiungi, quindi fare clic su Nuovo progetto per aprire la finestra di dialogo Aggiungi nuovo progetto.
Selezionare il modello Applicazione console flusso di lavoro, denominarlo
CustomActivityTemplateApp
e quindi fare clic su OK.Fare clic con il pulsante destro del mouse sulla directory Riferimenti del progetto CustomActivityTemplateApp in Esplora soluzioni e scegliere Aggiungi riferimento per aprire la finestra di dialogo corrispondente.
Andare alla scheda Progetti e selezionare DelayActivityTemplate dalla colonna Nome progetto a sinistra e fare clic su OK per aggiungere un riferimento al file DelayActivityTemplate.dll creato nella prima procedura.
Fare clic con il pulsante destro del mouse sul progetto CustomActivityTemplateApp in Esplora soluzioni e scegliere Compila per compilare l'applicazione.
Fare clic con il pulsante destro del mouse sul progetto CustomActivityTemplateApp in Esplora soluzioni e scegliere Imposta come progetto di avvio.
Selezionare Avvia senza eseguire debug dal menu Debug e premere qualsiasi tasto per continuare quando richiesto nella finestra di cmd.exe.
Aprire il file Workflow1.xaml e quindi Casella degli strumenti.
Individuare il modello MyDelayActivity nella categoria DelayActivityTemplate. Trascinarlo nell'area di progettazione. Nella finestra Proprietà verificare che la proprietà
Duration
sia impostata su 10 secondi.
Esempio
Il file MyDelayActivity.cs deve contenere il codice seguente.
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
//Namespaces added
using System.Activities;
using System.Activities.Statements;
using System.Activities.Presentation;
using System.Windows;
namespace DelayActivityTemplate
{
public sealed class MyDelayActivity : IActivityTemplateFactory
{
public Activity Create(System.Windows.DependencyObject target)
{
return new System.Activities.Statements.Delay
{
DisplayName = "DelayActivityTemplate",
Duration = new TimeSpan(0, 0, 10)
};
}
}
}