Wpf 使用样式稍微修改控件模板
我只需要在组合框周围添加一个厚边框。您可能已经知道,ComboBox的Wpf 使用样式稍微修改控件模板,wpf,combobox,styles,controltemplate,Wpf,Combobox,Styles,Controltemplate,我只需要在组合框周围添加一个厚边框。您可能已经知道,ComboBox的BorderThickness属性没有多大用处。因此,我尝试使用以下样式修改模板,但无法确定需要在边框标记中写入什么来表示ComboBox本身: <Style TargetType="{x:Type ComboBox}"> <Setter Property="Template"> <Setter.Value> <ControlTempla
BorderThickness
属性没有多大用处。因此,我尝试使用以下样式修改模板
,但无法确定需要在边框
标记中写入什么来表示ComboBox本身:
<Style TargetType="{x:Type ComboBox}">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="ComboBox">
<Border BorderBrush="Black" BorderThickness="2">
WHAT GOES HERE?
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
这里有什么?
我试过
ContentPresenter
和ContentControl
,但老实说,我不太了解它们在这个特定场景中的用法。如果我没弄错的话,你想把原来的组合框
放在边框中,对吗?您可以找到一个模板自定义示例。
因此,如果您复制边框中的重要部分(网格
),它应该看起来像标准的组合框
,边框较厚。也许你需要做一些小的修改,使它看起来很完美。顺便说一句,MS Blend在这里会有很大帮助。您必须编辑完整的controlTemplate。下面是一个可以随意扩展的小示例。
首先,打开组合框的ToggleButton的controlTemplate:
<ControlTemplate x:Key="ComboBoxToggleButton" TargetType="{x:Type ToggleButton}">
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition />
<ColumnDefinition Width="15" />
</Grid.ColumnDefinitions>
<Border x:Name="Border" Grid.ColumnSpan="2" BorderThickness="1" />
<Path x:Name="Arrow"
Fill="Black"
SnapsToDevicePixels="True"
StrokeThickness="1"
VerticalAlignment="Center"
HorizontalAlignment="Center"
Grid.Column="1"
Data="M0,0 L0,3 L1,3 L1,4 L2,4 L2,5 L3,5 L3,6 L4,6 L4,5 L5,5 L5,4 L6,4 L6,3 L7,3 L7,0 L6,0 L6,1 L5,1 L5,2 L4,2 L4,3 L3,3 L3,2 L2,2 L2,1 L1,1 L1,0 L0,0 Z" />
</Grid>
<ControlTemplate.Triggers>
<Trigger Property="IsMouseOver" Value="True">
<Setter Property="Background" Value="Gray" TargetName="Border"/>
<Setter Property="BorderBrush" Value="DarkGray" TargetName="Border"/>
</Trigger>
<Trigger Property="IsFocused" Value="true">
<Setter Property="BorderBrush" Value="DarkGray" TargetName="Border"/>
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
下面是使用此模板的组合框的样式
<Style TargetType="{x:Type ComboBox}">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type ComboBox}">
<Border CornerRadius="5" BorderThickness="2" BorderBrush="Red">
<Grid>
<ToggleButton x:Name="ToggleButton"
Grid.Column="2"
Focusable="false"
ClickMode="Press"
IsChecked="{Binding IsDropDownOpen, Mode=TwoWay, RelativeSource={RelativeSource TemplatedParent}}"
Template="{StaticResource ComboBoxToggleButton}"/>
<ContentPresenter x:Name="ContentSite"
IsHitTestVisible="False"
Content="{TemplateBinding SelectionBoxItem}"
ContentTemplate="{TemplateBinding SelectionBoxItemTemplate}"
ContentTemplateSelector="{TemplateBinding ItemTemplateSelector}"
Margin="3,3,21,3"
VerticalAlignment="Stretch"
HorizontalAlignment="Left">
</ContentPresenter>
<TextBox x:Name="PART_EditableTextBox"
Style="{x:Null}"
HorizontalAlignment="Left"
VerticalAlignment="Bottom"
Margin="3,3,21,3"
Focusable="True"
Background="Transparent"
Visibility="Hidden"
IsReadOnly="{TemplateBinding IsReadOnly}" />
<Popup x:Name="Popup"
Placement="Bottom"
IsOpen="{TemplateBinding IsDropDownOpen}"
AllowsTransparency="True"
Focusable="False"
PopupAnimation="Slide">
<Grid x:Name="DropDown"
Background="WhiteSmoke"
SnapsToDevicePixels="True"
MinWidth="{TemplateBinding ActualWidth}"
MaxHeight="{TemplateBinding MaxDropDownHeight}">
<Border x:Name="DropDownBorder" BorderThickness="1" Margin="0 0 2 0" />
<ScrollViewer SnapsToDevicePixels="True">
<StackPanel IsItemsHost="True" KeyboardNavigation.DirectionalNavigation="Contained" />
</ScrollViewer>
</Grid>
</Popup>
</Grid>
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
希望有帮助。相关问题:@Rachel:正确。不知道我怎么会错过这个。是的,如果OP跟随我的链接,这就是它的样子;o) @Olimpiu:非常感谢。正是我所需要的。虽然比我预期的要多做一点工作。:非常感谢DHN。我猜你和Olimpiu提出了同样的建议,但他继续提供实际的实现。不管怎样,我想你的答案是第一个出现的,值得投票。我不喜欢发布复制粘贴解决方案。但不管怎样,很高兴我们能帮助你;o)