WPF项目实战视频《三》(主要为客户端软件界面设计)

20.WPF项目实战(项目介绍)

1.WEB API:接口,如何获取数据(增删改查)
2.客户端 项目功能:
待办,备忘录,汇总,完成比例,设置系统主题等。

21.WPF项目实战(创建项目结构)

VS使用prism插件新建一个项目MyToDo
在这里插入图片描述

此插件自动安装依赖包Prism.DryIoc,还需安装材料包MaterialDesignThemes,安装之后打开项目UML,按它的文档操作一遍
在这里插入图片描述
在App.xaml.cs中使主程序继承自PrismApplication
在这里插入图片描述
在App.xaml中添加MaterialDesignThemes包的部分(可直接从文档中复制过来)
在这里插入图片描述
在MainWindow.xaml中新加一个按钮
在这里插入图片描述
下一步添加一个Web Api:在解决方案中新建项目-api项目,命名为MyToDo.Api
在这里插入图片描述
设为启动项可正常启动。
在这里插入图片描述

22.WPF项目实战(设计首页导航条)

实现效果:
在这里插入图片描述
先把整个页面分为两个区域(导航条和主要区域)

<Grid.RowDefinitions><RowDefinition Height="auto"/><RowDefinition/>
</Grid.RowDefinitions>

左边的部分:可以直接从MaterialDesignThemes源码中取出这部分到MyToDo项目中:MaterialDesignThemes中找到启动项的mainWindow,复制需要的部分,导入MaterialDesignThemes,
在这里插入图片描述
删掉复制内容中不需要的部分,最后实现:
在这里插入图片描述

现需要加入导航条右边的部分,三个按钮和放大缩小处理。
在这里插入图片描述
新加头像,在项目文件中新建文件夹Images,添加想要的图片,然后在xaml中添加图片即可

<Image Width="25" Height="25" Source="/Images/1.jpg"/>

注意:需要将图片属性设置为资源,否则可能会出错
在这里插入图片描述
注意:插件:XamlStyler.Extension.Windows.VS2022.vsix 安装后直接保存可进行代码的自动对齐。

之前的缩小窗口,放大窗口,关闭窗口,未实现功能,因为此功能本身没有什么多联系,所以可以使用事件来完成。
在这里插入图片描述

