• WPF样式和资源2


    <Window.Resources>
      <FontFamily x:key="ButtonFontFamily">Time New Roman</FontFamily>
      <sys:Double x:key="ButtonFontSize">18</s:Double>
      <FontWeight x:key="ButtonFontWeight">Bold</FontWeight>
    </Window.Resources>

    1:资源里定义了三个资源,分别设置对象属性
    接下来应用资源:

    <Button FontFamily="{StaticResource ButtonFontFamily}"
    FontWeight=="{StaticResource ButtonFontWeight}"
    FontSize=="{StaticResource ButtonFontSize}"
    </Button>

    2:另一种方式:(WPF中的一个元素都可以使用一个样式,只能使用一个样式

    创建一个独立的资源:

    <Window.Resources>
      <Style x:key="BigFontButtonStyle">
        <setter Property="control.FontFamily" Value="Tinmes New     Roman"/>
        <Setter Property="control.FontSize" Value="18"/>
        <Setter Property="control.FontWeight" Value="Bold"/>
      </Style>
    </Window.Resources>

    应用这个独立的样式资源

    <Button Sytle="{StaticResource BigFontButtonStyle}">a Customized</Button>

    Style类的属性:
    Setters:设置属性值并自动关联事件处理程序的Sette对象或EventSetter对象的集合

    Triggers:能够自动改变样式设置的对象集合

    Resources

    BasedOn:通过该属性可以创建继承其他样式设置的更复杂样式

    TargetType:该属性表示应用样式的元素的类型

    3:关联的事件处理程序

    <Style x:key="MouseOverHighLightStyle">
      <EventSetter Event="TextBlock.MouseEnter" Handler="element_MouseEnter"/>
      <EventSetter Event=="TextBlock.MouseLeave" Handler="element_MouseLeave"/>
      <Setter Property=TextBlock.Padding" Value="5"/>
    </Style>
    private void element_MouseEnter(object sender,MouseEventArgs e)
    {
    
      ((TextBlock)Senter.Background=new SolidColorBrush(Colors.LightGoldenrodYellow);
    
    }

    事件element_MouseLeave同样的道理

    接下来应用给样式;

    <Textklock Style="{StaticResouce MouseOverHightStyle}"> Hover Over me</Textklock >

    4:简单触发器

    <Style x:key="BigFontButton">
      <Style.Setters>
        <Setter Property="Control.FontFamily" Value="Time NEw Roman"/>
        <Setter Property="Control.FontSize" Value="18"/>
      </Style.Setters>
       
      <Style.Triggers>
        <Triggers Property="Control.IsFocused" Value="True">
        <Setter Property="Control.Foreground" Value="darkRed"/>
      </Style.Triggers>
    </Style>
    也可以定义多个触发器

    5:比较复杂的,这里用到了”行为“:

    <Style x:Key="OuterGlowStyle" TargetType="{x:Type FrameworkElement}">
                <Style.Triggers>
                    <Trigger Property="IsFocused" Value="True">
                        <Setter Property="Effect">
                            <Setter.Value>
                                <DropShadowEffect BlurRadius="10" Color="Black" Direction="0" Opacity="0.6"
     RenderingBias="Performance" ShadowDepth="0"/>
                            </Setter.Value>
                        </Setter>
                    </Trigger>
                    <Trigger Property="IsMouseOver" Value="True">
                        <Setter Property="Effect">
                            <Setter.Value>
                                <DropShadowEffect BlurRadius="10" Color="Black" Direction="0" Opacity="0.6"
     RenderingBias="Performance" ShadowDepth="0"/>
                            </Setter.Value>
                        </Setter>
                    </Trigger>
                </Style.Triggers>
            </Style>

    6:RelativeSource相对路径

        StaticSource绝对路径

        ElementSource通常绑定某个控件的Value

  • 相关阅读:
    String.format in JavaScript
    dojo/domReady! 中感叹号的作用
    文本三剑客之sed的用法
    文本三剑客之grep的用法
    通配符与特殊符号
    文件属性信息
    文件属性及find命令总结
    linux系统常用命令
    系统优化
    vim编辑器 与etc目录
  • 原文地址:https://www.cnblogs.com/tianma3798/p/3716199.html
Copyright © 2020-2023  润新知