【WPF】桌面程序开发之xaml页面主题和样式详解

news2025/1/10 3:29:24

使用Visual Studio开发工具,我们可以编写在Windows系统上运行的桌面应用程序。其中,WPF(Windows Presentation Foundation)项目是一种常见的选择。然而,对于初学者来说,WPF项目中xaml页面的布局设计可能是一个难点。下面将简要介绍WPF项目中xaml页面的主题和控件样式知识。

文章目录

  • 页面布局
  • 主题或样式
    • 主题样式
    • 样式
      • 内联样式
      • 外联样式
  • 运行效果
  • 查看工具

如果还不知道怎么创建WPF项目, 可先看以下文章,回顾一下再来

  • Windows系统桌面应用程序编程开发新手入门-打造自己的小工具
  • 桌面程序开发之xaml页面基础布局方式详解

学过web前端页面设计的同学应该很熟悉,在(网页)页面设计中有使用的样式

页面布局

带后缀名xaml的是页面的布局文件,打开内容大致如下

<Window x:Class="WpfApp4.MainWindow"
        ...
        Title="MainWindow" Height="450" Width="800">
    <Window.Resources>
    	<!-- 这里设置统一控件的样式 -->
    </Window.Resources>    
    <Grid>
        <!-- 这里开始添加控件布局 -->
    </Grid>
</Window>

注意看这个Window.Resources标签对,这里面是设置主题或添加样式资源的地方

主题或样式

在页面中设置加载主题或样式需要区分,区别如下

  • 注意看根标签Window,这是窗口里的,应在Window.Resources标签中 设置主题样式资源;
  • 如果根标签是Page,这是页面里的, 应在Page.Resources标签中 设置主题样式资源;
  • 如果根标签是UserControl,这是用户控件里的 ,应在UserControl.Resources标签中 设置主题样式资源

例如,在用户控件中加载主题或样式资源就在UserControl.Resources这里设置

<UserControl
	...
	Title="MainWindow" Height="450" Width="800">
	<UserControl.Resources>
        <ResourceDictionary>
            <!-- 这里设置统一控件的样式 -->
        </ResourceDictionary>
    </UserControl.Resources>
    <Grid>
        <!-- 这里开始布局添加页面控件 -->
    </Grid>
</UserControl>

主题样式

要加载一个主题,需要创建一个基本的样式(主题)文件,

项目根目录下/Styles/Base.xaml

创建一个样式文件Base.xaml,如下图
在这里插入图片描述

这是一个是资源词典文件,文件内容中它的根标签是ResourceDictionary

打开此文件继续写,添加一个主题中的默认按钮样式,内容如下

<ResourceDictionary xmlns="...">
    <Style x:Key="Button.Default" TargetType="Button">
	    <Setter Property="Padding" Value="5" />
	    <Setter Property="Margin" Value="5" />
	    <Setter Property="Width" Value="55" />
	    <Setter Property="Background" Value="#01A2E8" />
	    <Setter Property="Foreground" Value="White" />
	    <Setter Property="BorderBrush" Value="#01A2E8" />
	</Style>
</ResourceDictionary>

一个样式需要确定好控件类型,通过其属性TargetType指定控件名

如果要在此按钮默认样式上做一些改变,添加一个新按钮样式,内容如下

<ResourceDictionary xmlns="...">
    <Style x:Key="Button.Default" TargetType="Button">
	    <Setter ... />
	</Style>
	<Style x:Key="Button.Warn" TargetType="Button" BasedOn="{StaticResource Button.Default}">
	    <Setter Property="Background" Value="#f42424" />
	    <Setter Property="Foreground" Value="White" />
	    <Setter Property="BorderBrush" Value="#f42424" />
	</Style>
</ResourceDictionary>

使用x:Key给一个样式起名为Button.Default
然后通过另一个样式中属性BasedOn来继承它,使用基础的样式,
以此类推,你还可以添加一些其它不同控件的样式

