XAML制作Win8磁贴样式

本文主要讲述使用使用XAML制作Win8磁贴样式的方法。

应用范围包括Silverlight网页,Windows Phone,Win8应用商店,WPF等使用XAML作为界面设计的功能。

首先看下效果(网格线是XAML设计器中辅助设计使用,在最终应用中不会出现):

为了实现这样的效果,需要自定义Button控件的样式,即修改Button.Template。

在模板中加入一个Grid,中间置入一个Image控件,放在中央。一个TextBlock控件,放在最下方。

相应的XAML代码如下:

                <Button Height="160" Width="320" BorderBrush="{x:Null}" FontWeight="Bold">
                    <Button.Background>
                        <SolidColorBrush Color="{StaticResource PhoneAccentColor}"/>
                    </Button.Background>
                    <Button.Template>
                        <ControlTemplate>
                            <Grid>
                                <Grid.Background>
                                    <SolidColorBrush Color="{StaticResource PhoneAccentColor}"/>
                                </Grid.Background>
                                <TextBlock Text="新游戏" VerticalAlignment="Bottom"/>
                                <Image Source="/pic/game.png" Width="110"></Image>
                            </Grid>
                        </ControlTemplate>
                    </Button.Template>
                </Button>


在开发Windows Phone应用时,为了在按下Button时有磁贴倾斜的效果(TiltEffect),可以引用WP Toolkit,并添加:

TiltEffect.IsTiltEnabled="True"


在开发Win8或者WPF的桌面应用时,需要鼠标放在上面可以显示边框。需要自己添加一个触发器(Trigger),对应MouseOver事件。

在ControlTemplate标签内,添加如下代码:

                    <ControlTemplate.Triggers>
                        <Trigger Property="IsMouseOver" Value="true">
                            <Setter Property="BorderBrush" TargetName="border" Value="#FF3C7FB1"/>
                        </Trigger>
                    </ControlTemplate.Triggers>




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值