• WPF 如何创建自己的WPF自定义控件库


       在我们平时的项目中,我们经常需要一套自己的自定义控件库,这个特别是在Prism这种框架下面进行开发的时候,每个人都使用一套统一的控件,这样才不会每个人由于界面不统一而造成的整个软件系统千差万别,所以我们需要创建自己的一套界面库。下面介绍如何在WPF程序下创建自定义控件库。

          1 在我们的项目中,在解决方案右键-》新建项目,添加“WPF自定义控件库”。

          2 在默认生成的项目下面,会有两个文件,一个是“Generic.xaml”文件,另外一个是继承自Control类的CustomControl1这个文件,默认情况下这个文件的内容为:

    public class CustomControl1 : Control
     {
         static CustomControl1()
          {
               DefaultStyleKeyProperty.OverrideMetadata(typeof(CustomControl1), new FrameworkPropertyMetadata(typeof(CustomControl1)));
          }
     }
    

      在这个类里面,我们可以定义需要绑定到前台的各种依赖项属性,从而在后台实现数据的绑定。

        3  我们有时需要添加资源字典xaml文件,但是添加的资源字典必须放在Generic.xaml文件下面,比如我们添加了一个Group.xaml的文件,最后在Generic.xaml文件下必须通过ResourceDictionary.MergedDictionaries的方式将Group.xaml放在里面,这个是必须要引起注意的地方,否则添加的自定义控件是不能够进行识别的。

    <ResourceDictionary.MergedDictionaries>
           <ResourceDictionary Source="/X.UI;component/Themes/Group.xaml"></ResourceDictionary>
    </ResourceDictionary.MergedDictionaries>
    

      4  另外在定义完了Group.xaml文件之后,我们需要定义对应的Group.cs文件从而和前台的Group.xaml文件进行交互,这里我们需要定义很多依赖项属性。

        5  编译生成DLL文件。

        6  在其他项目中通过引用该程序集,通过clr-namespace和assembly引用该程序集,并达到引用该控件的目的。

        下面贴出Group.xaml和Group.cs文件来说明如何创建一个简单的自定义控件库。

       Group.xaml:   

    <ResourceDictionary
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:local="clr-namespace:X.UI.Controls">
        <ResourceDictionary.MergedDictionaries>
            <ResourceDictionary Source="/X.UI.Controls;Component/Themes/Public.xaml"></ResourceDictionary>
            <ResourceDictionary Source="/X.UI.Controls;Component/Themes/YouDaoPing.xaml"></ResourceDictionary>
        </ResourceDictionary.MergedDictionaries>
        <Style TargetType="local:Group">
            <Setter Property="Background" Value="#eee"></Setter>
            <Setter Property="HeaderBackground" Value="{StaticResource Decorative}"></Setter>
            <Setter Property="Foreground" Value="{StaticResource DarkColor}"></Setter>
            <Setter Property="Template">
                <Setter.Value>
                    <ControlTemplate TargetType="local:Group">
                        <Grid Background="{TemplateBinding Background}">
                            <Grid.RowDefinitions>
                                <RowDefinition Height="40"></RowDefinition>
                                <RowDefinition Height="*"></RowDefinition>
                            </Grid.RowDefinitions>
                            <Border Background="{TemplateBinding HeaderBackground}" Padding="10 0">
                                <Grid>
                                    <ContentPresenter Content="{TemplateBinding Header}" HorizontalAlignment="{TemplateBinding HeaderAlign}" VerticalAlignment="Center"></ContentPresenter>
                                    <ContentPresenter Content="{TemplateBinding ToolBar}" HorizontalAlignment="{TemplateBinding ToolBarAlign}" VerticalAlignment="Center"></ContentPresenter>
                                </Grid>
                            </Border>
                            <Border Background="{TemplateBinding Background}" Grid.Row="1">
                                <ContentPresenter Margin="{TemplateBinding Padding}"></ContentPresenter>
                            </Border>
                        </Grid>
                    </ControlTemplate>
                </Setter.Value>
            </Setter>
        </Style>
    </ResourceDictionary>
    

      Group.cs文件:

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    using System.Windows;
    using System.Windows.Controls;
    using System.Windows.Data;
    using System.Windows.Documents;
    using System.Windows.Input;
    using System.Windows.Media;
    using System.Windows.Media.Imaging;
    using System.Windows.Navigation;
    using System.Windows.Shapes;
    
    namespace X.UI.Controls
    {
        /// <summary>
        /// 按照步骤 1a 或 1b 操作,然后执行步骤 2 以在 XAML 文件中使用此自定义控件。
        ///
        /// 步骤 1a) 在当前项目中存在的 XAML 文件中使用该自定义控件。
        /// 将此 XmlNamespace 特性添加到要使用该特性的标记文件的根 
        /// 元素中:
        ///
        ///     xmlns:MyNamespace="clr-namespace:X.UI.Controls"
        ///
        ///
        /// 步骤 1b) 在其他项目中存在的 XAML 文件中使用该自定义控件。
        /// 将此 XmlNamespace 特性添加到要使用该特性的标记文件的根 
        /// 元素中:
        ///
        ///     xmlns:MyNamespace="clr-namespace:X.UI.Controls;assembly=X.UI.Controls"
        ///
        /// 您还需要添加一个从 XAML 文件所在的项目到此项目的项目引用,
        /// 并重新生成以避免编译错误:
        ///
        ///     在解决方案资源管理器中右击目标项目,然后依次单击
        ///     “添加引用”->“项目”->[选择此项目]
        ///
        ///
        /// 步骤 2)
        /// 继续操作并在 XAML 文件中使用控件。
        ///
        ///     <MyNamespace:CustomControl1/>
        ///
        /// </summary>
        public class Group : System.Windows.Controls.HeaderedContentControl
        {
            static Group()
            {
                DefaultStyleKeyProperty.OverrideMetadata(typeof(Group), new FrameworkPropertyMetadata(typeof(Group)));
            }
    
            public HorizontalAlignment HeaderAlign
            {
                get
                {
                    return (HorizontalAlignment)GetValue(HeaderAlignProperty);
                }
                set
                {
                    SetValue(HeaderAlignProperty, value);
                }
            }
    
            // Using a DependencyProperty as the backing store for HeaderAlign.  This enables animation, styling, binding, etc...
            public static readonly DependencyProperty HeaderAlignProperty =
                DependencyProperty.Register("HeaderAlign", typeof(HorizontalAlignment), typeof(Group), new PropertyMetadata(HorizontalAlignment.Center));
    
            public Panel ToolBar
            {
                get
                {
                    return (Panel)GetValue(ToolBarProperty);
                }
                set
                {
                    SetValue(ToolBarProperty, value);
                }
            }
    
            // Using a DependencyProperty as the backing store for ToolBar.  This enables animation, styling, binding, etc...
            public static readonly DependencyProperty ToolBarProperty =
                DependencyProperty.Register("ToolBar", typeof(Panel), typeof(Group), new PropertyMetadata(null));
    
            public HorizontalAlignment ToolBarAlign
            {
                get
                {
                    return (HorizontalAlignment)GetValue(ToolBarAlignProperty);
                }
                set
                {
                    SetValue(ToolBarAlignProperty, value);
                }
            }
    
    
            public static readonly DependencyProperty ToolBarAlignProperty =
                DependencyProperty.Register("ToolBarAlign", typeof(HorizontalAlignment), typeof(Group), new PropertyMetadata(HorizontalAlignment.Right));
    
    
            public Brush HeaderBackground
            {
                get
                {
                    return (Brush)GetValue(HeaderBackgroundProperty);
                }
                set
                {
                    SetValue(HeaderBackgroundProperty, value);
                }
            }
    
            // Using a DependencyProperty as the backing store for HeaderBackground.  This enables animation, styling, binding, etc...
            public static readonly DependencyProperty HeaderBackgroundProperty =
                DependencyProperty.Register("HeaderBackground", typeof(Brush), typeof(Group), new PropertyMetadata(null));
        }
    }
    

      在这里我们也可以着重看一下该文件中注释的部分。

  • 相关阅读:
    数据结构与算法——认识O(NlogN)的排序(2)
    数据结构与算法——简单排序算法(2)
    数据结构与算法——认识O(NlogN)的排序(1)
    论文翻译——Attention Is All You Need
    论文翻译——Character-level Convolutional Networks for Text Classification
    研究NLP100篇必读的论文---已整理可直接下载
    kaggle——绝地求生游戏最终排名预测
    tab栏切换
    css兄弟选择器(+ 和 ~)的使用和区别
    cookie和web storage的区别
  • 原文地址:https://www.cnblogs.com/seekdream/p/5239367.html
Copyright © 2020-2023  润新知