拼吾爱程序人生

首页 » .Net编程 » Silverlight » 在Silverlight2 Beta2中开发自定义控件
cobra - 2008-8-3 3:47:00
本文主要讲述如何在Silverlight2中开发一个自定义控件,我使用环境是VS2008 Silverlight2 Beta2。

一:创建Silverlight2 类库项目,如下图:


 附件: 您所在的用户组无法下载或查看附件


然后我们添加一个控件类,该可以继承自Control类,也可以继承自其他类比如ContentControl,ItemControl。我们继承自ContentControl,代码如下:

Code


其实现在已经做好了一个最简单的自定义控件,我们给给他一个控件模板就可以了。在Page.xaml的Grid中添加如下代码:

Code


效果如下图:

 附件: 您所在的用户组无法下载或查看附件

二:创建控件模板下面我们为控件提供一个默认的控件模板,像类库项目中添加添加Generic.xaml文件,代码如下:

Code


向我们的控件类CarySLCustomControl的构造函数中添加如下代码:

Code


在Page.xaml中我们只需要引用控件<custom:CarySLCustomControl/>,就可以达到上面一样的效果了。

三:模板绑定我们在使用控件的时候都会做响应的属性设定,比如:

Code


但是你现在做该设置是不会生效的,还仍然使用控件模板的设定,我们可以在控件模板中通过使用 {TemplateBinding ControlProperty} 的标识扩展句法来绑定到控件的属性来实现,使用ContentPresenter控件可以灵活的设置各个属性。修改后的Generic.xaml的代码如下:

Code


Page.xaml中更改控件的属性如下:

Code


效果如下图:

 附件: 您所在的用户组无法下载或查看附件

原文出处:http://www.cnblogs.com/carysun/a ... lcustomcontrol.html

 您可能对 [Silverlight] 的这些文章也感兴趣:

四个原因让Silverlight无法取代Flash
SilverLight 2.0 事件触发
使用Silverlight开发用户贡献内容的视频站点的快速入门包
微软Silverlight和Adobe Flash 谁是最后的王者?
Silverlight 2 (beta1)数据操作(3)
使用silverlight中的Storyboard实现动画效果
Silverlight教程第四部分:使用 Style 元素更好地封装观感
基于Silverlight的精简框架之应用
Silverlight 2中多语言支持实现(下)
三分钟制作精美电子地图(Silverlight 2 + Deep Zoom 含代码)
cobra - 2008-8-3 3:52:00
四:添加一个单击事件
WPF中支持向下和向下的事件路由,路由事件的路由可有效地向上遍历或向下遍历树,这要取决于该事件是隧道路由事件还是冒泡路由事件,而Silverlight中的路由事件只支持冒泡路由策略。下面我们为该控件添加一个单击事件,代码如下:

Code


现在我们就可以使用控件的单击事件了,Page.xaml中如下:

Code


Page.xaml.cs中编写事件处理程序如下:

Code


运行后如下图:

 附件: 您所在的用户组无法下载或查看附件


五:可视化状态



在Silverlight中微软引入一种新的模式来处理事件和用户进行交互,例如当鼠标经过控件时。控件可以从一种状态转换到另一种状态,我们下面就已从"normal" 状态到 "pressed" 状态来进行简单的说明。我们使用Silverlight中的Visual State Manager (VSM)来简化对可视化状态和可视化状态转换之间的处理。使用VisualState对象来定义不同的状态,Visual Transition对象定义状态间的转换。使用Visual StateManager类的静态方法GoToState来控制状态的装换。修改完成后的generic.xaml中的代码如下:

Code


在控件类CarySLCustomControl中添加如下代码:

Code


这样就可以了。到此一个最简单的控件就开发好了。
1
查看完整版本: 在Silverlight2 Beta2中开发自定义控件
Modify by pin5i DZNT_ExpandPackage 2.1.3237 2007-2008 pin5i.com
  Total Unique Visitors: