1. <Window x:Class="Wpf_GridHeaderStyle_sample.Window1"
  2. xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  3. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  4. xmlns:c="clr-namespace:Wpf_GridHeaderStyle_sample"
  5. Title="Window1" Height="300" Width="300">
  6. <Window.Resources>
  7. <ControlTemplate x:Key="tmpForThumb" TargetType="{x:Type Thumb}">
  8. <Border>
  9. <Rectangle Width="1" Name="rec">
  10. <Rectangle.Fill>
  11. <LinearGradientBrush StartPoint="0.5,0.3" EndPoint="1,1">
  12. <GradientStop Color="Orange" Offset="0.22"/>
  13. <GradientStop Color="White" Offset="1"/>
  14. </LinearGradientBrush>
  15. </Rectangle.Fill>
  16. </Rectangle>
  17. </Border>
  18. <ControlTemplate.Triggers>
  19. <Trigger Property="IsMouseOver" Value="True">
  20. <Setter TargetName="rec" Property="Fill" Value="LightGreen"/>
  21. </Trigger>
  22. </ControlTemplate.Triggers>
  23. </ControlTemplate>
  24. <Style TargetType="{x:Type GridViewColumnHeader}">
  25. <Setter Property="OverridesDefaultStyle" Value="True"/>
  26. <Setter Property="Template">
  27. <Setter.Value>
  28. <ControlTemplate TargetType="{x:Type GridViewColumnHeader}">
  29. <Grid Name="g">
  30. <Grid.Background>
  31. <LinearGradientBrush StartPoint="0.5,0" EndPoint="0.5,1">
  32. <GradientStop Color="Gold" Offset="0.3"/>
  33. <GradientStop Color="LightYellow" Offset="1"/>
  34. </LinearGradientBrush>
  35. </Grid.Background>
  36. <Border Name="bd" Padding="{TemplateBinding Padding}">
  37. <ContentPresenter Margin="5,4,1,3"  HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}"/>
  38. </Border>
  39. <Thumb Name="PART_HeaderGripper" Template="{StaticResource tmpForThumb}" HorizontalAlignment="Right" Margin="0,0,-1,0"/>
  40. </Grid>
  41. <ControlTemplate.Triggers>
  42. <Trigger Property="IsMouseOver" Value="True">
  43. <Setter TargetName="g" Property="Background">
  44. <Setter.Value>
  45. <LinearGradientBrush StartPoint="0.5,0" EndPoint="0.5,1">
  46. <GradientStop Color="DeepPink" Offset="0.3"/>
  47. <GradientStop Color="White" Offset="1"/>
  48. </LinearGradientBrush>
  49. </Setter.Value>
  50. </Setter>
  51. </Trigger>
  52. </ControlTemplate.Triggers>
  53. </ControlTemplate>
  54. </Setter.Value>
  55. </Setter>
  56. </Style>
  57. <!--数据源-->
  58. <c:Students x:Key="DBSource"/>
  59. <!--ListViewItem的样式-->
  60. <Style TargetType="{x:Type ListViewItem}">
  61. <Style.Setters>
  62. <Setter Property="SnapsToDevicePixels" Value="True"/>
  63. <Setter Property="Template">
  64. <Setter.Value>
  65. <ControlTemplate TargetType="{x:Type ListViewItem}">
  66. <Border x:Name="bd"
  67. BorderThickness="1"
  68. Padding="{TemplateBinding Padding}"
  69. SnapsToDevicePixels="True">
  70. <GridViewRowPresenter HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}"
  71. Margin="3"/>
  72. </Border>
  73. <ControlTemplate.Triggers>
  74. <Trigger Property="IsSelected" Value="True">
  75. <Trigger.Setters>
  76. <Setter TargetName="bd" Property="Background">
  77. <Setter.Value>
  78. <LinearGradientBrush StartPoint="0.5,0.22" EndPoint="0.5,1">
  79. <GradientStop Color="LightGray" Offset="0.31"/>
  80. <GradientStop Color="Gray" Offset="0.88"/>
  81. </LinearGradientBrush>
  82. </Setter.Value>
  83. </Setter>
  84. </Trigger.Setters>
  85. </Trigger>
  86. </ControlTemplate.Triggers>
  87. </ControlTemplate>
  88. </Setter.Value>
  89. </Setter>
  90. </Style.Setters>
  91. </Style>
  92. </Window.Resources>
  93. <Grid>
  94. <ListView x:Name="lv" ItemsSource="{StaticResource DBSource}">
  95. <ListView.View>
  96. <GridView AllowsColumnReorder="True">
  97. <GridViewColumn DisplayMemberBinding="{Binding Path=Name}" Header="姓名" Width="110"/>
  98. <GridViewColumn DisplayMemberBinding="{Binding Path=Phone}" Header="联系电话" Width="125"/>
  99. </GridView>
  100. </ListView.View>
  101. </ListView>
  102. </Grid>
  103. </Window>

