• <Window x:Class="Expander_Sample2.Window1"
  • xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  • xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  • Title="Window1" Height="300" Width="300">
  • <Window.Resources>
  • <!--
  • ToogleButton的模板,
  • 因为要进和状态切换,故要用到ToggleButton控件
  • -->
  • <ControlTemplate x:Key="ToggleButtonTemp" TargetType="{x:Type ToggleButton}">
  • <Border x:Name="bd"
  • BorderThickness="1"
  • CornerRadius="1,1,1,1">
  • <Border.Background>
  • <LinearGradientBrush StartPoint="0.5,0" EndPoint="0.5,1">
  • <GradientStop Color="LightGray" Offset="0"/>
  • <GradientStop Color="White" Offset="1"/>
  • </LinearGradientBrush>
  • </Border.Background>
  • <Border.BorderBrush>
  • <LinearGradientBrush StartPoint="0,0" EndPoint="1,1">
  • <GradientStop Color="Black" Offset="0"/>
  • <GradientStop Color="Gray" Offset="1"/>
  • </LinearGradientBrush>
  • </Border.BorderBrush>
  • <Path Margin="2,2,2,2" Fill="Black" x:Name="p"
  • Data="M 0,0 L 4,5 L8,0 Z"
  • HorizontalAlignment="Center"
  • VerticalAlignment="Center"/>
  • </Border>
  • <ControlTemplate.Triggers>
  • <Trigger Property="IsMouseOver" Value="True">
  • <Setter TargetName="bd" Property="Background">
  • <Setter.Value>
  • <LinearGradientBrush StartPoint="0.5,0" EndPoint="0.5,1">
  • <GradientStop Color="LightGreen" Offset="0"/>
  • <GradientStop Color="White" Offset="1"/>
  • </LinearGradientBrush>
  • </Setter.Value>
  • </Setter>
  • </Trigger>
  • <Trigger Property="IsChecked" Value="True">
  • <Setter TargetName="p" Property="Data"
  • Value="M0,5 L8,5 L4,0 Z"/>
  • </Trigger>
  • <Trigger Property="IsEnabled" Value="True">
  • <Setter TargetName="bd" Property="BorderBrush" Value="Gray"/>
  • <Setter TargetName="p" Property="Fill" Value="Gray"/>
  • </Trigger>
  • </ControlTemplate.Triggers>
  • </ControlTemplate>
  • <!--
  • Expnder的样式
  • -->
  • <Style TargetType="{x:Type Expander}">
  • <Setter Property="Template">
  • <Setter.Value>
  • <ControlTemplate TargetType="{x:Type Expander}">
  • <Grid>
  • <Grid.RowDefinitions>
  • <RowDefinition Height="auto"/>
  • <RowDefinition x:Name="gr" Height="0"/>
  • </Grid.RowDefinitions>
  • <BulletDecorator Background="DarkTurquoise" Grid.Row="0" VerticalAlignment="Center" >
  • <BulletDecorator.Bullet>
  • <ToggleButton Margin="1,1,1,1"  Height="18" Width="18" Template="{StaticResource ToggleButtonTemp}"
  • IsChecked="{Binding Path=IsExpanded, Mode=TwoWay, RelativeSource={RelativeSource TemplatedParent}}"
  • OverridesDefaultStyle="True"/>
  • </BulletDecorator.Bullet>
  • <ContentPresenter HorizontalAlignment="Center" Margin="1,1,1,1" ContentSource="Header"/>
  • </BulletDecorator>
  • <Border x:Name="scv" Background="LightGray" BorderThickness="1" BorderBrush="Black" Grid.Row="1" >
  • <ContentPresenter Margin="0" ContentSource="Content"/>
  • </Border>
  • </Grid>
  • <ControlTemplate.Triggers>
  • <Trigger Property="IsExpanded" Value="True">
  • <Setter TargetName="gr" Property="Height" Value="{Binding Path=DesiredSize/Height,ElementName=scv}"/>
  • </Trigger>
  • </ControlTemplate.Triggers>
  • </ControlTemplate>
  • </Setter.Value>
  • </Setter>
  • </Style>
  • </Window.Resources>
  • <Grid>
  • <Expander Margin="10,10" Height="210" Width="130" OverridesDefaultStyle="True">
  • <Expander.Header>
  • <TextBlock Text="相见恨晚" FontWeight="Bold" FontSize="16"/>
  • </Expander.Header>
  • <TextBlock TextWrapping="Wrap">
  • 如果相见不会太晚,我们就不会悲伤,和你堂堂的手牵手,过得好简单,
  • 若我有天不见了,或许你会比较快乐,虽然有万般舍不得,也不愿看你难割舍
  • 若我有天不在了。请你原谅我的困扰,虽然你给我的不算少,只是我没福气要就算是完美。
  • </TextBlock>
  • </Expander>
  • </Grid>
  • </Window>

