由于Writer嫌我文章过长,只能把上篇拆开两半了。以下是接着上篇的。

准备工作做完了,现在就要完成点击事件。

定义Expander和单击事件:

 1: /// <summary> 
 2: /// The togglebutton for expanding or collapsing the items when mouse left button clicked on it 
 3: /// </summary> 
 4: private ToggleButton expander;
 5:  
 1: /// <summary> 
 2: /// Gets or sets the toggle button Expander 
 3: /// </summary> 
 4: public ToggleButton Expander
 5: {
 6:  get 
 7: {
 8:  return this.expander;
 9: }
 10:  
 11:  set 
 12: {
 13:  if (this.expander != null)
 14: {
 15:  this.expander.Click -= new RoutedEventHandler(this.OnExpanderClick);
 16: }
 17:  
 18:  this.expander = value;
 19:  
 20:  if (this.expander != null)
 21: {
 22:  this.expander.IsChecked = new bool?(this.IsExpanded);
 23:  this.expander.Click += new RoutedEventHandler(this.OnExpanderClick);
 24: }
 25: }
 26: }
 27:  
 1: /// <summary> 
 2: /// Method occurs when mouse left button click on Expander 
 3: /// </summary> 
 4: /// <param name="sender">The source object</param> 
 5: /// <param name="e">The routed event arrguments</param> 
 6: private void OnExpanderClick(object sender, RoutedEventArgs e)
 7: {
 8:  bool flag = !this.IsExpanded;
 9:  this.IsExpanded = flag;
 10: }
 11:  
 1: /// <summary> 
 2: /// Method occurs when the expanded state has been changed 
 3: /// </summary> 
 4: /// <param name="handler">The target event handler</param> 
 5: /// <param name="args">The routed arrguments</param> 
 6: private void ChangeExpandedState(RoutedEventHandler handler, RoutedEventArgs args)
 7: {
 8:  ToggleButton button = this.Expander;
 9:  
 10:  if (button != null)
 11: {
 12: button.IsChecked = new bool?(this.IsExpanded);
 13: }
 14:  
 15:  this.UpdateVisualState(true);
 16:  this.RaiseEvent(handler, args);
 17: }
 18:  

接下来就是最后一步了,就是定义展开和收起事件,并把它们和刚才的准备工作结合起来

定义event handler:

 1: #region Events
 2:  
 3: /// <summary> 
 4: /// The expanded event 
 5: /// </summary> 
 6: public event RoutedEventHandler Expanded;
 7:  
 8: /// <summary> 
 9: /// The Collapsed event 
 10: /// </summary> 
 11: public event RoutedEventHandler Collapsed;
 12:  
 13: #endregion 
 14:  

定义事件:

 1: /// <summary> 
 2: /// To expand the children 
 3: /// </summary> 
 4: /// <param name="e">The routed event arrguments</param> 
 5: public void OnExpanded(RoutedEventArgs e)
 6: {
 7:  this.ChangeExpandedState(this.Expanded, e);
 8: }
 9:  
 10: /// <summary> 
 11: /// To collapse the children 
 12: /// </summary> 
 13: /// <param name="e">The routed event arrguments</param> 
 14: public void OnCollapsed(RoutedEventArgs e)
 15: {
 16:  this.ChangeExpandedState(this.Collapsed, e);
 17: }
 18:  

修改OnIsExpandedPropertyChanged方法:

 1: /// <summary> 
 2: /// Call back when IsExpanded property has been changed 
 3: /// </summary> 
 4: /// <param name="o">The target object</param> 
 5: /// <param name="e">The property changed event arrguments</param> 
 6: private static void OnIsExpandedPropertyChanged(DependencyObject o, DependencyPropertyChangedEventArgs e)
 7: {
 8:  FancyTreeViewItem item = o as FancyTreeViewItem;
 9:  bool newValue = (bool)e.NewValue;
 10:  RoutedEventArgs args = new RoutedEventArgs();
 11:  
 12:  if (newValue)
 13: {
 14: item.OnExpanded(args);
 15: }
 16:  else 
 17: {
 18: item.OnCollapsed(args);
 19: }
 20: }
 21:  

从模板中寻找Expander模块跟类中Expander按钮对应起来:

 1: /// <summary> 
 2: /// Override the function for banding template 
 3: /// </summary> 
 4: public override void OnApplyTemplate()
 5: {
 6:  this.Expander = this.GetTemplateChild("Expander") as ToggleButton;
 7:  base.OnApplyTemplate();
 8: }
 9:  

最后运行看下效果:

