WPF 自定义IconButton
2024-10-13 05:16:03
自定义一个按钮控件
按钮控件很简单,我们在项目中有时把样式封装起来,添加依赖属性,也是为了统一。
这里举例,单纯的图标控件怎么设置
1、UserControl界面样式
<UserControl x:Class="WpfApplication12.IconButton" 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" Loaded="IconButton_OnLoaded">
<UserControl.Resources>
<Style TargetType="Button">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="Button">
<Grid>
<Rectangle x:Name="T_Rectangle" Height="15" Width="15">
<Rectangle.Fill>
<ImageBrush ImageSource="{Binding ImagesSource}"></ImageBrush>
</Rectangle.Fill>
</Rectangle>
<ContentPresenter HorizontalAlignment="{TemplateBinding HorizontalAlignment}" VerticalAlignment="{TemplateBinding VerticalAlignment}"></ContentPresenter>
</Grid>
<ControlTemplate.Triggers>
<Trigger Property="IsMouseOver" Value="True">
<Setter TargetName="T_Rectangle" Property="Height" Value="18"></Setter>
<Setter TargetName="T_Rectangle" Property="Width" Value="18"></Setter>
</Trigger>
<Trigger Property="IsPressed" Value="True">
<Setter TargetName="T_Rectangle" Property="Height" Value="20"></Setter>
<Setter TargetName="T_Rectangle" Property="Width" Value="20"></Setter>
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</UserControl.Resources>
<Grid>
<Button Click="ButtonBase_OnClick"></Button>
</Grid>
</UserControl>
2、后台设置,我这边只添加了个图片路径和事件委托。其它的自己加吧
public partial class IconButton : UserControl
{
public IconButton()
{
InitializeComponent();
} public ImageSource ImagesSource
{
get { return (ImageSource)GetValue(ImagesSourceProperty); }
set { SetValue(ImagesSourceProperty, value); }
} public static readonly DependencyProperty ImagesSourceProperty = DependencyProperty.Register("ImagesSource",
typeof(ImageSource), typeof(IconButton)); private void IconButton_OnLoaded(object sender, RoutedEventArgs e)
{
var data = new IconButtonModel()
{
ImagesSource = ImagesSource
};
this.DataContext = data;
} public delegate void ClickEventArgs(object sender, RoutedEventArgs e); public event ClickEventArgs Click;
private void ButtonBase_OnClick(object sender, RoutedEventArgs e)
{
if (Click != null)
{
Click(sender, e);
}
}
} public class IconButtonModel
{
public ImageSource ImagesSource { get; set; }
}
最新文章
- 状态开关按钮(ToggleButton)和开关(Switch)
- java基础-复制
- UVA 10474 大理石在哪 lower_bound
- android 中targetSdkVersion和与target属性的区别
- Web浏览器的缓存机制
- EditText设置可以编辑和不可编辑状态
- Java性能漫谈-数组复制之System.arraycopy
- OpenCV学习(1) OpenCV的安装
- 判断浏览器及设备的打开方式,自动跳转app中
- 查看电脑已安装的Jdk的位数
- SSH-Struts(三)—ActionForm
- MVC之Ajax
- CDOJ 1324 卿学姐与公主 分块
- jQuery学习笔记(二)
- Android仿微信朋友圈,全文收起功能,附源码
- [Android App]IFCTT,即:If Copy Then That,是一个基于IFTTT的";This";实现
- 使用IDEA配置Maven + SpringMVC + Mybatis 【一步一步踩坑详细配置完成】
- [Swift]LeetCode722. 删除注释 | Remove Comments
- Python 离线 安装requests第三方库
- my题库
热门文章
- 在IDEA上跑eclipse开发的J2EE项目
- HTTP Method详细解读(`GET` `HEAD` `POST` `OPTIONS` `PUT` `DELETE` `TRACE` `CONNECT`)
- c#编程基础之函数可变参数
- 翻译:使用 ASP.NET MVC 4, EF, Knockoutjs and Bootstrap 设计和开发站点 - 2
- PDF编辑神器
- php mail 函数发送邮件
- Lightbox改造——支持滚轮缩放
- Java多线程整理(li)
- 记录一次bug解决过程:eclipse Installed JREs 配置引出的问题
- logstash+elasticsearch+kibana管理日志(安装)