UWP Group Project

该博客介绍了开发UWP应用先锋电脑维修网Win10版的过程,包括应用特色如开场动画、用户登录注册、预约功能等。应用采用SQLite数据库进行数据操作,计划集成第三方登录和分享功能,以及管理员公告推送。开发者参考了UWP官方文档和其他资源进行技术实现。

我们的应用是先锋电脑维修网的win10应用版。

我们的应用能够实现:

A.开场动画
B.用户注册、登陆,个人信息维护及查看
C.用户进行维修预约,查看和修改自己的预约信息
D.第三方登陆
E.分享到空间/QQ/微信等
F.管理员登陆
G.管理员查看所有用户信息和所有订单
H.管理员处理用户提交的预约订单,处理问题用户
I.管理员发布公告
J.预约成功添加事件
(其中D, E, J为扩展功能)

我们应用的特色在于:

1、Windows风格的开场动画
2、能够帮助用户方便地进行预约。

总体框架图:

这里写图片描述

具体设计:

(由于时间等原因,只是给出大概设计,具体还会再做改进)

管理员:

这里写图片描述
这里写图片描述
这里写图片描述

用户:

这里写图片描述
这里写图片描述

我们应用的每个功能所需的技术为:

A.进入应用后的动画
我们可以看到在我们应用的web版,在进入的时候会有一个很可爱的动画,为windows10系统的错误画面,这个动画中的百分比数字会不断改变,当其变为百分之百的时候即可进入我们的应用。所以我们也打算在我们的应用中实现这个功能。
我们实现这个功能需要的具体技术有两个,一个是动画的制作,一个是应用的启动,想到老师在课上提到的关于StoryBoard的知识,所以我找到了
https://docs.microsoft.com/en-us/uwp/api/windows.ui.xaml.media.animation.storyboard
UWP官方文档中对StoryBoard的说明和解释,但是我觉得完美的复制WEB版的动画可能会有一些难度,所以我又去查阅了更为详尽的关于StoryBoard的资料,结果发现了
https://www.cnblogs.com/shaomeng/p/8601962.html
其中提到的LottieUWP令我很感兴趣,于是我决定在最后的开发中尝试使用LottieUWP
之后是关于应用的启动,之前的作业中,关于APP的构建中,官方文档直接给出了关于应用启动的一些建议和意见以及一些可能用到的事件。
https://docs.microsoft.com/zh-cn/windows/uwp/debug-test-perf/best-practices-for-your-app-s-startup-performance
这里面介绍了关于应用的启动的知识,我打算将它们结合起来。
B.用户的注册,登录,基本信息的查看
用户的注册和登录所用到的主要知识和步骤大体就是UI的设计问题和数据库的操作问题,数据库的操作在后面的部分有所介绍,在这里就先跳过不提,之后就是每个输入进行格式上的限制,这部分也比较简单,在这之上我打算利用发送短信的方式,之后在一定时间内输入短信验证码的内容,来进行注册的验证,我查阅了一些资料,都没有与之完全相关的内容,只找到了
https://www.cnblogs.com/qq-smile/p/7273604.html
关于UI层的东西。
而发送短信并且验证这一点我们只能以UWP官方文档中发送短信这一部分来向外扩展了。
https://docs.microsoft.com/zh-cn/windows/uwp/contacts-and-calendar/sending-an-sms-message
C.预约信息的增删改查
这一部分主要还是对数据库的操作部分,主要的还是如何呈现用户的预约信息,能够让用户条理清晰的看到预约的信息。
在这里,由于每个预约信息都是分立且单独的,这让我想起了TODO,很多TODO中将每个任务分成很多小任务并且每个任务单独享有很多属性,于是我想到了用一个个CARD来呈现这些预约信息,于是我就查阅UWP控件中的有没有CARD之类的控件
结果查找到了
https://docs.microsoft.com/en-us/windows/uwp/design/controls-and-patterns/contact-card
我觉得通过些许的改变和定制就能实现好看的UI了。
D.第三方登录
我们应用打算提供第三方登录的功能
https://docs.microsoft.com/zh-cn/windows/uwp/security/web-authentication-broker
于是我找到了腾讯开发者平台,之后通过申请腾讯开发者来获取到对应的私钥和ID(正在申请中)
http://open.qq.com/
E.分享到QQ空间等
同上,但是在仔细研究后发现QQ开发者平台似乎没有提供对UWP的接口,我们打算使用web的登录和分享功能,来实现我们应用的第三方登录和分享功能。
F:管理员发布公告
https://docs.microsoft.com/zh-cn/azure/app-service-mobile/app-service-mobile-windows-store-dotnet-get-started-push
https://docs.microsoft.com/zh-cn/windows/uwp/publish/send-push-notifications-to-your-apps-customers
可以利用windows推送服务(wns,这是win10通知机制中的一种)向用户推送重要公告。

