news 2026/6/26 8:51:14

wpf之行为

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
wpf之行为

前言

行为是WPF中用于增强UI元素功能的一种重要模式,它允许在不修改原始控件代码的情况下,为控件添加交互逻辑。它可以封装某些功能(如拖放、命令执行、状态管理等),使这些功能可以在不同控件间复用

1、新建行为类

下面的代码给所有控件添加一个行为,添加行为分为两个步骤,第一步就是新建一个类继承Behavior,第二步就是在view视图代码中给指定的控件附加行为, Behavior中的T用于指定行为可以用在哪种控件上,这里使用了Control,由于Control是所有控件的基类,所以所以这个行为可以被所有控件使用,当鼠标进入控件时(在控件上方)更改控件的字体颜色为黄色,当鼠标离开控件时恢复控件原来的字体颜色。行为主要是重写OnAttached和OnDetaching方法,在OnAttached方法中订阅事件,在OnDetaching方法方法中取消订阅事件。下面的代码中在OnAttached订阅了MouseEnter和MouseLeave两个事件。

classChangeForegroundBehavior:Behavior<Control>{privateBrushoriginalForeground;privatestaticreadonlyBrushhoverBrush=Brushes.Yellow;protectedoverridevoidOnAttached(){base.OnAttached();originalForeground=AssociatedObject.Foreground;AssociatedObject.MouseEnter+=OnMouseEnter;AssociatedObject.MouseLeave+=OnMouseLeave;}protectedoverridevoidOnDetaching(){base.OnDetaching();// 取消订阅事件AssociatedObject.MouseEnter-=OnMouseEnter;AssociatedObject.MouseLeave-=OnMouseLeave;}privatevoidOnMouseEnter(objectsender,MouseEventArgse){// 当鼠标进入时,改变字体颜色AssociatedObject.Foreground=hoverBrush;}privatevoidOnMouseLeave(objectsender,MouseEventArgse){// 当鼠标离开时,恢复字体颜色AssociatedObject.Foreground=originalForeground;}}

2、给指定控件添加行为

下面的代码中分别给Label 和Button添加ChangeForegroundBehavior行为,

<Windowx:Class="行为.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:d="http://schemas.microsoft.com/expression/blend/2008"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"xmlns:local="clr-namespace:行为"xmlns:i="http://schemas.microsoft.com/xaml/behaviors"xmlns:ei="clr-namespace:Microsoft.Xaml.Behaviors.Core;assembly=Microsoft.Xaml.Behaviors"mc:Ignorable="d"Title="MainWindow"Height="450"Width="800"><Grid><Grid.RowDefinitions><RowDefinitionHeight="1*"/><RowDefinitionHeight="1*"/></Grid.RowDefinitions><Label Grid.Row=" 0"Content="test"Width="100"Height="30"Foreground="Red"Background="Blue"FontSize="15"><i:Interaction.Behaviors><local:ChangeForegroundBehavior/></i:Interaction.Behaviors></Label><Button Grid.Row=" 1"Content="test"Width="100"Height="30"Foreground="Red"FontSize="15"><i:Interaction.Behaviors><local:ChangeForegroundBehavior/></i:Interaction.Behaviors></Button></Grid></Window>

1)鼠标放在Label上方时

2)鼠标离开Label上方时

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/26 10:26:46

【无线可充电传感器网络(WRSN)】公交网络辅助的无人机调度,用于无线可充电传感器网络的可持续充电附Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 &#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室 &#x1f34a;个人信条&#xff1a;格物致知,完整Matlab代码及仿真…

作者头像 李华
网站建设 2026/6/26 10:24:45

大数据毕设项目:基于Python+Echart的学生心理健康数据可视化系统设计与实现(源码+文档,讲解、调试运行,定制等)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/6/26 10:27:24

计算机大数据毕设实战-基于Python+Echart的学生心理健康数据可视化系统设计与实现【完整源码+LW+部署说明+演示视频,全bao一条龙等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/6/26 11:38:08

基于图片识别的菜品销售系统(源码+lw+部署文档+讲解等)

课题介绍本课题旨在设计并实现一套基于图片识别的菜品销售系统&#xff0c;解决传统菜品销售中点餐效率低、菜品展示不直观、库存与销量统计繁琐、用户点餐体验不佳等问题。系统采用SpringBoot作为后端核心框架&#xff0c;结合MyBatis-Plus简化数据存储操作&#xff0c;搭配Vu…

作者头像 李华
网站建设 2026/6/26 11:46:45

【计算机毕业设计案例】基于Python+Echart的学生心理健康数据可视化系统设计与实现(程序+文档+讲解+定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/6/26 11:56:35

互联网人必藏:大模型技术落地实战指南,从小白到高手的进阶之路_互联网行业AI大模型开发解决方案

互联网行业进入存量竞争时代&#xff0c;大模型技术成为创新驱动力。企业面临模型应用、数据安全与快速落地的挑战。数商云推出全栈式AI解决方案&#xff0c;提供场景化能力、私有化部署和敏捷集成&#xff0c;通过三层架构设计&#xff0c;帮助企业实现AI赋能业务增长&#xf…

作者头像 李华