• C#如何在派生类中不显示父类的一些属性以及TypeDescriptor使用


    public SonClass:FatherClass

    {

    定义属性

    。。。。

    }

    Type thisType = typeof(SonClass);
    方法一:

    1. PropertyInfo[] pis = thisType.BaseType.GetProperties();//thisType.BaseType就是FatherClass
    2. foreach (PropertyInfo p in pps)
    3. {
    4. properties.Remove(p.Name);
    5. }

    方法二:

    1. PropertyInfo[] pis = thisType.GetProperties();
    2. foreach (PropertyInfo p in pps)
    3. {
    4. if (p.DeclaringType != thisType)
    5. properties.Remove(p.Name);
    6. }

    方法三:

    1. /// <summary>
    2. /// 支持展现属性的类型转换器
    3. /// </summary>
    4. /// <remarks></remarks>
    5. [System.Runtime.InteropServices.ComVisible(false)]
    6. [System.Reflection.Obfuscation(Exclude = true, ApplyToMembers = true)]
    7. public class TypeConverterSupportProperties : System.ComponentModel.TypeConverter
    8. {
    9. /// <summary>
    10. /// 支持获得属性
    11. /// </summary>
    12. /// <param name="context"></param>
    13. /// <returns></returns>
    14. public override bool GetPropertiesSupported(ITypeDescriptorContext context)
    15. {
    16. return true;
    17. }
    18. /// <summary>
    19. /// 获得属性
    20. /// </summary>
    21. /// <param name="context"></param>
    22. /// <param name="value"></param>
    23. /// <param name="attributes"></param>
    24. /// <returns></returns>
    25. public override PropertyDescriptorCollection GetProperties(ITypeDescriptorContext context, object value, Attribute[] attributes)
    26. {
    27. PropertyDescriptorCollection ps = TypeDescriptor.GetProperties(value, attributes);
    28. return ps;
    29. }
    30. public override bool CanConvertTo(ITypeDescriptorContext context, Type destinationType)
    31. {
    32. if (destinationType == typeof(string))
    33. {
    34. return false;
    35. }
    36. return base.CanConvertTo(context, destinationType);
    37. }
    38. }

    方法四:直接把下面的代码添加到需要的类里面即可(本代码演示了ClassAAA 继承了 Label, ICustomTypeDescriptor(接口),紫色的代码即为要添加的)

    1. using System;
    2. using System.Collections;
    3. using System.ComponentModel;
    4. using System.ComponentModel.Design;
    5. using System.Windows.Forms;
    6. using System.Reflection;
    7. namespace WindowsFormsApplication2
    8. {
    9. public class ClassAAA : Label, ICustomTypeDescriptor
    10. {
    11. private bool me = false;
    12. public bool IsMe
    13. {
    14. get
    15. {
    16. return me;
    17. }
    18. set
    19. {
    20. this.me = value;
    21. }
    22. }
    23. public int Code
    24. {
    25. get
    26. {
    27. return this.GetHashCode();
    28. }
    29. }
    30. #region ICustomTypeDescriptor 显式接口定义
    31. AttributeCollection ICustomTypeDescriptor.GetAttributes()
    32. {
    33. return TypeDescriptor.GetAttributes(this, true);
    34. }
    35. string ICustomTypeDescriptor.GetClassName()
    36. {
    37. return TypeDescriptor.GetClassName(this, true);
    38. }
    39. string ICustomTypeDescriptor.GetComponentName()
    40. {
    41. return TypeDescriptor.GetComponentName(this, true);
    42. }
    43. TypeConverter ICustomTypeDescriptor.GetConverter()
    44. {
    45. return TypeDescriptor.GetConverter(this, true);
    46. }
    47. EventDescriptor ICustomTypeDescriptor.GetDefaultEvent()
    48. {
    49. return TypeDescriptor.GetDefaultEvent(this, true);
    50. }
    51. PropertyDescriptor ICustomTypeDescriptor.GetDefaultProperty()
    52. {
    53. return null;
    54. }
    55. object ICustomTypeDescriptor.GetEditor(Type editorBaseType)
    56. {
    57. return TypeDescriptor.GetEditor(this, editorBaseType, true);
    58. }
    59. EventDescriptorCollection ICustomTypeDescriptor.GetEvents()
    60. {
    61. return TypeDescriptor.GetEvents(this, true);
    62. }
    63. EventDescriptorCollection ICustomTypeDescriptor.GetEvents(Attribute[] attributes)
    64. {
    65. return TypeDescriptor.GetEvents(this, attributes, true);
    66. }
    67. PropertyDescriptorCollection ICustomTypeDescriptor.GetProperties()
    68. {
    69. return ((ICustomTypeDescriptor)this).GetProperties(new Attribute[0]);
    70. }
    71. PropertyDescriptorCollection ICustomTypeDescriptor.GetProperties(Attribute[] attributes)
    72. {
    73. ArrayList props = new ArrayList();
    74. Type thisType = typeof(OneClass);
    75. PropertyInfo[] pis = thisType.GetProperties();
    76. foreach (PropertyInfo p in pis)
    77. {
    78. if (p.DeclaringType == thisType)
    79. {
    80. PropertyStub psd = new PropertyStub(p, attributes);
    81. props.Add(psd);
    82. }
    83. }
    84. PropertyDescriptor[] propArray =
    85. (PropertyDescriptor[])props.ToArray(typeof(PropertyDescriptor));
    86. return new PropertyDescriptorCollection(propArray);
    87. }
    88. object ICustomTypeDescriptor.GetPropertyOwner(PropertyDescriptor pd)
    89. {
    90. return this;
    91. }
    92. #endregion
    93. #region PropertyStub 定义
    94. private class PropertyStub : PropertyDescriptor
    95. {
    96. PropertyInfo info;
    97. public PropertyStub(PropertyInfo propertyInfo, Attribute[] attrs) :
    98. base(propertyInfo.Name, attrs)
    99. {
    100. this.info = propertyInfo;
    101. }
    102. public override Type ComponentType
    103. {
    104. get { return this.info.ReflectedType; }
    105. }
    106. public override bool IsReadOnly
    107. {
    108. get { return this.info.CanWrite == false; }
    109. }
    110. public override Type PropertyType
    111. {
    112. get { return this.info.PropertyType; }
    113. }
    114. public override bool CanResetValue(object component)
    115. {
    116. return false;
    117. }
    118. public override object GetValue(object component)
    119. {
    120. Console.WriteLine("GetValue: " + component.GetHashCode());
    121. return this.info.GetValue(component, null);
    122. }
    123. public override void ResetValue(object component)
    124. {
    125. }
    126. public override void SetValue(object component, object value)
    127. {
    128. Console.WriteLine("SetValue: " + component.GetHashCode());
    129. this.info.SetValue(component, value, null);
    130. }
    131. public override bool ShouldSerializeValue(object component)
    132. {
    133. return false;
    134. }
    135. }
    136. #endregion
    137. }
    138. }

    TypeDescriptor 类

    提供有关组件属性 (Attribute) 的信息,如组件的属性 (Attribute)、属性 (Property) 和事件。无法继承此类。

    命名空间:System.ComponentModel
    程序集:System(在 system.dll 中)

    语法
     
     C#
    public sealed class TypeDescriptor
    
     
    备注
     
     .NET Framework 提供了两种访问某类型的元数据的方式:通过 System.Reflection 命名空间中提供的反射 API,以及通过 TypeDescriptor类。反射是可用于所有类型的通用机制,因为它是基于根 Object 类的 GetType 方法建立的。反射为某个类型返回的信息不可扩展,因为编译了目标类型后就不能对其进行修改。有关更多信息,请参见 反射 中的主题。

    相反,TypeDescriptor 是组件的可扩展检查机制:即实现 IComponent 接口的那些类。与反射不同的是,它并不检查方法。通过目标组件的Site 中提供的几种服务,可以动态扩展 TypeDescriptor。下表显示这些服务。

     

    服务名

    说明

    IExtenderProvider

    启用其他类(如 ToolTip),以便为组件提供额外的属性 (Property)。

    ITypeDescriptorFilterService

    启用其他对象,以便修改由组件公开的标准元数据。

    ICustomTypeDescriptor

    启用一个类,以便完全且动态地指定其自身的元数据,进而替换 TypeDescriptor 的标准检查机制。

    TypeDescriptor 提供的扩展性允许组件的设计时表示形式不同于其实际的运行时表示形式,从而使 TypeDescriptor 对于生成设计时基础结构十分有用。

    TypeDescriptor 中的所有方法都是 static 的。不能创建此类的实例,也不能继承此类。

    可以通过两种不同的方式设置属性 (Property) 和事件值:在组件类中指定它们,或在设计时对它们进行更改。由于可以通过两种方式设置这些值,因此,TypeDescriptor 的重载方法采用两种不同类型的参数:类类型或对象实例。

    当要访问 TypeDescriptor 信息并且您具有对象的实例时,应使用调用组件的方法。只有当您不具有对象的实例时,才能使用调用类类型的方法。

    为了提高速度,将由 TypeDescriptor 缓存属性和事件。通常,它们在对象的生存期内保持不变。但是,扩展程序提供程序和设计器可以更改对象的属性集。如果是这种情况,则必须调用 Refresh 方法来更新缓存。

  • 相关阅读:
    python中使用scikit-learn和pandas决策树进行iris鸢尾花数据分类建模和交叉验证
    CNN+ Auto-Encoder 实现无监督Sentence Embedding ( 基于Tensorflow)
    R语言数据可视化分析案例:探索BRFSS数据
    1.微信小程序里如何设置当地时间?
    63.1拓展之纯 CSS 创作一个摇摇晃晃的 loader
    63.(原65)纯 CSS 创作一个摇摇晃晃的 loader
    6.HTML+CSS制作一双眼睛
    62.纯 CSS 创作一只蒸锅(感觉不好看呀)
    61.纯 CSS 创作一只咖啡壶(这个不好看)
    60.纯 CSS 创作一块乐高积木
  • 原文地址:https://www.cnblogs.com/1175429393wljblog/p/5559246.html
Copyright © 2020-2023  润新知