你必须添加额外的触发器(如IsPressed),但是这应该给你一个不错的主意:
<Button Height="30" Width="30">
<Button.Style>
<Style TargetType="{x:Type Button}">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate>
<Path Name="HalfEllipse" Stroke="Black" StrokeThickness="1" Fill="Blue">
<Path.Data>
<PathGeometry>
<PathFigure IsFilled="True" StartPoint="0,0">
<PolyBezierSegment Points="5,30 25,30 30,0" />
</PathFigure>
</PathGeometry>
</Path.Data>
</Path>
<ControlTemplate.Triggers>
<Trigger Property="IsMouseOver" Value="True">
<Setter TargetName="HalfEllipse" Property="Fill">
<Setter.Value>
<SolidColorBrush Color="Green"/>
</Setter.Value>
</Setter>
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</Button.Style>
</Button>
见此页面更多信息:http://www.codeproject.com/KB/WPF/glassbuttons.aspx
整个椭圆的大小发生变化。假设某人放置了一行代码,如myEllipse.xRadius = 40;每个按钮的宽度基本上都在按钮的中心大部分为40。如果类似的东西可以使用纯XAML,那么这将起作用。 – Nick 2009-01-29 16:14:05
是的!这将工作。 XAML非常适合这种布局。你可以很容易地做到这一点,只需公开一个Radius属性,然后在该集合中,将radius * 2应用到基本控件宽度,并且如果正确设置了该控件,控件将自动调整大小! :) – 2009-01-29 16:17:49