综合应用WPF/WCF/WF/LINQ之二十五:使用CustomControl技术编写一个翻页控件

简介:
 有了上篇文章的基础,这篇文章实现CustomControl就简单得多了,绝大多数代码也可以直接Copy过来使用。具体的创建CustomControl的步骤我就不累述了。
  为了方便大家学习,请 单击此处 下载该程序的代码。
  这次,Themes\Pager.xaml的代码如下:
    1  < ResourceDictionary
    2     xmlns ="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    3     xmlns : x ="http://schemas.microsoft.com/winfx/2006/xaml"
    4     xmlns : local ="clr-namespace:Eallies.OA.UI.Controls.Common">
    5 
    6       < Style  TargetType ="{ x : Type  local : Pager }">
    7           < Setter  Property ="Template">
    8               < Setter.Value >
    9                   < ControlTemplate >
   10                       < Grid >
   11                          ……
   12                       </ Grid >
   13                   </ ControlTemplate >
   14               </ Setter.Value >
   15           </ Setter >
   16       </ Style >
   17 
   18  </ ResourceDictionary >
  其中省略号的部分用上篇文章中的Grid之间的代码代替。唯一需要修改的是:将上篇文章中,各个Label控件的MouseLeftButtonUp方法删除。
  由于我曾经解释过,我们不建议在Themes目录下创建一个Pager.xaml.cs文件去处理各个Label控件的事件,所以我们需要在主程序中找到各个Label控件,并注册事件。
  我们可以重写OnApplyTemplate事件,在这里去找到各个Label控件,并注册事件。
    1          public  override  void OnApplyTemplate()
    2         {
    3              try
    4             {
    5                  base.OnApplyTemplate();
    6 
    7                  this.AttachToVisualTree();
    8             }
    9              catch
   10             {
   11                  throw;
   12             }
   13         }
   14 
   15          private  void AttachToVisualTree()
   16         {
   17              try
   18             {
   19                  this.DetachFromVisualTree();
   20 
   21                  this.lblFirst =  this.GetTemplateChild( "lblFirst"as  Label;
   22                  this.lblPrevious =  this.GetTemplateChild( "lblPrevious"as  Label;
   23                  this.lblPage1 =  this.GetTemplateChild( "lblPage1"as  Label;
   24                  this.lblPage2 =  this.GetTemplateChild( "lblPage2"as  Label;
   25                  this.lblPage3 =  this.GetTemplateChild( "lblPage3"as  Label;
   26                  this.lblPage4 =  this.GetTemplateChild( "lblPage4"as  Label;
   27                  this.lblPage5 =  this.GetTemplateChild( "lblPage5"as  Label;
   28                  this.lblNext =  this.GetTemplateChild( "lblNext"as  Label;
   29                  this.lblLast =  this.GetTemplateChild( "lblLast"as  Label;
   30                  this.lblPages =  this.GetTemplateChild( "lblPages"as  Label;
   31 
   32                  if ( this.lblFirst !=  nullthis.lblFirst.MouseLeftButtonUp +=  new  MouseButtonEventHandler(lblFirst_MouseLeftButtonUp);
   33                  if ( this.lblPrevious !=  nullthis.lblPrevious.MouseLeftButtonUp +=  new  MouseButtonEventHandler(lblPrevious_MouseLeftButtonUp);
   34                  if ( this.lblPage1 !=  nullthis.lblPage1.MouseLeftButtonUp +=  new  MouseButtonEventHandler(lblPage1_MouseLeftButtonUp);
   35                  if ( this.lblPage2 !=  nullthis.lblPage2.MouseLeftButtonUp +=  new  MouseButtonEventHandler(lblPage2_MouseLeftButtonUp);
   36                  if ( this.lblPage4 !=  nullthis.lblPage4.MouseLeftButtonUp +=  new  MouseButtonEventHandler(lblPage4_MouseLeftButtonUp);
   37                  if ( this.lblPage5 !=  nullthis.lblPage5.MouseLeftButtonUp +=  new  MouseButtonEventHandler(lblPage5_MouseLeftButtonUp);
   38                  if ( this.lblNext !=  nullthis.lblNext.MouseLeftButtonUp +=  new  MouseButtonEventHandler(lblNext_MouseLeftButtonUp);
   39                  if ( this.lblLast !=  nullthis.lblLast.MouseLeftButtonUp +=  new  MouseButtonEventHandler(lblLast_MouseLeftButtonUp);
   40             }
   41              catch
   42             {
   43                  throw;
   44             }
   45         }
   46 
   47          private  void DetachFromVisualTree()
   48         {
   49              try
   50             {
   51                  if ( this.lblFirst !=  nullthis.lblFirst.MouseLeftButtonUp -=  new  MouseButtonEventHandler(lblFirst_MouseLeftButtonUp);
   52                  if ( this.lblPrevious !=  nullthis.lblPrevious.MouseLeftButtonUp -=  new  MouseButtonEventHandler(lblPrevious_MouseLeftButtonUp);
   53                  if ( this.lblPage1 !=  nullthis.lblPage1.MouseLeftButtonUp -=  new  MouseButtonEventHandler(lblPage1_MouseLeftButtonUp);
   54                  if ( this.lblPage2 !=  nullthis.lblPage2.MouseLeftButtonUp -=  new  MouseButtonEventHandler(lblPage2_MouseLeftButtonUp);
   55                  if ( this.lblPage4 !=  nullthis.lblPage4.MouseLeftButtonUp -=  new  MouseButtonEventHandler(lblPage4_MouseLeftButtonUp);
   56                  if ( this.lblPage5 !=  nullthis.lblPage5.MouseLeftButtonUp -=  new  MouseButtonEventHandler(lblPage5_MouseLeftButtonUp);
   57                  if ( this.lblNext !=  nullthis.lblNext.MouseLeftButtonUp -=  new  MouseButtonEventHandler(lblNext_MouseLeftButtonUp);
   58                  if ( this.lblLast !=  nullthis.lblLast.MouseLeftButtonUp -=  new  MouseButtonEventHandler(lblLast_MouseLeftButtonUp);
   59             }
   60              catch
   61             {
   62                  throw;
   63             }
   64         }
  其它的代码就跟上一篇文章中的一样了。




本文转自 Eallies 51CTO博客,原文链接:http://blog.51cto.com/eallies/79016,如需转载请自行联系原作者
目录
相关文章
|
5月前
|
开发框架 缓存 前端开发
循序渐进介绍基于CommunityToolkit.Mvvm 和HandyControl的WPF应用端开发(11) -- 下拉列表的数据绑定以及自定义系统字典列表控件
循序渐进介绍基于CommunityToolkit.Mvvm 和HandyControl的WPF应用端开发(11) -- 下拉列表的数据绑定以及自定义系统字典列表控件
|
5月前
|
C# 开发者 Windows
一款基于Fluent设计风格、现代化的WPF UI控件库
一款基于Fluent设计风格、现代化的WPF UI控件库
133 1
|
5月前
|
C# Windows
WPF中如何使用HandyCotrol控件库
WPF中如何使用HandyCotrol控件库
227 1
|
5月前
|
vr&ar C# 图形学
WPF与AR/VR的激情碰撞:解锁Windows Presentation Foundation应用新维度,探索增强现实与虚拟现实技术在现代UI设计中的无限可能与实战应用详解
【8月更文挑战第31天】增强现实(AR)与虚拟现实(VR)技术正迅速改变生活和工作方式,在游戏、教育及工业等领域展现出广泛应用前景。本文探讨如何在Windows Presentation Foundation(WPF)环境中实现AR/VR功能,通过具体示例代码展示整合过程。尽管WPF本身不直接支持AR/VR,但借助第三方库如Unity、Vuforia或OpenVR,可实现沉浸式体验。例如,通过Unity和Vuforia在WPF中创建AR应用,或利用OpenVR在WPF中集成VR功能,从而提升用户体验并拓展应用功能边界。
103 0
|
5月前
|
C# Windows 开发者
当WPF遇见OpenGL:一场关于如何在Windows Presentation Foundation中融入高性能跨平台图形处理技术的精彩碰撞——详解集成步骤与实战代码示例
【8月更文挑战第31天】本文详细介绍了如何在Windows Presentation Foundation (WPF) 中集成OpenGL,以实现高性能的跨平台图形处理。通过具体示例代码,展示了使用SharpGL库在WPF应用中创建并渲染OpenGL图形的过程,包括开发环境搭建、OpenGL渲染窗口创建及控件集成等关键步骤,帮助开发者更好地理解和应用OpenGL技术。
401 0
|
5月前
|
开发者 C# 容器
【独家揭秘】当WPF邂逅DirectX:看这两个技术如何联手打造令人惊艳的高性能图形渲染体验,从环境搭建到代码实践,一步步教你成为图形编程高手
【8月更文挑战第31天】本文通过代码示例详细介绍了如何在WPF应用中集成DirectX以实现高性能图形渲染。首先创建WPF项目并使用SharpDX作为桥梁,然后在XAML中定义承载DirectX内容的容器。接着,通过C#代码初始化DirectX环境,设置渲染逻辑,并在WPF窗口中绘制图形。此方法适用于从简单2D到复杂3D场景的各种图形处理需求,为WPF开发者提供了高性能图形渲染的技术支持和实践指导。
341 0
|
5月前
|
C# 开发者 Windows
WPF遇上Office:一场关于Word与Excel自动化操作的技术盛宴,从环境搭建到代码实战,看WPF如何玩转文档处理的那些事儿
【8月更文挑战第31天】Windows Presentation Foundation (WPF) 是 .NET Framework 的重要组件,以其强大的图形界面和灵活的数据绑定功能著称。本文通过具体示例代码,介绍如何在 WPF 应用中实现 Word 和 Excel 文档的自动化操作,包括文档的读取、编辑和保存等。首先创建 WPF 项目并设计用户界面,然后在 `MainWindow.xaml.cs` 中编写逻辑代码,利用 `Microsoft.Office.Interop` 命名空间实现 Office 文档的自动化处理。文章还提供了注意事项,帮助开发者避免常见问题。
367 0
|
5月前
|
C# UED 开发者
WPF打印功能实现秘籍:从页面到纸张,带你玩转WPF打印技术大揭秘!
【8月更文挑战第31天】在WPF应用开发中,打印功能至关重要,不仅能提升用户体验,还增强了应用的实用性。本文介绍WPF打印的基础概念与实现方法,涵盖页面元素打印、打印机设置及打印预览。通过具体案例,展示了如何利用`PrintDialog`和`PrintDocument`控件添加打印支持,并使用`PrinterSettings`类进行配置,最后通过`PrintPreviewWindow`实现打印预览功能。
566 0
|
5月前
|
C# 前端开发 UED
WPF数据验证实战:内置控件与自定义规则,带你玩转前端数据验证,让你的应用程序更上一层楼!
【8月更文挑战第31天】在WPF应用开发中,数据验证是确保输入正确性的关键环节。前端验证能及时发现错误,提升用户体验和程序可靠性。本文对比了几种常用的WPF数据验证方法,并通过示例展示了如何使用内置验证控件(如`TextBox`)及自定义验证规则实现有效验证。内置控件结合`Validation`类可快速实现简单验证;自定义规则则提供了更灵活的复杂逻辑支持。希望本文能帮助开发者更好地进行WPF数据验证。
179 0
|
5月前
|
C# UED 定位技术
WPF控件大全:初学者必读,掌握控件使用技巧,让你的应用程序更上一层楼!
【8月更文挑战第31天】在WPF应用程序开发中,控件是实现用户界面交互的关键元素。WPF提供了丰富的控件库,包括基础控件(如`Button`、`TextBox`)、布局控件(如`StackPanel`、`Grid`)、数据绑定控件(如`ListBox`、`DataGrid`)等。本文将介绍这些控件的基本分类及使用技巧,并通过示例代码展示如何在项目中应用。合理选择控件并利用布局控件和数据绑定功能,可以提升用户体验和程序性能。
127 0