[源码下载]

背水一战 Windows 10 (113) - 锁屏: 将 Application 的 Badge 通知和 Tile 通知发送到锁屏, 将 secondary tile 的 Badge 通知和 Tile 通知发送到锁屏

作者:webabcd

介绍
背水一战 Windows 10 之 锁屏

  • 将 Application 的 Badge 通知和 Tile 通知发送到锁屏
  • 将 secondary tile 的 Badge 通知和 Tile 通知发送到锁屏

示例
1、演示如何将 Application 的 Badge 通知和 Tile 通知发送到锁屏
LockScreen/ApplicationNotification.xaml

<Page
x:Class="Windows10.LockScreen.ApplicationNotification"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:Windows10.LockScreen"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"> <Grid Background="Transparent">
<StackPanel Margin="10 0 10 10"> <Button Name="btnBadgeNotification" Content="发送 Application 的 Badge 通知" Click="btnBadgeNotification_Click" Margin="5" /> <Button Name="btnTileNotification" Content="发送 Application 的 Tile 通知" Click="btnTileNotification_Click" Margin="5" /> </StackPanel>
</Grid>
</Page>

LockScreen/ApplicationNotification.xaml.cs

/*
* 演示如何将 Application 的 Badge 通知和 Tile 通知发送到锁屏
*
*
* 注:
* 1、需要在 Package.appxmanifest 中配置好是否支持锁屏徽章和文本,以及要配置好徽章图标。类似如下:
* <LockScreen Notification="badgeAndTileText" BadgeLogo="Assets\LockScreenLogo.png" />
* 2、在 app 安装好后,去“设置”->“个性化”->“锁屏界面”中做如下选择
* 在“选择要显示详细状态的应用”中选择你的 app,则对此 app 发送 tile 通知后,此 tile 通知的文本就会显示在锁屏
* 在“选择要显示快速状态的应用”中选择你的 app,则对此 app 发送 badge 通知后,此 badge 通知的图标就会显示在锁屏
*/ using System;
using Windows.Data.Xml.Dom;
using Windows.UI.Notifications;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls; namespace Windows10.LockScreen
{
public sealed partial class ApplicationNotification : Page
{
public ApplicationNotification()
{
this.InitializeComponent();
} // 发送 Application 的 Badge 通知
private void btnBadgeNotification_Click(object sender, RoutedEventArgs e)
{
// 用于描述 badge 通知的 xml 字符串(数字在 1 - 99 之间,如果大于 99 则会显示 99+ ,如果是 0 则会移除 badge,如果小于 0 则无效)
string badgeXml = "<badge value='3'/>"; // 将 xml 字符串转换为 Windows.Data.Xml.Dom.XmlDocument 对象
XmlDocument badgeDoc = new XmlDocument();
badgeDoc.LoadXml(badgeXml); // 实例化 BadgeNotification 对象
BadgeNotification badgeNotification = new BadgeNotification(badgeDoc); // 将指定的 BadgeNotification 对象更新到 application
BadgeUpdater badgeUpdater = BadgeUpdateManager.CreateBadgeUpdaterForApplication();
badgeUpdater.Update(badgeNotification);
} // 发送 Application 的 Tile 通知
private void btnTileNotification_Click(object sender, RoutedEventArgs e)
{
/*
* 这里有几个要特别注意的地方:
* 1、锁屏只能显示 tile 的文本,不能显示 tile 的图片之类的
* 2、锁屏只会显示 tile 的 TileWide 模板的文本
* 3、要想在锁屏显示文本,则 tile 的 text 必须要有 id 属性并指定一个整型值
* 4、锁屏文本会按照 tile 的 text 的 id 的大小按顺序显示,如果 id 值一样则只显示后面的
* 5、tile 上的文本显示规则与其 text 的 id 无关(只有锁屏文本才有关系)
*/ // 用于描述 tile 通知的 xml 字符串
string tileXml = $@"
<tile>
<visual>
<binding template='TileSmall'>
<text id='1'>Small 1(小){DateTime.Now.ToString("HH:mm:ss")}</text>
</binding>
<binding template='TileMedium'>
<text id=''>Medium (中){DateTime.Now.ToString("HH:mm:ss")}</text>
</binding>
<binding template='TileWide'>
<text id=''>Wide (宽){DateTime.Now.ToString("HH:mm:ss")}</text>
<text id=''>Wide (宽){DateTime.Now.ToString("HH:mm:ss")}</text>
<text id=''>Wide (宽){DateTime.Now.ToString("HH:mm:ss")}</text>
</binding>
<binding template='TileLarge'>
<text id=''>Large (大){DateTime.Now.ToString("HH:mm:ss")}</text>
</binding>
</visual>
</tile>"; /*
* 如果需要锁屏显示的 tile 内容与 TileWide 显示的 tile 内容不一样的话,可以像下面这样写
* 设置 TileWide 所属 binding 的 hint-lockDetailedStatus1 属性和 hint-lockDetailedStatus2 属性和 hint-lockDetailedStatus3 属性
*/
string tileXml2 = $@"
<tile>
<visual>
<binding template='TileSmall'>
<text>Small 1(小){DateTime.Now.ToString("HH:mm:ss")}</text>
</binding>
<binding template='TileMedium'>
<text>Medium (中){DateTime.Now.ToString("HH:mm:ss")}</text>
</binding>
<binding template='TileWide'
hint-lockDetailedStatus1='hint-lockDetailedStatus1'
hint-lockDetailedStatus2='hint-lockDetailedStatus2'
hint-lockDetailedStatus3='hint-lockDetailedStatus3'>
<text>Wide (宽){DateTime.Now.ToString("HH:mm:ss")}</text>
<text>Wide (宽){DateTime.Now.ToString("HH:mm:ss")}</text>
<text>Wide (宽){DateTime.Now.ToString("HH:mm:ss")}</text>
</binding>
<binding template='TileLarge'>
<text>Large (大){DateTime.Now.ToString("HH:mm:ss")}</text>
</binding>
</visual>
</tile>"; // 将 xml 字符串转换为 Windows.Data.Xml.Dom.XmlDocument 对象
XmlDocument tileDoc = new XmlDocument();
tileDoc.LoadXml(tileXml); // 实例化 TileNotification 对象
TileNotification tileNotification = new TileNotification(tileDoc); // 将指定的 TileNotification 对象更新到 application tile
TileUpdater tileUpdater = TileUpdateManager.CreateTileUpdaterForApplication();
tileUpdater.Update(tileNotification);
}
}
}

