本文整理汇总了C#中IActivatedEventArgs.?.GetType方法的典型用法代码示例。如果您正苦于以下问题:C# IActivatedEventArgs.?.GetType方法的具体用法?C# IActivatedEventArgs.?.GetType怎么用?C# IActivatedEventArgs.?.GetType使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类IActivatedEventArgs
的用法示例。
在下文中一共展示了IActivatedEventArgs.?.GetType方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: HandleActivation
/// <summary>
/// Handle activation of the event and any navigation necessary.
/// </summary>
/// <param name="e">Activation args.</param>
/// <param name="rootFrame">Root frame of the app.</param>
public void HandleActivation(IActivatedEventArgs e, Frame rootFrame)
{
var handled = false;
try
{
Platform.Current.Analytics.Event("HandleActivation", e.Kind);
switch (e.Kind)
{
case ActivationKind.Launch:
var launchArg = e as LaunchActivatedEventArgs;
Platform.Current.Logger.Log(LogLevels.Warning, "Calling OnActivation({0}) TileID: {1} Arguments: {2}", e?.GetType().Name, launchArg.TileId, launchArg.Arguments);
handled = this.OnActivation(launchArg);
break;
case ActivationKind.VoiceCommand:
var voiceArgs = e as VoiceCommandActivatedEventArgs;
Platform.Current.Logger.Log(LogLevels.Warning, "Calling OnActivation({0})", e?.GetType().Name);
handled = this.OnActivation(voiceArgs);
break;
case ActivationKind.ToastNotification:
var toastArgs = e as ToastNotificationActivatedEventArgs;
Platform.Current.Logger.Log(LogLevels.Warning, "Calling OnActivation({0}) Arguments: {1}", e?.GetType().Name, toastArgs.Argument);
handled = this.OnActivation(toastArgs);
break;
case ActivationKind.Protocol:
var protocolArgs = e as ProtocolActivatedEventArgs;
Platform.Current.Logger.Log(LogLevels.Warning, "Calling OnActivation({0}) Arguments: {1}", e?.GetType().Name, protocolArgs.Uri.ToString());
handled = this.OnActivation(protocolArgs);
break;
default:
Platform.Current.Logger.LogError(new Exception(string.Format("Can't call OnActivation({0}) as it's not implemented!", e.Kind)));
handled = false;
break;
}
if (handled == false || rootFrame?.Content == null)
Platform.Current.Navigation.Home();
Platform.Current.Logger.Log(LogLevels.Information, "Completed Navigation.HandleActivation({0}) on RootFrame: {1} --- OnActivation Handled? {2}", e?.GetType().Name, rootFrame?.Content?.GetType().Name, handled);
}
catch (Exception ex)
{
Platform.Current.Logger.LogError(ex, "Error during App Navigation.HandleActivation({0}) on RootFrame: {1}", e?.GetType().Name, rootFrame?.Content?.GetType().Name);
throw ex;
}
}