首页 > 代码库 > 重新想象 Windows 8.1 Store Apps (92) - 其他新特性: CoreDispatcher, 日历, 自定义锁屏系列图片

重新想象 Windows 8.1 Store Apps (92) - 其他新特性: CoreDispatcher, 日历, 自定义锁屏系列图片

[源码下载]


重新想象 Windows 8.1 Store Apps (92) - 其他新特性: CoreDispatcher, 日历, 自定义锁屏系列图片



作者:webabcd


介绍
重新想象 Windows 8.1 Store Apps 之其他新特性

  • CoreDispatcher 的新特性
  • “日历”的相关操作
  • 自定义锁屏时需要显示的系列图片



示例
1、演示 CoreDispatcher 在 win8.1 中的新特性
CoreDispatcherDemo.xaml.cs

/* * 演示 CoreDispatcher 在 win8.1 中的新特性 *  * 关于几个 Core 的基础请参见:http://www.cnblogs.com/webabcd/archive/2013/11/11/3417379.html */using System;using Windows.UI.Xaml.Controls;namespace Windows81.Other{    public sealed partial class CoreDispatcherDemo : Page    {        public CoreDispatcherDemo()        {            this.InitializeComponent();            this.Loaded += CoreDispatcherDemo_Loaded;        }        async void CoreDispatcherDemo_Loaded(object sender, Windows.UI.Xaml.RoutedEventArgs e)        {            // CoreDispatcher - 消息调度器            Windows.UI.Core.CoreDispatcher coreDispatcher = Windows.UI.Xaml.Window.Current.Dispatcher;            // 优先级从高到低排序:            // 1、本地代码中的 SendMessage            // 2、CoreDispatcherPriority.High            // 3、CoreDispatcherPriority.Normal            // 4、所有设备输入消息            // 5、CoreDispatcherPriority.Low            // 6、CoreDispatcherPriority.Idle(一般用于后台任务)            await coreDispatcher.RunAsync(Windows.UI.Core.CoreDispatcherPriority.High, () =>            {                // 调用 coreDispatcher 所在的线程            });            // 以下为 win8.1 新增             // 获取或设置当前 CoreDispatcher 的优先级            // coreDispatcher.CurrentPriority            // 当前 CoreDispatcher 中的任务是否需要让步(即任务队列中是否存在更高优先级的任务,或指定的优先级及其以上的任务)            // coreDispatcher.ShouldYield()            // coreDispatcher.ShouldYield(CoreDispatcherPriority priority)        }    }}


2、演示“日历”的相关操作
AppointmentDemo.xaml

<Page    x:Class="Windows81.Other.AppointmentDemo"    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"    xmlns:local="using:Windows81.Other"    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="120 0 0 0">            <TextBlock Name="lblMsg" FontSize="14.667" />                        <Button Name="btnAddAppointment" Content="add appointment" Click="btnAddAppointment_Click" Margin="0 10 0 0" />            <Button Name="btnShowAppointment" Content="show appointment" Click="btnShowAppointment_Click" Margin="0 10 0 0" />        </StackPanel>    </Grid></Page>

AppointmentDemo.xaml.cs

/* * 演示“日历”的相关操作 */using System;using Windows.UI.Xaml;using Windows.UI.Xaml.Controls;using Windows.ApplicationModel.Appointments;using Windows.Foundation;using Windows.UI.Xaml.Media;namespace Windows81.Other{    public sealed partial class AppointmentDemo : Page    {        public AppointmentDemo()        {            this.InitializeComponent();        }        private async void btnAddAppointment_Click(object sender, RoutedEventArgs e)        {            // 实例化一个 Appointment 对象            var appointment = new Appointment();            // 约会的开始时间            var startTime = new DateTimeOffset(2015, 2, 14, 10, 10, 0, TimeZoneInfo.Local.GetUtcOffset(DateTime.Now));            appointment.StartTime = startTime;            // 约会的主题(不能超过 255 字符)            appointment.Subject = "情人节约会";            // 约会的地点(不能超过 32768 字符)            appointment.Location = "家里";            // 约会的详细内容(不能超过 1073741823 字符)            appointment.Details = "在家里做方便面吃,庆祝情人节";            // 约会的持续时间            appointment.Duration = TimeSpan.FromMinutes(30);            // 约会是否会持续一整天            appointment.AllDay = false;            // 提醒(提醒时间点为:约会开始时间减去此属性指定的时间),如果此属性设置为 null 则不提醒            appointment.Reminder = TimeSpan.FromMinutes(15);            // 约会参与者的繁忙状态(AppointmentBusyStatus 枚举)            appointment.BusyStatus = AppointmentBusyStatus.Free;            // 约会的隐私程度(AppointmentSensitivity 枚举:Public, Private)            appointment.Sensitivity = AppointmentSensitivity.Private;            // Uri            appointment.Uri = new System.Uri("http://webabcd.cnblogs.com");            // 约会的组织者            var organizer = new AppointmentOrganizer();            organizer.DisplayName = "webabcd"; // 组织者的显示名称(不能超过 255 字符)            organizer.Address = "email@mail.com"; // 组织者的地址(不能超过 321 字符)            // 指定约会的组织者            appointment.Organizer = organizer;            // 约会参与者            var invitee = new AppointmentInvitee();            invitee.DisplayName = "abc"; // 约会参与者的显示名称(不能超过 255 字符)            invitee.Address = "email2@mail.com"; // 约会参与者的地址(不能超过 321 字符)            invitee.Role = AppointmentParticipantRole.OptionalAttendee; // 约会参与者的赴约选项            invitee.Response = AppointmentParticipantResponse.Accepted; // 约会参与者的赴约响应            // 添加一个约会参与者            // appointment.Invitees.Add(invitee);             // 循环约会            var recurrence = new AppointmentRecurrence();            recurrence.Unit = AppointmentRecurrenceUnit.Daily; // 循环约会的发生频率(AppointmentRecurrenceUnit 枚举)            recurrence.Interval = 2; // 循环约会的发生间隔(比如 Unit 为 AppointmentRecurrenceUnit.Daily,Interval 为 2 则代表每两天发生一次)            recurrence.Occurrences = 10; // 循环约会的循环次数(null 代表不限制)            recurrence.Until = null; // 循环约会的截止时间(null 代表不限制)            recurrence.WeekOfMonth = AppointmentWeekOfMonth.First; // 循环约会发生在月中的第几周            recurrence.DaysOfWeek = AppointmentDaysOfWeek.Sunday | AppointmentDaysOfWeek.Monday; // 循环约会发生在星期几(flags 类型的枚举)            recurrence.Month = 1; // 约会发生的月            recurrence.Day = 1; // 约会发生的日            // 指定循环约会            // appointment.Recurrence = recurrence;            var rect = GetElementRect(sender as FrameworkElement);            // 在指定的位置弹出日历对话框,用于让用户确认是否将相关的约会加入日历(返回值为约会的标识,更新及删除约会都需要用到此标识)            String appointmentId = await AppointmentManager.ShowAddAppointmentAsync(appointment, rect, Windows.UI.Popups.Placement.Default);            if (appointmentId != String.Empty) // 约会标识,用于更新和删除约会            {                lblMsg.Text = "Appointment Id: " + appointmentId;            }            else            {                lblMsg.Text = "Appointment not added.";            }            // 相关的对话框还有如下几个:            // await AppointmentManager.ShowReplaceAppointmentAsync(); // 更新约会            // await AppointmentManager.ShowRemoveAppointmentAsync(); // 删除约会        }        private async void btnShowAppointment_Click(object sender, RoutedEventArgs e)        {            var dateToShow = new DateTimeOffset(2015, 2, 14, 0, 0, 0, TimeZoneInfo.Local.GetUtcOffset(DateTime.Now));            var duration = TimeSpan.FromDays(1);            // 显示指定的时间段内的日历            //     第一个参数:开始时间            //     第二个参数:从开始时间计算的时间跨度            await AppointmentManager.ShowTimeFrameAsync(dateToShow, duration);        }        private Rect GetElementRect(FrameworkElement element)        {            GeneralTransform buttonTransform = element.TransformToVisual(null);            Point point = buttonTransform.TransformPoint(new Point());            return new Rect(point, new Size(element.ActualWidth, element.ActualHeight));        }    }}


3、演示如何自定义锁屏时需要显示的系列图片(需要指定一个 rss 文件地址)
LockScreenWallpapers.xaml.cs

/* * 演示如何自定义锁屏时需要显示的系列图片(需要指定一个 rss 文件地址) *  *  * 关于设置和获取锁屏单张图片,请参见:http://www.cnblogs.com/webabcd/archive/2013/09/12/3316073.html *  *  * 注: * 1、本例使用的 rss 文件请参见:WebServer 项目下的 wallpapers.xml 文件 * 2、在“设置”->“锁屏界面”中可以设置是否打开锁屏图片的幻灯片显示,其中幻灯片图片提供者的名字是 rss 文件中的 title */using System;using Windows.System.UserProfile;using Windows.UI.Xaml;using Windows.UI.Xaml.Controls;namespace Windows81.Other{    public sealed partial class LockScreenWallpapers : Page    {        public LockScreenWallpapers()        {            this.InitializeComponent();        }        private async void btnDemo_Click(object sender, RoutedEventArgs e)        {            // 指定锁屏系列图片的数据源(一个 rss 数据),并弹出对话框让用户确认            SetImageFeedResult result = await LockScreen.RequestSetImageFeedAsync(new Uri("http://localhost:39630/wallpapers.xml"));            if (result == SetImageFeedResult.Success)            {                lblMsg.Text = "指定的 url 已经被设置为锁屏系列图片的数据源";            }            else if (result == SetImageFeedResult.ChangeDisabled)            {                lblMsg.Text = "安全策略不允许显示锁屏系列图片";            }            else if (result == SetImageFeedResult.UserCanceled)            {                lblMsg.Text = "用户取消了";            }            // 取消锁屏系列图片            // LockScreen.TryRemoveImageFeed();        }    }}



OK
[源码下载]

重新想象 Windows 8.1 Store Apps (92) - 其他新特性: CoreDispatcher, 日历, 自定义锁屏系列图片