iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >WPF依赖属性怎么使用
  • 902
分享到

WPF依赖属性怎么使用

2023-06-29 07:06:40 902人浏览 泡泡鱼
摘要

这篇文章主要介绍“WPF依赖属性怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“WPF依赖属性怎么使用”文章能帮助大家解决问题。一、什么是依赖属性依赖属性就是一种自己可以没有值,并且可以通过绑

这篇文章主要介绍“WPF依赖属性怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“WPF依赖属性怎么使用”文章能帮助大家解决问题。

一、什么是依赖属性

依赖属性就是一种自己可以没有值,并且可以通过绑定从其他数据源获取值。依赖属性可支持WPF中的样式设置、数据绑定、继承、动画及默认值。

将所有的属性都设置为依赖属性并不总是正确的解决方案,具体取决于其应用场景。有时,使用私有字段实现属性的典型方法便能满足要求。MSDN中给出了下面几种应用依赖属性的场景:

  • 希望可在样式中设置属性。

  • 希望属性支持数据绑定。

  • 希望可使用动态资源引用设置属性。

  • 希望从元素树中的父元素自动继承属性值。

  • 希望属性可进行动画处理。

  • 希望属性系统在属性系统、环境或用户执行的操作或者读取并使用样式更改了属性以前的值时报告。

  • 希望使用已建立的、WPF 进程也使用的元数据约定,例如报告更改属性值时是否要求布局系统重新编写元素的可视化对象。

二、依赖属性的特点

1、属性变更通知

无论什么时候,只要依赖属性的值发生改变,wpf就会自动根据属性的元数据触发一系列的动作,这些动作可以重新呈现UI元素,也可以更新当前的布局,刷新数据绑定等等,这种变更的通知最有趣的特点之一就是属性触发器,它可以在属性值改变的时候,执行一系列自定义的动作,而不需要更改任何其他的代码来实现。通过下面的示例来演示属性变更通知

示例:当鼠标移动到Button按钮上面时,文字的前景色变为红色,离开时变为默认颜色黑色,采用传统方式和依赖属性两种方式实现:

(1)、使用传统方式实现,在Button按钮上定义MouseEnter和MouseLeave两个事件,分别处理鼠标移动到按钮上面和离开,XAML界面代码:
<Window x:Class="WpfDemo.MainWindow"        xmlns="Http://schemas.microsoft.com/winfx/2006/xaml/presentation"        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"        Title="Grid面板" Height="237" Width="525" windowstartupLocation="CenterScreen">    <Grid >                      <Button Height="30" Width="200" MouseEnter="Button_MouseEnter" MouseLeave="Button_MouseLeave" >鼠标移动到上面,前景色变为红色</Button>            </Grid></Window>

