http://blog.csdn.net/wangrenzhu2011/article/details/8175492 (转)
在metro 风格中 动态磁贴是他的精髓
在wp7 的开发中 我们可以使用hubtile 来制作类似效果
但是在 win8 中并不具备这个功能,
下面我们来通过扩展GridViewItem 来实现 PictureHubTile
- <GridViewItem
- x:Class="App1.HubTile"
- xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
- xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
- xmlns:local="using:App1"
- xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
- xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
- mc:Ignorable="d"
- x:Name="gridViewItem"
- d:DesignHeight="150"
- d:DesignWidth="150">
- <GridViewItem.Resources>
- <Storyboard x:Name="UpperSecStoryboard">
- <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.RenderTransform).(CompositeTransform.TranslateY)" Storyboard.TargetName="SecImg">
- <SplineDoubleKeyFrame KeyTime="0:0:1.2" Value="-150" KeySpline="0.29,0.88,0,1"/>
- </DoubleAnimationUsingKeyFrames>
- <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.RenderTransform).(CompositeTransform.TranslateY)" Storyboard.TargetName="FirstImg">
- <SplineDoubleKeyFrame KeyTime="0:0:1.2" Value="150" KeySpline="1,0,1,0"/>
- </DoubleAnimationUsingKeyFrames>
- </Storyboard>
- <Storyboard x:Name="UpperFirstStoryboard">
- <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.RenderTransform).(CompositeTransform.TranslateY)" Storyboard.TargetName="SecImg">
- <SplineDoubleKeyFrame KeyTime="0:0:1.2" Value="0" KeySpline="1,0,1,0"/>
- </DoubleAnimationUsingKeyFrames>
- <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.RenderTransform).(CompositeTransform.TranslateY)" Storyboard.TargetName="FirstImg">
- <SplineDoubleKeyFrame KeyTime="0:0:1.2" Value="0" KeySpline="0.29,0.88,0,1"/>
- </DoubleAnimationUsingKeyFrames>
- </Storyboard>
- </GridViewItem.Resources>
- <Grid Width="{Binding Width, ElementName=gridViewItem}" Height="{Binding Height, ElementName=gridViewItem}">
- <Canvas x:Name="PART_LayoutRoot" >
- <StackPanel x:Name="PART_Panel">
- <Canvas
- Height="{Binding Height, ElementName=gridViewItem}"
- x:Name="FirstImg">
- <Grid x:Name="PART_FirstContent">
- <Image x:Name="Img1"
- Width="{Binding Width, ElementName=gridViewItem}"
- Height="{Binding Height, ElementName=gridViewItem}"
- Stretch="UniformToFill" VerticalAlignment="Center">
- </Image>
- </Grid>
- <Canvas.RenderTransform>
- <CompositeTransform/>
- </Canvas.RenderTransform>
- </Canvas>
- <Canvas
- x:Name="SecImg"
- Height="{Binding Height, ElementName=gridViewItem}">
- <Grid x:Name="SecGrid" Background="Red">
- <Image x:Name="Img2"
- Width="{Binding Width, ElementName=gridViewItem}"
- Height="{Binding Height, ElementName=gridViewItem}"
- Stretch="UniformToFill" VerticalAlignment="Center">
- </Image>
- </Grid>
- <Canvas.RenderTransform>
- <CompositeTransform/>
- </Canvas.RenderTransform>
- </Canvas>
- </StackPanel>
- </Canvas>
- <ContentPresenter Content="1111" VerticalAlignment="Bottom" HorizontalAlignment="Stretch" x:Name="PART_Title" Margin="0,0,10,7" />
- </Grid>
- </GridViewItem>
- using System;
- using System.Collections.Generic;
- using System.Collections.ObjectModel;
- using System.Diagnostics;
- using System.IO;
- using System.Linq;
- using Windows.Foundation;
- using Windows.Foundation.Collections;
- using Windows.UI.Xaml;
- using Windows.UI.Xaml.Controls;
- using Windows.UI.Xaml.Controls.Primitives;
- using Windows.UI.Xaml.Data;
- using Windows.UI.Xaml.Input;
- using Windows.UI.Xaml.Media;
- using Windows.UI.Xaml.Media.Animation;
- using Windows.UI.Xaml.Media.Imaging;
- using Windows.UI.Xaml.Navigation;
- using WinRTXamlToolkit.AwaitableUI;
- using WinRTXamlToolkit.Imaging;
- // “用户控件”项模板在 http://go.microsoft.com/fwlink/?LinkId=234236 上提供
- namespace App1
- {
- public sealed partial class HubTile : GridViewItem
- {
- #region propdp
- #region ImgList
- public List<string> ImgList
- {
- get { return (List<string>)GetValue(ImgListProperty); }
- set { SetValue(ImgListProperty, value); }
- }
- // Using a DependencyProperty as the backing store for ImgList. This enables animation, styling, binding, etc...
- public static readonly DependencyProperty ImgListProperty =
- DependencyProperty.Register(
- "ImgList",
- typeof(List<string>),
- typeof(HubTile),
- new PropertyMetadata(null, OnImgListChanged));
- private static void OnImgListChanged(
- DependencyObject d, DependencyPropertyChangedEventArgs e)
- {
- var target = (HubTile)d;
- }
- #endregion
- #endregion
- public HubTile()
- {
- this.InitializeComponent();
- DispatcherTimer timer = new DispatcherTimer();
- int index = 0;
- bool isFirst = true;
- Storyboard storySec = null;
- Storyboard storyFir = null;
- this.Loaded += ((sender, e) =>
- {
- storySec = Resources["UpperSecStoryboard"] as Storyboard;
- storyFir = Resources["UpperFirstStoryboard"] as Storyboard;
- var animation = storySec.Children[0] as DoubleAnimationUsingKeyFrames;
- var keyframe = animation.KeyFrames[0] as SplineDoubleKeyFrame;
- ((storySec.Children[1] as DoubleAnimationUsingKeyFrames).KeyFrames[0] as SplineDoubleKeyFrame).Value = this.Height;
- keyframe.Value = -this.Height;
- if (null != ImgList && ImgList.Count > 0)
- {
- var url = ImgList[0];
- BitmapImage _source = new BitmapImage(new Uri(url));
- this.Img1.Source = _source;
- timer.Start();
- }
- });
- Random r = new Random(Convert.ToInt32(DateTime.Now.Millisecond));
- var second = r.Next(2000, 6000);
- Debug.WriteLine(this.Name + "间隔时间:" + second);
- timer.Interval = TimeSpan.FromMilliseconds(second);
- timer.Tick += (async (o, b) =>
- {
- index++;
- var count = ImgList.Count;
- if (null != ImgList)
- {
- var url = ImgList[index % count];
- BitmapImage _source = new BitmapImage(new Uri(url));
- Debug.WriteLine(this.Name + "加载图片..." + url);
- if (isFirst)
- {
- this.Img2.Source = _source;
- isFirst = false;
- await storySec.BeginAsync();
- Canvas.SetZIndex(SecImg, 1);
- Canvas.SetZIndex(FirstImg, 2);
- }
- else
- {
- this.Img1.Source = _source;
- isFirst = true;
- await storyFir.BeginAsync();
- Canvas.SetZIndex(SecImg, 2);
- Canvas.SetZIndex(FirstImg, 1);
- }
- }
- });
- }
- }
- }
该样例代码中 我使用了awaitUI 来实现对动画执行的监控,
程序逻辑并不复杂,通过随机的timer 来切换图片 实现
开始菜单的效果
demo 稍后上传
最终效果图:
资源下载地址:http://download.csdn.net/detail/wangrenzhu2011/4760211
样例项目
首发 手把手教你制作 Windows8 应用程序内部的 hubtile (动态瓷砖控件) MetroStyle(转)的更多相关文章
-
手把手教你制作微信小程序,开源、免费、快速搞定
最近做了个"罗孚传车"的小程序 一时兴起,做了一个小程序,将个人收集的同汽车相关的行业资讯和学习资料,分享到小程序中,既作为历史资料保存,又提供给更多的人学习和了解,还能装一下:) ...
-
手把手教你制作AppPreview视频并上传到appStore进行审核
手把手教你制作AppPreview视频并上传到appStore进行审核 注意,你需要使用iMovie才能够制作AppPreview视频文件,用QuickTime录制的无效! 最终效果 1. 新建一个事 ...
-
手把手教你写Kafka Streams程序
本文从以下四个方面手把手教你写Kafka Streams程序: 一. 设置Maven项目 二. 编写第一个Streams应用程序:Pipe 三. 编写第二个Streams应用程序:Line Split ...
-
PWA入门:手把手教你制作一个PWA应用
摘要: PWA图文教程 原文:PWA入门:手把手教你制作一个PWA应用 作者:MudOnTire Fundebug经授权转载,版权归原作者所有. 简介 Web前端的同学是否想过学习app开发,以弥补自 ...
-
WPF 程序如何移动焦点到其他控件
原文:WPF 程序如何移动焦点到其他控件 WPF 中可以使用 UIElement.Focus() 将焦点设置到某个特定的控件,也可以使用 TraversalRequest 仅仅移动焦点.本文介绍如何在 ...
-
C# 向程序新建的窗体中添加控件,控件需要先实例化,然后用controls.add添加到新的窗体中去
C# 向程序新建的窗体中添加控件,控件需要先实例化,然后用controls.add添加到新的窗体中去 Form settingForm = new Form(); setForm deviceSet ...
-
手把手教你玩微信小程序跳一跳
最近微信小程序火的半边天都红了,虽然不会写,但是至少也可以仿照网上大神开发外挂吧!下面手把手教妹纸们(汉纸们请自觉的眼观耳听)怎么愉快的在微信小游戏中获得高分. 废话不多说,咱们这就发车了!呸!咱们这 ...
-
手把手教你WEB套打程序开发
WEB套打可选方案不多,理想的更少,利用免费控件Lodop+JavaScript实现精确套打,算是较为经典的选择.这种方案其实比较简单,利用一个htm文件就可以实现模板设计过程,几乎是“空手套”式的开 ...
-
教你写一个Android可快速复用的小键盘输入控件
引子 在Android项目开发中特别是一些稍大型的项目,面对需求文档的时候你经常会发现很多地方用到了同样的组件,但是又略有不同.比如这个: 右边是一个小键盘输入板,左边当焦点不同的时候分别用右边的小键 ...
随机推荐
-
lua解析赋值类型代码的过程
我们来看看lua vm在解析下面源码并生成bytecode时的整个过程: foo = "bar" local a, b = "a", "b" ...
-
PMP 第四章 项目整合管理
1.什么是整合管理,整合什么?如何整合? 项目整合管理包括识别 定义 组合 统一与协调项目管理过组的个过程及项目管理活动二进行的各种过程和活动. 整合兼具统一 合并 连接和一体化的性质,对 ...
-
css压缩(一)
基于require.js的压缩,至于require.js,网上有比较权威的解说 RequireJS进阶(一) RequireJS进阶(二) RequireJS进阶(三) 目前我所做的项目是把各个模块下 ...
-
【poj2226】 Muddy Fields
http://poj.org/problem?id=2226 (题目链接) 题意 给出一个只包含‘.’和‘*’的矩阵,用任意长度的宽为1的木板覆盖所有的‘*’而不覆盖‘.’,木板必须跟矩形的长或宽平行 ...
-
swift闭包传值
不知道原理,就知道这么用的,皮毛上的那一点. 寻思着把以前的项目改成swift的,结果了,,, 反向传值 一. //类似于OC中的typedef typealias sendValueClosure= ...
-
get方式编码问题解决方案 转载
我们的内容使用GET方式发送,就会在URL后面带上内容,在游览器发来的请求经过了游览器的URI编码,发送到服务器这边,如果是struts2会经过拦截器进行URI解码,并且使用"iso8859 ...
-
C语言入门(6)——C语言常用数学函数
在编码过程中会经遇到数学运算,幸运的是C语言提供了非常丰富的数学函数库. 在数学中使用函数有时候书写可以省略括号,而C语言要求一定要加上括号,例如sin(pi/2)这种形式.在C语言的术语中,pi/2 ...
-
ocp11g培训内部教材_053课堂笔记(043)_数据备份
053:数据库高级管理: 目录 第一部分:数据库备份与恢复... 4 第一章:备份恢复概述... 4 1.1 备份的意义: 4 1.2 数据库故障的类型:... 4 1.3 制定你的备份和恢复的计划. ...
-
POI单元格添加公式以及读取公式结果的值
POI提供了为单元格添加条件样式的方法,但是我并没有找到获取单元格改变后样式的方法,获取到样式依旧是没有改变之前的. 比如为单元格添加条件样式用于监听单元格值是否被修改,如果单元格值被修改那么字体颜色 ...
-
matlab GUI保存axes(坐标轴)上的图像
1.默认方式 matlab GUI默认菜单的保存图像默认为保持全部GUI,包括使用" 菜单->编辑->复制图形". 2 保存可见区域 2.1 代码 [FileName, ...