Udostępnij za pośrednictwem


TrackingProfile.ActivityTrackPoints Właściwość

Definicja

Pobiera kolekcję punktów śledzenia aktywności używanych przez infrastrukturę śledzenia środowiska uruchomieniowego w celu filtrowania zdarzeń stanu działania.

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

Wartość właściwości

Element ActivityTrackPointCollection określający punkty w wystąpieniu przepływu pracy, dla którego infrastruktura śledzenia środowiska uruchomieniowego powinna wysłać element ActivityTrackingRecord do usługi śledzenia.

Przykłady

Poniższy przykład kodu pokazuje, jak utworzyć TrackingProfile za pomocą TrackingProfile konstruktora i użyć właściwości obiektu, aby ułatwić śledzenie wykonywania przepływu pracy. Przykładowy kod używa ActivityTrackPointswłaściwości , Versioni WorkflowTrackPoints .

Ten przykład kodu jest częścią zapytania przy użyciu zestawu SQLTrackingService SDK z pliku Program.cs. Aby uzyskać więcej informacji, zobacz Query Using SQLTrackingService (Wykonywanie zapytań przy użyciu usługi 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

Uwagi

Wystąpienie przepływu pracy emituje zdarzenia stanu działania do infrastruktury śledzenia środowiska uruchomieniowego po zmianie ActivityExecutionStatus wystąpienia działania. Infrastruktura śledzenia środowiska uruchomieniowego używa ActivityTrackPoints właściwości do filtrowania tych zdarzeń stanu działania w celu określenia, kiedy wysłać element ActivityTrackingRecord do usługi śledzenia. Możesz dodać element ActivityTrackPoint do ActivityTrackPoints właściwości , aby określić punkty orientacyjne w potencjalnej ścieżce wykonywania wystąpienia przepływu pracy, dla którego infrastruktura środowiska uruchomieniowego ma wysłać ActivityTrackingRecordelement .

Element ActivityTrackPoint nie definiuje punktu fizycznego w wystąpieniu przepływu pracy, ale zamiast tego definiuje zestaw parametrów dopasowania, które mogą być używane przez infrastrukturę śledzenia środowiska uruchomieniowego w celu dopasowania zdarzenia stanu działania, dla którego powinien wysłać ActivityTrackingRecordelement . W związku z tym to samo ActivityTrackPoint może być dopasowywane wiele razy w ciągu cyklu życia wystąpienia przepływu pracy. Element ActivityTrackPoint może również określać dane, które mają zostać wyodrębnione z wystąpienia przepływu pracy i zwrócone w obiekcie ActivityTrackingRecord.

Dotyczy

Zobacz też