继续聊WPF——为ListView的行设置样式的更多相关文章

  1. WPF ListView控件设置奇偶行背景色交替变换以及ListViewItem鼠标悬停动画

    原文:WPF ListView控件设置奇偶行背景色交替变换以及ListViewItem鼠标悬停动画 利用WPF的ListView控件实现类似于Winform中DataGrid行背景色交替变换的效果,同 ...

  2. WPF,ListView设置分组

    原文:WPF,ListView设置分组 今天遇到一个问题,就是在ListView中设置分组.想了很久在网上早了些资料作出一个例子. 分组字段也可以在后台中定义: CollectionView view ...

  3. (转)利用WPF的ListView进行大数据量异步加载

    原文:http://www.cnblogs.com/scy251147/archive/2012/01/08/2305319.html 由于之前利用Winform的ListView进行大数据量加载的时 ...

  4. 利用WPF的ListView进行大数据量异步加载

    原文:利用WPF的ListView进行大数据量异步加载 由于之前利用Winform的ListView进行大数据量加载的时候,诟病良多,所以今天试着用WPF的ListView来做了一下,结果没有让我失望 ...

  5. wpf datagrid row height 行高自动计算使每行行高自适应文本

    wpf 的datagrid的行高 要么是Auto,要么是定值:但会带来麻烦就是每行行高都一样. 当需要按内容(主要是wrap 换行的textbox或textblock)来动态调整行高的时候,需要用到d ...

  6. WPF之ListView使用WrapPanel

    原文:WPF之ListView使用WrapPanel 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/jiuzaizuotian2014/articl ...

  7. 【C#/WPF】ListView的MVVM例子,及禁止拖动ListView的头部Header

    一个ListView的MVVM简单例子: <ListView ItemsSource="{Binding GoodsList}" Margin="0,10,0,10 ...

  8. word-wrap&&word-break,奇偶行、列设置样式

    1.word-wrap和word-break区分. 来源场景:机械租赁mvc驾驶员信息查看: 当备注的文字多的时候,第一列的值成这模样: 解决方案:设置table 的td可自动换行.首先table设置 ...

  9. WPF Button的背景图片设置

    这个问题很简单,但是对于从winfrom转过来的来讲,在做事的时候就会被绕进去,言归正传,如何设置一个bUtton的背景图片?如何去掉让人烦的默认选中时的灰色背景?请看如下的描述.问题的来源和解决都在 ...

随机推荐

  1. 一个简单RPC框架是怎样炼成的(I)——开局篇

    开场白,这是一个关于RPC的相关概念的普及篇系列,主要是通过一步步的调整,提炼出一个相对完整的RPC框架. RPC(Remote Procedure Call Protocol)--远程过程调用协议, ...

  2. Hadop使用Partitioner后,结果还是一个文件,怎样解决??

    近期看了一下partitioner.于是照着写了一个列子.最后发现程序并没有将结果分开写入对应的文件,结果还是一个文件,于是乎感觉是不是没实用集群去执行程序,发现control中还是本地执行的代码: ...

  3. HDU2037 事件排序问题

    题目要求: Problem Description "今年暑假不AC?" "是的." "那你干什么呢?" "看世界杯呀,笨蛋!&q ...

  4. Java执行定时任务

    一.用java.util.Timer 使用JAVA类Timer可实现简单的延迟和周期性任务,其中的任务使用java.util.TimerTask表示.任务的执行方式有两种: 按固定速率执行:即sche ...

  5. nodejs windows环境安装

    相信对于很多关注javascript发展的同学来说,nodejs已经不是一个陌生的词眼.有关nodejs的相关资料网上已经铺天盖地.由于它的高并发特性,造就了其特殊的应用地位. 国内目前关注最高,维护 ...

  6. 如何让 vue 在 sublime 中变成彩色的

    在 sublime 中编辑 vue 时,导入后是纯白色的文本,如下图: 想让其变成彩色的文本,需要安装插件,步骤如下: 1. 按住:Ctrl + Alt + P 2. 输入:install Packa ...

  7. docker(一):docker是什么?

    认识容器:docker入门篇 docker是什么? Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚 ...

  8. POJ 1172 DFS

    (感谢wzc学长的幻灯片) 单组数据 注意从必经点能到标记过的点则此点不是分裂点. //By: Sirius_Ren #include <cstdio> #include <queu ...

  9. window.dialogArguments

    弹出子窗口window.showModalDialog( url, window ); 然后在弹出的子窗口中: window.dialogArguments 即为父窗口window对象的引用.想搞什么 ...

  10. sql 改字段名

    sp_rename '[zErpMini].[dbo].[STK_Stock].Isextension','IsExtened'