zoukankan      html  css  js  c++  java
  • WPF样式学习第一天

    因为上班的公司要我用wpf写软件,刚毕业出来,学校也没教过wpf,只会winform,再加上wpf用winform的框架写法也能实现很多需求,但是就不能体现wpf的优点了,今天就先来学wpf的样式,因为对美的认识不足,所以排版不好,对代码有意见或建议的,希望多多提出,我是初学者。

    今天就先弄个Button的简单样式吧

    ButtonStyle是源名称。

    Property="Control.FontFamily" 是用来声明字体的,后边跟着的Value的值是字体类型(下同)

    Property="Control.FontSize"  设置字体大小

    Property="Control.FontWeight" 字体样式,例如Value="Black"是设置成黑体字体的意思,

    这样设置好后,拉一个button控件到窗体,然后加上Style="{StaticResource ButtonStyle}"就可以了,多个button绑定同一个数据源所有绑定的button的样式都是相同的

    改数据源就可以达到修改所有button的目的,要修改某一个button,就只需要在那个button上添加样式即可,例如FontSize="15",就会覆盖数据源的字体大小。

    不过这个写法,有一个缺的,就是,所有包含FontFamily,FontSize,FontWeight 样式的控件都会有效果,如果只改button的效果,就需要指定对象

    把 <Style x:Key="ButtonStyle">写成<Style x:Key="ButtonStyle" TargetType="Button">

    这样只有button控件可以绑定这个数据源了其他控件绑定会报错的

    <Style TargetType="Button"
    BasedOn="{StaticResource ButtonStyle}">
    <Setter Property="Control.Foreground" Value="Green"/>
    </Style>

    加上这一段后,就是所有button都自行绑定的了在控件里就不写 Style="{StaticResource ButtonStyle}"这个绑定了,拖出来的button控件都自行绑定到设置好的样式

    还有一个更简单的绑定使用同类型控件样式的方法,就下边这个

    <Style TargetType="Button" >
    <Setter Property="Control.Foreground" Value="Green"/>
    </Style>

    就是把上面的key:,去掉后,想这样写,所有来出来或XAML手动写的Button都会自动添加样式

    今天就这样,一天学一点,哈哈哈

  • 相关阅读:
    ElasticSearch2.3.1环境搭建哪些不为人知的坑
    don't run elasticsearch as root.
    翻译 Asp.Net Core 2.2.0-preview1已经发布
    微信小程序与AspNetCore SignalR聊天实例
    .Net Core扩展 SharpPlugs简单上手
    Docker折腾手记-linux下安装
    C#3.0 扩展方法
    微软微服务eShopOnContainers示例之EventBusRabbitMq解析与实践
    C#3.0智能的编译器
    C#3.0导航
  • 原文地址:https://www.cnblogs.com/chenxiaojie/p/13064090.html
Copyright © 2011-2022 走看看