当前位置: 首页 > news >正文

C# WPF编程-XAML

C# WPF编程-XAML

  • XAML简述
  • XAML子集
  • XAML编译
  • XAML基础
  • XAML名称空间
  • XAML中的属性和事件
    • 属性
    • 事件
    • 使用其他名称空间中的类型
  • 加载和编译XAML

XAML简述

XAML(Extensible Application Markup Language的简写,发音"zammel")是用于实例化.NET对象的标记语言。XAML可引用于诸多领域的技术,但主要作用是构造WPF用户界面。WPF通过XAML设计用户界面。但XAML对于WPF不是必需的,通过代码来构造WPF窗口也是可以的。

XAML子集

  • WPF XAML 包含描述WPF内容的元素,如矢量图形,控件及文档。
  • XPS XAML是WPF XAML的一部分,它为格式化的电子文档定义了一种XML表示方式。
  • Silverlight XAML是一个用于Microsoft Silverlight应用程序的WPF XAML子集。Silverlight是一个跨平台的浏览器插件,通过它可创建具有二维图形、动画、音视频的富Web内容。
  • WF XAML包括描述WF(Work Flow,工作流)内容的元素。

XAML编译

XML的设计目标是具有逻辑性、易读且简单,但没有被压缩。WPF使用BAML(Binary Application Markup Language,二进制应用程序标记语言)来克服这个缺点。BAML实际就是XAML的二进制表示。Visual Studio编译WPF应用程序时,所有XAML文件都被转换为BAML,这些BAML然后作为资源被嵌入到最终的DLL或EXE程序集中。编译器会在后台执行这项工作。但也可以使用未经编译的XAML,这对于需要即时提供一些用于界面的情况可能是有意义的。

XAML基础

XAML标准是非常简单的:

  • XAML文档中的每个元素都映射为.NET类的一个实例。元素的名称也完全对应于类名。
  • 与所有XML文档一样,可以在一个元素中嵌套另一元素。
  • 可通过特性(attribute)设置每个类的属性(property)。

XAML文档基本框架,一个空白窗口:

<Window x:Class="WpfHelloWorld.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:d="http://schemas.microsoft.com/expression/blend/2008"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"Title="MainWindow" Height="450" Width="800"><Grid></Grid>
</Window>

尽管可以使用任何顶级元素,但是WPF应用程序只使用以下元素作为顶级元素:

  • Window元素
  • Page元素(该元素和Window元素类似,但它用于可导航的应用程序)
  • Application元素(该元素定义应用程序资源和启动设置)

XAML名称空间

只提供类名是不够的。XAML解析器还需要知道类位于哪个.NET名称空间。XAML解析器会检查应用于元素的XML名称空间。

示例文档定义的名称空间:

 xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:d="http://schemas.microsoft.com/expression/blend/2008"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"

xmlns特性是XML中的一个特殊特性,它专门用来声明名称空间。在创建的所有WPF XAML文档中都会使用到这两个名称空间:

  • xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"是WPF核心名称空间。包含了所有WPF类,包括用来构建用户界面的控件。
  • xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"是XAML名称空间。它包含各种XAML使用特性,这些特性可影响文档的解释方式。该名称空间被映射为前缀x。通过在元素名称之前放置名称空间前缀x来使用该名称空间(如:<x:ElementName>)。

WPF包含了十几种名称空间(都以System.Windows开头),如System.Windows.Window类和System.Windows.Controls.Grid类。

  • 代码隐藏类
    可通过XAML构造用户界面,但为了使应用程序具有一定的功能,就需要用于连接包含应用程序代码的事件处理程序的方法。XAML通过使用如下所示的Class特性简化这个问题:
    < Window x:Class=“WpfHelloWorld.MainWindow”
    在XAML名称空间的Class特性之前放置名称空间前缀x意味着这是XAML语言中更通用的部分。实际上,Class特性高速XAML解析器用指定的名称生成一个新类。

Visual Studio会自动创建可放置事件处理代码的部分类。Visual Studio将首先提供基本的类框架:

namespace WpfHelloWorld
{/// <summary>/// MainWindow.xaml 的交互逻辑/// </summary>public partial class MainWindow : Window{public MainWindow(){InitializeComponent();}}
}
  1. InitializeComponent()方法:当创建一个Window实例类是,该构造函数调用InitializeComponent()方法。
  2. 命名元素:< Grid x:Name=“grid1”>< /Grid>
    Name特性会告诉XAML解析器将这一字段添加到为MainWindow类自动生成的部分:
    private System.Windows.Controls.Grid grid1;
    代码中使用grid1控件
    grid1.ActualWidth:获取grid1控件的实际宽度;
    grid1.ActualHeight:获取grid1控件的实际高度;

XAML中的属性和事件

属性

Grid控件(在WPF中最常见的布局工具),示例XAML文档结构:

  • 简单属性
<Window x:Class="WpfHelloWorld.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:d="http://schemas.microsoft.com/expression/blend/2008"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"xmlns:local="clr-namespace:WpfHelloWorld"mc:Ignorable="d"Title="MainWindow" Height="450" Width="800"><Grid Name="grid1"><Grid.Background><LinearGradientBrush></LinearGradientBrush></Grid.Background><Grid.ColumnDefinitions></Grid.ColumnDefinitions><TextBox Name="textQ" VerticalAlignment="Stretch" HorizontalAlignment="Stretch"FontFamily="Verdana" FontSize="24" Foreground="Green" Background="AliceBlue">Hello World</TextBox></Grid>
</Window>
  • 复杂属性
<Grid Name="grid1"><Grid.Background><LinearGradientBrush><LinearGradientBrush.GradientStops><GradientStop Offset="0.00" Color="Red"/><GradientStop Offset="0.50" Color="Indigo"/><GradientStop Offset="1.0" Color="Violet"/></LinearGradientBrush.GradientStops></LinearGradientBrush></Grid.Background>
</Grid>

通过代码实现渐变颜色填充背景:

LinearGradientBrush brush = new LinearGradientBrush();GradientStop gradientStop1 = new GradientStop();
gradientStop1.Offset = 0;
gradientStop1.Color = Colors.Red;
brush.GradientStops.Add(gradientStop1);GradientStop gradientStop2 = new GradientStop();
gradientStop2.Offset = 0.5;
gradientStop2.Color = Colors.Indigo;
brush.GradientStops.Add(gradientStop2);GradientStop gradientStop3 = new GradientStop();
gradientStop3.Offset = 1;
gradientStop3.Color = Colors.Violet;
brush.GradientStops.Add(gradientStop3);grid1.Background = brush;
  • 标记扩展
    标记扩展允许引用另一个类中的静态属性,他们总是被{}包围起来:
    < Button … Foreground=“{x:Static SystemColors.ActiveCaptionBrush}”>

  • 附件属性
    除普通属性外,XAML还包括附件属性(attached property)的概念,附件属性是可用于多个控件但在另一个类中定义的属性。

如这里TextBox 和Button 的 Grid.Row附件属性

<TextBox ... Grid.Row="0"></TextBox><Button ... Grid.Row="1"></Button>

代码中也可以使用Grid.SetRow()方法。
如Grid.SetRow(txtQ, 0); 或 txtQ.SetValue(Grid.Rowproperty, 0);

  • 特殊字符
    小于号&lt;
    大于号&gt;
    &符号&amp;
    "引号&quot;

事件

用于关联事件处理程序的语法为:事件名=“事件处理程序方法名”。
如Button的Click事件
< Button … Click=“btn_Click”>

private void btn_Click(object sender, RoutedEventArgs e)
{

}

使用其他名称空间中的类型

为使用未在WPF名称空间中定义的类,需要将.NET名称控件映射到XML名称空间。
XMAL有一种特殊的语法完成这一工作,该语法如下:
xmlns:Prefix="clr-namespace:Namespace;assembly=AssemblyName
通常在XAML文档的根元素中,在紧随声明WPF和XAML名称空间的特性之后放置这个名称空间。

  • Prefix:是希望在XAML标记中用于指示名称空间的XML前缀。如,XAML语言使用的x前缀。
  • Namespace:是完全限定的.NET名称控件的名称。
  • AssmblyName:是声明类型的程序集,没有.dll扩展名。
  1. 访问System名称空间中的基本类型,并将其映射为前缀sys:
    xmlns:sys=“clr-namespace:System;assembly=mscorlib”

  2. 访问当前项目名称间中声明的类型,并将他们映射为前缀local:
    xmlns:local=“clr-namespace:WpfHelloWorld”

加载和编译XAML

可以使用三中不同的编码方式来创建WPF应用程序:

  • 只使用代码:通过代码生成用户界面。
  • 使用代码和未经编译的标记(XAML):如创建高度动态化的用户界面。这种方式在运行时使用System.Windows.Markup名称空间中的XamlReader类,从XAML文件中加载部分用户界面。
  • 使用代码和编译过的标记(BMAL):对于WPF而言这是一种更好的方式,也是Visual Studio支持的方式。

相关文章:

C# WPF编程-XAML

C# WPF编程-XAML XAML简述XAML子集XAML编译XAML基础XAML名称空间XAML中的属性和事件属性事件使用其他名称空间中的类型 加载和编译XAML XAML简述 XAML(Extensible Application Markup Language的简写&#xff0c;发音"zammel")是用于实例化.NET对象的标记语言。XAML…...

java 高级面试题(借鉴)(下)

雪花算法原理 第1位符号位固定为0&#xff0c;41位时间戳&#xff0c;10位workId&#xff0c;12位序列号&#xff0c;位数可以有不同实现。 优点&#xff1a;每个毫秒值包含的ID值很多&#xff0c;不够可以变动位数来增加&#xff0c;性能佳&#xff08;依赖workId的实现…...

C++测试代码

C测试代码 目录 基于C实现的AOP功能 基于C实现的AOP功能 #include <iostream> #include <string>struct LogHeader {std::string prefix;std::string aspect; };template <typename T> void before(const std::string& msg, const LogHeader& heade…...

Flask python 开发篇:蓝图的使用

蓝图 引言一、为什么使用蓝图&#xff1f;二、蓝图的概念三、创建蓝图四、注册蓝图五、分享我的creat_app方法六、写在最后 引言 falsk是个轻量级的框架&#xff0c;核心实现简单&#xff0c;但同事可以让开发人员自由的扩展功能。开发中&#xff0c;使用模块导入的方式。 一…...

抖音视频爬虫下载软件|可导出视频分享链接|视频批量采集工具

无水印视频关键词批量下载工具操作指南 我们自主开发了一款便捷的音视频批量下载工具&#xff0c;不仅支持单个视频链接提取&#xff0c;还可通过关键词搜索实现批量采集和选择性下载&#xff0c;让您轻松获取所需视频内容。 操作说明&#xff1a; 关键词批量采集视频 进入软件…...

CentOS DHCP服务器部署指南

title: DHCP 服务器部署以及配置 search: 2024-03-21 tags: “#DHCP 服务器部署以及配置” CentOS DHCP 服务器部署指南 背景 &#xff1a;因上了 Linux 的实验课程&#xff0c;在课程中&#xff0c;老师要求我们自己搭建 DHCP 服务器构建局域网&#xff0c;在构建的时候问题百…...

llvm后端

SelectionDAGBuilder是LLVM&#xff08;Low Level Virtual Machine&#xff09;编译器中的一个重要组件&#xff0c;它负责将LLVM中间表示&#xff08;Intermediate Representation&#xff0c;IR&#xff09;转换为SelectionDAG&#xff08;选择有向无环图&#xff09;的形式。…...

【JSON2WEB】10 基于 Amis 做个登录页面login.html

【JSON2WEB】01 WEB管理信息系统架构设计 【JSON2WEB】02 JSON2WEB初步UI设计 【JSON2WEB】03 go的模板包html/template的使用 【JSON2WEB】04 amis低代码前端框架介绍 【JSON2WEB】05 前端开发三件套 HTML CSS JavaScript 速成 【JSON2WEB】06 JSON2WEB前端框架搭建 【J…...

Android 你遇到的无障碍onGesture不执行

你是不是和我一样&#xff0c;在开发无障碍应用的时候&#xff0c;翻边了Android的AccessibilityService源码 但是就是发现不了onGesture不执行的原因&#xff1f; 你是不是和我一样&#xff0c;在好多测试手机之间徘徊&#xff0c;发现还是不执行&#xff1f; 你是不是和我一…...

