爆款云主机2核4G限时秒杀,88元/年起!
查看详情

活动

天翼云最新优惠活动,涵盖免费试用,产品折扣等,助您降本增效!
热门活动
  • 618智算钜惠季 爆款云主机2核4G限时秒杀,88元/年起!
  • 免费体验DeepSeek,上天翼云息壤 NEW 新老用户均可免费体验2500万Tokens,限时两周
  • 云上钜惠 HOT 爆款云主机全场特惠,更有万元锦鲤券等你来领!
  • 算力套餐 HOT 让算力触手可及
  • 天翼云脑AOne NEW 连接、保护、办公,All-in-One!
  • 中小企业应用上云专场 产品组合下单即享折上9折起,助力企业快速上云
  • 息壤高校钜惠活动 NEW 天翼云息壤杯高校AI大赛,数款产品享受线上订购超值特惠
  • 天翼云电脑专场 HOT 移动办公新选择,爆款4核8G畅享1年3.5折起,快来抢购!
  • 天翼云奖励推广计划 加入成为云推官,推荐新用户注册下单得现金奖励
免费活动
  • 免费试用中心 HOT 多款云产品免费试用,快来开启云上之旅
  • 天翼云用户体验官 NEW 您的洞察,重塑科技边界

智算服务

打造统一的产品能力,实现算网调度、训练推理、技术架构、资源管理一体化智算服务
智算云(DeepSeek专区)
科研助手
  • 算力商城
  • 应用商城
  • 开发机
  • 并行计算
算力互联调度平台
  • 应用市场
  • 算力市场
  • 算力调度推荐
一站式智算服务平台
  • 模型广场
  • 体验中心
  • 服务接入
智算一体机
  • 智算一体机
大模型
  • DeepSeek-R1-昇腾版(671B)
  • DeepSeek-R1-英伟达版(671B)
  • DeepSeek-V3-昇腾版(671B)
  • DeepSeek-R1-Distill-Llama-70B
  • DeepSeek-R1-Distill-Qwen-32B
  • Qwen2-72B-Instruct
  • StableDiffusion-V2.1
  • TeleChat-12B

应用商城

天翼云精选行业优秀合作伙伴及千余款商品,提供一站式云上应用服务
进入甄选商城进入云市场创新解决方案
办公协同
  • WPS云文档
  • 安全邮箱
  • EMM手机管家
  • 智能商业平台
财务管理
  • 工资条
  • 税务风控云
企业应用
  • 翼信息化运维服务
  • 翼视频云归档解决方案
工业能源
  • 智慧工厂_生产流程管理解决方案
  • 智慧工地
建站工具
  • SSL证书
  • 新域名服务
网络工具
  • 翼云加速
灾备迁移
  • 云管家2.0
  • 翼备份
资源管理
  • 全栈混合云敏捷版(软件)
  • 全栈混合云敏捷版(一体机)
行业应用
  • 翼电子教室
  • 翼智慧显示一体化解决方案

合作伙伴

天翼云携手合作伙伴,共创云上生态,合作共赢
天翼云生态合作中心
  • 天翼云生态合作中心
天翼云渠道合作伙伴
  • 天翼云代理渠道合作伙伴
天翼云服务合作伙伴
  • 天翼云集成商交付能力认证
天翼云应用合作伙伴
  • 天翼云云市场合作伙伴
  • 天翼云甄选商城合作伙伴
天翼云技术合作伙伴
  • 天翼云OpenAPI中心
  • 天翼云EasyCoding平台
天翼云培训认证
  • 天翼云学堂
  • 天翼云市场商学院
天翼云合作计划
  • 云汇计划
天翼云东升计划
  • 适配中心
  • 东升计划
  • 适配互认证

开发者

开发者相关功能入口汇聚
技术社区
  • 专栏文章
  • 互动问答
  • 技术视频
资源与工具
  • OpenAPI中心
开放能力
  • EasyCoding敏捷开发平台
培训与认证
  • 天翼云学堂
  • 天翼云认证
魔乐社区
  • 魔乐社区

支持与服务