接下来,我们将在页面布局中的所有控件使用此样式文件的基础样式(主题)

样式

学过web前端页面设计的同学应该很熟悉,页面设计中的样式有内联和外联样式

内联样式

如果每个控件的样式是不相同的,就在各自的控件中去修改它自己支持的样式属性值,

是和内联样式一样的,修改按钮控件属性后,内容如下

<Window 
	...
	Title="MainWindow" Height="450" Width="800">
	<Window.Resources>
    	<!-- 这里设置统一控件的样式 -->
    </Window.Resources>   
    <Grid>
        <!-- 这里开始布局添加页面控件 -->
        <Button Padding="5" Margin="5" Width="55" Click="Button_Click" Tag="save">保存</Button>
    </Grid>
</Window>

由此看出,页面中的按钮控件通过属性(内联样式)直接改变了按钮的基础样式

外联样式

如果有两个以上的控件需要使用相同的样式,就需要单独写一个外联样式来使用,

这样处理是高效的,修改后内容如下

<Window 
	...
	Title="MainWindow" Height="450" Width="800">
	<Window.Resources>
        <ResourceDictionary>
            <!-- 外联样式 -->
            <Style TargetType="Button" x:Key="Button.Default">
                <Setter Property="Padding" Value="5" />
                <Setter Property="Margin" Value="5" />
                <Setter Property="Width" Value="55" />
            </Style>
        </ResourceDictionary>
    </Window.Resources>
    <Grid>
        <!-- 这里开始布局添加页面控件 -->
        <Button Style="{StaticResource Button.Default}" Click="Button_Click" Tag="save">保存</Button>
    </Grid>
</Window>

这里可以看到,按钮控件通过属性Style使用了上面的外联样式;

外联样式还可以这样使用,加载外部的样式资源文件,

这样方便后面的维护,样式文件可复用,十分高效,

修改后内容如下

<Window 
	...
	Title="MainWindow" Height="450" Width="800">
	<Window.Resources>
        <ResourceDictionary>
            <ResourceDictionary.MergedDictionaries>
            	<!-- 样式资源加载 -->
            	<ResourceDictionary Source="Styles/Button.xaml" />
            </ResourceDictionary.MergedDictionaries>
           	<!-- 这里设置其它的样式 -->
        </ResourceDictionary>
    </Window.Resources>
    <Grid>
        <!-- 这里开始布局添加页面控件 -->
        <Button Style="{StaticResource Button.Default}" Click="Button_Click" Tag="save">保存</Button>
    </Grid>
</Window>

其中标签ResourceDictionary.MergedDictionaries是合并样式的,应放在其它样式设置前面,在这标签里是可以加载多个样式资源文件

运行效果

最后,修改好保存,开发工具的设计模式窗口下会实时更新页面显示效果,也可以运行查看效果
在这里插入图片描述

查看工具

当项目运行时,窗口上通过会带上悬浮的查看工具,可拖动放置在不同位置
在这里插入图片描述

学过web前端页面设计的同学应该知道,这个和浏览器的开发者调试工具里面功能一样的

点击其中一件字图标按钮,再选择页面的其中一个控件,可以查看到该控件布局情况,如下图
在这里插入图片描述

这里就不作多介绍工具上每个按钮功能,请自行研究。

我先溜了

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2116159.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Bat的退役前

我们很讨厌bat 语法这版的命令形式后缀尽管古老&#xff0c;可是在涉及细微VS 项目op 时候&#xff0c;它起到了不可忽视且非它不行的效应 我们不想替历史背上厚重的学习包袱&#xff0c;可是我们能忽视BAT 吗 如若进入到 无window时代&#xff0c;我们几乎得全然依仗BAT专家。…

35天学习小结

距离上次纪念日&#xff0c;已经过去了35天咯 算算也有5周了&#xff0c;在这一个月里&#xff0c;收获的也挺多&#xff0c;在这个过程中认识的大佬也是越来越多了hh 学到的东西&#xff0c;其实也没有很多&#xff0c;这个暑假多多少少还是有遗憾的~ 第一周 学习了一些有…

