Search
一步一步学Silverlight 2系列(3):界面布局
概述
Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, Ironpython,对JSON、Web Service、WCF以及Sockets的支持等一系列新的特性。《一步一步学Silverlight 2系列》文章带您快速进入Silverlight 2开发。
本文为系列文章第三篇,学习Silverlight 2中的界面布局,Silverlight 2中新增加了Grid和Panel两个布局容器,使得界面布局更加的强大和灵活。
Canvas面板
Canvas是在Silverlight 1.0时代就有的一种基础布局面板,它采用绝对坐标定位。可以使用附加属性(Attached Property)对Canvas中的元素进行定位,通过附加属性我们指定控件相对于其直接父容器Canvas 控件的上、下、左、右坐标的位置。如下面的XAML声明了两个矩形,它们分别相对于父容器Canvas的左边距是50,相对于父容器Canvas的上边距分别是50和150:
运行后界面的效果如下所示:
除了上面我们用到的Canvas.Top和Canvas.Left两个附加属性外,还有一个Canvas.ZIndex附加属性。如果指定了两个控件相对于父容器Canvas同样的边距,则后面声明的控件父覆盖前面声明的控件。这时我们可以使用Canvas.ZIndex属性来改变它们的显示顺序,如下面的XAML声明:
<Canvas Background="#46461F"> <Rectangle Fill="#0099FF" Width="160" Height="80" Canvas.Top="100" Canvas.Left="100"> <Rectangle Fill="#FF9900" Width="160" Height="80" Canvas.Top="100" Canvas.Left="100"/> </Canvas>
指定两个矩形相对于父容器Canvas的边距相同,这时默认的后声明的橙色矩形会覆盖蓝色矩形:
指定Canvas.ZIndex为1
<Canvas Background="#46461F"> <Rectangle Fill="#0099FF" Width="160" Height="80" Canvas.Top="100" Canvas.Left="100" Canvas.ZIndex="1"/> <Rectangle Fill="#FF9900" Width="160" Height="80" Canvas.Top="100" Canvas.Left="100"/> </Canvas>
将会让蓝色矩形显示在上面,值最大的显示在最上面:
StackPanel
StackPanel支持用行或列的方式来进行页面布局,默认情况下所有的子元素会垂直的排列显示,如下面的XAML声明三个矩形:
<StackPanel Background="#46461F"> <Rectangle Fill="#0099FF" Stroke="White" Width="100" Height="50" Margin="10"/> <Rectangle Fill="#0099FF" Stroke="White" Width="100" Height="50" Margin="10"/> <Rectangle Fill="#0099FF" Stroke="White" Width="100" Height="50" Margin="10"/> </StackPanel>
当然我们也可以指定为水平排列,通过Orientation属性指定:
<StackPanel Background="#46461F" Orientation="Horizontal"> <Rectangle Fill="#0099FF" Stroke="White" Width="100" Height="50" Margin="10"/> <Rectangle Fill="#0099FF" Stroke="White" Width="100" Height="50" Margin="10"/> <Rectangle Fill="#0099FF" Stroke="White" Width="100" Height="50" Margin="10"/> </StackPanel>
运行后界面显示效果如下:
在这里为了让各个控件之间有一定的距离,使用了Margin属性,该属性类似于HTML中的Margin。
Grid
Grid控件类似与HTML中的Table,只不过子元素不用放在单元格中。通过<Grid.RowDefinitions> 和 <Grid.ColumnDefinitions>来定义Grid的行和列,使用Grid.Row和Grid.Column两个附加属性指定子元素在Grid中显示的位置,这是一种非常灵活的布局方式。如下面的XAML声明:
<Grid x:Name="LayoutRoot" Background="#46461F" ShowGridLines="True"> <Grid.RowDefinitions> <RowDefinition Height="120"/> <RowDefinition Height="*"/> </Grid.RowDefinitions> <Grid.ColumnDefinitions> <ColumnDefinition Width="100"/> <ColumnDefinition Width="*"/> </Grid.ColumnDefinitions> <TextBlock Grid.Row="0" Grid.Column="0" Text="UserName:" VerticalAlignment="Center" Foreground="White"></TextBlock> <TextBlock Grid.Row="1" Grid.Column="0" Text="Password:" VerticalAlignment="Center" Foreground="White"></TextBlock> <TextBox Grid.Row="0" Grid.Column="1" Width="200" Height="30" HorizontalAlignment="Left"></TextBox> <TextBox Grid.Row="1" Grid.Column="1" Width="200" Height="30" HorizontalAlignment="Left"></TextBox> </Grid>
定义一个两行两列的Grid,做一个简单的用户登录的布局,为了明显起见,把ShowGridLines属性设为True,以便能够显示出边框线。同时,我们指定了第一行的高度为120,而第二行的则是剩余的高度,用*来指定。运行后效果如下:
综合实例
分别了解了上面的三个布局控件,接下来我们看一个综合实例,如何完成如下的一个取色器:
首先我们添加一个两行两列的Grid控件,分别指定行高和列宽:
<Grid x:Name="LayoutRoot" Background="White"> <Grid.ColumnDefinitions> <ColumnDefinition Width="260" /> <ColumnDefinition Width="*" /> </Grid.ColumnDefinitions> <Grid.RowDefinitions> <RowDefinition Height="120" /> <RowDefinition Height="120" /> </Grid.RowDefinitions> </Grid>
添加颜色显示区域,用一个矩形显示,放入Grid的第0行第1列:
<Rectangle Grid.Row="0" Grid.Column="1" x:Name="PreviewColor" Fill="#FF6600" Margin="10" Stroke="#666666" StrokeThickness="2" />
再添加颜色值显示区,嵌套一个StackPanel控件,让它里面的子控件垂直显示:
<StackPanel Grid.Row="1" Grid.Column="1" > <TextBlock FontSize="12">Color</TextBlock> <TextBox x:Name="HexColor" Width="160" Height="30" Text="#FF6600" Margin="10,5" FontSize="11"/> </StackPanel>
左边用四个Silder控件和四个TextBlock控件显示,需要对Grid的行进行合并Grid.RowSpan属性:
<StackPanel Grid.Row="0" Grid.Column="0" Grid.RowSpan="2" VerticalAlignment="Center"> <TextBlock Text="Alpha" FontSize="12" Margin="10,15,0,0"/> <Slider x:Name="AlphaSlider" Margin="20,0,10,0" Maximum="255" Value="255" ValueChanged="RedSlider_ValueChanged"/> <TextBlock Text="Red" FontSize="12" Margin="10,15,0,0"/> <Slider x:Name="RedSlider" Margin="20,0,10,0" Maximum="255" Value="255" ValueChanged="RedSlider_ValueChanged"/> <TextBlock Text="Green" FontSize="12" Margin="10,15,0,0"/> <Slider x:Name="GreenSlider" Margin="20,0,10,0" Maximum="255" Value="102" ValueChanged="RedSlider_ValueChanged"/> <TextBlock Text="Blue" FontSize="12" Margin="10,15,0,0"/> <Slider x:Name="BlueSlider" Margin="20,0,10,0" Maximum="255" Value="0" ValueChanged="RedSlider_ValueChanged"/> </StackPanel>
这样我们就完成了上面这样相对复杂的界面布局,对Slider控件添加事件处理程序:
private void RedSlider_ValueChanged(object sender, RoutedPropertyChangedEventArgs<double> e) { Color color = Color.FromArgb((byte)AlphaSlider.Value, (byte)RedSlider.Value, (byte)GreenSlider.Value, (byte)BlueSlider.Value); PreviewColor.Fill = new SolidColorBrush(color); HexColor.Text = color.ToString(); }
结束语
关于界面布局就说到这里,在Silverlight 2中,通过上面的三种布局控件相结合,可以进行非常强大和灵活的界面布局。


