手把手教你:亲手打造Silverlight的Win8 Metro外观(2) 菜单

 

经过上一篇的分析,现在开始动手!

首先来看一下. 我们的菜单他的表现形式是如何的.

比如说我们现在有一个数据库叫  lonix_gls_2  有一个表menu (菜单)

id 为主键,  fore_id 为上级id  , name 为菜单名 , Code为菜单所对面的xaml文件名

菜单为树形结构.数据如下,  红色为 主菜单

T-SQL 代码
 1 SET ANSI_NULLS ON
 2 GO
 3 SET QUOTED_IDENTIFIER ON
 4 GO
 5 IF NOT EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[menu]') AND type in (N'U'))
 6 BEGIN
 7 CREATE TABLE [dbo].[menu](
 8     [id] [int] IDENTITY(1,1) NOT NULL,
 9     [name] [nvarchar](10) NULL,
10     [foreid] [int] NULL,
11 PRIMARY KEY CLUSTERED 
12 (
13     [id] ASC
14 )WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY]
15 ) ON [PRIMARY]
16 END


我们用RIA SERVICE 所查出来的代码结构应该如下

 1 new List<TestModel> 
 2             {
 3                 new TestModel {
 4                     Name = "编码设置",
 5                     Children = new List<TestModel> { 
 6                         new TestModel { Name = "00101", Code="Test" } ,
 7                         new TestModel { Name = "00102", Code="Test1" } ,
 8                         new TestModel { Name = "00103"  } 
 9                     } 
10                 },
11                 new TestModel {
12                     Name = "系统设置",
13                     Children = new List<TestModel> { 
14                         new TestModel { Name = "00201" } 
15                     }
16                 },
17             };


以上为测试数据..

打开VS  新建三个模版控件!

新建的类默认从  Control  继承. 我们需要手动将其改为从 ItemsControl继承..

总共新建 

Desktop(继承ItemsControl[主菜单容器])  以作用于包含任意项的 DesktopGroup

DesktopGroup(继承ItemsControl[分组菜单容器])  以作用于包含任意项的 DesktopItem

DesktopItem(继承ContentControl[子主菜单项])

 

一. Desktop  主菜单容器

1. 使desktop 中的子项 横向自动布局, 因此我们将他的ItemsPanel 设为StackPanle

2. 使循环绑定子项

3. 容器的布局

代码如下:

 1     <Style TargetType="local:Desktop">
 2         <Setter Property="ItemsPanel">
 3             <Setter.Value>
 4                 <ItemsPanelTemplate>
 5                     <StackPanel x:Name="DesktopRootPanel" Orientation="Horizontal" Background="{x:Null}">
 6                     </StackPanel>
 7                 </ItemsPanelTemplate>
 8             </Setter.Value>
 9         </Setter>
10         <Setter Property="ItemTemplate">
11             <Setter.Value>
12                 <common:HierarchicalDataTemplate>
13                     <local:DesktopGroup ItemsSource="{Binding Path=Children}" />
14                 </common:HierarchicalDataTemplate>
15             </Setter.Value>
16         </Setter>
17         <Setter Property="Template">
18             <Setter.Value>
19                 <ControlTemplate TargetType="local:Desktop">
20                     <Grid>
21                         <Border Background="White" Opacity="0.1">
22                         </Border>
23                         <Border Margin="50,0,50,0">
24                             <ItemsPresenter />
25                         </Border>
26                     </Grid>
27                 </ControlTemplate>
28             </Setter.Value>
29         </Setter>
30     </Style>

 

local 命名空间为 当前项目

xmlns:local="clr-namespace:当前项目"

 

common 命名空间为

xmlns:common="clr-namespace:System.Windows;assembly=System.Windows.Controls"

Desktop 数据绑循环为 DesktopGroup

二. DesktopGroup子菜单容器

同Desktop 基本相同

 

 1   <Style TargetType="local:DesktopGroup">
 2         <Setter Property="ItemsPanel">
 3             <Setter.Value>
 4                 <ItemsPanelTemplate>
 5                     <tlk:WrapPanel  x:Name="DesktopGroupRootPanel" Orientation="Vertical" />
 6                 </ItemsPanelTemplate>
 7             </Setter.Value>
 8         </Setter>
 9         <Setter Property="ItemTemplate">
10             <Setter.Value>
11                 <common:HierarchicalDataTemplate>
12                     <local:DesktopItem />
13                 </common:HierarchicalDataTemplate>
14             </Setter.Value>
15         </Setter>
16         <Setter Property="Template">
17             <Setter.Value>
18                 <ControlTemplate TargetType="local:DesktopGroup">
19                     <Grid Margin="0,0,50,0" Height="Auto">
20                         <Grid.RowDefinitions>
21                             <RowDefinition Height="Auto" />
22                             <RowDefinition Height="*" />
23                         </Grid.RowDefinitions>
24                         <TextBlock Text="{Binding Name}" Grid.Row="0" FontSize="15" FontWeight="Black" />
25                         <Border Grid.Row="1"  Background="{TemplateBinding Background}"
26                             BorderBrush="{TemplateBinding BorderBrush}"
27                             BorderThickness="{TemplateBinding BorderThickness}" >
28                             <Border.Effect>
29                                 <BlurEffect Radius="5" />
30                             </Border.Effect>
31                         </Border>
32                         <ItemsPresenter Margin="2" Grid.Row="1" />
33                     </Grid>
34                 </ControlTemplate>
35             </Setter.Value>
36         </Setter>
37     </Style>

DesktopGroup 数据绑定循环为 DesktopItem

DesktopItem相比这二个之下可能有点繁琐,因此放在下一篇来制作

posted @ 2012-04-14 17:02  董侨  阅读(2792)  评论(4编辑  收藏  举报