为您提供全方位支持与服务,全流程技术保障,助您轻松上云,安全无忧
文档与工具
  • 文档中心
  • 新手上云
  • 自助服务
  • OpenAPI中心
定价
  • 价格计算器
  • 定价策略
基础服务
  • 售前咨询
  • 在线支持
  • 在线支持
  • 工单服务
  • 建议与反馈
  • 用户体验官
  • 服务保障
  • 客户公告
  • 会员中心
增值服务
  • 红心服务
  • 首保服务
  • 客户支持计划
  • 专家技术服务
  • 备案管家

了解天翼云

天翼云秉承央企使命,致力于成为数字经济主力军,投身科技强国伟大事业,为用户提供安全、普惠云服务
品牌介绍
  • 关于天翼云
  • 智算云
  • 天翼云4.0
  • 新闻资讯
  • 天翼云APP
基础设施
  • 全球基础设施
  • 信任中心
最佳实践
  • 精选案例
  • 超级探访
  • 云杂志
  • 分析师和白皮书
  • 天翼云·创新直播间
市场活动
  • 2025智能云生态大会
  • 2024智算云生态大会
  • 2023云生态大会
  • 2022云生态大会
  • 天翼云中国行
天翼云
  • 活动
  • 智算服务
  • 产品
  • 解决方案
  • 应用商城
  • 合作伙伴
  • 开发者
  • 支持与服务
  • 了解天翼云
      • 文档
      • 控制中心
      • 备案
      • 管理中心

      【Win10应用开发】自定义磁贴通知的排版

      首页 知识中心 软件开发 文章详情页

      【Win10应用开发】自定义磁贴通知的排版

      2024-06-17 09:52:23 阅读次数:115

      App,Win10

      前面老周用了两篇烂文,向大家介绍了Adaptive磁贴的模板使用。那些XML模板已经很强大了,不过,如果你觉得那些排版还不足以满足需求,不妨试试自己来定义磁贴的内容。

      其实,Runtime App支持在后台任务中生成XAML呈现,只要你编写的后台任务类从XamlRenderingBackgroundTask(位于Windows.UI.Xaml.Media.Imaging命名空间)类派生即可。利用这一特性,我们可以在后台生成XAML布局,然后通过RenderTargetBitmap类来呈现XAML内容,再把它保存为图片,最后把保存的图片作为磁贴的背景,就能达到自定义磁贴内容的功效了。

      第一步,在主应用程序项目中,添加一个XAML文件,因为这个文件不参与编译,也没有对应的Code hide文件,就单个XAML文件即可,实际上是一个文本文件。因此,在生成操作上要设置为“内容”,是否复制到输出目录,选择“不复制”,自定义工具不用填。如图

      【Win10应用开发】自定义磁贴通知的排版

      然后你可以自己来设计排版,就和平时用XAML设计界面一样。

      <Border 
          xmlns="http:///winfx/2006/xaml/presentation"
          xmlns:x="http:///winfx/2006/xaml"
          BorderThickness="0">
          <Border.Background>
              <ImageBrush AlignmentX="Center" AlignmentY="Center" Stretch="UniformToFill" ImageSource="Assets/1.jpg" />
          </Border.Background>
      </Border>

      好了,我的界面就这样吧,简单好用。

      第二步,向解决方案添加一个Windows运行时组件项目,用来在其中定义后台任务类。代码如下:

          public sealed class UpdatetileTask : XamlRenderingBackgroundTask
          {
              protected override async void OnRun(IBackgroundTaskInstance taskInstance)
              { 
                     ……
               }
          }

      注意,这里和以前我们定义普通的后台任务不同,这一次不是实现后台任务接口,而是从XamlRenderingBackgroundTask类派生,然后重写OnRun方法。
      里面的处理和一般的后台任务一样了。

      1、先要从项目目录加载我们刚才自己定义的那个.xaml文件。

                  Border root = new Border();
                  Application.LoadComponent(root, new Uri("ms-appx:///customRender.xaml"));
                  root.Width = 310;
                  root.Height = 150;

      LoadComponent是Application类的一个静态方法,直接调用即可,第一个参数是要生成的可视化对象的实例,第二个参数是XAML文件的URI。

      我们声明的可视化对象的类型一定要与XAML文档中的根节点的类型匹配,上面在定义XAML文档时,根节点是Border,因此这里声明的变量类型必须为Border,LoadComponent方法调用后,会自动加载并编译XAML文档,然后填充Border变量。

      为了让可视化对象能够呈现到位图中,记住要显示设置它的高度和宽度,因为默认情况下Width和Height都为0。

      2、呈现XAML对象到位图。

                  // 将XAML对象呈现到图像中
                  RenderTargetBitmap rtb = new RenderTargetBitmap();
                  // 因为示例是为宽磁贴生成背景图片的
                  // 所以目标的图像大小与宽磁贴相同即可
                  // 310 x 150
                  await rtb.RenderAsync(root, 310, 150);
                  // 取出图像数据
                  IBuffer bfData = await rtb.GetPixelsAsync();
                  // 将其转换为字节数组
                  byte[] data = bfData.ToArray();


      3、在本地目录中创建新的PNG文件,并把呈现的XAML内容编码到图像文件中。

                  // 在本地目录中创建新的PNG图像文件
                  StorageFolder localfd = ApplicationData.Current.LocalFolder;
                  StorageFile pngFile = await localfd.CreateFileAsync("bg.png", CreationCollisionOption.ReplaceExisting);
                  // 打开文件流
                  using (IRandomAccessStream stream = (await pngFile.OpenAsync(FileAccessMode.ReadWrite)))
                  {
                      // 创建PNG图像编码器
                      BitmapEncoder encoder = await BitmapEncoder.CreateAsync(BitmapEncoder.PngEncoderId, stream);
                      // 设置图像数据
                      encoder.SetPixelData(BitmapPixelFormat.Bgra8, BitmapAlphaMode.Straight, (uint)rtb.PixelWidth, (uint)rtb.PixelHeight, 72d, 72d, data);
                      await encoder.FlushAsync();
                  }

      4、文件保存后,可以用ms-appdata:///local/开头的URI来访问文件。这时候,我们可以生成磁贴通知的XML文档,并更新磁贴。

                  // 组创XML文档
                  string xml = "<tile>" +
                                  "<visual>" +
                                      "<binding template=\"TileWide\">" +
                                          "<image src=\"ms-appdata:///local/bg.png\" placement=\"background\" />" +
                                      "</binding>"   +
                                   "</visual>" +
                               "</tile>";
                  // 创建XML文档
                  XmlDocument doc = new XmlDocument();
                  doc.LoadXml(xml);
                  // 更新磁贴通知
                  TileNotification notification = new TileNotification(doc);
                  TileUpdater updater = TileUpdateManager.CreateTileUpdaterForApplication();
                  updater.Update(notification);

      第三步,在主应用程序中引用刚才的后台任务项目。然后配置一下清单文件,在正式版的SDK中,已经可以使用图形化的清单编辑器了,可以直接操作。

      添加一个后台任务声明,类型为“常规”。

      【Win10应用开发】自定义磁贴通知的排版

      填上后台任务类的入口点,即类名,要包括命名空间的名字。

      第四步,在前台代码中注册后台任务。前面的文章中,老周给大家介绍过可以通ApplicationTrigger直接在应用程序中触发后台任务,所以本示例我就用它了。

                  var res = await BackgroundExecutionManager.RequestAccessAsync();
                  if (res == BackgroundAccessStatus.Denied || res == BackgroundAccessStatus.Unspecified)
                  {
                      Debug.WriteLine("后台任务被禁用。"); return;
                  }
      
                  // 考虑注册后台任务
                  BackgroundTaskRegistration reg = BackgroundTaskRegistration.AllTasks.Values.FirstOrDefault(t => t.Name == TASK_NAME) as BackgroundTaskRegistration;
      
                  if (reg == null)
                  {
                      BackgroundTaskBuilder bd = new BackgroundTaskBuilder();
                      bd.Name = TASK_NAME;
                      bd.TaskEntryPoint = typeof(backUpdater.UpdatetileTask).FullName;
                      ApplicationTrigger trigger = new ApplicationTrigger();
                      bd.SetTrigger(trigger);
                      reg = bd.Register();
                  }

      最后,我们可以在代码中手动触发这个后台。

                  BackgroundTaskRegistration reg = BackgroundTaskRegistration.AllTasks.Values.FirstOrDefault(t => t.Name == TASK_NAME) as BackgroundTaskRegistration;
                  if (reg == null)
                  {
                      return;
                  }
      
                  ApplicationTrigger trigger = reg.Trigger as ApplicationTrigger;
                  await trigger.RequestAsync();

      运行应用程序后,把程序固定到开始屏幕,并把图标改为宽磁贴,然后回到应用程序,触发后台,更新磁贴。

      版权声明:本文内容来自第三方投稿或授权转载,原文地址:https://www.cnblogs.com/tcjiaan/p/4711455.html,作者:东邪独孤,版权归原作者所有。本网站转在其作品的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如因作品内容、版权等问题需要同本网站联系,请发邮件至ctyunbbs@chinatelecom.cn沟通。

      上一篇:解决pandas读取文件报错ValueError: Invalid file path or buffer object type: <class ‘tuple‘>

      下一篇:Android RecyclerView 列表加载图片宽高适配

      相关文章

      2025-04-09 09:11:38

      Vue学习笔记:$panrent $root

      Vue学习笔记:$panrent $root

      2025-04-09 09:11:38
      App , root , 组件
      2025-03-28 07:41:55

      antDesign在react项目中样式失效

      antDesign在react项目中样式失效

      2025-03-28 07:41:55
      App , css , react , src , 安装 , 引入
      2025-01-06 08:42:57

      Vue学习笔记:组件 slot等综合示例

      Vue学习笔记:组件 slot等综合示例

      2025-01-06 08:42:57
      App , vue , 组件
      2025-01-06 08:42:57

      Vue3学习笔记:使用$emit实现子组件传递数据给父组件

      Vue3学习笔记:使用$emit实现子组件传递数据给父组件

      2025-01-06 08:42:57
      App , event , vue , 事件 , 组件 , 自定义
      2024-11-19 09:36:27

      利用区块链技术实现返利App的透明化追溯

      区块链是一种分布式账本技术,通过去中心化的网络节点共同维护和管理数据,保证数据的不可篡改性和透明性。每个区块包含了交易信息及其时间戳,通过加密技术确保数据的安全性和一致性。

      2024-11-19 09:36:27
      App , 区块链
      2024-11-15 06:53:34

      Vue中父组件和子组件的关系

      Vue中父组件和子组件的关系

      2024-11-15 06:53:34
      App , props , 传递 , 组件
      2024-06-26 06:18:07

      【Win10 应用开发】使用“实时可视化树”工具查看应用界面元素

      实时可视化树工具只能查看XAML定义的界面,如WPF和Win App。现在,Win App都编译为本地代码,直接找可执行文件是走不通了。

      2024-06-26 06:18:07
      App , Win10
      2024-06-26 06:18:07

      【Win 10应用开发】分阶段进行数据绑定

      使用x:Bind扩展标记进行数据绑定,是在编译阶段完成,至于说性能优化方面,大概主要是优化CPU资源的使用,因为免去了运行阶段进行绑定的过程。

      2024-06-26 06:18:07
      App , Win10
      2024-06-26 06:18:07

      【Win 10 应用开发】多媒体转码

      【Win 10 应用开发】多媒体转码

      2024-06-26 06:18:07
      App , Win10
      2024-06-26 06:18:07

      【Win10应用开发】签名与验证

      对数据进行签名和验证,是为了防止数据被“盗版”。比较常规的做法是通过公钥进行验证。

      2024-06-26 06:18:07
      App , Win10
      查看更多
      推荐标签

      作者介绍

      天翼云小翼
      天翼云用户

      文章

      33561

      阅读量

      5232025

      查看更多

      最新文章

      【Win10 应用开发】使用“实时可视化树”工具查看应用界面元素

      2024-06-26 06:18:07

      【Win 10应用开发】分阶段进行数据绑定

      2024-06-26 06:18:07

      【Win 10 应用开发】多媒体转码

      2024-06-26 06:18:07

      【Win10应用开发】签名与验证

      2024-06-26 06:18:07

      【Win10 应用开发】自定义应用标题栏

      2024-06-26 06:17:16

      【Win10 应用开发】解决VS 2015 RC不能调试手机应用的问题

      2024-06-26 06:17:16

      查看更多

      热门文章

      Java基础(6)-Win10系统下载安装配置JDK1.8

      2023-04-07 06:44:05

      【Win10应用开发】签名与验证

      2024-06-26 06:18:07

      【Win 10应用开发】AdaptiveTrigger在自定义控件中是可以触发的

      2024-06-26 06:17:16

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

      2024-06-17 10:03:58

      【Win 10应用开发】分阶段进行数据绑定

      2024-06-26 06:18:07

      【Win10 应用开发】使用“实时可视化树”工具查看应用界面元素

      2024-06-26 06:18:07

      查看更多

      热门标签

      java Java python 编程开发 代码 开发语言 算法 线程 Python html 数组 C++ 元素 javascript c++
      查看更多

      相关产品

      弹性云主机

      随时自助获取、弹性伸缩的云服务器资源

      天翼云电脑(公众版)

      便捷、安全、高效的云电脑服务

      对象存储

      高品质、低成本的云上存储服务

      云硬盘

      为云上计算资源提供持久性块存储

      查看更多

      随机文章

      【Win 10应用开发】分阶段进行数据绑定

      【Win10应用开发】相对布局(RelativePanel)

      【Win10 应用开发】人脸识别

      【Win 10 应用开发】多媒体转码

      【Win10 应用开发】自定义应用标题栏

      【Win10应用开发】签名与验证

      • 7*24小时售后
      • 无忧退款
      • 免费备案
      • 专家服务
      售前咨询热线
      400-810-9889转1
      关注天翼云
      • 旗舰店
      • 天翼云APP
      • 天翼云微信公众号
      服务与支持
      • 备案中心
      • 售前咨询
      • 智能客服
      • 自助服务
      • 工单管理
      • 客户公告
      • 涉诈举报
      账户管理
      • 管理中心
      • 订单管理
      • 余额管理
      • 发票管理
      • 充值汇款
      • 续费管理
      快速入口
      • 天翼云旗舰店
      • 文档中心
      • 最新活动
      • 免费试用
      • 信任中心
      • 天翼云学堂
      云网生态
      • 甄选商城
      • 渠道合作
      • 云市场合作
      了解天翼云
      • 关于天翼云
      • 天翼云APP
      • 服务案例
      • 新闻资讯
      • 联系我们
      热门产品
      • 云电脑
      • 弹性云主机
      • 云电脑政企版
      • 天翼云手机
      • 云数据库
      • 对象存储
      • 云硬盘
      • Web应用防火墙
      • 服务器安全卫士
      • CDN加速
      热门推荐
      • 云服务备份
      • 边缘安全加速平台
      • 全站加速
      • 安全加速
      • 云服务器
      • 云主机
      • 智能边缘云
      • 应用编排服务
      • 微服务引擎
      • 共享流量包
      更多推荐
      • web应用防火墙
      • 密钥管理
      • 等保咨询
      • 安全专区
      • 应用运维管理
      • 云日志服务
      • 文档数据库服务
      • 云搜索服务
      • 数据湖探索
      • 数据仓库服务
      友情链接
      • 中国电信集团
      • 189邮箱
      • 天翼企业云盘
      • 天翼云盘
      ©2025 天翼云科技有限公司版权所有 增值电信业务经营许可证A2.B1.B2-20090001
      公司地址:北京市东城区青龙胡同甲1号、3号2幢2层205-32室
      • 用户协议
      • 隐私政策
      • 个人信息保护
      • 法律声明
      备案 京公网安备11010802043424号 京ICP备 2021034386号