WPF创建不规则形状的按钮

本文介绍使用Blend for Studio在WPF中创建不规则形状按钮的方法。通过钢笔工具绘制图形,将其转换为Button控件,并利用触发器实现鼠标悬停效果。最后,展示了按钮的XAML样式代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转自:https://blog.youkuaiyun.com/sinat_34328764/article/details/72943050

在WPF中用到不规则形状的按钮的时候一般是使用下载visual studio时自带的的blend for studio。
Blend是一款方便的UI设计工具,将它与WPF结合使用,可以实现很多静态或者动态的UI效果,在这里介绍一个简单的小应用,不规则的的按钮如何创建。
首先,创建新工程,这时候的主界面是这样的:

 

 

创建不规则形状的按钮的话,首先是用右侧的钢笔工具在设计器中画出一个图形,这里使用的是一个不规则的五边形:

为了让效果显示的清楚一些,给五边形添加背景色:

接下来选中五边形之后再工具栏中选中“工具”->“构成控件”并在弹出的选择框中选择“Button”,单击“确定”

可以看见左边的变成了这样子

这个时候已经构成了一个简单的Button,可以单击“运行”观察效果,但是这样的Button很没有美感,我们希望按钮在单击的时候可以触发一些效果,就像常见的鼠标移入按钮内部时颜色有变化,这样的功能要通过触发器(Trigger)来实现,这个工作如果我们是在WPF中直接写的话是非常麻烦的,但是通过blend确很简单,完成上面一步之后可以看到左上角的面板中有“资产”,“触发器”等选项,选择“触发器”,可以看到几个事件,例如,点击“IsMouseOver=True”这个选项,此时屏幕上会有“IsMouseOver=True 触发器已打开的字样”,这个时候我们对控件所做的操作都会作为触发器的动作,比如,对此时的控件的边框颜色(Stroke),颜色(Background)进行设置并进行保存。

此时,单击“运行”,我们可以看到鼠标指针移动到按钮区域的时候颜色发生了改变。

 

这只是一个小例子,当然同样也可以设置IsPressed等事件。

 

这时候切换到“XAML”视图,可以看到创建的按钮的样式,这时候可以直接将Style标签内容复制进你的WPF程序的资源字典中进行引用了。

 


 
  1. <Window x:Class="Text.MainWindow"
  2. xmlns= "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  3. xmlns:x= "http://schemas.microsoft.com/winfx/2006/xaml"
  4. xmlns:d= "http://schemas.microsoft.com/expression/blend/2008"
  5. xmlns:mc= "http://schemas.openxmlformats.org/markup-compatibility/2006"
  6. xmlns:local= "clr-namespace:Text"
  7. mc:Ignorable= "d"
  8. Title= "MainWindow" Height= "350" Width= "525">
  9. <Window.Resources>
  10. <Style x:Key="ButtonStyle1" TargetType="{x:Type Button}">
  11. <Setter Property="Template">
  12. <Setter.Value>
  13. <ControlTemplate TargetType="{x:Type Button}">
  14. <Grid>
  15. <Path x:Name="path" Data="M160,80 L134.5,109.5 169.5,134.5 229.5,129.5 219.5,69.5 z" Fill="#FF5B5BC5" Stretch="Fill" Stroke="Black"/>
  16. <ContentPresenter HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" RecognizesAccessKey="True" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" VerticalAlignment="{TemplateBinding VerticalContentAlignment}"/>
  17. </Grid>
  18. <ControlTemplate.Triggers>
  19. <Trigger Property="IsFocused" Value="True"/>
  20. <Trigger Property="IsDefaulted" Value="True"/>
  21. <Trigger Property="IsMouseOver" Value="True">
  22. <Setter Property="Fill" TargetName="path" Value="#FF43A873"/>
  23. <Setter Property="Stroke" TargetName="path" Value="#FFBFD132"/>
  24. <Setter Property="StrokeThickness" TargetName="path" Value="3"/>
  25. </Trigger>
  26. <Trigger Property="IsPressed" Value="True"/>
  27. <Trigger Property="IsEnabled" Value="False"/>
  28. </ControlTemplate.Triggers>
  29. </ControlTemplate>
  30. </Setter.Value>
  31. </Setter>
  32. </Style>
  33. </Window.Resources>
  34. <Grid>
  35. <Button x:Name="button" Content="Button" HorizontalAlignment="Left" Height="66" Margin="134.5,69.5,0,0" Style="{DynamicResource ButtonStyle1}" VerticalAlignment="Top" Width="96"/>
  36. <Path Data="M430,160" Fill="#FF5B5BC5" HorizontalAlignment="Right" Margin="0,160,87.6,159.4" Stretch="Fill" Stroke="Black" Width="1"/>
  37. </Grid>
  38. </Window>

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值