`
izuoyan
  • 浏览: 9221875 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

WPF组件化开发技术实践

阅读更多

WPF技术拼图之

WPF自定义组件开发实践

WPF是微软最新的桌面应用程序框架,拥有与过去的Windows Form技术相近的功能,全面支持组件化开发技术。本文是对在WPF应用程序中使用组件化技术的一个简要介绍。

在.NET平台上,程序集是最基本的软件组件。程序集有两种用得最广的类型,一种是用于封装业务逻辑的中间层组件,另一种是可视化的界面组件(如各种控件)。

中间层组件的开发方式非常简单,使用Visual Studio创建一个类库,编译生成DLL。在新的项目中引用此DLL即可创建定义在此程序集中的类的对象。这个技术在传统的.NET应用程序中被广泛应用,大家都非常熟悉了。我就不浪费笔墨了。

下面着重介绍一下大家可能还不熟悉的WPF界面层组件。

WPF界面层组件主要有两种类型:WPF用户控件和WPF自定义控件。

默认情况下,Visual Studio指定WPF用户控件的基类是UserControl,WPF自定义控件的基类是Control。两者本质是一样的,只不过用户控件提供有一个XAML文件用于定制外观,使用起来非常方便,可以使用Blend等工具直接生成你所需要外观,而自定义控件一般要求你完全从头开始定制控件的外观,多用于实现Visual Studio标配控件所不具备的特殊功能和行为。

以一个例子来说明这两种控件的使用方法。

1 在Visual Studio中创建一个“WPF自定义控件库”项目:

2 删除其默认生成的CustomControl1.cs,从“项目”菜单中选“添加新项”:

选中“自定义控件”,输入控件名称为MySuperRichTextBox。修改其基类为RichTextBox,并给其添加一个新的方法:

public class MySuperRichTextBox : RichTextBox
{
static MySuperRichTextBox()
{
//DefaultStyleKeyProperty.OverrideMetadata(typeof(MySuperRichTextBox), new FrameworkPropertyMetadata(typeof(MySuperRichTextBox)));
}

public void InsertCurrentDate()
{
this.CaretPosition.InsertTextInRun(DateTime.Now.ToShortDateString());
}
}

注意:

  Visual Studio会为“WPF自定义控件库”项目添加一个Generic.xaml文件,放在Themes文件夹中,其中为自定义控件定义了默认的样式(style),然后,其自定义控件的静态构造函数中应用此样式。在本例中,我们直接使用RichTextBox现有的样式,所以,注销掉了样式的应用语句。

3 用同样的步骤,向“WPF自定义控件库”项目添加一个用户控件(这次是选择“用户控件”模板),取名“MyUserControl”。

让我们给这个用户控件添加一个有渐变填充的矩形,给其添加一个响应鼠标单击的响应函数,还给UserControl的Loaded事件编写响应代码,让其自动与矩形对象一样大小。

<UserControl x:Class="MyWPFControlLibrary.MyUserControl"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" Loaded="UserControl_Loaded" >

<Rectangle Width="100" Height="50" Name="rect1" MouseDown="rect1_MouseDown">
<Rectangle.Fill>
<LinearGradientBrush>
<GradientStop Offset="0" Color="LightBlue"/>
<GradientStop Offset="0.4" Color="Blue"/>
<GradientStop Offset="0.8" Color="Purple"/>
<GradientStop Offset="1.0" Color="Lavender"/>
</LinearGradientBrush>
</Rectangle.Fill>
</Rectangle>


</UserControl>

后台代码如下:

public partial class MyUserControl : UserControl
{
public MyUserControl()
{
InitializeComponent();
}

private void rect1_MouseDown(object sender, MouseButtonEventArgs e)
{
MessageBox.Show("I'm Clicked!");
}

private void UserControl_Loaded(object sender, RoutedEventArgs e)
{
Height = rect1.ActualHeight;
Width = rect1.ActualWidth;
}
}

4 下一步给控件指定一个要显示在Visual Studio工具箱中的小图标。将一个小的16*16的小图标加入到项目中,并按照:

控件类名.icon.图形文件扩展名

的格式取名。

在我们的示例中,由于自定义控件直接继承自RichTextBox,它会自动提取RichTextBox的默认图标。因此,我们就只给用户控件定制图标了,文件名如下:

MyUserControl.icon.png

注意,要将此文件的属性设置为“嵌入的资源”:

5 编译项目,生成DLL程序集。

6 在Visual Studio工具箱上右击,选“添加选项卡”,取名“MyControl”,再次右击,选“选择项”命令:

在上图中点击“浏览”,找到前面生成的“DLL“文件,注意,是在“WPF组件”选项卡中点击“浏览”按钮的。

成功之后,就可以在工具箱中看到控件了:

7 后面的工作就很简单了,新建一个WPF应用程序,将这些控件拖到窗体设计器上:

<Window x:Class="UseMyWPFControl.Window1"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="Window1" Height="300" Width="300" xmlns:my="clr-namespace:MyWPFControlLibrary;assembly=MyWPFControlLibrary">
<Grid>
<my:MySuperRichTextBox Height="138" Margin="26,27,28,97" Name="mySuperRichTextBox1" Width="224" />
<my:MyUserControl Height="50" Margin="35,0,0,27" Name="myUserControl1" VerticalAlignment="Bottom" HorizontalAlignment="Left" Width="100" />
<Button Height="44" HorizontalAlignment="Right" Margin="0,0,28,29" Name="btnInsert" VerticalAlignment="Bottom" Width="91" Click="btnInsert_Click">Insert Date</Button>
</Grid>
</Window>

后台代码:

public partial class Window1 : Window
{
public Window1()
{
InitializeComponent();
}

private void btnInsert_Click(object sender, RoutedEventArgs e)
{
mySuperRichTextBox1.InsertCurrentDate();
mySuperRichTextBox1.Focus();
}
}

注意,要给Xaml文件添加特定的命名空间my,同时确保添加了对控件库程序集MyWPFControlLibrary的引用。

示例程序运行结果如下:

好了,到此为止,我已带领大家进行了一次WPF组件化开发技术的探索之旅,相信有基础的程序员已能举一反三,将组件化技术用于自己的实践中了。

以后有时间有兴致时,再向大家介绍WPF中许多重要实用而又有趣的技术点,帮助大家拼出一张较为完整的技术拼图。 :)

分享到:
评论

相关推荐

    C#+WPF+Prism模块化开发示例

    通过学习和实践这个`C#+WPF+Prism模块化开发示例`,开发者能够更好地理解如何利用Prism实现模块化设计,提高代码质量和可维护性,同时也能掌握WPF应用开发的高级技巧,如数据绑定、依赖注入和事件处理。

    基于Chrome内核的WPF浏览器开发

    "基于Chrome内核的WPF浏览器开发"是一个项目,它利用了Google Chrome的开源项目Chromium,构建了一个Windows Presentation Foundation (WPF) 应用程序中的浏览器组件。这个项目的核心在于将Chromium的强大浏览能力与...

    WPF 控件开发教程

    通过动手实践,你可以更深入地理解如何在实际项目中利用这些工具和模式,提升你的WPF控件开发技能。这包括学习如何创建和使用视图模型,以及如何利用数据绑定和命令来实现视图和模型的交互。同时,掌握如何集成第三...

    WPF分布式开发,实现样式统一

    模块化开发是一种将大型项目拆分为小而独立的模块或组件的方法。在WPF中,我们可以创建多个用户控件、视图模型和资源字典,每个都专注于特定的功能或界面元素。这使得开发者能够独立工作,减少代码冲突,并易于测试...

    WPF开发教程

    ### WPF开发教程知识点梳理 #### 一、WPF基础入门 ##### 1.1 WPF基础之体系结构 ...通过以上知识点的梳理,读者能够系统地学习和掌握WPF开发的基础知识和高级特性,为进一步深入学习和实践打下坚实的基础。

    SuperMap iObject .NET在WPF应用程序开发

    本篇文章将深入探讨如何在WPF(Windows Presentation Foundation)应用程序中利用SuperMap iObject .NET进行开发,以及涉及的关键技术点。 首先,我们要理解WPF与SuperMap iObject .NET的集成机制。WPF是微软推出的...

    WPF开发框架源码 交通建设管理系统架构

    **正文** ...通过深入研究源码,开发者不仅可以掌握WPF的实践技巧,还能了解到如何将这些技术应用于实际的业务场景中,从而提升自己的开发能力。然而,购买源码时需要注意版权问题,确保合法合规使用。

    C#组件开发简易教程.

    通过学习这个C#组件开发简易教程,你将能够理解组件的基本概念,掌握组件开发的关键技术和实践,为构建高效、可维护的C#应用程序打下坚实基础。在实际开发过程中,不断实践和优化,将使你成为组件开发的专家。

    WPF图形化编程实用手册 (高清英文版+源码)

    **WPF图形化编程实用手册**是一本专为开发者设计的指南,主要涵盖了Windows Presentation Foundation(WPF)的图形化编程技术。WPF是.NET Framework的一部分,由Microsoft开发,用于构建具有丰富用户界面的Windows...

    WPF图形化编程实用手册(含源码)

    通过阅读《WPF图形化编程实用手册》并实践其中的源码,开发者不仅可以掌握WPF 2D图形编程的基础,还能提升在创建复杂、美观且响应式的用户界面方面的技能。对于想要提升WPF应用开发能力的程序员来说,这本书无疑是一...

    WPF非常精美界面 WPF漂亮首页界面 WPF精美首页可以直接使用在项目当中 WPF入门布局的完美Demo 经典WPF快速入门漂

    **WPF技术详解** WPF(Windows Presentation Foundation)是微软.NET Framework的一部分,它提供了一种强大的、基于XAML的框架来构建丰富的、交互式的桌面应用程序。这个标题和描述提到的"非常精美界面"和"漂亮首页...

    最好的WPF界面开发demo,不下要后悔2

    下载并学习这样的demo,可以帮助开发者快速掌握WPF的核心概念和实用技术,避免走弯路,提高开发效率。 **WPF核心概念** 1. **XAML**: XML标记语言,用于定义用户界面元素和它们的属性。XAML提供了简洁的语法,允许...

    WPF实现系统托盘 NotifyIcon

    在Windows Presentation Foundation (WPF) 中,开发人员经常需要实现应用程序窗口最小化到系统托盘,而不是传统的桌面底部任务栏。这种功能通过使用`NotifyIcon`组件可以轻松达成。`NotifyIcon`是Windows Forms库中...

    AE 组件式开发及应用

    AE组件式开发是一种高效、模块化的软件开发方法,它允许开发者将应用程序分解为一系列可重用的组件,每个组件都负责...通过理解并应用组件化开发的最佳实践,开发者可以构建出更高质量的应用程序,同时提高开发效率。

    基于WPF MVVM框架开发的串口调试助手Assistant,带有Scichart波形插件

    **基于WPF MVVM框架开发的串口调试助手Assistant,带有Scichart波形插件** 本项目是一款基于Windows Presentation Foundation ...无论是学习WPF、MVVM还是数据可视化,这个项目都能作为一个有价值的参考和实践案例。

    WPF.DazzleUI.rar_360ui页面wpf_WPF_WPF.DazzleUI2_WPF实现的360界面_wpf界面

    总之,WPF.DazzleUI是WPF技术在模仿360界面设计上的一次实践,结合了WPF的诸多优势,为开发者提供了一个高效且易于扩展的框架。如果你正在寻找一个能快速构建专业界面的工具,WPF.DazzleUI无疑是一个值得考虑的选择...

    使用 ElementUI 组件构建 Window 桌面应用探索与实践(WPF)

    在本文中,我们将深入探讨如何利用ElementUI组件库在Windows桌面应用程序开发中,特别是WPF(Windows Presentation Foundation)平台上进行实践。ElementUI是一款基于Vue.js的现代化UI组件库,广泛应用于Web开发,其...

    WPF工控源码分享.rar

    【标题】:“WPF工控源码分享.rar”是一份基于Windows Presentation Foundation(WPF)技术的工控软件源码,包含丰富的学习和实践资源。它不仅提供了对MVVM(Model-View-ViewModel)设计模式的实现,还融入了谷歌的...

    WPF开发相关主题包源代码

    这个源代码包为WPF初学者提供了一个实践平台,他们可以通过实际操作来掌握WPF界面设计的核心技术,同时对高级主题定制有更深入的理解。对于有经验的开发者,它则提供了一个研究和学习WPF界面设计技巧的宝贵资源。

    WPF手写输入+虚拟键盘源码

    总之,"WPF手写输入+虚拟键盘源码"是一个涵盖了多方面技术的项目,包括WPF基础、图形交互、手写识别算法、虚拟键盘设计以及用户设置持久化等。无论是初学者还是有经验的开发者,都能从中获得宝贵的学习资料和实践...

Global site tag (gtag.js) - Google Analytics