【Win 10应用开发】延迟共享

延迟共享是啥呢,这么说吧,就是在应用程序打开共享面板选择共享目标时,不会设置要共享的数据,而是等到共享目标请求数据时,才会发送数据,而且,延迟操作可以在后台进行。

这样说似乎过于抽象,最好的诠释方法,还是通过实例对比来观察吧。

老周设计的示例解决方案包含三个项目,其中一个是共享目标,用来接收共享的文本内容,并把文本写入到一个.txt文件中,存放到“文档”库中。

另外两个项目是:一个是未延迟的共享行为,再一个是延迟共享行为。

下面来对比一下效果。

先看未延迟共享的操作,如下图。

因为我在发送数据前故意拖延了10秒钟,因此你会看到,打开共享面板后会显示“正在从XXXXX获取信息”的等待过程,而且需要等待数据设置完毕后,才会显示共享目标的选择列表。

然后,我们再来看看延迟共享是什么情况。

当我打开共享面板后,就会马上显示共享目标的选择列表,当我从中选择共享目标后,会激活目标应用,并且等到目标应用要读取共享的数据时,源应用才会设置数据共享的数据,所以,拖延的10秒钟是在目标应用被激活后才发生。

而且这个时候,就算你关闭了共享面板,数据仍然会在后台进行处理。然后打开“文档”目录,就会看到保存的文本文件了。

好,效果看完了。总结一下,正常共享是先发送共享数据,再显示共享目标列表,要是要共享的数据很大,就会使得共享面板出现延迟,此时如果你关闭共享面板,共享操作就会被取消。

而延迟共享则是先选择共享目标,而不发送共享数据,直到共享数据的接收者请求(读取)数据时才进行发送,即把共享数据的发送行为延后执行,此时,就算共享面板被关闭,共享目标应用也可以在后台接收数据。

延迟共享适合用于共享比较大的数据,比如视频。

下面就分别实现两种共享行为。

先看常规共享。

        public MainPage()
        {
            this.InitializeComponent();

            DataTransferManager.GetForCurrentView().DataRequested += async (c, d) =>
            {
                DataRequest req = d.Request;
                var def = req.GetDeferral();
                await Task.Delay(10 * 1000);
                // 设置共享内容
                req.Data.Properties.Title = "分享文本(未延迟)";
                await Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.High,
                    () => req.Data.SetText(txtInput.Text));
                def.Complete();
            };
        }

这种方式相信各位都比较熟。先获取一个用于当前应用的DataTransferManager实例,然后响应 DataRequested 事件,当要进行共享时就会发生该事件(共享面板打开时)。然后当然是设置要共享的数据内容了。

延迟共享和常规共享相似。

        public MainPage()
        {
            this.InitializeComponent();

            DataTransferManager.GetForCurrentView().DataRequested += (a, e) =>
            {
                DataRequest r = e.Request;
                r.Data.Properties.Title = "共享文本(延迟)";
                r.Data.SetDataProvider(StandardDataFormats.Text, new DataProviderHandler(OnSetDataDelay));
            };
        }

        private async void OnSetDataDelay(DataProviderRequest request)
        {
            var def = request.GetDeferral();
            await Task.Delay(10 * 1000); //延迟
            await Dispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.High, () => request.SetData(txtInput.Text));
            def.Complete();
        }

与常规共享的差异在于,延迟共享在处理 DataRequested 事件时并不会马上设置要共享的数据,而是调用 DataPackage 例的 SetDataProvider 方法,然后向方法传递一个委托,数据发送操作会延迟到共享目标应用请求数据内容时才执行,委托实例所绑定的方法用来发送数据,打开共享面板时不会发送数据。

而打开共享面板的方式都相同,直接调用DataTransferManager类的ShowShareUI静态方法就可以了。在UWP应用中,应该这样做,因为 Win 10 右边沿向左滑动,打开的是通知中心,不是 Win 8 时的超级按钮。

当然,你也可以通过快捷键 Win + H 来打开共享面板。

好了,牛皮就不多吹,今天到此作罢。

示例源代码下载

时间: 2024-10-09 07:30:42

【Win 10应用开发】延迟共享的相关文章

【Win 10应用开发】如何知道当前APP在哪个平台设备上运行

[Win 10应用开发]如何知道当前APP在哪个平台设备上运行 在做Win10开发的时候,我们可能经常会需要获得当前程序在在哪个平台设备上运行,用于UI和相关API的调用,那么可以通过什么方式知道当前APP运行的平台呢? 今天这里提供两个方法给大家做参考: 方法一:DeviceFamily 通过Windows.System.Profile.AnalyticsInfo.VersionInfo.DeviceFamily,来获取当前的平台设备,目前只可以得到两个值Windows.Mobile或Wind

【Win 10 应用开发】打印UI元素