评论
ED hardy bikini
Ed Hardy Hats
ED hardy men jeans
ED hardy women jeans
ED mens hooded sweatshirts
ED womens hooded sweatshirts
Men's Ed Hardy T-Shirts
Women's Ed Hardy T-Shirts
ed hardy
ed hardy shirts
ed hardy sale
cheap ed hardy
ed hardy outlet
Beats By Dr. Dre Earphones
Monster Beats by Dre Studio
Monster Beats In Ear
Monster Beats Solo Headphones
Monster Butterfly
Monster Diddy Beats
Monster Heartbeats By Lady Gaga
Monster Miles Davis Tribute
monster beats pro
monster beats
dr dre beats
beats by dre
dre beats
dre headphone
Lady Gaga Heartbeats
Monster Beats Butterfly
Monster Beats by Dre Studio
Monster Beats Solo
Monster Beats Tour
Monster Diddy Beats
Monster Miles Davis Tribute
Monster beats dre
beats by monster
cheap beats headphones
Mens True Religion
Mens Bootcut
Mens Corduroy
Mens Flare
Mens Skinny
Mens Straight Leg
Mens T-shirts
Womens True Religion
Womens Bootcut
Womens Cargo
Womens Corduroy
Womens Crops
Womens Flare
Womens Legging
Womens Petite
Womens Shorts
Womens Skinny
Womens Straight Leg
cheap true religion
true religion jeans
cheap true religion
true religion sale
true religion outlet
Canada Goose Coats
Mens Coats
Womens Coats
Canada Goose Glove
Canada Goose Hats
Canada Goose Jackets
Canada Goose New Style
Canada Goose Parka
Chilliwack Parka
Expedition Parka
Mens Chateau Parka
Snow Mantra Parka
Womens Expedition Parka
Womens Montebello Parka
Womens Sollaris Parka
Womens Trillium Parka
Yorkville Parka
Canada Goose Vest
Mens Vest
Women Icicle Vest
Womens Vest
canada goose online
canada goose jacket
canada goose jackets
anada goose jakke
canada goose sale
moncler men
2011 moncler coat
moncler men coat
coats for men cheapMoncler Men's Vests
2011 moncler jackets
2011 Moncler Men
men cheap coatsaffordable winter coats menribera moncler
men winter coats 2011
black moncler nibble boot
2011 New Style Moncler Men Jackets Black
silver winter jacket
new moncler scarf hat black set
moncler scarfs in whole black
moncler scarf and hat set in grey
moncler scarf
moncler mens cheep
moncler men red black vests
moncler k2 women vests
moncler jacket outlet 2011
Moncler
Moncler Outlet
Moncler Men Jackets
cheap nike shoes
wholesale nike shoes
wholesale nike
moncler outlet online
doudoune moncler
moncler jackets
outlet moncler
moncler da donna
moncler cappotti donne
moncler piumini donna
moncler giubbotti donna
moncler donne stivali
moncler uomo
piumino uomo moncler
piumini moncler uomini
moncler giubbotti uomo
maglioni oncler uomini
moncler bambini
moncler borse
moncler sciarpa cappello
ghd sale
cheap ghd straighteners
ghd straighteners uk
uk ghd
uk ghd straighteners
cheap ghd hair straighteners
cheap ghd straighteners uk
Deluxe GHD Midnight Collection
GHD Boho Chic Limited Edition
GHD Carry Case
GHD Diamond Flag Styler
GHD Glamour Limited Edition
GHD IV Blue Serenity
GHD IV Green Envy
GHD IV Mini Styler
GHD IV Red Lust
GHD IV Styler Styling Set
GHD Limited Edition
GHD Limited Edition Pink Orchid
GHD MK4 Black
GHD MK4 Flat Iron
GHD MK4 IV Dark
GHD MK4 IV Gold
GHD MK4 IV Kiss
GHD MK4 IV Pure
GHD MK4 Pink
GHD New Wave Limited Edition
GHD Pink 2011 Limited Edition
GHD Pretty in Pink
GHD Radiance Set
GHD RARE Styler
GHD Rare Styler Leopard
Hair Straightener GHD New Black
Benefit Limited Edition
GHD Mini Styler
GHD MK IV kiss
GHD MK4 Black
GHD MK4 Gold
GHD MK4 Pink
GHD Salon Styler
Leopard Grain
mk4 Dark GLOSS Black
Precious gift set
Pretty Pink Limited Edition
Pure Gloss White
Purple IV styler
NFL Player
Aaron Rodgers Jersey
Adrian Peterson Jersey
Barry Sanders Jersey
Bo Jackson Jersey
Brandon Jacobs Jersey
Brett Favre Jersey
Brian Cushing Jersey
Carson Palmer Jersey
Dallas Clark Jersey
Dan Marino Jersey
DeSean Jackson Jersey
Dez Bryant Jersey
Donald Driver Jersey
Donovan McNabb Jersey
Drew Brees Jersey
Eli Manning Jersey
Hines Ward Jersey
Jared Allen Jersey
Joe Flacco Jersey
Joe Montana Jersey
John Elway Jersey
Ladainian Tomlinson Jersey
Larry Fitzgerald Jersey
Marion Barber Jersey
Mark Sanchez Jersey
Maurice Jones-Drew Jersey
Miles Austin Jersey
Patrick Willis Jersey
Percy Harvin Jersey
Peyton Manning Jersey
Philip Rivers Jersey
Ray Lewis Jersey
Reggie Bush Jersey
Reggie Wayne Jersey
Tim Tebow Jersey
Tom Brady Jersey
Tony Romo Jersey
Troy Polamalu Jersey
Walter Payton Jersey
NHL Player
Ales Hemsky Jersey
Alex Ovechkin Jersey
Alexander Semin Jersey
Alexandre Burrows Jersey
Alexei Kovalev Jersey
Andre Fleury Jersey
Andrei Markov Jersey
Andrew Ladd Jersey
Antti Niemi Jersey
Bobby Clarke Jersey
Bobby Hull Jersey
Brian Gionta Jersey
Brooks Orpik Jersey
Chris Pronger Jersey
Claude Giroux Jersey
Daniel Sedin Jersey
Derek Boogaard Jersey
Dion Phaneuf Jersey
Drew Doughty Jersey
Ductin Byfuglien Jersey
Duncan Keith Jersey
Eric Staal Jersey
Evgeni Malkin Jersey
Gordie Howe Jersey
Henrik Lundqvist Jersey
Henrik Sedin Jersey
Henrik Zetterberg Jersey
Jamie Langenbrunner Jersey
Jarome Iginla Jersey
Jaroslav Halak Jersey
Jason Spezza Jersey
Jeff Carter Jersey
Joe Sakic Jersey
Joe Thornton Jersey
John Tavares Jersey
Jonathan Cheechoo Jersey
Jonathan Toews Jersey
Kris Letang Jersey
Kris Versteeg Jersey
Marc Savard Jersey
Mario Lemieux Jersey
Martin Brodeur Jersey
Martin Havlat Jersey
Maxime Talbot Jersey
Michael Cammalleri Jersey
Mike Green Jersey
Mike Modano Jersey
Mike Richards Jersey
Milan Lucic Jersey
Nicklas Backstrom Jersey
Nicklas Lidstrom Jersey
Nikals Hjalmarsson Jersey
Niklas Backstrom Jersey
Patrice Bergeron Jersey
Patrick Kane Jersey
Patrick Marleau Jersey
Patrick Sharp Jersey
Pavel Datsyuk Jersey
PK Subban Jersey
Rick Depietro Jersey
Rick Nash Jersey
Roberto Luongo Jersey
Ryan Getzlaf Jersey
Ryan Kesler Jersey
Ryan Miller Jersey
Scott Gomez Jersey
Shane Doan Jersey
Shea Weber Jersey
Sidney Crosby Jersey
Simon Gagne Jersey
Steve Yzerman Jersey
Steven Stamkos Jersey
Thomas Vanek Jersey
Tj Oshie Jersey
Vincent Lecavalier Jersey
Wayne Gretzky Jersey
The hottest new traditional and seasonal
coach outlet store online
. Keep up to date with the latest trends. Look at this zip top closure with colorful C logo printed fabric bag.You may find the most affordable Bags here.This brown handbag called Flagship Signature Brown Handbag has been the best seller in the
coach factory outlet
for almost three weeks.Everyone believes the fact that
coach outlet store online
can be well-known simply because of its high quality and the lovely pattern.My friend is dying to get a coach purse at
coach outlet store
because all of her friends have them at work. They earn great reputation from many people.The latest fashion collection contains those bags suitable to be worn in both casual and formal environment. We provide the best quality
louis vuitton uk
with the most reasonable price we can offer as you see in our online store.in fact,
louis vuitton
is one of the most famous fashion design master.he opened the fist suitcase shop called after his name.louis vuitton outlet
,welcome to buy urban louis vuitton on our online shop.discount price is our special offer, durability and high quality is our promise.They're not chosen, so one of these ideal for you.For more flexibleness a lot more like these, there are lots of discount 'shoulder' variations outlet
louis vuitton bags
.Show someone how much you care with this sophisticated and sparkling
christian louboutin
collection. Cut with exquisite detail, this can be a beautiful yet practical gift.All of the
armani watches
Denim handbags at the High quality, practical, timeless yet resolutely modern design with our professional and excellent service.You can choose the discount Louis Vuitton bags on our website. Cheap
emporio armani watches
are specifically designed to make a statement of fashion and elegance..With the safe door to door shipping, the
gucci outlet
will send the products to your hands, which are of top quality and at competitive factory prices.One of my friend wants to buy a gift for her mother on the Mother's Day. She asks me, I suggest her to buy
hermes bags
, which has good quality and unique design.I can't wait sharing the
hermes birkin
with you.It's an online crystal shopping paradise supplying delicate Swarovski jewelry.coach outlet is the market popular time the longest and most successful brand of one of the leather. coach handbags most people on behalf of the American fashion during the innovation style and traditional skills. coach bags durable quality and exquisite craft in the female consumers have a good reputation.
As one fans of football games, I am really interested in the NFL Jerseys. As far I am cared, wearing these jerseys is the perfect course to way to show your enthusiasm ,advocate for your particular and favourite team.The Wholesale NFL Jerseys have numerous conveniences that make them stand out in the many kinds of jerseys surround. In the competitive servant market, the Cheap NFL Jerseys in our website are well-known for the the ingenious chart and limited edition that make your favorite team stand out.There was a time when football was meant for men only.But now,The high quality and nice craftsmanship of Cheap jerseys are a great gift for whether you are men or women.
NFL Cardinals Jerseys now depict a style for people wearing them. In common, everyone can show his passion for their favourite team along with wearing these wonderful and comfortable jerseys.The most momentous thing is that these jerseys are exceedingly fashionable, update and have the high quality, the NFL Cardinals Jerseys are peppery selling in the mall immediately.Which is the most fantastic object for me is the Kolb Kevin Jerseys are accessible in the our store for everyone to choose.
进行个判断,若未初始化实例对象,则不执行语句即可。
if ((RedSlider != null) && (GreenSlider != null) && (BlueSlider != null))
{
Color color = Color.FromArgb((byte)AlphaSlider.Value, (byte)RedSlider.Value, (byte)GreenSlider.Value, (byte)BlueSlider.Value);
PreviewColor.Fill = new SolidColorBrush(color);
HexColor.Text = color.ToString();
}
Color color = Color.FromArgb((byte)AlphaSlider.Value, (byte)RedSlider.Value, (byte)GreenSlider.Value, (byte)BlueSlider.Value);
说是未将对象引用设置到对象的实例。
将页面Slider中控件的value去掉就好了
为什么 去掉Slider中的value 就好了 ?
我刚开始看了一下sl2, 感觉还是比较爽, 只是很多东西没可能是不会用,现在很不顺手
能不能说说代码控制界面布局哪, 我做了一个地图基础图层就发现很多问题:
1. 不知道怎么将一个类似工具条的UserControl 放在界面的最顶层;
2.好像sl2的GC不起作用,我去掉了所有的引用还是无法释放内存;
http://www.shareach.com:81
我的email:yinpengxiang@hotmail.com
或者到我 http://sps.shareach.com上流言讨论,谢谢
Gift-Van Cleef & Arpels Chronograph Watch A thing is only ed hardy completely our own when it is a thing of joy ed hardy Gift-Van Cleef & Arpels Chronograph Watch A thing is only red soul shoes designer completely our own when it is a thing of joy christian louboutin cheap Gift-Van Cleef & Arpels Chronograph Watch A thing is only cheap fashion jewelry completely our own when it is a thing of joy tiffany & Co jewelry Gift-Van Cleef & Arpels Chronograph Watch A thing is only herve leger replica dress completely our own when it is a thing of joy sandals for cocktail dress
intellectual but not in the form of a. If we herve leger replica add these things on the impact of Tagore on the fake christian louboutin shoes intellectual but not in the form of a. If we high heeled shoes add these things on the impact of Tagore on the ladies shoes intellectual but not in the form of a. If we ed hardy uk add these things on the impact of Tagore on the ed hardy clothing intellectual but not in the form of a. If we silver jewelry wholesale add these things on the impact of Tagore on the silver jewelry