现代操作系统应用开发:UWP——UI共享:DataTransferManager

功能简介

使用DataTransferManager的ShowShareUI()功能,实现界面共享

示例项目有一个页面MainPage,页面内只有一个按钮,点击按钮即发生共享界面功能

实现效果

  • 点击按钮

  • 选择其中的邮件

实现过程

在MainPage.xaml中添加一个按钮并设置相应事件

<Grid Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">
    <Button Content="ShareUI" Click="Button_Click" HorizontalAlignment="Center"></Button>
</Grid>

在MainPage.xaml.cs文件中添加代码

namespace ShowShareUISample
{
    public sealed partial class MainPage : Page
    {
        public MainPage()
        {
            this.InitializeComponent();
            //使ShareRequested函数在共享操作时发生
            DataTransferManager.GetForCurrentView().DataRequested += ShareRequested;
        }

        private void Button_Click(object sender, RoutedEventArgs e)
        {
            //启动共享
            DataTransferManager.ShowShareUI();
        }

        //设置想要共享的内容
        private void ShareRequested(DataTransferManager sender, DataRequestedEventArgs args)
        {
            var deferral = args.Request.GetDeferral();
            DataRequest request = args.Request;
            request.Data.Properties.Title = "ShareUISample";
            request.Data.SetText("Description:" + "This is a line from ShareUISample. Welcome to learn UWP.");
            //flash.jpg是示例代码中Asssets文件夹中的图片,可以将其改为你自己的图片
            request.Data.SetBitmap(RandomAccessStreamReference.CreateFromUri(new Uri("ms-appx:///Assets/flash.jpg")));
            deferral.Complete();
        }
    }
}

需要注意的地方:

  • 在构造函数中绑定方法
  • 在ShareRequested中添加共享的内容(Title和Text是必须的)

FYI

项目下载:ShowShareUISample

项目下载之后记住把Debug模式从ARM换成X86或X64(根据你自己的机型选择),之前一开始学习的时候不知道这一点,从网上下载下来的项目都运行不了,纠结的一逼(╥╯^╰╥)

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值