G.预约成功添加事件
为了防止用户在预约之后忘记,我们在成功预约之后添加事件,事件将被添加到用户的日历里。
https://docs.microsoft.com/en-us/windows/uwp/contacts-and-calendar/managing-appointments
这个页面简单介绍了如何添加一个约定事件。

H.数据库操作:
数据库是我们这个应用里最重要的部分之一,我们的app就是基于数据库的。
每个新用户注册,都应该保存用户信息,每个用户登录,都要判断密码是否正确。每次进行填写、修改、查看等操作时,都要从数据库里取出相应的表单,进行读写操作。https://docs.microsoft.com/en-us/windows/uwp/data-access/sqlite-databases,这个网页介绍了uwp应用如何使用SQLite数据库。
https://blog.youkuaiyun.com/github_36704374/article/details/60469324
这个网站里介绍了基本的增删改查步骤。我们会为不同的存储内容设计不同的表,以达到对数据进行操作的目的。

我们的采访视频为:

(写博文时视频审核中,若没有请等等) https://www.bilibili.com/video/av21948722/

根据采访的结果,我们更新后的设计为:

增加SSO登陆
这里写图片描述

基于NSGA-III算法求解微电网多目标优化调度研究(Matlab代码实现)内容概要:本文围绕基于NSGA-III算法的微电网多目标优化调度展开研究,重点介绍了如何利用该先进多目标进化算法解决微电网系统中多个相互冲突的目标(如运行成本最小化、碳排放最低、供电可靠性最高等)的协同优化问题。文中结合Matlab代码实现,详细阐述了NSGA-III算法的基本原理、在微电网调度模型中的建模过程、约束条件处理、目标函数设计以及仿真结果分析,展示了其相较于传统优化方法在求解高维、非线性、多目标问题上的优越性。同时,文档还提供了丰富的相关研究案例和技术支持背景,涵盖电力系统优化、智能算法应用及Matlab仿真等多个方面。; 适合人群:具备一定电力系统基础知识和Matlab编程能力的研究生、科研人员及从事能源优化领域的工程技术人员;尤其适合正在进行微电网调度、多目标优化算法研究或撰写相关论文的研究者。; 使用场景及目标:①掌握NSGA-III算法的核心思想及其在复杂能源系统优化中的应用方式;②学习如何构建微电网多目标调度模型并利用Matlab进行仿真求解;③为科研项目、毕业论文或实际工程提供算法实现参考和技术支撑。; 阅读建议:建议读者结合文中提供的Matlab代码实例,逐步调试运行并深入理解算法流程与模型构建细节,同时可参考文档中列出的其他优化案例进行横向对比学习,以提升综合应用能力。
<?xml version="1.0" encoding="UTF-8"?> <Wix xmlns="http://wixtoolset.org/schemas/v6/wxs"> <!-- 包级属性 --> <Package InstallerVersion="600" Compressed="yes" InstallScope="perMachine" Platform="x64" Manufacturer="MyCompany"/> <Product Id="*" Name="MyApp" Language="1033" Version="1.0.0.0"> <!-- 目录结构 --> <StandardDirectory Id="ProgramFiles64Folder"> <Directory Id="INSTALLDIR" Name="MyApp"> <Component> <File Source="MyApp.exe" /> </Component> </Directory> </StandardDirectory> <Directory Id="INSTALLDIR" Name="MyApp"> <Component> <File Source="MyApp.exe" /> </Component> </Directory> </StandardDirectory> <!-- 快捷方式 (v6兼容性修复) --> <StandardDirectory Id="DesktopFolder"> <Component> <Shortcut Id="DesktopShortcut" Name="MyApp" Target="[INSTALLDIR]MyApp.exe" WorkingDirectory="INSTALLDIR"/> <!-- v6要求显式声明KeyPath --> <RegistryValue Root="HKCU" Key="Software\MyApp" Name="DesktopShortcutInstalled" Type="integer" Value="1" KeyPath="yes"/> <!-- 关键修复 --> </Component> </StandardDirectory> <!-- 新增v6特性:ARM64支持 --> <Condition Message="本安装包仅支持ARM64架构"> <![CDATA[Installed OR (VersionNT >= 1000)]]> <!-- 条件语法优化 --> </Condition> </Product> </Wix> D:\QuickStart>dotnet build 还原完成(0.3) QuickStart 失败,出现 1 错误 (1.5 秒) D:\QuickStart\Packge.wxs(24): error WIX0104: Not a valid source file; detail: The 'Product' start tag on line 10 position 4 does not match the end tag of 'StandardDirectory'. Line 24, position 7. 在 2.1 秒内生成 失败,出现 1 错误 帮我解决这个错误,而且我不是armx64,而是x64
07-29
<think>我们正在处理一个WiX安装项目构建错误:WIX0104: The 'Product' start tag does not match the end tag of 'StandardDirectory'。同时,用户要求适配x64架构。 根据错误信息,这通常是由于XML标签不匹配造成的。具体来说,在Product元素内部,一个名为StandardDirectory的结束标签与Product的开始标签不匹配。实际上,WiX中没有StandardDirectory元素,可能是用户误写。正确的目录元素是Directory。 另外,用户提到要适配x64架构,因此我们需要在WiX脚本中正确设置平台为x64。 解决方案步骤: 1. **检查XML结构**:确保所有标签都正确嵌套和关闭。特别是,检查Product元素内部的所有元素,确保没有错误的标签(如StandardDirectory)和正确的结束标签。 2. **修正目录结构**:WiX中定义目录结构的标准方法是使用Directory元素。常见的错误可能是将Directory写成了StandardDirectory(可能是笔误)。因此,将StandardDirectory替换为Directory。 3. **设置平台为x64**:在Package元素中设置Platform属性为x64,或者通过构建命令行参数指定平台。 4. **检查项目文件(.wixproj)**:根据引用[1]中的信息,有时WiX项目文件(.wixproj)中需要设置Cultures属性。但此错误与Cultures无关,不过我们可以检查项目文件以确保平台配置正确。 示例修正: 假设原始的WiX脚本中有类似以下错误: ```xml <Product ...> <StandardDirectory Id="TARGETDIR"> ... </StandardDirectory> </Product> ``` 正确的写法应该是: ```xml <Product ...> <Directory Id="TARGETDIR" Name="SourceDir"> <!-- 子目录定义 --> </Directory> </Product> ``` 另外,为了适配x64,我们可以: - 在Package元素中指定Platform属性: ```xml <Package InstallerVersion="200" Compressed="yes" InstallScope="perMachine" Platform="x64"/> ``` - 或者在构建时通过命令行参数指定:`-platform x64` 5. **检查项目文件(.wixproj)**:打开.wixproj文件,确保在Debug和Release配置中,Platform设置为x64(如果需要在项目文件中指定)。同时,检查是否有Cultures属性(根据引用[1],如果缺失可能会引发其他错误,但不是当前错误)。如果项目需要本地化,可以按照引用[1]的方法设置Cultures属性。 6. **构建命令**:如果使用命令行构建,确保使用正确的平台参数: ``` msbuild MySetup.wixproj -p:Platform=x64 ``` 7. **完整示例**: 修正后的WiX脚本片段(Product部分): ```xml <?xml version="1.0" encoding="UTF-8"?> <Wix xmlns="http://schemas.microsoft.com/wix/2006/wi"> <Product Id="*" Name="My Application" Language="1033" Version="1.0.0.0" Manufacturer="My Company" UpgradeCode="PUT-GUID-HERE"> <Package InstallerVersion="200" Compressed="yes" InstallScope="perMachine" Platform="x64"/> <MajorUpgrade DowngradeErrorMessage="A newer version of [ProductName] is already installed." /> <MediaTemplate /> <Directory Id="TARGETDIR" Name="SourceDir"> <Directory Id="ProgramFiles64Folder"> <Directory Id="INSTALLFOLDER" Name="My Application" /> </Directory> </Directory> <!-- 其他组件等 --> </Product> </Wix> ``` 注意:对于64位安装,我们使用ProgramFiles64Folder,而不是ProgramFilesFolder(32位)。 如果问题仍然存在,请检查整个WiX脚本,确保没有其他标签不匹配的情况。 根据引用[2],WiX也支持创建适用于Windows Store的UWP包,但这不是当前问题的重点。 最后,构建项目,应该不再出现WIX0104错误。 相关问题: 1. 如何在WiX中创建64位安装程序? 2. 如何解决WiX中的XML标签不匹配错误? 3. 如何配置WiX项目以支持多语言? 4. 如何将传统的MSI安装包转换为UWP应用包?</think>针对您的 WiX 安装包构建错误 `WIX0104: The 'Product' start tag does not match the end tag of 'StandardDirectory'` 以及 x64 架构适配问题,以下是完整的解决方案: ### 🔧 错误原因分析 1. **标签不匹配**:`<Product>` 开始标签与 `</StandardDirectory>` 结束标签不匹配(WiX 中实际不存在 `StandardDirectory` 元素) 2. **架构未明确定义**:未显式指定 x64 架构导致目录结构冲突 3. **常见错误模式**: ```xml <!-- 错误示例 --> <Product> <StandardDirectory> <!-- 错误标签 --> ... </StandardDirectory> </Product> ``` ### ✅ 解决方案(适配 x64 架构) #### 步骤 1:修复标签结构 ```xml <Wix xmlns="http://schemas.microsoft.com/wix/2006/wi"> <!-- 正确结构 --> <Product> <Package InstallScope="perMachine" Platform="x64"/> <!-- 关键:指定x64平台 --> <Directory Id="TARGETDIR" Name="SourceDir"> <Directory Id="ProgramFiles64Folder"> <!-- 64位程序目录 --> <Directory Id="INSTALLFOLDER" Name="MyApp"/> </Directory> </Directory> <!-- 组件定义 --> <ComponentGroup> <Component Directory="INSTALLFOLDER"> <File Source="MyApp.exe"/> </Component> </ComponentGroup> </Product> </Wix> ``` #### 步骤 2:关键修改点 1. **替换错误标签**: - 将 `StandardDirectory` 替换为正确的 `Directory` 层级结构 - 删除所有 `StandardDirectory` 引用 2. **显式声明 x64 架构**: ```xml <Package InstallerVersion="200" Platform="x64" <!-- 强制指定x64 --> Compressed="yes"/> ``` 3. **使用正确的目录常量**: - `ProgramFiles64Folder`:64位程序安装目录 - `System64Folder`:64位系统目录 - 避免使用 `ProgramFilesFolder`(32位兼容目录) #### 步骤 3:验证项目文件设置 按引用[1]建议检查 `.wixproj` 文件: ```xml <!-- 在.wixproj中添加 --> <PropertyGroup> <Cultures>en-US</Cultures> <!-- 或您的实际语言 --> <Platform>x64</Platform> <!-- 显式指定平台 --> </PropertyGroup> ``` ### 🛠️ 完整 x64 适配示例 ```xml <?xml version="1.0" encoding="UTF-8"?> <Wix xmlns="http://schemas.microsoft.com/wix/2006/wi"> <Product Id="*" Name="MyApp" Language="1033" Version="1.0.0" Manufacturer="Company" UpgradeCode="YOUR-GUID"> <Package InstallerVersion="200" Platform="x64" Compressed="yes"/> <MajorUpgrade DowngradeErrorMessage="Newer version already installed"/> <!-- 64位目录结构 --> <Directory Id="TARGETDIR" Name="SourceDir"> <Directory Id="ProgramFiles64Folder"> <Directory Id="INSTALLFOLDER" Name="MyApp"/> </Directory> </Directory> <!-- 64位组件 --> <Feature Id="MainFeature" Title="Main" Level="1"> <ComponentGroupRef Id="AppComponents"/> </Feature> </Product> <Fragment> <ComponentGroup Id="AppComponents" Directory="INSTALLFOLDER"> <Component Guid="*"> <File Source="MyApp.exe"/> <RegistryValue Root="HKLM" Key="Software\MyApp" Name="Installed" Type="integer" Value="1" KeyPath="yes"/> </Component> </ComponentGroup> </Fragment> </Wix> ``` ### ⚠️ 注意事项 1. **架构一致性**: - 所有组件必须包含 `Win64="yes"` 属性(WiX v4+ 自动处理) ```xml <!-- WiX v3 需要显式声明 --> <Component Win64="yes"> ... </Component> ``` 2. **混合架构检测**: - 使用 `VersionNT64` 属性检测64位系统: ```xml <Condition Message="需要64位Windows系统"> <![CDATA[Installed OR VersionNT64]]> </Condition> ``` 3. **构建命令**: ```bash msbuild YourProject.wixproj /p:Platform=x64 /p:Configuration=Release ``` > 通过引用[2]提到的 Desktop Bridge 技术,您将来还可将适配后的安装包转换为 UWP 应用包上架商店[^2]。
评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值