图3.1 节点收起的效果图

图3.2 节点展开的效果图

Silverlight自定义控件系列 – TreeView (3) 添加展开和收起事件的更多相关文章

  1. Silverlight自定义控件系列 – TreeView (2) 基本布局和States

    TreeView的树形结构都以缩进方式显示,现在来完成这部分. 首先,要定义出每个节点上都包含什么东西.先看看Win7资源管理器的TreeView: 图2.1 资源管理器 一个通用的TreeView至 ...

  2. Silverlight自定义控件系列 – TreeView (1)

      原文路径:http://blog.csdn.net/wlanye/article/details/7265457 很多人都对MS自带的控件不太满意(虽然MS走的是简约风格),都会试图去修改或创建让 ...

  3. Silverlight自定义控件系列 – TreeView (4) 缩进

    接下来是缩进,没有缩进的Tree怎么看都不顺眼. 首先,定义节点深度Depth(注:回叫方法暂没有代码,以后要用到): 1: /// <summary> 2: /// Using a De ...

  4. 一步一步学Silverlight 2系列(25):综合实例之Live Search

    概述 Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, ...

  5. 一步一步学Silverlight 2系列(22):在Silverlight中如何用JavaScript调用.NET代码

    概述 Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, ...

  6. 一步一步学Silverlight 2系列(21):如何在Silverlight中调用JavaScript

    概述 Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, ...

  7. 一步一步学Silverlight 2系列(20):如何在Silverlight中与HTML DOM交互(下)

    述 Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, ...

  8. 一步一步学Silverlight 2系列(19):如何在Silverlight中与HTML DOM交互(上)

    概述 Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, ...

  9. 一步一步学Silverlight 2系列(17):数据与通信之ADO.NET Data Services

    概述 Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, ...

随机推荐

  1. hdu5195 二分+线段树+拓扑序

    这题说的给了n个点m条边要求保证是一个有向无环图,可以删除至多k条边使得这个图的拓扑序的字典序最大,我们知道如果我们要排一个点的时候一定要考虑比他大的点是否可以.通过拆边马上拆出来,如果可以拆当然是拆 ...

  2. LINUX环境变量(一)

    Linux 的变量可分为两类:环境变量和本地变量 环境变量,或者称为全局变量,存在与所有的shell 中,在你登陆系统的时候就已经有了相应的系统定义的环境变量了.Linux 的环境变量具有继承性,即子 ...

  3. Linux基础命令---swapoff

    swapoff 关闭交换分区,同时可以刷新交换分区的缓存.关闭交换分区后,使用free指令查看内存,swap数值会减少.此命令的适用范围:RedHat.RHEL.Ubuntu.CentOS.SUSE. ...

  4. 关于微信分享到朋友圈(Thinkphp-tp3.2框架下实现)

    PHP部分 扩展类代码部分: <?php namespace Think; class JsSdk { private $appId; private $appSecret; public $d ...

  5. 如何用tomcat发布自己的Java项目

    如何用tomcat发布自己的Java项目 tomcat是什么?它是一个免费的开放源代码的Web 应用服务器,属于轻量级应用服务器.我们用Java开发出来的web项目,通过tomcat发布出来,别人就可 ...

  6. java service wrapper日志参数设置及优化

    一般在容器比如tomcat/weblogic中运行时,我们都是通过log4j控制日志输出的,因为我们现在很多服务端使用java service wrapper(至于为什么使用jsw,原先是比较排斥使用 ...

  7. JavaScript 添加新元素

    JavaScript 添加新元素 版权声明:未经授权,严禁转载! 添加元素 创建元素 使用 JS 可以为一个已有的元素添加一个新的子元素. 第一步:创建空元素. - var elem = docume ...

  8. 20145106 《Java程序设计》第9周学习总结

    教材学习内容总结 JDBC标准主要分为两个部分:JDBC应用程序开发者接口以及JDBC驱动程序开发者接口. 如果将来要换为Oracle数据库,只要置换Oracle驱动程序. Java中的数据类型和SQ ...

  9. 20145310《网络对抗》Exp9 Web安全基础实践

    基础问题回答 SQL注入攻击原理,如何防御? SQL注入攻击就是通过把SQL命令插入到Web表单递交或输入域名或页面请求的查询字符串,通过执行SQL语句进执行攻击者所要的操作. 如何防御?首先严格区分 ...

  10. tf.reduce_sum tensorflow维度上的操作

    tensorflow中有很多在维度上的操作,本例以常用的tf.reduce_sum进行说明.官方给的api reduce_sum( input_tensor, axis=None, keep_dims ...