【计算机组成原理】详细解读带符号整数的原码表示法

带符号整数的表示——原码 导读一、有符号整数的存储结构二、有符号整数的表现形式三、原码3.1 原码与真值之间的转换3.2 原码的运算3.3 原码的优缺点 结语 导读 大家好&#xff0c;很高兴又和大家见面啦&#xff01;&#xff01;&#xff01; 在上一篇内容中我们介绍了无符号…

828华为云征文|基于华为云Flexus云服务器X搭建jumpserver堡垒机软件

文章目录 ❀前言❀jumpserver堡垒机概述❀环境准备❀部署说明❀在线安装❀浏览器访问❀资产添加❀资产授权❀资产登录❀总结 ❀前言 近期华为云推出了最新的华为云Flexus云服务器X&#xff0c;这款云主机在算柔性算力做出了重大变革。华为云Flexus云服务器X基于擎天QingTian架…

Xilinx FPGA 原语解析(二):IBUFDS差分输入缓冲器(示例源码及仿真)

目录 前言&#xff1a; 一、原语使用说明 二、原语实例化代码模版 三、使用示例 1.设计文件代码 2.仿真文件代码 3.仿真结果 前言&#xff1a; 本文主要参考资料xilinx手册&#xff0c;《Xilinx 7 Series FPGA and Zynq-7000 All Programmable SoC Libraries Guide for…

LeetCode 热题 100 回顾1

干货分享&#xff0c;感谢您的阅读&#xff01;原文见&#xff1a;LeetCode 热题 100 回顾_力code热题100-CSDN博客 一、哈希部分 1.两数之和 &#xff08;简单&#xff09; 题目描述 给定一个整数数组 nums 和一个整数目标值 target&#xff0c;请你在该数组中找出 和为目标…

【Python 千题 —— 算法篇】词频统计

Python 千题持续更新中 …… 脑图地址 👉:⭐https://twilight-fanyi.gitee.io/mind-map/Python千题.html⭐ 题目背景 在日常开发和文本处理工作中,单词计数是一个非常基础但又极为重要的操作。无论是统计一篇文章的词频,还是分析一段文本的关键词,单词计数都起着关键作用…

Spring Boot 集成 MinIO 与 KKFile 实现文件预览功能

文件预览功能是提升用户体验的重要部分,尤其是在文档管理系统中。本文将带你逐步实现如何在 Spring Boot 项目中集成 MinIO(一个对象存储系统)与 KKFileView(一个开源文件预览工具),以实现对各种类型文件的在线预览 项目准备 Java 11+ Spring Boot MinIO 服务器 KKFileV…

C语言 ——— 带副作用的宏参数

目录 带有副作用的代码 带有副作用的宏参数 结论 带有副作用的代码 代码演示&#xff1a; int a 10;int b a; 副作用解析&#xff1a; 变量 a 在赋值给 b 之前 a 的值自增了1&#xff0c;那么 int b a; 这条代码就带有副作用 带有副作用的宏参数 代码演示&#xff1a…

学会收纳,对“衣服山”说再见,我推荐你读这4本书

面对日积月累形成的“衣服山”&#xff0c;我们还是会经常苦恼“没有衣服穿”&#xff0c;主要原因是我们出门前&#xff0c;很难用手边的衣服对相应的场合进行搭配。 我们的衣柜存在这样一个怪圈&#xff1a;衣柜里的衣服不断增加&#xff0c;尽管数量多&#xff0c;但是“能…

CSS —— display属性

用于指定一个元素在页面中的显示方式 HTML中标签元素大体被分为三种类型&#xff1a;块元素、行内元素和行内块元素 块元素 &#xff1a;block 1.独占一行 2.水平方向&#xff0c;占满它父元素的可用空间&#xff08;宽度是父级的100%&#xff09; 3.垂直方向&#xff0c;占据的…