2、演示如何将 secondary tile 的 Badge 通知和 Tile 通知发送到锁屏
LockScreen/SecondaryTileNotification.xaml

<Page
x:Class="Windows10.LockScreen.SecondaryTileNotification"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:Windows10.LockScreen"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"> <Grid Background="Transparent">
<StackPanel Margin="10 0 10 10"> <TextBlock Name="lblMsg" Margin="5" /> <Button Name="btnBadgeNotification" Content="发送 secondary tile 的 Badge 通知" Click="btnBadgeNotification_Click" Margin="5" /> <Button Name="btnTileNotification" Content="发送 secondary tile 的 Tile 通知" Click="btnTileNotification_Click" Margin="5" /> </StackPanel>
</Grid>
</Page>

LockScreen/SecondaryTileNotification.xaml.cs

/*
* 演示如何将 secondary tile 的 Badge 通知和 Tile 通知发送到锁屏
*
*
* SecondaryTile - secondary tile
* LockScreenDisplayBadgeAndTileText - 是否允许此 secondary tile 在锁屏上显示徽章和文本
* LockScreenBadgeLogo - 锁屏上徽章图标的地址
*
* 注:
* 在 app 安装好后,先要将 secondary tile 固定到开始屏幕,然后去“设置”->“个性化”->“锁屏界面”中做如下选择
* 在“选择要显示详细状态的应用”中选择你的 secondary tile,则对此 secondary tile 发送 tile 通知后,此 tile 通知的文本就会显示在锁屏
* 在“选择要显示快速状态的应用”中选择你的 secondary tile,则对此 secondary tile 发送 badge 通知后,此 badge 通知的图标就会显示在锁屏
*/ using System;
using Windows.Data.Xml.Dom;
using Windows.UI.Notifications;
using Windows.UI.StartScreen;
using Windows.UI.Xaml;
using Windows.UI.Xaml.Controls;
using Windows.UI.Xaml.Navigation; namespace Windows10.LockScreen
{
public sealed partial class SecondaryTileNotification : Page
{
private const string TILEID = "tile_lockscreen"; public SecondaryTileNotification()
{
this.InitializeComponent();
} // 在开始屏幕固定一个 secondary tile 磁贴
protected async override void OnNavigatedTo(NavigationEventArgs e)
{
base.OnNavigatedTo(e); Uri square150x150Logo = new Uri("ms-appx:///Assets/Square150x150Logo.png");
Uri wide310x150Logo = new Uri("ms-appx:///Assets/Wide310x150Logo.png");
Uri square310x310Logo = new Uri("ms-appx:///Assets/Square310x310Logo.png");
SecondaryTile secondaryTile = new SecondaryTile(TILEID, "我的 secondary tile", "arguments", square150x150Logo, TileSize.Wide310x150);
secondaryTile.VisualElements.Wide310x150Logo = wide310x150Logo;
secondaryTile.VisualElements.Square310x310Logo = square310x310Logo; // 允许此 secondary tile 在锁屏上显示徽章和文本
secondaryTile.LockScreenDisplayBadgeAndTileText = true;
// 此 secondary tile 在锁屏上显示徽章时的图标
secondaryTile.LockScreenBadgeLogo = new Uri("ms-appx:///Assets/LockScreenLogo.png"); try
{
bool isPinned = await secondaryTile.RequestCreateAsync();
lblMsg.Text = isPinned ? "固定成功" : "固定失败";
}
catch (Exception ex)
{
lblMsg.Text = "固定失败: " + ex.ToString();
}
} // 发送 secondary tile 的 Badge 通知
private void btnBadgeNotification_Click(object sender, RoutedEventArgs e)
{
// 用于描述 badge 通知的 xml 字符串(数字在 1 - 99 之间,如果大于 99 则会显示 99+ ,如果是 0 则会移除 badge,如果小于 0 则无效)
string badgeXml = "<badge value='3'/>"; // 将 xml 字符串转换为 Windows.Data.Xml.Dom.XmlDocument 对象
XmlDocument badgeDoc = new XmlDocument();
badgeDoc.LoadXml(badgeXml); // 实例化 BadgeNotification 对象
BadgeNotification badgeNotification = new BadgeNotification(badgeDoc); // 将指定的 BadgeNotification 对象更新到指定的 secondary tile 磁贴
BadgeUpdater badgeUpdater = BadgeUpdateManager.CreateBadgeUpdaterForSecondaryTile(TILEID);
badgeUpdater.Update(badgeNotification);
} // 发送 secondary tile 的 Tile 通知
private void btnTileNotification_Click(object sender, RoutedEventArgs e)
{
/*
* 这里有几个要特别注意的地方:
* 1、锁屏只能显示 tile 的文本,不能显示 tile 的图片之类的
* 2、锁屏只会显示 tile 的 TileWide 模板的文本
* 3、要想在锁屏显示文本,则 tile 的 text 必须要有 id 属性并指定一个整型值
* 4、锁屏文本会按照 tile 的 text 的 id 的大小按顺序显示,如果 id 值一样则只显示后面的
* 5、tile 上的文本显示规则与其 text 的 id 无关(只有锁屏文本才有关系)
*/ // 用于描述 tile 通知的 xml 字符串
string tileXml = $@"
<tile>
<visual>
<binding template='TileSmall'>
<text>Small 1(小){DateTime.Now.ToString("HH:mm:ss")}</text>
</binding>
<binding template='TileMedium'>
<text>Medium (中){DateTime.Now.ToString("HH:mm:ss")}</text>
</binding>
<binding template='TileWide'>
<text id=''>Wide (宽){DateTime.Now.ToString("HH:mm:ss")}</text>
<text id=''>Wide (宽){DateTime.Now.ToString("HH:mm:ss")}</text>
<text id=''>Wide (宽){DateTime.Now.ToString("HH:mm:ss")}</text>
</binding>
<binding template='TileLarge'>
<text>Large (大){DateTime.Now.ToString("HH:mm:ss")}</text>
</binding>
</visual>
</tile>"; /*
* 如果需要锁屏显示的 tile 内容与 TileWide 显示的 tile 内容不一样的话,可以像下面这样写
* 设置 TileWide 所属 binding 的 hint-lockDetailedStatus1 属性和 hint-lockDetailedStatus2 属性和 hint-lockDetailedStatus3 属性
*/
string tileXml2 = $@"
<tile>
<visual>
<binding template='TileSmall'>
<text>Small 1(小){DateTime.Now.ToString("HH:mm:ss")}</text>
</binding>
<binding template='TileMedium'>
<text>Medium (中){DateTime.Now.ToString("HH:mm:ss")}</text>
</binding>
<binding template='TileWide'
hint-lockDetailedStatus1='hint-lockDetailedStatus1'
hint-lockDetailedStatus2='hint-lockDetailedStatus2'
hint-lockDetailedStatus3='hint-lockDetailedStatus3'>
<text>Wide (宽){DateTime.Now.ToString("HH:mm:ss")}</text>
<text>Wide (宽){DateTime.Now.ToString("HH:mm:ss")}</text>
<text>Wide (宽){DateTime.Now.ToString("HH:mm:ss")}</text>
</binding>
<binding template='TileLarge'>
<text>Large (大){DateTime.Now.ToString("HH:mm:ss")}</text>
</binding>
</visual>
</tile>"; // 将 xml 字符串转换为 Windows.Data.Xml.Dom.XmlDocument 对象
XmlDocument tileDoc = new XmlDocument();
tileDoc.LoadXml(tileXml); // 实例化 TileNotification 对象
TileNotification tileNotification = new TileNotification(tileDoc); // 将指定的 TileNotification 对象更新到 secondary tile
TileUpdater tileUpdater = TileUpdateManager.CreateTileUpdaterForSecondaryTile(TILEID);
tileUpdater.Update(tileNotification);
}
}
}

