zoukankan      html  css  js  c++  java
  • 组件用户控件引用样式资源(二)---代码引用

    关于样式文件引用方式存在以下弊端(摘自官方)

    When you reference a ResourceDictionary in XAML, a ResourceDictionary object is created each time you reference it.  So if you have 10 custom controls in your library and merge the shared ResourceDictionaries for each control by using XAML, you create 10 identical ResourceDictionary objects.  You can avoid this by creating a static class that returns the ResourceDictionary and merging the resources in code. 

    因此,我们可以通过下面方式规避这个问题

    1. 在基础资源类库中创建资源文件夹Resources,在Resources中创建字典资源样式styles.xaml

        <LinearGradientBrush x:Key="NormalBrush" StartPoint="0,0" EndPoint="0,1">
            <GradientBrush.GradientStops>
                <GradientStopCollection>
                    <GradientStop Color="#Red" Offset="0.0"/>
                    <GradientStop Color="#Blue" Offset="1.0"/>
                </GradientStopCollection>
            </GradientBrush.GradientStops>
        </LinearGradientBrush>

    2. 在Resources中创建类

     public static class SharedDictionaryStyleManager
        {
            static ResourceDictionary _SharedStyleDictionary;
            public static ResourceDictionary SharedStyleDictionary
            {
                get
                {
                    if (_SharedStyleDictionary == null)
                    {
                        System.Uri resourceLocater = new System.Uri("/MyGlobal.Infrustructure;component/Resources/Styles.xaml", System.UriKind.Relative);
                        _SharedStyleDictionary = (ResourceDictionary)Application.LoadComponent(resourceLocater);
                    }
                    return _SharedStyleDictionary;
                }
            }
        }

    3.创建用户控件UPJAppMenuView.xaml,在构造函数前访问加载样式

      public UPJAppMenuView()
            {
                //*************************************引用全局单例样式代码******************************
                this.Resources.MergedDictionaries.Add(SharedDictionaryStyleManager.SharedStyleDictionary);
                InitializeComponent();
            }

    4. 用户控件xaml就可引用了

    <Border Width="auto" Height="auto" BorderBrush="Blue" BorderThickness="10" CornerRadius="10" >
                <Rectangle Stroke="Black" StrokeThickness="2" Fill="{StaticResource NormalBrush}"></Rectangle>       
                
            </Border>

  • 相关阅读:
    Oracle记录-Linux JDK与Oracle profile环境配置
    MySQL记录-Lost Connect MySQL Server during query解决方案
    Hive记录-配置远程连接(JAVA/beeline)
    CM记录-Hadoop 分布式文件系统HDFS(登录、配置、监控)
    currentStyle
    封装用className选元素
    event
    jQuery全局函数
    ajax请求
    [Swift-2019力扣杯春季决赛]1. 有序数组中的缺失元素
  • 原文地址:https://www.cnblogs.com/jeffry/p/5694565.html
Copyright © 2011-2022 走看看