前言
使用WINUI开发也有一年有余,前前后后踩的坑有不少;而由SDK版本问题导致的一些坑,回头来看,这些问题有的除自己不了解外,微软也必须得背下锅。下文将介绍一下在开发过程中SDK相关的一些问题。
开发环境
windows11 操作系统
VS2022
SDK相关问题
SDK安装不上
去年在将项目SDK升级后,在运行时无论如何处理也安装不上新版本的SDK。网上查找无果,AI也是半夜擤鼻涕——乱答。
不断摸索中,尝试将应用(设置——应用——安装的应用)中涉及windows app的几个应用都卸载了,如下所示:
卸载之后再安装新版本的SDK,再次运行程序,发现问题得到了解决,但此在MS的文档中并未进行相应的介绍(当前24年5月下旬,仍未发现将此写入文档中)。
回过头来看,产生这个问题的原因:要安装新版本的SDK,必须将旧版本的SDK相应的应用卸载干净才行,否则就会导致要安装的SDK不能正常安装。
不能使用低版本SDK
最近开发中遇到过一次不能使用1.3版本的SDK,一直提示要安装1.4版本的SDK,百思不得其解。今天终于发现了问题产生的原因:引用的一个项目A中使用了1.4版本的Windows App SDK,在项目B中将SDK降低到了1.3,但由于程序为了要兼容1.4导致它只能提示需要安装1.4版本的SDK。
明白了问题产生的原因,解决办法就简单了,将两个项目引用的SDK同步为一个版本即可。
针对此问题,想到了一个解决办法可以尝试:在解决方案中添加一个没有代码的项目,这个项目主要用来安装各种引用与包,而其它项目则都引用这个项目。如此就可以解决多个项目就不用都引用自己的包了,而只需要引用这个无代码项目即可。
Webview2存在bug
webView2在开发中发现的一些问题:
1. 在使用中键滚动时,若碰触了左键或右键,就会导致整个程序卡死(1.4版本的SDK存在此问题)。 解决办法是可以升级到1.5版本的SDK,但1.5SDK又存在后续的两个问题。
2. 若使用WebView2加载3D图,在进行放大缩小时极易导致WebView2卡住。 但若将webview2加载的网页用浏览器加载时,无论如何操作也不会导致浏览器出现卡顿的情况,同时在webview2卡顿时,程序的其他模块是可以正常使用的,故判断是webview2的问题,而webview2则是由SDK提供。
3. WebView2的一些属性设置了,也不会生效。如: webView.CoreWebView2.Settings.IsPinchZoomEnabled = false;
将IsPinchZoomEnabled设置为false,就是尝试解决加载3D,在触屏上用手缩放时会卡住的问题,但是经过多次试验,IsPinchZoomEnabled设置为false是无效的。
当前正测试切换不同的SDK,主要是1.3版本,以期解决问题2与3(从22日的测试来看,1.3是没有问题2与3的,且1问题也没有);若不能解决,时间允许的情况下,可以在github相应仓库提issue或尝试获取sdk源码,以找到问题解决之。
以上记之,供各位参考之,避免在开发过程走弯路。