如何使用QT完成记事本程序的UI界面布局

每日QT技巧查询表-CSDN博客 会持续更新记事本编写的全部过程&#xff0c;关注不迷路 一、相关控件 ①水平和垂直布局 ②按键 ③文本框 ④水平弹簧 ⑤标签 ⑥Widget 二、控件使用方法 1、PushButton 拖出三个按键&#xff0c;并对其进行命名&#xff0c;两处地方命名可以不一…

亚马逊IP关联及其解决方案

在电子商务领域&#xff0c;亚马逊作为全球领先的在线购物平台&#xff0c;吸引了众多商家和个人的参与。然而&#xff0c;随着业务规模的扩大&#xff0c;商家在使用亚马逊服务时可能会遇到IP关联的问题&#xff0c;这不仅影响账户的正常运营&#xff0c;还可能带来一系列不利…

频谱图在频率为0附近有较大幅度,这是为什么

如下图所示&#xff0c;很明显看出&#xff0c;相比于其他频率段&#xff0c;在频率为0Hz左右&#xff0c;其幅值幅度较大。这是为什么呢&#xff1f; 在频谱图中&#xff0c;频率为0 Hz附近的幅值较大&#xff0c;通常意味着信号中存在较强的低频成分或直流分量&#xff08;D…

春日美食:基于SpringBoot的在线订餐系统

1 绪论 1.1 研究背景 随着互联网技术的快速发展&#xff0c;网络时代的到来&#xff0c;网络信息也将会改变当今社会。各行各业在日常企业经营管理等方面也在慢慢的向规范化和网络化趋势汇合[13]。电子商务必将成为未来商务的主流&#xff0c;因此对于餐饮行业来说&#xff0c;…

【动手学深度学习】05 线性代数(个人向笔记)

1. 线性代数 向量的一些公式 ∣ ∣ a ∣ ∣ ||a|| ∣∣a∣∣ 表示向量 a 的范数&#xff0c;课上没有讲范数的概念 其中第一条为求向量的二范数 第四条表示如果a为标量&#xff0c;那么向量 ∣ ∣ a ⋅ b ∣ ∣ ||ab|| ∣∣a⋅b∣∣ 的长度等于 ∣ a ∣ ⋅ ∣ ∣ b ∣ ∣…

T2打卡——彩色图片分类

&#x1f368; 本文为&#x1f517;365天深度学习训练营中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 1.导入数据&#xff1a; #设置gpu import tensorflow as tf gpustf.config.list_physical_devices(GPU) if gpus:#如果有多个gpu仅使用第一个gpu0gpus[0]#设置…

基于图谱的记忆存储 - mem0 graph memory + neo4j

log 日志版 【LLM最强大脑】基于图谱的记忆存储 - mem0 graph memory neo4j_哔哩哔哩_bilibili 获取API Key 谷歌邮箱注册&#xff0c;需科学上网&#xff0c;你知道的┗|&#xff40;O′|┛ 嗷~~ 获取 mem0ai key Dashboard | Mem0.ai 获取 neo4j key Neo4j Graph Databa…

Linux:软硬连接和动静态库

一般ll一下&#xff0c;最左边一列就是文件类型&#xff1a; 怎么创建链接文件&#xff1a; ln -s 目标文件 创建的链接文件名 来试试&#xff1a;这叫软连接&#xff0c;软连接相当于Windows下的快捷方式&#xff0c;直接指向原文件的绝对路径&#xff1b;删除软连接不影响原…

通义千问大模型Java调用,百炼

文章目录 一、大模型服务平台[百炼](https://help.aliyun.com/zh/model-studio/getting-started)二、Java sdk调用与eventStream三、百炼平台其它 一、大模型服务平台百炼 百炼是阿里新出的一个大模型服务平台&#xff0c;聚合了多个千问大模型及其它一些大模型的调用&#xf…