我有一个下载图像的函数,当下载完成时,它会触发toast通知。当用户单击toast通知时,我想使用默认程序打开该文件。但是启动器在匿名委托中会失败。
下面是设置匿名委托的代码 var savefolder= await KnownFolders.PicturesLibrary.GetFolderAsync("savefolder");
Uri source;
if (!Uri.TryCreate(ImageUrl, UriKind.Absolute, out source))
{
return;
}
var destination = imageFileName;
if (string.IsNullOrWhiteSpace(destination))
{
return;
}
var destinationFile = await savefolder.CreateFileAsync(destination, CreationCollisionOption.GenerateUniqueName);
var httpClient = new HttpClient();
var data = await httpClient.GetByteArrayAsync(source);
var targetStream = await destinationFile.OpenAsync(FileAccessMode.ReadWrite);
await targetStream.AsStreamForWrite().WriteAsync(data, 0, data.Length);
await targetStream.FlushAsync();
targetStream.Dispose();
TypedEventHandler<ToastNotification, object> openPic =
async delegate(ToastNotification toastSender, object toastArgs)
{
var success = await Launcher.LaunchFileAsync(destinationFile);
var i = 0;
};
CommentProcessing.LoadToast("The image has been saved to your pictures library", openPic);
这是Toast函数
public static void LoadToast(string text, TypedEventHandler<ToastNotification, object> toastActivated = null)
{
var toastXml = ToastNotificationManager.GetTemplateContent(ToastTemplateType.ToastText01);
var elements = toastXml.GetElementsByTagName("text");
elements[0].AppendChild(toastXml.CreateTextNode(text));
var toast = new ToastNotification(toastXml);
if (toastActivated != null)
toast.Activated += toastActivated;
ToastNotificationManager.CreateToastNotifier().Show(toast);
}
现在,它几乎完全按照计划工作。委托触发并调用启动器。但当它试图发射时,却失败了。
我已经能够遍历代码,并且当委托触发时,所有文件信息仍然是完整的。
任何想法?
这有点不太可能,但您可以尝试将图像的打开部分卸载给调度程序:
TypedEventHandler<ToastNotification, object> openPic =
async delegate(ToastNotification toastSender, object toastArgs)
{
Window.Current.Dispatcher.RunAsync(CoreDispatcherPriority.Normal,
() => var success = await Launcher.LaunchFileAsync(destinationFile);
};