OK
[源码下载]

背水一战 Windows 10 (113) - 锁屏: 将 Application 的 Badge 通知和 Tile 通知发送到锁屏, 将 secondary tile 的 Badge 通知和 Tile 通知发送到锁屏的更多相关文章

  1. 背水一战 Windows 10 (3) - UI: 窗口全屏, 窗口尺寸

    [源码下载] 背水一战 Windows 10 (3) - UI: 窗口全屏, 窗口尺寸 作者:webabcd 介绍背水一战 Windows 10 之 UI 窗口全屏 窗口尺寸 示例1.窗口全屏UI/F ...

  2. 背水一战 Windows 10 (112) - 通知(Badge): application 的 badge 通知, secondary 的 badge 通知, 轮询服务端以更新 badge 通知

    [源码下载] 背水一战 Windows 10 (112) - 通知(Badge): application 的 badge 通知, secondary 的 badge 通知, 轮询服务端以更新 bad ...

  3. 背水一战 Windows 10 (108) - 通知(Tile): application tile 基础, secondary tile 基础

    [源码下载] 背水一战 Windows 10 (108) - 通知(Tile): application tile 基础, secondary tile 基础 作者:webabcd 介绍背水一战 Wi ...

  4. 背水一战 Windows 10 (91) - 文件系统: Application Data 中的文件操作, Application Data 中的“设置”操作, 通过 uri 引用 Application Data 中的媒体

    [源码下载] 背水一战 Windows 10 (91) - 文件系统: Application Data 中的文件操作, Application Data 中的“设置”操作, 通过 uri 引用 Ap ...

  5. 背水一战 Windows 10 (121) - 后台任务: 推送通知

    [源码下载] 背水一战 Windows 10 (121) - 后台任务: 推送通知 作者:webabcd 介绍背水一战 Windows 10 之 后台任务 推送通知 示例演示如何接收推送通知/WebA ...

  6. 背水一战 Windows 10 (2) - UI: 概述, 启动屏幕, 屏幕方向

    [源码下载] 背水一战 Windows 10 (2) - UI: 概述, 启动屏幕, 屏幕方向 作者:webabcd 介绍背水一战 Windows 10 之 UI UI 设计概述 启动屏幕(闪屏) 屏 ...

  7. 背水一战 Windows 10 (114) - 后台任务: 后台任务的 Demo(与 app 不同进程), 后台任务的 Demo(与 app 相同进程)

    [源码下载] 背水一战 Windows 10 (114) - 后台任务: 后台任务的 Demo(与 app 不同进程), 后台任务的 Demo(与 app 相同进程) 作者:webabcd 介绍背水一 ...

  8. 背水一战 Windows 10 (66) - 控件(WebView): 监听和处理 WebView 的事件

    [源码下载] 背水一战 Windows 10 (66) - 控件(WebView): 监听和处理 WebView 的事件 作者:webabcd 介绍背水一战 Windows 10 之 控件(WebVi ...

  9. 背水一战 Windows 10 (57) - 控件(集合类): ListViewBase - 增量加载, 分步绘制

    [源码下载] 背水一战 Windows 10 (57) - 控件(集合类): ListViewBase - 增量加载, 分步绘制 作者:webabcd 介绍背水一战 Windows 10 之 控件(集 ...

随机推荐

  1. vue小结

    一:MVVM模型的理解 Model:数据模型,数据和业务逻辑都在这里定义:View代表视图,负责数据的展示:ViewModel:负责监听model中数据的改变并且控制视图的更新,处理用户交互操作:Mo ...

  2. jQuery index() 方法

    比如同一级有多个li,获得点击的元素的下标,确定第几个. $("li").click(function(){alert($(this).index());});

  3. spring-boot的Hello World案例,最简单的spring-boot项目

    Spring Boot HelloWorld 一个功能: 浏览器发送hello请求,服务器接收请求并处理,响应Hello World字符串. 1.创建一个maven项目 2.导入依赖spring-bo ...

  4. crm开发之用户重置密码

    重置 密码这这功能. 我是没有在,stark组件中. 内置的.所以需要,自己进行定制.也就只是,在已有的增删改查的基础上,再增加一条url  和相对应的  视图函数. 好的是, 我已经预留了,增加的接 ...

  5. git hub命令,上传到github

    git hub命令,上传到github   1,git  init;      初始化 2,git   config   --global   user.email  " ....@.... ...

  6. jQuery的1.x版本的$(element).css()设置元素字体颜色时出现的问题(在IE8以下)

    最近赶项目,自己写了个基于jQuery的弹出层插件,中间遇到一个问题,怎么也找不到解决方法,最后发现就是空格的问题...欲哭无泪啊... 在给函数传参时,因为写css代码时习惯在:后面加个空格在写样式 ...

  7. echart 图例

    说明:stack相同,两个bar合并但是不会重叠 如果需要重叠 用barGap: '-100%', 根据不同的需求来使用两者. <template> <div> echart ...

  8. 校赛F

    问题描述 例如对于数列[1 2 3 4 5 6],排序后变为[6 1 5 2 4 3].换句话说,对于一个有序递增的序列a1, a2, a3, ……, an,排序后为an, a1, an-1, a2, ...

  9. 洛谷P3916||图的遍历||反向建图||链式前向星||dfs

    题目描述 给出 NN 个点, MM 条边的有向图,对于每个点 vv ,求 A(v)A(v) 表示从点 vv 出发,能到达的编号最大的点. 解题思路 看起来很简单的一道题, 但我依然调了一天,我还是太菜 ...

  10. MyBatis 一级缓存,二级缓存,延迟加载设置

       1  什么是延迟加载  resultMap中的association和collection标签具有延迟加载的功能. 延迟加载的意思是说,在关联查询时,利用延迟加载,先加载主信息.使用关联信息时再 ...