[转]【全面解禁!真正的Expression Blend实战开发技巧】第六章 认识ListBox

反反复复考虑后,准备把这一章的切入点瞄准ListBox。并用了一个看起来有点别扭的标题“认识ListBox",许多人看到这里就不爱看了,即使是大学里用winform的学生也会说ListBox我看他好几年了。但我想说,在实际项目开发中,界面元素除了Button,另一个使用率最高的就是ListBox,你认识ListBox,但未必认识下面几种特殊的ListBox,也未必知道如何最快速构建这样特殊的ListBox,这背后还涉及了blend独有的很重要的一个元素的用法,sampledatasource!有兴趣了吗?好,请看下图。

    

  在我做过的项目中很多都用到了图2和3的表达方式,比如下图中就是用了图3的布局:

    

  国内某个非常著名的公司有一款siverlight产品,也用到了上图中的布局效果。一次交流中我给他们的开发人员看了我做的一个demo,然后他问我:“你这个布局用的是什么控件啊?stackpanel? wrappanel? grid? ” ,当我跟他说是ListBox时他很意外。他告诉我他们产品中,使用grid实现这个效果, 要用code动态生成grid的行与列,把元素一个一个的加进去,由于grid不自带滚动条,所以他们还要用code控制滚动条。如此这般麻烦下才实现了上图中的效果。我听后非常无语,也非常钦佩他们的耐心。其实,实现上面的效果只要30秒。兄弟们,打开Blend,跟我一起做。

  

  打开Data面板,点击Create a sample data按钮,在弹出菜单中选择第一项,new sample data...

    

  

  在弹出菜单中直接点击OK

    

  然后blend会自动生成一个sampleDataSource,他下面紧跟一个名为Collection的集合,集合中包含两个属性Property1,Property2,点击Property1最右侧的按钮,在弹出框中将Type类型选择为Image。如下图所示:

     

  然后点击上图中的Browse...按钮,浏览一个预先准备好图片的文件夹。然后点击OK。我电脑中的位置是“e:\图片文件夹”

    

  下一步,请直接将Property1拖拽到画布上,blend会自动生成一个ListBox。并用刚才浏览的图片内容,填充ListBox。

    

  

  这样我们得到了一个默认样式的ListBox,他就像我们常见的ListBox一样,自上而下排列内容。下一步,为了让他变得特殊一点,请右击ListBox,在弹出菜单中选择Edit Additional Templates -> Edit Layout Of Items ->Create Empty

    

  在弹出对话框中,为你的Template取一个名字,然后点击OK按钮。

    

  然后你会发现,Objects and timeline面板自动切换到了Template编辑模式。如下图:

    

  在右侧属性面板中,找到StackPanel的Orientation属性,我们看到该属性默认值为vertical,也就是说自上而下排列的,请把它修改为horizontal

    

  

  在Objects and timeline面板中,点击下图中最左的“”按钮返回主界面编辑模式。

    

  这样一个水平方向,从左向右排列的ListBox便制作完毕了。

    

  下一步我们来实现图3中的另外一种效果,可以自动换行的ListBox。首先右击ListBox,在弹出菜单中选择Edit Additional Templates -> Edit Layout Of Items ->Edit Current                  

      

  将模板中的StackPanel替换为WrapPanel。(替换方法为:先删除StackPanel,然后点击工具条上的按钮,在搜索栏中输入wrappanel,稍等1分钟左右,blend才会搜索到wrappanel。如果按照上面步骤依然无法找到wrappanel,请确认电脑中是否安装了Microsoft Silverlight 4 Toolkit April 2010)

          

  在Objects and timeline面板中,点击下图中最左的“”按钮返回主界面编辑模式。

    

  

  接下来得到下图中的效果,做到这一步大家可能会有疑问,怎么ListBox一点效果也没有变化呢?

    

  别着急,这是因为wrapPanle的特性是当wrapPanle的宽度不够容下所有子Item时才会换行排列其余的Item。所以我们下一步需要禁用ListBox的水平滚动条,让他内部的wrapPanle没有延展的空间。请点击ListBox,在右侧属性面板中找到HorizontalScrollBarVislbility属性,将它设置为Disabled。

    

  这样就实现了图3中的ListBox效果。

    

  背后的故事

  也许有人会问,假设ListBox中有一万张图片数据,一起加载岂不是会消耗很多的资源? 也许你想到,如果可以随着滚动条向下拖拽,内容被逐步的加载并显示就好了。

其实微软已经替我们考虑并默认集成了这一特性。在WPF中,VirtualizingStackPanel等集合控件本身具有名为virtualizes的特性。请看下图

    

  这是一个拥有10个Item的ListBox。但他的高度只够显示4项Item,5~10(半透明的部分)用户是看不到的。我们从此可以发现,无论ListBox有多少子项,用户同一时间可以看到的只有四项,利用这一点,在WPF中,VirtualizingStackPanel无论有多少子项,实际消耗资源的只有用户看到的那四项,当滚动条向下滑动时,会动态的加载后续资源并使其可视化,同时自动释放移出用户的视野的Items。Silverlight作为WPF的弟弟,当然也默认集成了virtualizes特性。

  详细请参阅http://msdn.microsoft.com/en-us/library/bb613565.aspx  User Interface Virtualization

 

转载文章来源:http://www.cnblogs.com/kaodigua/archive/2011/02/21/1959650.html

转载于:https://www.cnblogs.com/luohengstudy/p/3896612.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【1】项目代码完整且功能都验证ok,确保稳定可靠运行后才上传。欢迎下载使用!在使用过程,如有问题或建议,请及时私信沟通,帮助解答。 【2】项目主要针对各个计算机相关专业,包括计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网等领域的在校学生、专业教师或企业员工使用。 【3】项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 【4】如果基础还行,或热爱钻研,可基于此项目进行二次开发,DIY其他不同功能,欢迎交流学习。 【注意】 项目下载解压后,项目名字和项目路径不要用文,否则可能会出现解析不了的错误,建议解压重命名为英文名字后再运行!有问题私信沟通,祝顺利! 基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip基于C语言实现智能决策的人机跳棋对战系统源码+报告+详细说明.zip
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值