Java学习10

目录 一.多态&#xff1a; 1.方法的多态&#xff1a; 2.对象的多态&#xff1a; 3.多态的注意事项与细节&#xff1a; 5.多态的应用: 二.Java的动态绑定机制&#xff1a; 三.多态应用&#xff1a; 1.多态数组&#xff1a; 2.多态参数&#xff1a; 三.Object类&#xf…...

第二十章 TypeScript(webpack构建ts+vue3项目)

构建项目目录 src-- main.ts-- App.vue--shim.d.tswebpack.config.jsindex.htmlpackage.jsontsconfig.json 基础构建 npm install webpack -D npm install webpack-dev-server -D npm install webpack-cli -D package.json 添加打包命令和 启动服务的命令 {"scripts…...

白酒:陈酿过程中的老熟度评价与品质提升方法

在豪迈白酒的酿造过程中&#xff0c;陈酿是一个至关重要的环节。陈酿不仅能使白酒老熟&#xff0c;提品质&#xff0c;还能发展出与众不同的风味和口感。云仓酒庄深知陈酿的重要性&#xff0c;并进行了深入的研究和实践。本文将探讨陈酿过程中的老熟度评价与品质提升方法。 首先…...

BoostSeacher

前言&#xff1a; 基于Boost库的搜索引擎 为何基于Boost库&#xff1f; 从技术上说&#xff1a;这个项目用了很多Boost库的接口从搜索引擎存储内说&#xff1a;存储的内容是Boost库的内容预期效果 预期效果:用户在浏览器输入关键词&#xff0c;浏览器显示相关结果 STEP1&#x…...

我的算法刷题笔记(3.18-3.22)

我的算法刷题笔记&#xff08;3.18-3.22&#xff09; 1. 螺旋矩阵1. total是总共走的步数2. int[][] directions {{0, 1}, {1, 0}, {0, -1}, {-1, 0}};方位3. visited[row][column] true;用于判断是否走完一圈 2. 生命游戏1. 使用额外的状态22. 再复制一份数组 3. 旋转图像观…...

初探Ruby编程语言

文章目录 引言一、Ruby简史二、Ruby特性三、安装Ruby四、命令行执行Ruby五、Ruby的编程模型六、案例演示结语 引言 大家好&#xff0c;今天我们将一起探索一门历史悠久、充满魅力的编程语言——Ruby。Ruby是由松本行弘&#xff08;Yukihiro Matsumoto&#xff09;于1993年发明…...

深圳MES系统如何提高生产效率

深圳MES系统可以通过多种方式提高生产效率&#xff0c;具体如下&#xff1a; 实时监控和分析&#xff1a;MES系统可以实时收集并分析生产数据&#xff0c;帮助企业及时了解生产状况&#xff0c;发现问题并迅速解决&#xff0c;避免问题扩大化。这种实时监控和分析功能可以显著…...

QT常见Layout布局器使用

布局简介 为什么要布局&#xff1f;通过布局拖动不影响鼠标拖动窗口的效果等优点.QT设计器布局比较固定&#xff0c;不方便后期修改和维护&#xff1b;在Qt里面布局分为四个大类 &#xff1a; 盒子布局&#xff1a;QBoxLayout 网格布局&#xff1a;QGridLayout 表单布局&am…...

Elasticsearch8 - Docker安装Elasticsearch8.12.2

前言 最近在学习 ES&#xff0c;所以需要在服务器上装一个单节点的 ES 服务器环境&#xff1a;centos 7.9 安装 下载镜像 目前最新版本是 8.12.2 docker pull docker.elastic.co/elasticsearch/elasticsearch:8.12.2创建配置 新增配置文件 elasticsearch.yml http.host…...

还在为不知道怎么学习网络安全而烦恼吗?这篇文带你从入门级开始学习网络安全—认识网络安全

随着网络安全被列为国家安全战略的一部分&#xff0c;这个曾经细分的领域发展提速了不少&#xff0c;除了一些传统安全厂商以外&#xff0c;一些互联网大厂也都纷纷加码了在这一块的投入&#xff0c;随之而来的吸引了越来越多的新鲜血液不断涌入。 不同于Java、C/C等后端开发岗…...

DFS基础——迷宫

迷宫 配套视频讲解 关于dfs和bfs的区别讲解。 对于上图&#xff0c;假设我们要找从1到5的最短路&#xff0c;那么我们用dfs去找&#xff0c;并且按照编号从大到小的顺序去找&#xff0c;首先找到的路径如下&#xff0c; 从节点1出发&#xff0c;我们发现节点2可以走&#xff…...

通过Wrangler CLI在worker中创建数据库和表

官方使用文档&#xff1a;Getting started Cloudflare D1 docs 创建数据库 在命令行中执行完成之后&#xff0c;会在本地和远程创建数据库&#xff1a; npx wranglerlatest d1 create prod-d1-tutorial 在cf中就可以看到数据库&#xff1a; 现在&#xff0c;您的Cloudfla…...

visual studio 2022更改主题为深色

visual studio 2022更改主题为深色 点击visual studio 上方的 工具-> 选项 在选项窗口中&#xff0c;选择 环境 -> 常规 &#xff0c;将其中的颜色主题改成深色 点击确定&#xff0c;更改完成...

反射获取方法和属性

Java反射获取方法 在Java中&#xff0c;反射&#xff08;Reflection&#xff09;是一种强大的机制&#xff0c;允许程序在运行时访问和操作类的内部属性和方法。通过反射&#xff0c;可以动态地创建对象、调用方法、改变属性值&#xff0c;这在很多Java框架中如Spring和Hiberna…...

SpringTask-03.入门案例

一.入门案例 启动类&#xff1a; package com.sky;import lombok.extern.slf4j.Slf4j; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cache.annotation.EnableCach…...

ip子接口配置及删除

配置永久生效的子接口&#xff0c;2个IP 都可以登录你这一台服务器。重启不失效。 永久的 [应用] vi /etc/sysconfig/network-scripts/ifcfg-eth0修改文件内内容 TYPE"Ethernet" BOOTPROTO"none" NAME"eth0" DEVICE"eth0" ONBOOT&q…...

Java线上CPU飙高问题排查全指南

一、引言 在Java应用的线上运行环境中&#xff0c;CPU飙高是一个常见且棘手的性能问题。当系统出现CPU飙高时&#xff0c;通常会导致应用响应缓慢&#xff0c;甚至服务不可用&#xff0c;严重影响用户体验和业务运行。因此&#xff0c;掌握一套科学有效的CPU飙高问题排查方法&…...

代码随想录刷题day30

1、零钱兑换II 给你一个整数数组 coins 表示不同面额的硬币&#xff0c;另给一个整数 amount 表示总金额。 请你计算并返回可以凑成总金额的硬币组合数。如果任何硬币组合都无法凑出总金额&#xff0c;返回 0 。 假设每一种面额的硬币有无限个。 题目数据保证结果符合 32 位带…...

Redis:现代应用开发的高效内存数据存储利器

一、Redis的起源与发展 Redis最初由意大利程序员Salvatore Sanfilippo在2009年开发&#xff0c;其初衷是为了满足他自己的一个项目需求&#xff0c;即需要一个高性能的键值存储系统来解决传统数据库在高并发场景下的性能瓶颈。随着项目的开源&#xff0c;Redis凭借其简单易用、…...

【SpringBoot自动化部署】

SpringBoot自动化部署方法 使用Jenkins进行持续集成与部署 Jenkins是最常用的自动化部署工具之一&#xff0c;能够实现代码拉取、构建、测试和部署的全流程自动化。 配置Jenkins任务时&#xff0c;需要添加Git仓库地址和凭证&#xff0c;设置构建触发器&#xff08;如GitHub…...

uniapp 实现腾讯云IM群文件上传下载功能

UniApp 集成腾讯云IM实现群文件上传下载功能全攻略 一、功能背景与技术选型 在团队协作场景中&#xff0c;群文件共享是核心需求之一。本文将介绍如何基于腾讯云IMCOS&#xff0c;在uniapp中实现&#xff1a; 群内文件上传/下载文件元数据管理下载进度追踪跨平台文件预览 二…...