为什么微软 WSL 的默认终端输入体验比其他同类的

社会热点 2020-09-05 17:06www.guomeikuaidi.com快递查询单号

  一名开发者(下用Nick代称)在 Wdos Termal的GitHub repo中发表了一个不是反馈问题的 issue ——他只是好奇该终端拥有这种如此顺滑输入的效果是如何实现的。

  Nick觉得这种顺滑感是其他Wdos应用都不具备的,甚至是最轻量的 notepad.exe 都未能提供这种输入体验。他还问到,这种 UI增强功能将来是否会应用于所有Wdos应用程序。

  很快,负责此项目的Wdos开发团队成员(@miksa)对Nick的疑问进行了解答。

  miksa表示,保持在WSL(Wdos Subsystem for Lux)默认终端输入内容的速度比其他应用快,这实际上就是他们唯一的工作!除此之外,也可能是因为他们必须使用Wdos最旧和最低级别的API来完成此项工作。

  WSL的默认终端不像 Electron等框架那样涉及到许多其他的层或框架,它有一个并不特别的裸窗口,并且没有任何附加组件。他们会从窗口消息(do messages)而不是某种事件框架((WPF, WForms, UWP, Electron))来处理键入的内容,而这些内容是通过内核传输过来的。接着,他们使用GDI的PolyTextOut将文本直接转储到窗口而不带多余的装饰。

  miksa解释道,notepad.exe确实很轻量,不过在其窗口上也具有多个控件,并且可能在编辑控件中使用某种库、框架来确定其文本布局(也可能正在使用其他库或框架进行国际化支持...),这些都使得它们的输入速度比不上WSL默认终端。,WSL也需要进行权衡取舍,它不像其他应用那样提供完全的国际化支持。

  为什么要这样做?第一,conhost.exe已十分陈旧。它必须使用所有内容的裸机底层,因为它是在创建其他大多数框架之前创建的。第二,它需要保持尽可能底层的级别,而且它是用C/C++编写的,它需要尽可能保持底层的状态以方便提供给第三方使用。

  至于其他Wdos应用是否有机会用上这种顺滑的输入效果,miksa觉得几乎是没机会。这些应用能够以一种简单的方式用任何一门语言来调用一种方法和布局文本(layout text),而无需手动计算像素或关心它们的字体该采用哪种样式。而恰好miksa手动计算像素、滑动区域和数学应用区域等的方式正是使得WSL默认终端输入速度更快的原因。

特别提醒本网内容转载自其他媒体,目的在于传递更多信息,并不代表本网赞同其观点。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,并请自行核实相关内容。本站不承担此类作品侵权行为的直接责任及连带责任。如若本网有任何内容侵犯您的权益,请及时联系我们,本站将会在24小时内处理完毕。


Copyright © 2016-2025 www.guomeikuaidi.com 寄快递 版权所有 Power by