原文:[Win 10 应用开发]打印UI元素 Windows App支持将UI界面进行打印的功能,这与浏览器中的打印网页的用途相近,其好处就是“所见即所得”,直接把界面上呈现的内容打印下来,比重新创建打印图像方便得多. 要在通用App中实现打印,主要依靠以下几个类型: PrintManager:位于Windows.Graphics.Printing命名空间,主要负责显示打印对话框,设置打印源等操作.在使用时,首先调用GetForCurrentView静态方法得到一个PrintManager实例:

【Win 10应用开发】实现全屏播放的方法

原文:[Win 10应用开发]实现全屏播放的方法 有人会问,以前的MediaElement控件不是有现成的一排操作按钮吗?而且可以直接进入全屏播放.是的,我们知道,以往的Store App都是在全屏模式下运行的,只要MediaElement控件填满整个窗口,就等于全屏播放了,但是,Win10应用是窗口化的,将MediaElement控件的IsFullWindow属性设置为true后,就会这样: 从上面的截图看,MediaElement控件只是覆盖整个窗口而已,并没有实现全屏.那有办法让它全屏播放

【Win 10应用开发】如何知道UAP在哪个平台上运行

原文:[Win 10应用开发]如何知道UAP在哪个平台上运行 面向22世纪的现代化应用程序可以同时在多种设备上运行,于是有朋友会有一个疑问:有时候,我们还真的需要判断一下,UAP应用程序在哪个平台上运行.尽管大多情况下我们不必要这样做,但某些特殊情况还得考虑.比如一串数据列表,我希望如果在桌面上运行时就以横向列表展现:但要是运行在手机上就以纵向列表展现. 也就是说,其实我们只需分析两种情况即可: 一.桌面.(台式机.笔记本.平板.游戏机.发广告专用机.导航器……) 二.移动环境.其实就是手机.

【Win 10 应用开发】RTM版的UAP项目解剖

原文:[Win 10 应用开发]RTM版的UAP项目解剖 Windows 10 发布后,其实SDK也偷偷地在VS的自定义安装列表中出现了,今天开发人员中心也更新了下载.正式版的SDK在API结构上和以前预览的时候是一样的,只是版本变成10240罢了,所以大家不要问老周有什么新的API. API虽然没变,但VS中的应用程序项目是有了新变化.毕竟以前都是预览的,而现在是“正规军”,以前练兵时都用土豆枪,现在都是真刀真枪干了,故而应用程序项目是有变化的. 以前老周跟大家讲的修改项目模板,去掉遥测类库的

【Win 10 应用开发】Toast通知激活应用——前台&后台

原文:[Win 10 应用开发]Toast通知激活应用--前台&后台 老周最近热衷于讲故事,接下来还是讲故事时间. 有人问我:你上大学的时候,有加入过学生会吗?读大学有没有必要加入学生会? 哎哟,这怎么回答呢,从短期来说,加入学生会有点用,至少可以娱乐一下,运气好的话,说不定能遇到红颜知己,但这概率相当低.从长远发展看嘛,是没什么用.老周当年读了四年本科,在学生会混了四年,什么名堂也没混出来. 一方面老周向来不求虚名,所以也没去参选所谓的什么部长.主席之类的,这些“官衔”听起来很高大上,实际上很

【Win 10 应用开发】导入.pfx证书

这个功能其实并不常用,一般开发较少涉及到证书,不过,简单了解一下还是有必要的. 先来说说制作测试证书的方法,这里老周讲两种方法,可以生成用于测试的.pfx文件. 产生证书,大家都知道有个makecert工具.好,我们先用这个工具来生成一个证书,并存放到当前用户的证书存储中.打开VS的开发人员命令提示符,然后输入: makecert -n "CN=中国好男人" -pe -sr CurrentUser -ss My -b 01/01/2016 -e 12/31/2018 -n 表示证书的标

【Win 10应用开发】Adaptive磁贴模板的XML文档结构

在若干天之前,老周给大家讲了Adaptive Toast通知的XML模板,所以相应地,今天老周给大家介绍一下Adaptive磁贴的新XML模板. 同样道理,你依旧可以使用8.1时候的磁贴模板,在win 10的API中也是支持的,此外,Win10 App还支持全新的自适应磁贴模板,本文老周就给大家先讲一下基本结构,下一篇文章中咱们再说一说复杂排版. 应用程序的图标可以分为两类:第一类是应用商店上专用的,就是你的应用提交到商店后,给用户看的图标:另一类就是应用本身的一些图标或磁贴. 磁贴其实也就这么

【Win 10 应用开发】启动远程设备上的应用

这个功能必须在“红石-1”(build 14393)以上的系统版中才能使用,运行在一台设备上的应用,可以通过URI来启动另一台设备上的应用.激活远程应用需要以下前提: 系统必须是build 14393或以上版本,UWP应用必须使用14393或以上版本的SDK开发. 被启动的应用应当支持协议激活,比如Cortana的协议URI为:[ms-cortana:],当然如果是你自己开发的应用,可以自己定义一个协议,名字随便取,不要跟系统的协议或别人的应用冲突就行,比如:[haha:][zxzx:]等. 必