public MainWindow()
{InitializeComponent();btnMin.Click += (s, e) =>{//把当前窗口的状态改成最小this.WindowState = WindowState.Minimized;};btnMax.Click += (s, e) =>{//判断当前窗口状态,如果是最大化则变为正常的,否则把当前窗口的状态改成最大if(this.WindowState == WindowState.Maximized)this.WindowState = WindowState.Normal;elsethis.WindowState = WindowState.Maximized;};btnClose.Click += (s, e) =>{//关闭当前窗口this.Close();};
}

还可以添加鼠标事件:拖动和鼠标双击处理。
鼠标拖动控件:为需要拖动的控件增加name
在这里插入图片描述

//添加鼠标拖动事件
ColorZone.MouseMove += (s, e) => { //判断,如果是正在移动,则拖动窗口if(e.LeftButton == MouseButtonState.Pressed){this.DragMove();}
};//双击的处理
ColorZone.MouseDoubleClick += (s, e) =>
{if (this.WindowState == WindowState.Normal)this.WindowState = WindowState.Maximized;elsethis.WindowState = WindowState.Normal;
};

23.WPF项目实战(绑定菜单)

实现点击旁边的菜单栏,可根据选项动态进行切换界面,动态绑定菜单。有图标,名字,命名空间(用来导航)
创建公共的文件夹,创建一些实体类
1.添加一个系统导航菜单类MenuBar:(包含icon图标,title名字,命名控件nameSpace)
在这里插入图片描述
2.在view文件夹中新加窗口:MainView.xaml,在ViewModels新加类:MainViewModels类。

在MainViewModels类中可使用之前创建的MenuBar类,类函数添加导航每个选项的内容。

在主页面:xaml左边的代码中找到对应的需要添加的内容,头像/选项栏/数据模板,数据模板用list绑定MenuBars,界面相关位置绑定MainViewModels中的Icon,Title数据。

使用MainView而不是之前的MainWindowViewModel,在App中的窗口设置修改一下

MainView中需要导入prism,设置上下文实现自动绑定

运行之后,发现选中之后的样式类型可以优化,在app.xaml中增加样式,添加触发器,如果是选中的状态则更改样式,边框大小,边框颜色等(可使用MD中的动态变换颜色)

在MainView.xaml中引用app.xaml中增加样式

再改变选中的颜色和背景颜色:app.xaml中修改对应样式的Border

24.WPF项目实战(菜单导航)

在上一节实现了菜单的界面,这届实现导航的功能。
1.添加所有的子页面。View文件夹中,新添加用户控件IndexView.xaml,MemoView.xaml,SettingsView.xaml,ToDoView.xaml。

2.在ViewModels文件夹中,添加对应的ViewModels类:IndexViewModel.cs,MemoViewModel.cs,SettingsViewModel.cs,ToDoViewModels.cs。

3.加完之后在App.xaml.cs中添加依赖注入,注册为导航

4.实现导航的功能:在MainViewModel.cs中加入命令 DelegateCommand

5.在MainView.xaml中多注册一个区域(新建Extensions文件夹,中新建一个类PrismManager.cs管理区域信息)

6.注册之后就可以在MainViewModel中进行使用了。regionManager

7.导航中上一步下一步切换的功能,使用导航中的回调函数(导航日志,区域导航)

25.WPF项目实战(设计首页)

子页面的样式
显示主页四个图片,手动点击按钮添加代办,手动点击按钮添加备忘录

修改IndexView.xaml,修改样式

(另外:.cs中的快捷键:propfull 然后自动生成变量代码)

26.WPF项目实战(设计首页2)

子页面的样式设计完之后内容填充。

修改IndexView.xaml.cs ,修改实现,列表的绑定,显示所有待办事项。

27.WPF项目实战(设计待办事项界面)

新增待办事项按钮
新增之后显示待办事项

28.WPF项目实战(设计备忘录界面)

新增备忘录按钮
新增之后显示备忘录

29.WPF项目实战(设置界面)

个性化
系统设置
关于更多

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

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

相关文章

nodejs与npm版本对应表

Node.js — Node.js 版本 (nodejs.org)

Springboot集成微信公众号模板通知java

先看效果 1、微信模板消息官方文档 微信公众平台 2、申请微信公众平台接口测试账号 微信公众平台 3、创建3个实体 &#xff08;1&#xff09;、ConfigBean import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configurat…

python中,jsonpath提取数据的时候出现TypeError: ‘bool‘ object is not subscriptable怎么解决

json格式如下&#xff1a; { success: True, result: { codeInfo: { code: 0, msg: 成功 }, uploadToken: { resId: rzJRpo, endpoint: https://sit-api-ypsx-resource.ypsx-internal.com/r…

stm32入门-----DMA直接存储器存取(上——理论篇)

目录 前言 DMA 1.简介 2.存储器映像 3.DMA结构 4.数据宽度与对齐 5.DMA工作示例 前言 本期我们就开始学习DMA直接存储器存取&#xff0c;DMA是一个数据装运的小助手&#xff0c;执行数据的搬运处理&#xff0c;减少了CPU的负担&#xff0c;在stm32中担当重要的工作。在前…

pypi如何上传自己的代码记录

目录 一. 注册pypi账号并创建token 1. 注册pypi账号并创建token 2. Pypi账号注册 3. 邮箱验证 ​编辑 4. 重新生成恢复代码 5. 输入账号密码 ​编辑 6. 保存code并继续 ​编辑7. 输入一行即可&#xff0c;然后点击verify 8. 点击左方目录内的account setting&#xff…

基于微信小程序的高校排课系统 /基于微信小程序的排课管理系统/课程管理系统

摘 要 随着信息技术和网络技术的飞速发展&#xff0c;人类已进入全新信息化时代&#xff0c;传统管理技术已无法高效&#xff0c;便捷地管理信息。为了迎合时代需求&#xff0c;优化管理效率&#xff0c;各种各样的管理系统应运而生&#xff0c;各行各业相继进入信息管理时代&a…

爱快路由的dns强制客户端代理真是个强大的功能

大致情况是这样的&#xff1a;同事说在linux服务器/etc/resolv.conf上随便写个IP地址【不在线的】&#xff0c;dns地址也能解析&#xff0c;让我帮忙查查。 我看了下也感觉纳闷&#xff0c;试了下不光在服务器上&#xff0c;我本地的pc随便设置了个dns解析也是一样的。 通过wir…

解决Qt6 error: The kit needs to define a CMake tool to parse this project.

cmake对于Qt6来说很重要&#xff0c;所以学会cmake是必须的。 上述错误&#xff0c;就是我在Windows10下运行cmake项目总是报错的一个问题。 明明路径已经配好了&#xff0c;却总是报错。 具体原因可能和cmake的版本&#xff0c;以及是否设置为默认有关。另外也和QtCreator中…

飞凌全志T527开发板实现局域网内文件传输功能

之前玩开发板的时候&#xff0c;如果需要实现主机与开发板之间的文件传输&#xff0c;通常是通过挂载NFS的方式&#xff0c;而飞凌的OKT527板载WIFI&#xff0c;并且官方提供的镜像中已经将其成功驱动&#xff0c;那我们就可以通过WIFI连接家中的路由器的方式&#xff0c;实现局…

【Redis】Centos7 安装 redis(详细教程)

查看当前 Redis 版本&#xff1a; 当前的 redis 版本太老了&#xff0c;选择安装 Redis5。 一、使用 yum 安装 1、首先安装 scl 源 yum install centos-release-scl-rh 由于我之前已经安装过了&#xff0c;所以加载速度比较快&#xff0c;且显示已经安装成功&#xff0c;是最…

MongoDB整合SpringBoot

文章目录 SpringBoot整合MongoDB环境准备文档操作相关注解创建实体添加文档查询文档更新文档删除文档 小技巧&#xff1a;如何去掉_class属性 SpringBoot整合MongoDB https://docs.spring.io/spring-boot/docs/current/reference/html/data.html#data.nosql.mongodb.repositor…

prompt技巧(2) - 如何解决对话过程中角色反转问题

在一些角色扮演场景下&#xff0c;需要大模型扮演某个角色进行对话&#xff0c;但是在对话过程中偶尔会发生角色反转问题&#xff0c;如大模型扮演客户角色与销售人员进行对话&#xff0c;大模型有时会忘记自己身份&#xff0c;突然以销售人员的身份进行回答&#xff0c;这种情…

ubuntu上部署vue项目到ngixn中+SpringBoot项目+postgresql数据库

文章目录 前提1.Ubuntu上安装ngix2.部署Vue项目2.1上传vue项目2.2.配置 3.Ubuntu上安装Postgres4.部署springboot项目 前提 记一次在ubuntu部署前端vue和后端springboot项目&#xff0c;以及数据库postgresql的安装以及启动、停止等常用的命令。 1.Ubuntu上安装ngix 1、检查…

Cuppa CMS v1.0 任意文件读取漏洞(CVE-2022-25578)

前言 春秋云镜靶场是一个专注于网络安全培训和实战演练的平台&#xff0c;旨在通过模拟真实的网络环境和攻击场景&#xff0c;提升用户的网络安全防护能力和实战技能。这个平台主要提供以下功能和特点&#xff1a; 实战演练&#xff1a; 提供各种网络安全攻防演练场景&#…

yolo模型训练出的.pt文件过大

当我们使用yolov8训练时候&#xff0c;保存的模型变大&#xff0c;如下图&#xff1a; 原模型 训练出来的模型 经过仔细调查&#xff0c;发现是保存的模型中多了很多数据。 原模型 训练出来的模型 只需要把文件中.pt文件读取&#xff0c;重写一遍保存。 from ultralytics im…

深入源码:解析SpotBugs (6)jvm 字节码简介

文章目录 一、JVM字节码概述一、文件结构概述二、详细解析1. 魔数和Class文件的版本2. 常量池3. 访问标志4. 类索引、父类索引与接口索引集合5. 字段表和方法表6. 属性表 字节码Spotbugs 作为一名资深的Java开发工程师&#xff0c;对JVM及其字节码有着深入的理解。现在&#xf…

Linux基于centOS7 【进度条】【Git】【gdb】学习

目录 进度条 进度条的前置准备 sleep &#xff08;秒&#xff09;& usleep&#xff08;微秒&#xff09; sleep加\n和不加\n的区别 IO函数的缓冲区 回车&换行 10秒倒计时 进度条编写 git的使用 为什么要有git&#xff08;git版本控制器&#xff09; git的主要…

江科大/江协科技 STM32学习笔记P13

文章目录 TIM定时中断1、TIM简介计数器PSC预分频器ARR自动重装寄存器 2、定时器类型基本定时器主模式触发DAC 通用定时器高级定时器 3、定时器原理定时中断基本结构预分频器时序计数器时序RCC时钟树 TIM定时中断 1、TIM简介 定时器的基准时钟一般都是主频72MHz&#xff0c;如果…

业绩增长新引擎:智能名片如何助力销售突破

01、智能名片&#xff0c;营销增长利器 在当今竞争激烈的市场环境下&#xff0c;企业正面临着类似品牌曝光不足、销售线索获取困难、客户关系维护复杂等诸多挑战。为帮助企业解决相关难题&#xff0c;促进业绩高效增长&#xff0c;纷享营销通的 智能名片 应运而生&#xff0…

Leetcode—74. 搜索二维矩阵【中等】

2024每日刷题&#xff08;149&#xff09; Leetcode—74. 搜索二维矩阵 实现代码 class Solution { public:bool searchMatrix(vector<vector<int>>& matrix, int target) {int m matrix.size();int n matrix[0].size();int l 0;int r m * n;int mid -1…