2010-11-08 132 views
5

我注意到了TextBox的一个奇怪行为,而BorderThickness属性设置为1 - 焦点导致边框改变颜色(像白色一样)。 但是,如果我将边框厚度设置为不同于1的值,例如.99或1.01,则问题会消失。WPF中的文本框的边框厚度(一个bug?)

它是WPF中的错误吗?还是它的目的?

+0

什么是您的视频适配器的DPI设置为? SnapToDevicePixels有效吗? – 2010-11-08 21:36:54

+0

我想我可以重现这一点。如果你有一个文本框并且它获得焦点,那么边框会改变颜色。但是,如果BorderThickness不是“1”,则不会发生。从未见过这个,不要以为我以前曾经设置过TextBox的BorderThickness。 (+1) – 2010-11-08 21:49:22

+0

@Hans,我认为SnapToDevicePixels没有任何合理的效果。只有当TextBox获得关键焦点时(即正在写入并且鼠标移动到TextBox上),问题才会发生。 – Jamie 2010-11-08 21:59:51

回答

1

这是TextBoxes的Aero样式的默认行为。要禁用它,你需要重新设置TextBox。您可以从here中获取默认样式(请参阅下载示例)。

在TextBoxBase(TextBox所基于的)的默认样式中,您会看到它使用ListBoxChrome。此元素在Presentation.Aero程序集中定义,并负责呈现“聚焦”外观。您可以简单地删除RenderFocus设置,也可以删除RenderMouseOver,或将其替换为边框。

然后你想要将它包含在你的应用程序资源中。

<LinearGradientBrush x:Key="TextBoxBorder" 
     StartPoint="0,0" EndPoint="0,20" MappingMode="Absolute"> 
    <LinearGradientBrush.GradientStops> 
     <GradientStop Color="#ABADB3" Offset="0.05" /> 
     <GradientStop Color="#E2E3EA" Offset="0.07" /> 
     <GradientStop Color="#E3E9EF" Offset="1" /> 
    </LinearGradientBrush.GradientStops> 
</LinearGradientBrush> 

<Style x:Key="{x:Type TextBoxBase}" TargetType="{x:Type TextBoxBase}" BasedOn="{x:Null}"> 
    <Setter Property="Foreground" Value="{DynamicResource {x:Static SystemColors.ControlTextBrushKey}}" /> 
    <Setter Property="Background" Value="{DynamicResource {x:Static SystemColors.WindowBrushKey}}" /> 
    <Setter Property="BorderBrush" Value="{StaticResource TextBoxBorder}" /> 
    <Setter Property="BorderThickness" Value="1" /> 
    <Setter Property="Padding" Value="1" /> 
    <Setter Property="AllowDrop" Value="true" /> 
    <Setter Property="FocusVisualStyle" Value="{x:Null}" /> 
    <Setter Property="Template"> 
     <Setter.Value> 
      <ControlTemplate TargetType="{x:Type TextBoxBase}"> 
       <Border x:Name="Bd" BorderThickness="{TemplateBinding BorderThickness}" 
         BorderBrush="{TemplateBinding BorderBrush}" Background="{TemplateBinding Background}" 
         SnapsToDevicePixels="true"> 
        <ScrollViewer x:Name="PART_ContentHost" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" /> 
       </Border > 
       <ControlTemplate.Triggers> 
        <Trigger Property="IsEnabled" Value="false"> 
         <Setter TargetName="Bd" Property="Background" Value="{DynamicResource {x:Static SystemColors.ControlBrushKey}}" /> 
         <Setter Property="Foreground" Value="{DynamicResource {x:Static SystemColors.GrayTextBrushKey}}" /> 
        </Trigger> 
       </ControlTemplate.Triggers> 
      </ControlTemplate> 
     </Setter.Value> 
    </Setter> 
</Style> 
<Style x:Key="{x:Type TextBox}" BasedOn="{StaticResource {x:Type TextBoxBase}}" TargetType="{x:Type TextBox}"/> 

如果你看看在反射器ListBoxChrome类(特别是法的OnRender),你可以看到它只会呈现专注的神情,如果它是了borderThickness,“1,1,1,1”。