Silverlight2是怎么解决ListBox中一个LayoutBug

本篇文章为大家展示了Silverlight 2是怎么解决ListBox中一个Layout Bug,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

创新互联公司主营师宗网站建设的网络公司,主营网站建设方案,app软件开发公司,师宗h5小程序制作搭建,师宗网站营销推广欢迎师宗等地区企业咨询

Silverlight自身还有没有问题? 谁也没法回答.

工作中遇到了一个关于ListBox的问题. 简单描述一下: 使用ListBox来显示某对象集合, 在排版的时候, 发现无论怎么调整ListBox的属性, 都无法让ListItem充满整个空间; 令人郁闷的是,ListItem中排放的TextBlock/TextBox总会根据自身文本的大小, 自动设定自己的长度; ListItem中的所有控件都自动向左对齐,造成了一副"甘特图"式的图像, 举例(姓名, 年龄, 邮件地址)如下:

Silverlight 2是怎么解决ListBox中一个Layout Bug

在设置了浅蓝色的Border之后, 这个现象实在是太明显了!

按照MSDN的说法, 我们只需要在ListBox的属性中加入如下设定语句, 就会强制长度自动Fill了:

HorizontalContentAlignment="Stretch"
但是加入之后没有效果! 这显然是Silverlight 2的又一个bug.

我们可以在MSDN上看到ItemContainer的默认Style(你也可以从这里看: http://msdn.microsoft.com/en-us/library/cc278062%28vs.95%29.aspx):

   1: 
   2:   
   3:   
   4:   
   5:   
   6:   
   7:   
   8:   
   9:     
  10:       
  11:         
  12:           
  13:             
  14:               
  15:               
  16:                 
  17:                   
  18:                 
  19:               
  20:             
  21:             
  22:               
  23:               
  24:                 
  25:                   
  26:                 
  27:               
  28:             
  29:             
  30:               
  31:                 
  32:                   
  33:                     
  34:                       
  35:                         Visible
  36:                       
  37:                     
  38:                   
  39:                 
  40:               
  41:               
  42:             
  43:           
  44:           
  45:           
  46:           
  47:             x:Name="contentPresenter"
  48:             Content="{TemplateBinding Content}"
  49:             ContentTemplate="{TemplateBinding ContentTemplate}"
  50:             HorizontalAlignment="Left"
  51:             Margin="{TemplateBinding Padding}"/>
  52:           
  53:         
  54:       
  55:     
  56:   
  57: 


可以看出来, 值设置为Left的属性仅有2个:

第3行 HorizontalContentAlignment

第50行 HorizontalAlignment

问题出在了第50行的这个Left,它默认将一个List Item中的所有内容都按照想做对齐的方式排列,由于这个style已经写在了Silverlight Runtime内,所以我们只能重写这个Style去掉这一行并为ListBox指定新的Style。

解决方法:

为ListBox添加属性 HorizontalContentAlignment="Stretch", 强制Fill

在App.xaml中添加命名空间: xmlns:vsm="clr-namespace:System.Windows;assembly=System.Windows"

在App.xaml中添加去掉了HorizontalAlignment="Left"的Style, 并给它的key命名为ListBoxItemContainerStyle ---x:Key="ListBoxItemContainerStyle"

为ListBox添加属性 ItemContainerStyle="{StaticResource ListBoxItemContainerStyle}, 指定用户自定义Style
Done!

现在你可以看到这个运行结果了:

Silverlight 2是怎么解决ListBox中一个Layout Bug

中间的年龄部分是可以随着窗体大小变化自动变化宽度的.

上述内容就是Silverlight 2是怎么解决ListBox中一个Layout Bug,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注创新互联行业资讯频道。


名称栏目:Silverlight2是怎么解决ListBox中一个LayoutBug
文章网址:http://myzitong.com/article/ippsop.html