自定义一个按钮控件

按钮控件很简单,我们在项目中有时把样式封装起来,添加依赖属性,也是为了统一。

这里举例,单纯的图标控件怎么设置

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; }
}

最新文章

  1. 状态开关按钮(ToggleButton)和开关(Switch)
  2. java基础-复制
  3. UVA 10474 大理石在哪 lower_bound
  4. android 中targetSdkVersion和与target属性的区别
  5. Web浏览器的缓存机制
  6. EditText设置可以编辑和不可编辑状态
  7. Java性能漫谈-数组复制之System.arraycopy
  8. OpenCV学习(1) OpenCV的安装
  9. 判断浏览器及设备的打开方式,自动跳转app中
  10. 查看电脑已安装的Jdk的位数
  11. SSH-Struts(三)—ActionForm
  12. MVC之Ajax
  13. CDOJ 1324 卿学姐与公主 分块
  14. jQuery学习笔记(二)
  15. Android仿微信朋友圈,全文收起功能,附源码
  16. [Android App]IFCTT,即:If Copy Then That,是一个基于IFTTT的&quot;This&quot;实现
  17. 使用IDEA配置Maven + SpringMVC + Mybatis 【一步一步踩坑详细配置完成】
  18. [Swift]LeetCode722. 删除注释 | Remove Comments
  19. Python 离线 安装requests第三方库
  20. my题库

热门文章

  1. 在IDEA上跑eclipse开发的J2EE项目
  2. HTTP Method详细解读(`GET` `HEAD` `POST` `OPTIONS` `PUT` `DELETE` `TRACE` `CONNECT`)
  3. c#编程基础之函数可变参数
  4. 翻译:使用 ASP.NET MVC 4, EF, Knockoutjs and Bootstrap 设计和开发站点 - 2
  5. PDF编辑神器
  6. php mail 函数发送邮件
  7. Lightbox改造——支持滚轮缩放
  8. Java多线程整理(li)
  9. 记录一次bug解决过程:eclipse Installed JREs 配置引出的问题
  10. logstash+elasticsearch+kibana管理日志(安装)