动态加载资源文件(ResourceDictionary)

在xaml中控件通过绑定静态资源StaticResource来获取样式Style有多种方式:

       1.在项目的启动文件App中<Application.Resources>里添加相应的样式内容,当然也可以在控件所在的控件的资源(如:<UserControl.Resources>)中添加相应样式内容       

2.通过后台代码向当前程序的资源中动态添加,代码如下:(TextBlockStyle.xaml是一个ResourceDictionary,包含了所需样式),这段代码只要在引用样式的那个控件加载之前运行就可以。

 

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
好的,针对你的问题,我来简单介绍一下Style样式的四种使用方法,以及用C#代码动态资源文件并设置样式的方法。 1. 在XAML中定义Style 在XAML中,我们可以使用Style标签来定义样式,然后在控件中引用该样式即可。 ```xml <Window.Resources> <Style x:Key="myButtonStyle" TargetType="Button"> <Setter Property="Background" Value="Red"/> <Setter Property="Foreground" Value="White"/> <Setter Property="FontSize" Value="12"/> </Style> </Window.Resources> <Button Content="Click Me" Style="{StaticResource myButtonStyle}"/> ``` 2. 直接在控件中定义Style 除了在XAML中定义Style外,我们还可以在控件中直接定义Style。 ```xml <Button Content="Click Me"> <Button.Style> <Style TargetType="Button"> <Setter Property="Background" Value="Red"/> <Setter Property="Foreground" Value="White"/> <Setter Property="FontSize" Value="12"/> </Style> </Button.Style> </Button> ``` 3. 在资源字典中定义Style 我们还可以将Style定义在资源字典中,以便在整个应用程序中重复使用。 ```xml <Application.Resources> <ResourceDictionary> <Style x:Key="myButtonStyle" TargetType="Button"> <Setter Property="Background" Value="Red"/> <Setter Property="Foreground" Value="White"/> <Setter Property="FontSize" Value="12"/> </Style> </ResourceDictionary> </Application.Resources> <Button Content="Click Me" Style="{StaticResource myButtonStyle}"/> ``` 4. 动态Style 最后,我们可以使用C#代码动态资源文件并设置样式。 ```csharp var resourceUri = new Uri("/MyAssembly;component/Styles.xaml", UriKind.Relative); var resource = Application.LoadComponent(resourceUri) as ResourceDictionary; var style = resource["myButtonStyle"] as Style; myButton.Style = style; ``` 以上就是关于Style样式的四种使用方法,以及用C#代码动态资源文件并设置样式的介绍。希望能够对你有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值