继续聊WPF——Expander控件(2)的更多相关文章

  1. 继续聊WPF——Expander控件(1)

    这个控件最实用的地方,就是做导航栏. <StackPanel Margin="20,20" Width="100" Height="460&qu ...

  2. WPF Expander控件(扩展面板)

    这算是我比较喜欢的一个控件,以前在Winform中也常用类似的.它包装了一块内容,通过单击一个小箭头按钮可以显示或隐藏所包含的内容.在线帮助以及Web页面经常使用这种技术,因为既可以包含大量内容,而又 ...

  3. 继续聊WPF——Thumb控件

    这个控件,真不好介绍,MSDN上也是草草几句,反正就是可以让用户拖动的玩意儿,但是,你会发现,当你在该控件上拖动时,它没有反响,也就是说这个东西默认不做任何操作的,它是赖在那里什么都不干,除非你去踢上 ...

  4. WPF中Expander控件样式,ListBox的样式(带checkbox)恢复

    Expander控件样式: <ControlTemplate x:Key="ExpanderToggleButton" TargetType="ToggleButt ...

  5. 《WPF》Expander控件简单美化

    示例图: Expander控件功能很常见, 一般用于系统左侧的菜单收缩面板. 1.主要的组成 一个头部(header) 和 一个 内容(content) 组成. <Expander Expand ...

  6. 迟到的 WPF 学习 —— 控件

    这一章书中内容比较多而杂,但每个对象的内容又相对简短,所以只挑选里边有代表性的内容做记录. 1. Label 控件:一个基础的简单的 ContentControl,Labe 支持快捷键文本的设置,可以 ...

  7. 在 UWP 中实现 Expander 控件

    WPF 中的 Expander 控件在 Windows 10 SDK 中并不提供,本文主要说明,如何在 UWP 中创建这样一个控件.其效果如下图: 首先,分析该控件需要的一些特性,它应该至少包括如下三 ...

  8. WPF Popup 控件导致被遮挡内容不刷新的原因

    WPF Popup 控件导致被遮挡内容不刷新的原因 周银辉 今天在写一个WPF控件时用到了Popup控件,很郁闷的情况是:当popup关闭时,原来被popup挡住的界面部分不刷新,非要手动刷新一下(比 ...

  9. 创建 WPF 工具箱控件

    创建 WPF 工具箱控件 WPF (Windows Presentation Framework) 工具箱控件模板允许您创建 WPF 控件,会自动添加到 工具箱 安装扩展的安装. 本主题演示如何使用模 ...

随机推荐

  1. 天了噜,我国4G用户超过2亿了!

    近期,看到工信部一组统计数据,小编整个人都不好了,数据显示,2015年5月我国4G用户净增2281.6万,总数超过2亿户. 没错,卡是换成了4G卡,还是那句话,然并卵,用的还是3G手机.开的还是2G网 ...

  2. Codeforces Round #306 (Div. 2) A

    题意 给一个字符串(长度<=10^5).问当中有没有一个"BA"和一个"AB"呢?假设都有而且它们不反复(即ABA不算),输出YES.否则输出NO. 思路 ...

  3. SpringMVC中的 --- 异常处理

    系统异常处理器SimpleMappingExceptionResolver 处理器方法执行过程中,可能会发生异常,不想看到错误黄页,想看到一个友好的错误提示页. 自定义异常处理器 使用异常处理注解

  4. luogu2152 [SDOI2009]SuperGCD

    要你求两个非常大的数字的GCD. 不要想复杂,用高精度整更相减损术即可. #include <cstdio> #include <cstring> #include <a ...

  5. oc48--多个对象内存管理练习

    // // main.m // 多个对象内存管理练习 // // ARC是Xcode帮我们生成内存释放的代码,MRC是需要我买自己写retain和release.想研究内存管理只能在MRC,管理对象就 ...

  6. APP-Android:APK

    ylbtech-APP-Android:APK APK是AndroidPackage的缩写,即Android安装包(apk).APK是类似Symbian Sis或Sisx的文件格式.通过将APK文件直 ...

  7. ThreadLocal,静态变量,实例变量,局部变量的线程安全

    之前都是业务层次开发,现在公司进行的网络编程,一下子要了解太多java底层的东西并进行应用,我现在边学习边应用.由于知识能力有限,在上次发博客时出现了一个小小的纰漏,而这个纰漏被细心的博友发现了. 首 ...

  8. ASP.NET MVC + 工厂模式 + 三层 + 缓存

    最近将手头的项目总结整理了一下,以方便自己的学习.... 下面直接上图先介绍项目的结构图: 项目是ASP.NET MVC 4.0的应用程序,DBUtility这个类库主要是DbHelper操作数据库的 ...

  9. HttpServletResponse对象,自己学习的心得

    Web服务器收到客户端的http请求,会针对每一次请求,分别创建一个用于代表请求的request对象,和代表响应response对象. request和response对象既然代表请求和响应,那我们要 ...

  10. vue中的config配置

    在webpack.base.conf文件中配置别名以及扩展名 resolve: { extensions: ['.js', '.vue', '.json', '.styl'], alias: { 'v ...