• Silverlight TreeView 控件带虚线样式


    在 App文件加上

        <Application.Resources>
                <LinearGradientBrush x:Key="MyBrushNormalBorder" EndPoint="1,1" StartPoint="0.2,0">
                    <GradientStop Color="#FFB1B1B1" Offset="0.391"/>
                    <GradientStop Color="#46FFFFFF" Offset="1"/>
                </LinearGradientBrush>
                <LinearGradientBrush x:Key="MyBrushNormalBevelBackground" EndPoint="0.5,1" StartPoint="0.5,0">
                    <GradientStop Color="#FF414349" Offset="0.136"/>
                    <GradientStop Color="#FF202124" Offset="0.668"/>
                    <GradientStop Color="#FF0B153F" Offset="1"/>
                </LinearGradientBrush>
                <LinearGradientBrush x:Key="MyTreeBackground" EndPoint="0.5,1" StartPoint="0.5,0">
                    <GradientStop Color="#FF202124" Offset="0.136"/>
                    <GradientStop Color="#FF202124" Offset="0.668"/>
                    <GradientStop Color="#FF181B28" Offset="1"/>
                </LinearGradientBrush>
                <Style TargetType="controls:TreeViewItem">
                    <Setter Property="Padding" Value="0" />
                    <Setter Property="Foreground" Value="#FFD2DCA6"/>
                    <Setter Property="FontFamily" Value="Georgia"/>
                    <Setter Property="FontSize" Value="11"/>
                    <Setter Property="FontWeight" Value="Normal"/>
                    <Setter Property="Background">
                        <Setter.Value>
                            <LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
                                <GradientStop Color="#FFD2DCA6" Offset="0"/>
                                <GradientStop Color="#FFD2DCA6" Offset="1"/>
                            </LinearGradientBrush>
                        </Setter.Value>
                    </Setter>
                    <Setter Property="BorderThickness" Value="0"/>
                    <Setter Property="BorderBrush">
                        <Setter.Value >
                            <LinearGradientBrush EndPoint="1,1" StartPoint="0.2,0">
                                <GradientStop Color="#FFB1B1B1" Offset="0.391"/>
                                <GradientStop Color="#46FFFFFF" Offset="1"/>
                            </LinearGradientBrush>
                        </Setter.Value>
                    </Setter>
                    <Setter Property="HorizontalContentAlignment" Value="Stretch" />
                    <Setter Property="VerticalContentAlignment" Value="Top" />
                    <Setter Property="IsTabStop" Value="True" />
                    <Setter Property="TabNavigation" Value="Once" />
                    <Setter Property="Template">
                        <Setter.Value>
                            <ControlTemplate TargetType="controls:TreeViewItem">
                                <Grid Background="Transparent" Margin="{TemplateBinding Padding}">
                                    <vsm:VisualStateManager.VisualStateGroups>
                                        <vsm:VisualStateGroup x:Name="CommonStates">
                                            <vsm:VisualState x:Name="Normal" >
                                                <Storyboard>
                                                    <DoubleAnimation Storyboard.TargetName="HoverBorder" 
                                                             Storyboard.TargetProperty="Opacity" 
                                                             Duration="0:0:0.3" To="0" />
                                                </Storyboard>
                                            </vsm:VisualState>
                                            <vsm:VisualState x:Name="MouseOver" >
                                                <Storyboard>
                                                    <DoubleAnimation Storyboard.TargetName="HoverBorder" 
                                                             Storyboard.TargetProperty="Opacity" 
                                                             Duration="0:0:0.2" To="0.5" />
                                                </Storyboard>
                                            </vsm:VisualState>
                                            <vsm:VisualState x:Name="Pressed" />
                                            <vsm:VisualState x:Name="Disabled">
    
                                            </vsm:VisualState>
                                        </vsm:VisualStateGroup>
                                        <vsm:VisualStateGroup x:Name="SelectionStates">
                                            <vsm:VisualState x:Name="Unselected" />
                                            <vsm:VisualState x:Name="Selected">
                                                <Storyboard>
                                                    <DoubleAnimation Storyboard.TargetName="SelectBorder"
                                                             Storyboard.TargetProperty="Opacity"
                                                             To="1" Duration="0:0:0.1"/>
                                                    <DoubleAnimation Storyboard.TargetName="HoverBorder"
                                                             Storyboard.TargetProperty="Opacity"
                                                             To="0" Duration="0:0:0.1"/>
                                                    <ColorAnimation Storyboard.TargetName="Header"
                                                             Storyboard.TargetProperty="(Foreground).(SolidColorBrush.Color)"
                                                             To="#FFB5BD24" Duration="0:0:0.1"/>
                                                </Storyboard>
                                            </vsm:VisualState>
                                            <vsm:VisualState x:Name="SelectedInactive">
                                                <Storyboard>
                                                    <DoubleAnimation Storyboard.TargetName="SelectBorder"
                                                             Storyboard.TargetProperty="Opacity"
                                                             To="1" Duration="0:0:0.1"/>
                                                    <DoubleAnimation Storyboard.TargetName="HoverBorder"
                                                             Storyboard.TargetProperty="Opacity"
                                                             To="0" Duration="0:0:0.1"/>
                                                    <ColorAnimation Storyboard.TargetName="Header"
                                                             Storyboard.TargetProperty="(Foreground).(SolidColorBrush.Color)"
                                                             To="#FF202124" Duration="0:0:0.1"/>
                                                </Storyboard>
                                            </vsm:VisualState>
                                        </vsm:VisualStateGroup>
                                        <vsm:VisualStateGroup x:Name="HasItemsStates">
                                            <vsm:VisualState x:Name="HasItems" />
                                            <vsm:VisualState x:Name="NoItems">
                                                <Storyboard>
                                                    <ObjectAnimationUsingKeyFrames Storyboard.TargetName="ExpanderButton" 
                                                                           Storyboard.TargetProperty="Visibility" 
                                                                           Duration="0">
                                                        <DiscreteObjectKeyFrame KeyTime="0" Value="Collapsed" />
                                                    </ObjectAnimationUsingKeyFrames>
                                                    <ObjectAnimationUsingKeyFrames Storyboard.TargetName="ExpanderButton" 
                                                                           Storyboard.TargetProperty="IsHitTestVisible" 
                                                                           Duration="0">
                                                        <DiscreteObjectKeyFrame KeyTime="0" Value="False" />
                                                    </ObjectAnimationUsingKeyFrames>
                                                </Storyboard>
    
                                            </vsm:VisualState>
                                        </vsm:VisualStateGroup>
                                        <vsm:VisualStateGroup x:Name="ExpansionStates">
                                            <vsm:VisualState x:Name="Collapsed" >
                                                <Storyboard>
                                                    <ObjectAnimationUsingKeyFrames Storyboard.TargetName="ExpandSite" 
                                                                           Storyboard.TargetProperty="Visibility" 
                                                                           BeginTime="0:0:0.2">
                                                        <DiscreteObjectKeyFrame KeyTime="0:0:0.0" Value="Collapsed" />
                                                    </ObjectAnimationUsingKeyFrames>
                                                    <ObjectAnimationUsingKeyFrames Storyboard.TargetName="line" 
                                                                           Storyboard.TargetProperty="Visibility" 
                                                                           Duration="0:0:0.2">
                                                        <DiscreteObjectKeyFrame KeyTime="0:0:0.2" Value="Collapsed" />
                                                    </ObjectAnimationUsingKeyFrames>
                                                    <DoubleAnimation Storyboard.TargetName="line"
                                                             Storyboard.TargetProperty="Opacity"
                                                             Duration="0:0:0.2" To="0"/>
                                                    <DoubleAnimation Storyboard.TargetName="ExpandSite"
                                                             Storyboard.TargetProperty="Opacity"
                                                             BeginTime="0:0:0"
                                                             Duration="0:0:0.2" To="0"/>
                                                </Storyboard>
                                            </vsm:VisualState>
                                            <vsm:VisualState x:Name="Expanded">
                                                <Storyboard>
                                                    <ObjectAnimationUsingKeyFrames Storyboard.TargetName="ExpandSite" 
                                                                           Storyboard.TargetProperty="Visibility" 
                                                                           BeginTime="0:0:0">
                                                        <DiscreteObjectKeyFrame KeyTime="0" Value="Visible" />
                                                    </ObjectAnimationUsingKeyFrames>
                                                    <ObjectAnimationUsingKeyFrames Storyboard.TargetName="line" 
                                                                           Storyboard.TargetProperty="Visibility" 
                                                                           Duration="0">
                                                        <DiscreteObjectKeyFrame KeyTime="0" Value="Visible" />
                                                    </ObjectAnimationUsingKeyFrames>
                                                    <DoubleAnimation Storyboard.TargetName="line"
                                                             Storyboard.TargetProperty="Opacity"
                                                             Duration="0:0:0.2" To="1"/>
                                                    <DoubleAnimation Storyboard.TargetName="ExpandSite"
                                                             Storyboard.TargetProperty="Opacity"
                                                             BeginTime="0:0:0.01"
                                                             Duration="0:0:0.3" To="1"/>
                                                </Storyboard>
                                            </vsm:VisualState>
                                        </vsm:VisualStateGroup>
                                        <vsm:VisualStateGroup x:Name="ValidationStates">
                                            <vsm:VisualState x:Name="Valid" />
                                            <vsm:VisualState x:Name="InvalidUnfocused">
                                            </vsm:VisualState>
                                            <vsm:VisualState x:Name="InvalidFocused">
                                            </vsm:VisualState>
                                        </vsm:VisualStateGroup>
                                    </vsm:VisualStateManager.VisualStateGroups>
                                    <Grid.RowDefinitions>
                                        <RowDefinition Height="Auto" />
                                        <RowDefinition Height="*" />
                                    </Grid.RowDefinitions>
                                    <Grid x:Name="HoverBorder" Opacity="0"
                                  IsHitTestVisible="False" Margin="5 0 0 0">
                                        <Border BorderBrush="{TemplateBinding BorderBrush}" 
                                        CornerRadius="3"
                                        BorderThickness="{TemplateBinding BorderThickness}"
                                        Background="{TemplateBinding Background}"/>
                                    </Grid>
    
                                    <Grid x:Name="SelectBorder" Opacity="0" 
                                  IsHitTestVisible="False" Margin="5 0 0 0">
                                        <Border BorderBrush="{TemplateBinding BorderBrush}" 
                                        CornerRadius="3"
                                        BorderThickness="{TemplateBinding BorderThickness}"
                                        Background="{TemplateBinding Background}"/>
                                    </Grid>
                                    <Grid >
                                        <StackPanel Orientation="Horizontal" HorizontalAlignment="Left"
                                        MinHeight="20">
                                            <Line x:Name="lineH" Stroke="{TemplateBinding Foreground}" 
                                          StrokeThickness="1" X1="0" X2="10"
                                          Y1="0" Y2="0" StrokeDashArray="1 2" Stretch="UniformToFill"
                                          VerticalAlignment="Center" HorizontalAlignment="Left"                           
                                          UseLayoutRounding="True" IsHitTestVisible="False"/>
    
                                            <ToggleButton x:Name="ExpanderButton" HorizontalAlignment="Left" Width="14"
                                              Height="14" Margin="3 0 0 0"
                                          VerticalAlignment="Center" IsTabStop="False" TabNavigation="Once">
                                                <ToggleButton.Template>
                                                    <ControlTemplate TargetType="ToggleButton">
                                                        <Grid x:Name="Root" Background="Transparent" >
                                                            <vsm:VisualStateManager.VisualStateGroups>
                                                                <vsm:VisualStateGroup x:Name="CommonStates">
                                                                    <vsm:VisualState x:Name="Normal" />
                                                                    <vsm:VisualState x:Name="MouseOver">
                                                                        <Storyboard>
                                                                            <DoubleAnimation Storyboard.TargetName="OuterBorder" 
                                                                             Storyboard.TargetProperty="Opacity" 
                                                                             To="1" Duration="0:0:0.1" />
                                                                        </Storyboard>
                                                                    </vsm:VisualState>
                                                                    <vsm:VisualState x:Name="Disabled">
                                                                        <Storyboard>
                                                                            <DoubleAnimation Storyboard.TargetName="Root" 
                                                                             Storyboard.TargetProperty="Opacity" 
                                                                             To="0.5" 
                                                                             Duration="0" />
                                                                        </Storyboard>
                                                                    </vsm:VisualState>
                                                                </vsm:VisualStateGroup>
                                                                <vsm:VisualStateGroup x:Name="CheckStates">
                                                                    <vsm:VisualState x:Name="Unchecked" />
                                                                    <vsm:VisualState x:Name="Checked">
                                                                        <Storyboard>
                                                                            <DoubleAnimation Storyboard.TargetName="UncheckedVisual" 
                                                                             Storyboard.TargetProperty="Opacity" 
                                                                             To="0" Duration="0" />
                                                                            <DoubleAnimation Storyboard.TargetName="CheckedVisual" 
                                                                             Storyboard.TargetProperty="Opacity" 
                                                                             To="1" Duration="0" />
                                                                        </Storyboard>
                                                                    </vsm:VisualState>
                                                                </vsm:VisualStateGroup>
                                                            </vsm:VisualStateManager.VisualStateGroups>
                                                            <Border x:Name="OuterBorder" 
                                                        BorderBrush="{StaticResource MyBrushNormalBorder}" 
                                                        CornerRadius="3"
                                                        BorderThickness="1" Opacity="0.5"
                                                            Background="{StaticResource MyBrushNormalBevelBackground}"/>
                                                            <Grid Margin="3" >
                                                                <Path x:Name="UncheckedVisual" UseLayoutRounding="False"
                                                      HorizontalAlignment="Center"  Stretch="Uniform" 
                                                      Data="M0,4 L4,4 L4,0 L6,0 L6,4 L10,4 L10,6 L6,6 L6,10 L4,10 L4,6 L0,6 z" 
                                                      VerticalAlignment="Center" 
                                                      Opacity="1" Fill="#FFB5BD24">
                                                                </Path>
                                                                <Path x:Name="CheckedVisual" UseLayoutRounding="False"
                                                      HorizontalAlignment="Center" Stretch="Uniform" 
                                                      Data="M0,4 L10,4 L10,6 L0,6 z" 
                                                      VerticalAlignment="Center" 
                                                      Opacity="0" Fill="#FFB5BD24">
                                                                </Path>
                                                            </Grid>
                                                        </Grid>
                                                    </ControlTemplate>
                                                </ToggleButton.Template>
                                            </ToggleButton>
    
                                            <Button x:Name="Header" ClickMode="Hover"
                                            Background="{TemplateBinding Background}" 
                                            Foreground="{TemplateBinding Foreground}" 
                                            BorderBrush="{TemplateBinding BorderBrush}" 
                                            BorderThickness="{TemplateBinding BorderThickness}" 
                                            Cursor="{TemplateBinding Cursor}" 
                                            HorizontalAlignment="Stretch" 
                                            VerticalAlignment="Stretch" Margin="3 0"
                                            FontFamily="{TemplateBinding FontFamily}"
                                            FontWeight="{TemplateBinding FontWeight}"
                                            FontSize="{TemplateBinding FontSize}"
                                            IsTabStop="False" TabNavigation="Once">
                                                <Button.Template>
                                                    <ControlTemplate TargetType="Button">
                                                        <Grid>
                                                            <vsm:VisualStateManager.VisualStateGroups>
                                                                <vsm:VisualStateGroup x:Name="CommonStates">
                                                                    <vsm:VisualState x:Name="Normal" />
                                                                    <vsm:VisualState x:Name="Pressed">
                                                                    </vsm:VisualState>
                                                                    <vsm:VisualState x:Name="Disabled">
                                                                        <Storyboard>
                                                                            <DoubleAnimation Storyboard.TargetName="Content" 
                                                                                     Storyboard.TargetProperty="Opacity" 
                                                                                     Duration="0" To="0.5" />
                                                                        </Storyboard>
                                                                    </vsm:VisualState>
                                                                </vsm:VisualStateGroup>
                                                            </vsm:VisualStateManager.VisualStateGroups>
                                                            <Grid Background="Transparent" >
                                                                <ContentPresenter x:Name="Content" Cursor="{TemplateBinding Cursor}" 
                                                              Content="{TemplateBinding Content}" 
                                                              ContentTemplate="{TemplateBinding ContentTemplate}" 
                                                              HorizontalAlignment="Stretch"
                                                              VerticalAlignment="Center"/>
                                                            </Grid>
                                                        </Grid>
                                                    </ControlTemplate>
                                                </Button.Template>
                                                <Button.Content>
                                                    <Grid Background="Transparent" >
                                                        <ContentPresenter Content="{TemplateBinding Header}" 
                                                        ContentTemplate="{TemplateBinding HeaderTemplate}" />
                                                    </Grid>
                                                </Button.Content>
                                            </Button>
                                        </StackPanel>
                                    </Grid>
                                    <ContentControl x:Name="ExpandSite" Grid.Row="1"
                                          Margin="20 0 0 0"
                                          Visibility="Collapsed"
                                          HorizontalAlignment="Stretch"
                                          HorizontalContentAlignment="Stretch">
                                        <ItemsPresenter />
                                    </ContentControl>
    
                                    <Border Grid.Row="1" Margin="20 0 0 0" IsHitTestVisible="False">
                                        <Line x:Name="line" Stroke="{TemplateBinding Foreground}" 
                                      StrokeThickness="1" X1="0" X2="0"
                                  Y1="0" Y2="2" StrokeDashArray="1 1"
                                      Stretch="UniformToFill"
                                  Width="1"  VerticalAlignment="Stretch" HorizontalAlignment="Left"                              
                                  UseLayoutRounding="False" Opacity="0" Visibility="Collapsed"/>
                                    </Border>
    
                                </Grid>
                            </ControlTemplate>
                        </Setter.Value>
                    </Setter>
                </Style>
    
                <Style TargetType="controls:TreeView" x:Key="TreeType">
                    <Setter Property="Background" Value="{StaticResource MyTreeBackground}"/>
                    <Setter Property="Foreground" Value="#FFD2DCA6" />
                    <Setter Property="HorizontalContentAlignment" Value="Left" />
                    <Setter Property="VerticalContentAlignment" Value="Top" />
                    <Setter Property="BorderThickness" Value="1" />
                    <Setter Property="Padding" Value="2" />
                    <Setter Property="BorderBrush">
                        <Setter.Value>
                            <LinearGradientBrush EndPoint="1,1" StartPoint="0.2,0">
                                <GradientStop Color="#FFB1B1B1" Offset="0.391"/>
                                <GradientStop Color="#46FFFFFF" Offset="1"/>
                            </LinearGradientBrush>
                        </Setter.Value>
                    </Setter>
                    <Setter Property="IsTabStop" Value="True" />
                    <Setter Property="TabNavigation" Value="Once" />
                    <Setter Property="Template">
                        <Setter.Value>
                            <ControlTemplate TargetType="controls:TreeView">
                                <Grid>
                                    <vsm:VisualStateManager.VisualStateGroups>
                                        <vsm:VisualStateGroup x:Name="CommonStates">
                                            <vsm:VisualState x:Name="Normal" />
                                            <vsm:VisualState x:Name="MouseOver" />
                                            <vsm:VisualState x:Name="Pressed" />
                                            <vsm:VisualState x:Name="Disabled" />
                                        </vsm:VisualStateGroup>
                                        <vsm:VisualStateGroup x:Name="FocusStates">
                                            <vsm:VisualState x:Name="Unfocused" />
                                            <vsm:VisualState x:Name="Focused" />
                                        </vsm:VisualStateGroup>
                                        <vsm:VisualStateGroup x:Name="ValidationStates">
                                            <vsm:VisualState x:Name="Valid" />
                                            <vsm:VisualState x:Name="InvalidUnfocused">
    
                                            </vsm:VisualState>
                                            <vsm:VisualState x:Name="InvalidFocused">
    
                                            </vsm:VisualState>
                                        </vsm:VisualStateGroup>
                                    </vsm:VisualStateManager.VisualStateGroups>
    
                                    <Border x:Name="InnerBorder" BorderThickness="1" CornerRadius="4" 
                                    Background="{TemplateBinding Background}" 
                                    BorderBrush="{TemplateBinding BorderBrush}"
                                    Padding="0">
    
                                        <ScrollViewer x:Name="ScrollViewer" Padding="{TemplateBinding Padding}"
                                              Background="{x:Null}" 
                                              BorderBrush="Transparent" BorderThickness="0" Margin="0"
                                              TabNavigation="{TemplateBinding TabNavigation}">
                                            <ItemsPresenter />
                                        </ScrollViewer>
                                    </Border>
                                </Grid>
                            </ControlTemplate>
                        </Setter.Value>
                    </Setter>
                </Style>
        </Application.Resources>
    

    在树控件加上 Style="{StaticResource TreeType}"

  • 相关阅读:
    VMware6.0-vCenter的安装准备及安装
    VeeamBackup9.5安装与配置
    VeeamOne(Free Edition 9.5 )-安装与配置
    UIDatePicker
    UIImagePicker照片选择器
    UIImageView
    UILabel
    UIScrollView 期本使用方法
    UISegment
    UISlide
  • 原文地址:https://www.cnblogs.com/geass/p/2024102.html
Copyright © 2020-2023  润新知