C#后台代码实现:

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 WpfDemo{    /// <summary>    /// MainWindow.xaml 的交互逻辑    /// </summary>    public partial class MainWindow : Window    {        public MainWindow()        {            InitializeComponent();        }        /// <summary>        /// 鼠标移动到按钮上面        /// </summary>        /// <param name="sender"></param>        /// <param name="e"></param>        private void Button_MouseEnter(object sender, MouseEventArgs e)        {            Button btn = sender as Button;            if (btn != null)            {                btn.Foreground = Brushes.Red;            }        }        /// <summary>        /// 鼠标离开按钮        /// </summary>        /// <param name="sender"></param>        /// <param name="e"></param>        private void Button_MouseLeave(object sender, MouseEventArgs e)        {            Button btn = sender as Button;            if (btn != null)            {                btn.Foreground = Brushes.Black;            }        }    }}
(2)使用依赖属性实现,XAML界面代码:
<Window x:Class="WpfDemo.MainWindow"        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"        Title="Grid面板" Height="237" Width="525" WindowStartupLocation="CenterScreen">    <Grid >        <Button Height="30" Width="200">鼠标移动到上面,前景色变为红色            <Button.Style>                <Style TargetType="Button">                    <Style.Triggers>                        <Trigger Property="IsMouseOver" Value="true">                            <Setter Property="Foreground" Value="Red"></Setter>                        </Trigger>                    </Style.Triggers>                </Style>            </Button.Style>        </Button>    </Grid></Window>

使用上面的两种方式都可以实现Button按钮的前景色改变,效果如下:

WPF依赖属性怎么使用

在判断属性IsMouseOver的值为false的时候,自动将Foreground的值改为之前的值,因此就不需要写IsMouseOver的值为false的时候,将Foreground的值改为Black。

2、属性值继承

是指属性值自顶向下沿着元素树进行传递。

<Window x:Class="WpfDemo.MainWindow"        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"        Title="依赖属性" Height="237" Width="525" FontSize="18" WindowStartupLocation="CenterScreen">    <Grid >        <StackPanel>            <TextBlock>我使用的是继承的fontsize</TextBlock>            <TextBlock FontSize="11">我使用的是自己的fontsize</TextBlock>        </StackPanel>    </Grid></Window>

界面运行效果:

WPF依赖属性怎么使用

3、节省内存空间

依赖属性和CLR属性在内存的使用上是截然不同的,每个CLR属性都包含一个非static的字段,因此当我们实例化一个类型的时候,就会创建该类型所拥有的所有CLR属性,也就是说一个对象所占用的内存在调用new操作进行实例化的时候就已经决定了、而wpf允许对象在创建的时候并不包含用于存储数据的空间,只保留在需要用到数据的时候能够获得该默认值,即用其他对象数据或者实时分配空间的能力。

三、如何自定义依赖属性

  • 声明依赖属性变量。依赖属性的声明都是通过public static来公开一个静态变量,变量的类型必须是DependencyProperty

  • 在属性系统中进行注册。使用DependencyProperty.ReGISter方法来注册依赖属性,或者是使用DependencyProperty.RegisterReadOnly方法来注册

  • 使用.net属性包装依赖属性

在类上实现属性时,只要该类派生自 DependencyObject,便可以选择使用 DependencyProperty 标识符来标示属性,从而将其设置为依赖属性。其语法如下:

public static DependencyProperty TextProperty;       TextProperty =       DependencyProperty.Register("Text", //属性名称       typeof(string), //属性类型       typeof(TestDependencyPropertyWindow), //该属性所有者,即将该属性注册到那个类上       new PropertyMetadata("")); //属性默认值public string Text{   get { return (string)GetValue(TextProperty); }   set { SetValue(TextProperty, value); }}

 示例:自定义一个依赖属性,界面包括一个TextBox和TextBlock,TextBlock上面字体的前景色随TextBox里面输入的颜色而改变,如果TextBox里面输入的值可以转换成颜色,TextBlock字体的前景色会显示输入的颜色值,如果不能转换,显示默认的前景色。

1、在当前项目里面添加一个WPF版的用户控件,命名为“MyDependencyProperty”,在MyDependencyProperty.xaml.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 WpfDemo{    /// <summary>    /// MyDependencyProperty.xaml 的交互逻辑    /// </summary>    public partial class MyDependencyProperty : UserControl    {        public MyDependencyProperty()        {            InitializeComponent();        }        //1、声明依赖属性变量        public static readonly DependencyProperty MyColorProperty;        //2、在属性系统中进行注册        static MyDependencyProperty()        {            MyColorProperty = DependencyProperty.Register("MyColor", typeof(string), typeof(MyDependencyProperty),                new PropertyMetadata("Red", (s, e) =>                {                    var mdp = s as MyDependencyProperty;                    if (mdp != null)                    {                        try                        {                            var color = (Color)ColorConverter.ConvertFromString(e.NewValue.ToString());                            mdp.Foreground = new SolidColorBrush(color);                        }                        catch                        {                            mdp.Foreground = new SolidColorBrush(Colors.Black);                        }                    }                }));        }        //3、使用.NET属性包装依赖属性:属性名称与注册时候的名称必须一致,        //即属性名MyColor对应注册时的MyColor        public string MyColor        {            get            {                return (string)GetValue(MyColorProperty);            }            set            {                SetValue(MyColorProperty, value);            }        }    }}

快速定义依赖属性的快捷方式:

输入propdp,连续按两下Tab健,自动生成定义依赖属性的语法。和输入cw连续按两下Tab健,自动生成Console.Write()一样。

public int MyProperty        {            get { return (int)GetValue(MyPropertyProperty); }            set { SetValue(MyPropertyProperty, value); }        }        // Using a DependencyProperty as the backing store for MyProperty.  This enables animation, styling, binding, etc...        public static readonly DependencyProperty MyPropertyProperty =            DependencyProperty.Register("MyProperty", typeof(int), typeof(ownerclass), new PropertyMetadata(0));

2、在MyDependencyProperty.xaml里面添加一个TextBlock

<UserControl x:Class="WpfDemo.MyDependencyProperty"             xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"             xmlns:mc="http://schemas.openxmlfORMats.org/markup-compatibility/2006"             xmlns:d="http://schemas.microsoft.com/expression/blend/2008"             mc:Ignorable="d"             d:DesignHeight="300" d:DesignWidth="300">    <Grid>        <TextBlock>我是自定义的依赖属性</TextBlock>    </Grid></UserControl>

3、在MainWindow.xaml里面引用新创建的用户控件,并添加一个TextBox,用于输入颜色值,并将自定义的依赖属性MyColor绑定到TextBox

<Window x:Class="WpfDemo.MainWindow"        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"        xmlns:p="clr-namespace:WpfDemo"        Title="依赖属性" Height="237" Width="525" WindowStartupLocation="CenterScreen">    <Grid >        <StackPanel>            <TextBox Name="tbColor"></TextBox>            <p:MyDependencyProperty MyColor="{Binding Path=Text,ElementName=tbColor}" ></p:MyDependencyProperty>        </StackPanel>    </Grid></Window>

在设计界面显示的效果:

WPF依赖属性怎么使用

4、程序运行效果:

在TextBox里面输入正确的颜色值,前景色会显示为当前输入的颜色:

WPF依赖属性怎么使用

在TextBox里面输入错误的颜色值,前景色会显示为默认颜色:

WPF依赖属性怎么使用

关于“WPF依赖属性怎么使用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网精选频道,小编每天都会为大家更新不同的知识点。

--结束END--

本文标题: WPF依赖属性怎么使用

本文链接: https://www.lsjlt.com/news/323445.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • WPF依赖属性怎么使用
    这篇文章主要介绍“WPF依赖属性怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“WPF依赖属性怎么使用”文章能帮助大家解决问题。一、什么是依赖属性依赖属性就是一种自己可以没有值,并且可以通过绑...
    99+
    2023-06-29
  • WPF依赖属性用法详解
    一、什么是依赖属性 依赖属性就是一种自己可以没有值,并且可以通过绑定从其他数据源获取值。依赖属性可支持WPF中的样式设置、数据绑定、继承、动画及默认值。 将所有的属性都设置为依赖属性...
    99+
    2024-04-02
  • c# wpf如何附加依赖项属性
      附加依赖项属性是一个属性本来不属于对象自己,但是某些特定场景其他的对象要使用该对象在这种场景下的值。这个值只在这个场景下使用。基于这个需求设计出来的属性。这里主要涉及到一个解耦问...
    99+
    2024-04-02
  • WPF中的RelativeSource属性怎么使用
    在WPF中,RelativeSource属性用于绑定到相对于目标元素的其他元素的属性。它可以帮助我们实现一些复杂的数据绑定和样式设置...
    99+
    2023-08-09
    WPF RelativeSource
  • MavenOptional依赖属性的含义及妙用
    目录什么是Maven Optional依赖?为什么需要Maven Optional依赖?减少依赖传递避免依赖冲突减少构建大小Maven Optional依赖的妙用场景1:降低库的依赖...
    99+
    2023-05-19
    Maven Optional依赖属性 Maven Optional
  • 怎么排除Maven依赖项的传递性依赖
    有以下几种方法可以排除Maven依赖项的传递性依赖: 使用元素:在pom.xml文件中,可以使用元素排除指定依赖项的传递性依赖。例...
    99+
    2024-04-09
    Maven
  • 如何使用replace属性来避免Composer的依赖冲突
    这篇文章将为大家详细讲解有关如何使用replace属性来避免Composer的依赖冲突,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Composer 文档提供了两个基本的示例。 我将尝试解释一下:列出被该...
    99+
    2023-06-09
  • SpringBootbean依赖属性配置详细介绍
    创建实体类 @Data public class Cat { private String name; private Integer age; } @Data pu...
    99+
    2024-04-02
  • package.json依赖环境相关属性详解
    目录引言一、package.json1. package.json简介2. package-lock.json二、package.json常用属性1. script2. bin3. ...
    99+
    2024-04-02
  • laravel依赖注入怎么使用
    Laravel的依赖注入是一种通过自动解析和解决类之间的依赖关系的机制。下面是在Laravel中使用依赖注入的步骤:1. 声明依赖关...
    99+
    2023-09-21
    laravel
  • Spring依赖注入怎么使用
    Spring是一个开源的Java框架,提供了一个容器来管理应用程序的组件并实现了依赖注入(Dependency Injection)...
    99+
    2023-09-26
    Spring
  • FastJson使用和依赖
    FastJson是阿里巴巴提供的JSON框架,可以将Java对象转换为JSON格式的字符串,也可以将JSON格式的字符串转换为Java对象。 使用FastJson需要在项目中引入依赖。在Maven项目...
    99+
    2023-08-31
    java json 开发语言
  • wpf怎么绑定对象的属性
    在WPF中,可以使用数据绑定来绑定对象的属性。 首先,确保你的对象实现了INotifyPropertyChanged接口。这个接口定...
    99+
    2023-10-24
    wpf
  • maven怎么排除依赖包的子依赖
    在Maven中,排除依赖包的子依赖可以通过在pom.xml文件中使用标签来实现。例如,假设要排除spring-boot-starte...
    99+
    2023-09-23
    maven
  • 怎么使用docker打包依赖环境
    使用Docker打包依赖环境可以通过以下步骤进行: 创建一个Dockerfile文件:在项目根目录下创建一个名为Dockerfi...
    99+
    2023-10-24
    docker
  • Angular中依赖注入怎么用
    这篇文章主要介绍了Angular中依赖注入怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、什么是依赖注入控制反转(IoC)控制反转的...
    99+
    2024-04-02
  • php依赖注入怎么应用
    这篇“php依赖注入怎么应用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“php依赖注入怎么应用”文章吧。一、什么是依赖注入...
    99+
    2023-06-30
  • golang 怎么安装依赖
    近年来,Golang 越来越受到开发者的青睐。由于其并行、易于部署、高效等特性,在各类场景应用中都有着广泛的应用。在使用 Golang 进行开发时,安装依赖是一个必备的步骤。本文将从以下几个方面进行分享:Golang 安装依赖的方式和步骤G...
    99+
    2023-05-14
  • ASP.NETCore使用AutoFac依赖注入
    实现代码新建接口类:IRepository.cs,规范各个操作类的都有那些方法,方便管理。using System;using System.Collections.Generic;using System.L...
    99+
    2023-06-03
  • Maven的传递性依赖是什么
    Maven的传递性依赖指的是当一个项目依赖于另一个项目时,如果被依赖的项目又依赖于其他项目,那么这些依赖也会被自动引入到当前项目中。...
    99+
    2024-04-09
    Maven
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作