Share via


TrackingProfile.ActivityTrackPoints Propriété

Définition

Obtient la collection de trackpoints d’activité utilisée par l’infrastructure de suivi d’exécution pour filtrer les événements de statut d’activité.

public:
 property System::Workflow::Runtime::Tracking::ActivityTrackPointCollection ^ ActivityTrackPoints { System::Workflow::Runtime::Tracking::ActivityTrackPointCollection ^ get(); };
public System.Workflow.Runtime.Tracking.ActivityTrackPointCollection ActivityTrackPoints { get; }
member this.ActivityTrackPoints : System.Workflow.Runtime.Tracking.ActivityTrackPointCollection
Public ReadOnly Property ActivityTrackPoints As ActivityTrackPointCollection

Valeur de propriété

ActivityTrackPointCollection qui spécifie les points dans une instance de workflow pour lesquels l'infrastructure de suivi d'exécution doit envoyer un ActivityTrackingRecord au service de suivi.

Exemples

L'exemple de code suivant montre comment créer un TrackingProfile à l'aide du constructeur TrackingProfile et utiliser les propriétés de l'objet pour aider à effectuer le suivi de l'exécution d'un workflow. L'exemple de code utilise les propriétés ActivityTrackPoints, Version et WorkflowTrackPoints.

Cet exemple de code fait partie de l'exemple du Kit de développement logiciel Query using SQLTrackingService (SDK) et provient du fichier Program.cs. Pour plus d’informations, consultez Interroger à l’aide de SQLTrackingService.

private static void CreateAndInsertTrackingProfile()
{
    TrackingProfile profile = new TrackingProfile();
    ActivityTrackPoint activityTrack = new ActivityTrackPoint();
    ActivityTrackingLocation activityLocation = new ActivityTrackingLocation(typeof(Activity));
    activityLocation.MatchDerivedTypes = true;
    IEnumerable<ActivityExecutionStatus> statuses = Enum.GetValues(typeof(ActivityExecutionStatus)) as IEnumerable<ActivityExecutionStatus>;
    foreach (ActivityExecutionStatus status in statuses)
    {
        activityLocation.ExecutionStatusEvents.Add(status);
    }

    activityTrack.MatchingLocations.Add(activityLocation);
    profile.ActivityTrackPoints.Add(activityTrack);
    profile.Version = version;

    WorkflowTrackPoint workflowTrack = new WorkflowTrackPoint();
    WorkflowTrackingLocation workflowLocation = new WorkflowTrackingLocation();
    IEnumerable<TrackingWorkflowEvent> eventStatuses = Enum.GetValues(typeof(TrackingWorkflowEvent)) as IEnumerable<TrackingWorkflowEvent>;
    foreach (TrackingWorkflowEvent status in eventStatuses)
    {
        workflowLocation.Events.Add(status);
    }

    workflowTrack.MatchingLocation = workflowLocation;
    profile.WorkflowTrackPoints.Add(workflowTrack);

    TrackingProfileSerializer serializer = new TrackingProfileSerializer();
    StringWriter writer = new StringWriter(new StringBuilder(), CultureInfo.InvariantCulture);
    serializer.Serialize(writer, profile);
    string trackingprofile = writer.ToString();
    InsertTrackingProfile(trackingprofile);
}
Shared Sub CreateAndInsertTrackingProfile()
    Dim profile As TrackingProfile = New TrackingProfile()

    Dim activityTrack As ActivityTrackPoint = New ActivityTrackPoint()
    Dim activityLocation As ActivityTrackingLocation = New ActivityTrackingLocation(GetType(Activity))
    activityLocation.MatchDerivedTypes = True
    Dim statuses As IEnumerable(Of ActivityExecutionStatus) = CType(System.Enum.GetValues(GetType(ActivityExecutionStatus)), IEnumerable(Of ActivityExecutionStatus))
    For Each status As ActivityExecutionStatus In statuses
        activityLocation.ExecutionStatusEvents.Add(status)
    Next

    activityTrack.MatchingLocations.Add(activityLocation)
    profile.ActivityTrackPoints.Add(activityTrack)
    profile.Version = version

    Dim workflowTrack As WorkflowTrackPoint = New WorkflowTrackPoint()
    Dim workflowLocation As WorkflowTrackingLocation = New WorkflowTrackingLocation()
    Dim eventStatuses As IEnumerable(Of TrackingWorkflowEvent) = CType(System.Enum.GetValues(GetType(TrackingWorkflowEvent)), IEnumerable(Of TrackingWorkflowEvent))
    For Each status As TrackingWorkflowEvent In eventStatuses
        workflowLocation.Events.Add(status)
    Next

    workflowTrack.MatchingLocation = workflowLocation
    profile.WorkflowTrackPoints.Add(workflowTrack)

    Dim serializer As TrackingProfileSerializer = New TrackingProfileSerializer()
    Dim writer As StringWriter = New StringWriter(New StringBuilder(), CultureInfo.InvariantCulture)
    serializer.Serialize(writer, profile)
    Dim trackingProfile As String = writer.ToString()
    InsertTrackingProfile(trackingProfile)
End Sub

Remarques

Une instance de workflow envoie des événements de statut d'activité à l'infrastructure de suivi d'exécution chaque fois que le ActivityExecutionStatus d'une instance d'activité change. L'infrastructure de suivi d'exécution utilise la propriété ActivityTrackPoints pour filtrer ces événements de statut d'activité afin de déterminer quand envoyer un ActivityTrackingRecord au service de suivi. Vous pouvez ajouter un ActivityTrackPoint à la propriété ActivityTrackPoints pour spécifier des points d'intérêt dans le chemin d'exécution potentiel de l'instance de workflow pour lesquels vous souhaitez que l'infrastructure d'exécution envoie un ActivityTrackingRecord.

Un ActivityTrackPoint ne définit pas réellement de point physique dans une instance de workflow, mais définit plutôt un ensemble de paramètres de correspondance qui peuvent être utilisés par l'infrastructure de suivi d'exécution pour faire correspondre un événement de statut d'activité pour lequel elle doit envoyer un ActivityTrackingRecord. Par conséquent, le même ActivityTrackPoint peut être mis en correspondance de nombreuses fois pendant la durée de vie d'une instance de workflow. Un ActivityTrackPoint peut également spécifier des données à extraire de l'instance de workflow et à retourner dans le ActivityTrackingRecord.

S’applique à

Voir aussi