共用方式為


IInteractionTrackerOwner 介面

定義

包含 InteractionTracker 事件將觸發的回呼。

實作此介面可接收 有關 InteractionTracker狀態和值的回呼,以及是否接受 對 InteractionTracker 屬性的要求更新。

public interface class IInteractionTrackerOwner
/// [Windows.Foundation.Metadata.ContractVersion(Microsoft.Foundation.LiftedContract, 65536)]
/// [Windows.Foundation.Metadata.Guid(2288613277, 7466, 22550, 131, 106, 104, 169, 16, 80, 125, 135)]
struct IInteractionTrackerOwner
/// [Windows.Foundation.Metadata.Guid(2288613277, 7466, 22550, 131, 106, 104, 169, 16, 80, 125, 135)]
/// [Windows.Foundation.Metadata.ContractVersion(Microsoft.Foundation.WindowsAppSDKContract, 65536)]
struct IInteractionTrackerOwner
[Windows.Foundation.Metadata.ContractVersion(typeof(Microsoft.Foundation.LiftedContract), 65536)]
[Windows.Foundation.Metadata.Guid(2288613277, 7466, 22550, 131, 106, 104, 169, 16, 80, 125, 135)]
public interface IInteractionTrackerOwner
[Windows.Foundation.Metadata.Guid(2288613277, 7466, 22550, 131, 106, 104, 169, 16, 80, 125, 135)]
[Windows.Foundation.Metadata.ContractVersion(typeof(Microsoft.Foundation.WindowsAppSDKContract), 65536)]
public interface IInteractionTrackerOwner
Public Interface IInteractionTrackerOwner
屬性

範例

class InteractionBehavior : Behavior<UIElement>, IInteractionTrackerOwner
{
  public void CustomAnimationStateEntered(InteractionTracker sender, InteractionTrackerCustomAnimationStateEnteredArgs args)
  {
    //Logic to run when InteractionTracker enters CustomAnimation 
  }

  public void IdleStateEntered(InteractionTracker sender, InteractionTrackerIdleStateEnteredArgs args)
  {
    //Logic to run when InteractionTracker enters Idle
  }

  public void InertiaStateEntered(InteractionTracker sender, InteractionTrackerInertiaStateEnteredArgs args)
  {
    //Logic to run when InteractionTracker enters Inertia
  }

  public void InteractingStateEntered(InteractionTracker sender, InteractionTrackerInteractingStateEnteredArgs args)
  {
    //Logic to run when InteractionTracker enters Interacting
  }

  public void RequestIgnored(InteractionTracker sender, InteractionTrackerRequestIgnoredArgs args)
  {
    //Logic to run when a request to update position or scale is ignored
  }

  public void ValuesChanged(InteractionTracker sender, InteractionTrackerValuesChangedArgs args)
  {

    //Logic to run when position or scale change
  }
}

備註

如果應用程式需要更新 InteractionTracker的狀態或值,則需要實作 IInteractionTrackerOwner。 由於此模型的非同步本質,這些回呼是更新應用程式邏輯的最佳方式。 若要深入瞭解 InteractionTracker 狀態和轉換,請參閱 InteractionTracker

您可以使用或不使用擁有者來建立 InteractionTracker 。 若要註冊回呼,需要與擁有者建立 InteractionTracker 。 如果這些回呼對應用程式狀態而言並不重要,則不需要擁有者即可建立 InteractionTracker

建立與擁有者的 InteractionTracker 也需要適當地處置 InteractionTracker

方法

CustomAnimationStateEntered(InteractionTracker, InteractionTrackerCustomAnimationStateEnteredArgs)

InteractionTracker進入自訂動畫狀態時觸發的回呼。

IdleStateEntered(InteractionTracker, InteractionTrackerIdleStateEnteredArgs)

InteractionTracker進入閒置狀態時觸發的回呼。

InertiaStateEntered(InteractionTracker, InteractionTrackerInertiaStateEnteredArgs)

InteractionTracker進入慣性狀態時觸發的回呼。

InteractingStateEntered(InteractionTracker, InteractionTrackerInteractingStateEnteredArgs)

InteractionTracker進入互動狀態時所觸發的回呼。

RequestIgnored(InteractionTracker, InteractionTrackerRequestIgnoredArgs)

InteractionTracker忽略要求時所觸發的回呼。

ValuesChanged(InteractionTracker, InteractionTrackerValuesChangedArgs)

InteractionTracker輸出值變更時所觸發的回呼。

適用於