为控件动态添加Style

简介: 原文:为控件动态添加Style此文可解决:  重写控件时,给控件加入子控件或父控件的样式切换问题。 很灵活的可以根据不同内容显示不同样式   子控件作用在: ...
原文: 为控件动态添加Style

此文可解决:  重写控件时,给控件加入子控件或父控件的样式切换问题。 很灵活的可以根据不同内容显示不同样式

 

子控件作用在:

 <DataTemplate x:Key="ColmunHeader1">
                <DockPanel Background="Transparent">
                    <!-- The control to host the filter UI for this column -->
                    <controls:dgDataGrid DockPanel.Dock="Right" />
                    <ContentPresenter x:Name="PART_Content" Content="{Binding}"
                        SnapsToDevicePixels="{Binding SnapsToDevicePixels, RelativeSource={RelativeSource Mode=FindAncestor, AncestorType=DataGridColumnHeader}}"
                        HorizontalAlignment="{Binding HorizontalContentAlignment, RelativeSource={RelativeSource Mode=FindAncestor, AncestorType=DataGridColumnHeader}}"
                        VerticalAlignment="{Binding VerticalContentAlignment, RelativeSource={RelativeSource Mode=FindAncestor, AncestorType=DataGridColumnHeader}}" />
                </DockPanel>
            </DataTemplate>

 

如下样式:

<ControlTemplate x:Key="DataGridCheckBoxColumn1">
                <Grid>
                    <CheckBox 
                />
                </Grid>
</ControlTemplate>

<ControlTemplate x:Key="DataGridTextBoxColumn1">
                <Grid>
                    <TextBox/> 
        </Grid>
</ControlTemplate>
 

然后在子控件类的loaded事件中加入:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Controls.Primitives;
using System.Windows.Media;

namespace WpfApp1.Controls
{
    public class dgDataGrid : Control
    {
        public DataGridColumnHeader ColumnHeader { get; set; }

        public dgDataGrid()
        {
            this.Loaded += (s, e) =>
              {
                  ColumnHeader = this.FindAncestorOrSelf<DataGridColumnHeader>();
                  var value = ColumnHeader.Column.GetType();
                  if (value == typeof(DataGridTextColumn))
                  {
                      this.Template = this.FindResource("DataGridTextColumn1") as ControlTemplate;
                  }
                  else
                  {
                      this.Template = this.FindResource("DataGridCheckBoxColumn1") as ControlTemplate;
                  }
              };
        }
    }
}

  

 

目录
相关文章
|
JavaScript 前端开发 开发者
在组件中使用 style 行内样式并封装样式对象|学习笔记
快速学习在组件中使用 style 行内样式并封装样式对象
204 0
在组件中使用 style 行内样式并封装样式对象|学习笔记
17EasyUI 布局- 动态添加标签页(Tabs)
17EasyUI 布局- 动态添加标签页(Tabs)
65 0
element-ui框架的el-dialog弹出框被遮罩层挡住了/el-drawer....会生成v-model元素的组件被遮罩层挡住
element-ui框架的el-dialog弹出框被遮罩层挡住了/el-drawer....会生成v-model元素的组件被遮罩层挡住
539 1
C# checkBox控件CheckedChanged与CheckedStateChanged区别
CheckedChanged:          当Checked属性的值更改时就引发该事件。注意在复选框中,当ThreeState属性为true时,单击复选框可能不会改变Checked属性。在复选框从Checked变为Indeterminate状态时,就会出现这种情况。 小注:          ThreeState属性:用来返回或设置复选框是否能表示三种状态,如果属性值为true
1474 0
Element UI - el-scrollbar 如何隐藏横向滚动条?
Element UI - el-scrollbar 如何隐藏横向滚动条?
672 0
|
前端开发
css3新属性position: sticky 一分钟实现 导航栏悬停功能
想必很多前端小伙伴经常会在开发中遇到这样一个需求,就是在下划时,导航栏悬停在屏幕最上方,例如csdn网站: 那么你们都是使用什么方法实现的呢?今天我们就用css3的一个新的属性position: sticky 来实现这个功能吧,坚持看下去,就只需一分钟就能搞定。
444 0
css3新属性position: sticky 一分钟实现 导航栏悬停功能
|
前端开发 数据安全/隐私保护 JavaScript
利用 hover 伪类创建纯 CSS 收缩面板
SVN 源码/例子:http://naturaljs.googlecode.com/svn/trunk/demo/widgets/hoverTab.htm 这是一个非常简单的例子,主要利用了元素 hover 高亮效果的特性创建收缩面板。
1028 0
|
前端开发 JavaScript
css重写checkbox样式
一、前言 默认的checkbox长这样: 空闲 服务中 有点丑,我想把它变成这样: 二、实现 1、checkbox 难看的框框隐...
1304 0

热门文章

最新文章