UWP toast
Windows10的自适应和交互式toast通知是一个新特性。它可以让你:
创建灵活的toast通知,包括内嵌图片及更多的内容,不在局限于之前Windows 8.1和Windows Phone 8.1提供的toast模板。
概述
Toast 通知使用 XML 构建,这通常包含以下关键元素:
- <visual> 涵盖可供用户从视觉上查看的内容,包括文本和图像
- <actions> 包含开发人员希望在通知内添加的按钮/输入
- <audio> 指定在通知弹出时播放的声音
Toast通知的使用场景
Toast 通知支持四种默认场景,可在<toast><\toast>中设置scenario
default
reminder
: 通知会持续显示在屏幕上alarm
: 通知会持续显示在屏幕上并且循环播放声音inComingCall
: 在Moblie下全屏显示等
Toast的XML结构
<toast>
<visual/>
<actions/>
<audio/>
</toast>
视觉(Visual)
在视觉元素内,你必须正好有一个包含 Toast 的视觉内容的绑定元素。
通用 Windows 平台 (UWP) 应用中的磁贴通知支持基于不同磁贴大小的多个模板。 但是,Toast 通知只有一个模板名称:ToastGeneric。 只有一个模板名称意味着:
- 你可以更改 Toast 内容,例如添加另一行文本、添加嵌入式图像或将缩略图图像从显示应用图标更改为其他内容,并且在执行任意上述操作时无需担心更改整个模板或由于模板名称和内容之间的不匹配而创建无效的负载。
- 你可以使用相同代码为专用于传递到不同类型的 Microsoft Windows 设备(包括手机、平板电脑、PC 和 Xbox One)的 Toast 通知构建相同的负载。 其中每台设备都将接受通知,并使用相应的视觉提示和交互模型根据其 UI策略向用户显示通知。
有关视觉部分及其子元素中受支持的所有属性,请参阅下面的“架构”部分。 有关更多示例,请参阅下面的 XML 示例部分。
以上是MSDN上对视觉的介绍
<binding/>绑定元素
而template的唯一值为ToastGeneric
<text/> 文本
<image/>图片
src:图片源
hint-crop:是否裁剪,none 不裁剪,circle 将图像裁剪成圆形
操作(actions)
在 UWP 应用中,你可以将按钮和其他输入添加到 Toast 通知,这可使用户在应用外执行更多操作。 这些操作在 <actions> 元素下指定,其中有两个可以指定的类型:
- <action> 这将显示为桌面和移动设备上的按钮。 你可以在 Toast 通知内指定最多五个自定义或系统操作。
- <input> 这允许用户提供输入,如对消息的快速回复或从下拉菜单中选择一个选项。
<action> 和 <input> 在 Windows 设备系列内均是自适应的。 例如,在移动或桌面设备上,面向用户的 <action> 是可点击/单击的按钮。 文本 <input> 是用户可使用物理键盘或屏幕键盘输入文本的框。 这些元素还会适应将来的交互方案,如通过语音宣布的 操作或通过听写获取的文本输入。
当用户采用某个操作时,你可以通过在 <action> 元素内指定 ActivationType 属性来执行以下操作之一:
- 使用特定于操作的参数在前台激活应用,该参数可用于导航到特定页面/上下文。
- 在不影响用户的情况下激活应用的后台任务。
- 通过协议启动激活另一个应用。
- 执行要执行的系统操作。 当前可用系统操作将推迟和解除计划的警报/提醒,这将在下面部分中进一步介绍。
有关视觉部分及其子元素中受支持的所有属性,请参阅下面的“架构”部分。 有关更多示例,请参阅下面的 XML 示例部分。
<input/>
id:必填,用于后台和前台获取输入值
type:必填 ,有text和selection两个属性,显然字面意思
title:选填,标题将呈现在输入的上方
placeholderContent:选填,填写将在输入框中显示提示
defaultInput:选填,设置默认值,type为text时将值视为字符串,selection时将值视为可选id之一
<action/>
content:必填 显示button的文本
arguments:必填,类同input的id,用于检索用户是否操作
hint-inputId:必填,需要填入与action关联的input的id,用于action和input的匹配
音频(audio)
自定义声音当前在面向桌面平台的 UWP 应用上不受支持;相反,你可以为你的桌面上的应用从 ms-winsoundevents 列表中进行选择。 移动平台上的 UWP 应用支持 ms-winsoundevents 以及采用以下格式的自定义声音:
- ms-appx:///
- ms-appdata:///
有关 Toast 通知中的音频的信息(其中包括 ms-winsoundevents 的完整列表),请参阅音频架构页面。
src:选填,音频路径
loop:选填,boolean ,是否循环,ture 循环播放、false 仅播放一次
silent:选填,boolean,是否静音,true 静音、false 允许播放
Toast的Demo
含有图片的Toast
xml代码Demo
<?xml version="1.0" encoding="utf-8" ?>
<toast launch="app-defined-string">
<visual>
<binding template="ToastGeneric">
<text>这是你的标题</text>
<text>这是你的内容</text>
<image placement="appLogoOverride" src="Assets/Square44x44Logo.scale-200.png" />
<image placement="inline" src="Assets/test.png" />
</binding>
</visual>
</toast>
含有输入的Toast
xml代码Demo
<?xml version="1.0" encoding="utf-8" ?>
<toast>
<visual>
<binding template="ToastGeneric">
<text>Hello World!</text>
<text>回复toast</text>
<image src = "ms-appx://Assets/Images/photo.jpg" placement="appLogoOverride"/>
</binding>
</visual>
<actions>
<input id = "reply" type="text" placeHolderContent="输入内容"/>
<action content = "回复" arguments="reply" hint-inputId="reply"/>
</actions>
<audio src = "ms-winsoundevent:Notification.Default" />
</toast>
含有音频的Toast
xml的Demo
<?xml version="1.0" encoding="utf-8" ?>
<toast launch="app-defined-string">
<visual>
<binding template="ToastGeneric">
<text>提醒标题</text>
<text>提醒内容</text>
<!--<image placement="AppLogoOverride" src="oneAlarm.png" />-->
</binding>
</visual>
<actions>
<action content="确定" arguments="check" />
<action content="取消" arguments="cancel" />
</actions>
<audio src="ms-winsoundevent:Notification.Looping.Call9"/>
</toast>
C#代码
读取xml文件
XDocument xd = XDocument.Load("XML/Pictrue.xml");
创建Toast模板
XmlDocument doc = new XmlDocument();
利用xml创建Toast,利用ToastNotificationManeger创建Toast
doc.LoadXml(xd.ToString());
ToastNotification notification = new ToastNotification(doc);
ToastNotificationManager.CreateToastNotifier().Show(notification);
输入文本Toast
声音Toast
图片Toast
定时发送Toast
若需要定时Toast通知
使用ScheduledToastNotification类
public ScheduledToastNotification(XmlDocument content, DateTimeOffset deliveryTime);
public ScheduledToastNotification(XmlDocument content, DateTimeOffset deliveryTime, TimeSpan snoozeInterval, System.UInt32 maximumSnoozeCount);
上面两个构造函数第一个是仅一次,第二个可以设置循环次数
ToastNotificationManager.CreateToastNotifier().AddToSchedule(SToastNotification);
将通知添加系统中
UWP toast的更多相关文章
- 【完全开源】知乎日报UWP版:增加Live磁贴、Badge、以及Toast通知
目录 说明 实现方法 APP生命期 后台任务 说明 之前网上有人建议增加磁贴(tile).徽章(badge)功能.利用周末的时间,将这两个功能添加上去了.如果将磁贴固定到开始屏幕,磁贴就会循环播放首页 ...
- 【UWP开发】一个简单的Toast实现
Toast简介 在安卓里Toast是内置原生支持,它是Android中用来显示显示信息的一种机制.它主要用于向用户显示提示消息,没有焦点,显示的时间有限,过一定的时间就会自动消失.在UWP中虽然没有原 ...
- [UWP 开发] 一个简单的Toast实现
Toast简介 在安卓里Toast是内置原生支持,它是Android中用来显示显示信息的一种机制.它主要用于向用户显示提示消息,没有焦点,显示的时间有限,过一定的时间就会自动消失.在UWP中虽然没有原 ...
- win10 uwp 通知Toast
win10通知使用Toast 可以使用win10 模板添加通知 var t = Windows.UI.Notifications.ToastTemplateType.ToastText02; 使用Ge ...
- uwp 之吐司 toast
Toast -------------------------------------------------------------- var t = Windows.UI.Notification ...
- Win10 UWP开发系列——开源控件库:UWPCommunityToolkit
在开发应用的过程中,不可避免的会使用第三方类库.之前用过一个WinRTXamlToolkit.UWP,现在微软官方发布了一个新的开源控件库—— UWPCommunityToolkit 项目代码托管在G ...
- Windows10自适应和交互式toast通知[1]
阅读目录: 概述 toast通知的结构 视觉区域(Visual) 行为(Actions) 特定场景下的Toast通知 带多内容的通知 带行为的通知(例子1) 带行为的通知(例子2) 带文本输入框和行为 ...
- 【Win10 应用开发】自适应Toast通知的XML文档结构
老规矩,在开始之前老周先讲个故事. 话说公元2015年7月20日,VS 2015发布.于是,肯定有人会问老周了,C#6有啥新特性,我学不来啊.学不来的话你应该检讨.老周比较保守地计算一下,学会C# 6 ...
- 【Win10开发】Toast通知
Toast 通知是一种发送给用户的暂时消息,包含相关的.具有时效性的信息,并且提供对应用中相关内容的快速访问.它可显示你是在另一个应用中.在“开始”屏幕上.在锁屏上,还是在桌面上.Toast 应该被视 ...
随机推荐
- java位操作总结
在计算机中所有数据都是以二进制的形式储存的. 位运算其实就是直接对在内存中的二进制数据进行操作,因此处理数据的速度非常快. 方便演示,首先写个二进制打印方法: private static void ...
- PHP初学习笔记(2015/4/8)
//echo C('name'); App/Action/IndexAction.class.php文件夹下的 URL模式 //输出URL模式 //echo C('URL_MODEL'),'<b ...
- Linux:使用nohup让进程在后台可靠运行
学习之余我最大的乐趣是找一部不错的电影慢慢品味,这也是我缓解压力的最好方式之一,由于我常去的字幕组网站需要签到才可以下载字幕,像这种娱乐网站谁有时间天天记得去签到呢,but作为一个准程序猿应该有更好的 ...
- JavaScript如何使用this
学习this的使用必须牢记以下两点 1.this是一个只能在函数内部使用的关键字 2.this指向调用函数的那个对象 下面我们来具体讨论一下this的具体使用方法 第一种:通过函数调用的方式----- ...
- 本周psp
本周PSP 类别 内容 开始时间 中止时间 终止时间 总用时 产品计划会议 定义产品的用户需求,以及从这个产品中得到什么.解决啥问题 18:00 0 20:00 120分钟 撰写博客 会议记录与个 ...
- 原来 laravel 路由 参数可以为可选。。。 很灵活
基本路由 您的应用程序的绝大多数路由将在 app/routes.php 文件中定义.Laravel 中最简单的路由由一个 URI 和一个闭包调用组成. 基本 GET 路由 复制代码代码如下: Rout ...
- sublime work flow
Tools -> Developer -> New Snippet <snippet> <content><![CDATA[ }() { ${} } ]]&g ...
- MyEclipse设置像visual studio一样的智能提示
打开 Eclipse -> Window -> Perferences -> Java -> Editor -> Content Assist, 在右边最下面一栏找到 ...
- OC的类别(分类)和拓展
一.分类: 1.适用范围 当你已经封装好了一个类(也可能是系统类.第三方库),不想在改动这个类了,可是随着程序功能的增加需要在类中增加一个方法,这时我们不必修改主类,只需要给你原来的类增加一 ...
- Linq to Sql : 并发冲突及处理策略
原文:Linq to Sql : 并发冲突及处理策略 1. 通过覆盖数据库值解决并发冲突 try { db.SubmitChanges(ConflictMode.ContinueOnConflict) ...