@lsmn
2018-08-17T21:45:11.000000Z
字数 1428
阅读 2024
语言
微软
XAML
你可能会觉得,Windows桌面开发已经彻底完蛋了,但根据Visual Studio中的遥测数据,每个月有大约240万开发人员在积极地开发桌面应用程序,比20个月前增长了50%。有一个如此大的社区支持,微软正在寻找方法,帮助开发人员把那些资产整合进Windows 10。
如果你的信息来源仅限于互联网,你可能会觉得,Windows桌面开发已经彻底完蛋了,但根据Visual Studio中的遥测数据,每个月有大约240万开发人员在积极地开发桌面应用程序,比20个月前增长了50%。有一个如此大的社区支持,微软正在寻找方法,帮助开发人员把那些资产整合进Windows 10。
关于微软的Windows开发,其中一个最大的抱怨是微软在Winforms和WPF上投入少;Windows 10提供的大部分新特性都只是针对UWP构建的。虽然我们现在可以从.NET Framework调用UWP API,但仅适用于不涉及UI的情况。
为了解决这个问题,微软创建了两个新控件:WinForms XAML Host和WPF XAML Host,使开发人员可以把为UWP编写的UI嵌入到现有的WinForms/WPF应用程序。
开发人员之所以继续使用WinForms或WPF,其中一个原因是为了支持Windows 7。后来,人们需要新推出的XAML Islands,这是因为它使得应用程序不在Windows 10上也可以正常运行。
其中一个例子是现在已经可以使用的WebView。如果应用程序在Windows 10上运行,那么WebView就是Edge浏览器的宿主。如果是运行在Windows 7上,那么它就会加载IE浏览器控件。
其他控件还处于规划阶段,包括MediaPlayer、InkCanvas/InkToolBar、Map和SwapChainPanel。
把WinForms和WPF混合使用的开发人员都熟悉“空域(airspace)”的概念,它是用于处理在同一个窗口中来自不同UI框架的控件相互重叠的问题。
在Win32开发中,屏幕上的每个对象自己都有一个在OS层面注册的窗口句柄(HWND)。HWND关联着屏幕上的一个矩形,对象可以在其中渲染其内容。一般来说,每个WinForms控件都会获得自己的HWND,而大多数WPF控件都共享整个窗口的HWND。
对于XAML Islands(WinForms和WPF),HWND创建后供UWP控件使用。这会带来一些不明显的影响。例如,如果你旋转UWP控件,HWND不会随之旋转,也就是说,HWND需要更大一些才能为它提供空间。
弹出式上下文菜单尤其难以处理。它们通常有自己的HWND,但是,该HWND不一定能够和XAML的HWND正确堆叠,导致菜单看上去在另一个控件后面。
目前在UWP中,每个顶级窗口预计都有自己专有的UI线程。例如说,你有一个主-从视图,从视图是用UWP编写的。你可以通过以下几种方式实现:
最终,这个问题将通过引入轻量级窗口来解决。
查看英文原文:Modernizing Windows Desktop Applications with XAML Islands