为啥 Windows 上的第三方软件对高清屏支持这么差

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了为啥 Windows 上的第三方软件对高清屏支持这么差相关的知识,希望对你有一定的参考价值。

  从 Windows Vista 开始微软引入了一套新 API 用来处理界面缩放(是 06 年提出的,比苹果早很多)。这套机制叫 DPI Virtualization。在 Windows 8.1 里 DPI Virtualization 被强化以让不同显示器有不同的 DPI 设定。DPI Virtualization 的目的是不让老程序在高 DPI 设置下出现界面错位,同时如果新程序可以处理缩放,则交给程序自己处理。

  DPI Virtualization 依赖 dwm 实现。当 Windows 检测到你的程序(进程)不支持 DPI 缩放时(即运行非 DPI-Aware 程序),它直接放大窗口,因为有非整比的缩放所以可能会造成界面「模糊」(不信你在 8.1 里可以试试 200% 缩放,结果是锯齿状的,和 OSX 一模一样);而对于新应用则不作特别处理。这套机制的具体行为非常复杂(特别是在引入分屏 dpi 设置之后),就不多展开了。有兴趣可以参阅 High DPI Settings in Windows。判断进程是否支持缩放的 API 很奇怪地在 8.1 之前的系统里一直没给,8.1 提供了,叫 GetProcessDpiAwareness。

  Windows 应用通知系统自己支持高 DPI 有两种方式,一种是向主进程的 manifest 中写入信息,另一种是使用 SetProcessDpiAwareness 函数。在 Windows 8.1 中应用程序对高 DPI 支持有三级,对应 PROCESS_DPI_AWARENESS 的三个属性,它们分别是:
  Process_DPI_Unaware:此程序不支持高 DPI
  Process_System_DPI_Aware:此程序支持在第一屏上按高 DPI 显示,不能处理多显示器的分别设置
  Process_Pre_Monitor_DPI_Aware:此程序可以在不同显示器设置不同 DPI 时仍然工作良好
  Vista 到 Win8 只有前两级,因为它们没分显示器的 DPI 设置。此时 API 稍有变化,是使用 SetProcessDPIAware API。

  对于那些被放大窗口的应用,系统会生成一系列的「假」数据给他们,包括屏幕分辨率和鼠标座标。这样就可以保证最大程度的兼容性。

  从这种处理机制中可以看出微软在 Vista 的年代就提出了一套良好的系统来对付高 DPI 环境可能造成的兼容性问题。然而现在被很多人诟病的「Windows 不支持高分」原因在哪里呢?原因有三:
  DPI Virtualization 支持非整比缩放,导致被放大的窗口会变模糊。这是微软的责任,他们应该使用更好的缩放算法,例如 hqx 或者 xBRZ。但是记住,「模糊」是相对显示屏密度而言的,在高密度显示屏上它并没有那么「模糊」。更好的策略可能是像一些游戏机模拟器那样用两个缓冲,一个送显示一个给程序读屏用。
  仍然有大量的应用程序不支持高 DPI。这是第三方的问题。下面详细展开。
  和座标变换相关的问题。这个比较复杂,只会涉及一些跨窗口操作的应用程序和钩子程序,不展开了。
  在第三方应用程序这边,因为系统得知应用是否支持高 DPI 是,应用程序通知系统的,因此就会出现四种情况:
  应用在高 DPI 下运作正常,并通知系统:很好,应用清晰显示,行为正确。微软许多原厂应用(包括 Word 2013、VS2013 等)都能做到这一点。Sublime Text 3 也属于这一类。
  应用在高 DPI 下运作正常,然未通知系统:窗口被放大,应用程序显示模糊但是行为正确。这种应用数量不多,一些 CAD 软件有可能属于这一类(CAD 界使用高分屏已久,不少软件都有不错的高 DPI 支持)。
  应用不支持高 DPI 却错误通知系统:系统不对应用作特别处理导致界面错位或者大小不正确。类似题主中 WPS、Photoshop、Chrome 的情况。还有一种可能是用于启动程序的快捷方式里设定了「在高 DPI 下禁用界面缩放」,QQ 应当是这个问题。(因为写这个答案的时候我同时开着 QQ 和高 dpi,而我能明显看见 QQ 窗口是被放大的。WPS 也可能是这种情况。)
参考技术A 不垄断发行渠道,对第三方软件不强制品质。(因为一旦控制必然导致第三方倒戈。当年任天堂怎么死的知道没?)
没有 C/C++ 版的类 WPF 界面库。(因此如果第三方想要软件「清楚」,就必须自己处理界面缩放——这可不是个简单活。当然也可以用 .NET,问题是不是所有人都装了 .NET。)
XP 退市太晚。(导致第三方不敢使用 Vista 以来的新功能。原因太多,当然在国内绝对是因为 Vista 和之后的 OS 不好破解。)
参考技术B 因为在电脑平台,小尺寸,高分辩率的屏幕还没有普及,所以各软件厂商还没有开发支持高PPI的软件,因此字体是个问题。 参考技术C 因为在电脑平台,小尺寸,高分辩率的屏幕还没有普及,所以各软件厂商还没有开发支持高PPI的软件,因此字体是个问题。 参考技术D 毕竟大多数电脑都是普通1920*1080的,软件厂商都是针对这个分辨率啦设计软件的,所以到了高清屏字体就会显得特别小,这是软件厂商优化的问题,并不是屏幕的问题

支持投屏的视频手机软件求推荐?

很多宝宝们都在找投屏软件神器,因为这样就可以把手机里面好看的图片以及视频放在电脑上了,手机这个小屏幕真的长时间不受大家欢迎,对眼睛伤害大不说,简直时间久了看着一点都不舒服,如果投到电脑上的话那不是美滋滋,现在的投屏软件也是非常之多,接下来小编就来给你们推荐一款好用的。

  投屏软件http://www.xunjieshipin.com/download-airscreen
  安卓录屏软件http://dl.pconline.com.cn/download/1760585.html

  软件介绍:
  迅捷录屏大师APP是一款适用于安卓手机的软件,它可以录制手机屏幕视频,并且支持横竖录屏双选择、支持悬浮窗菜单,通知栏实时状态、扫一扫一键投屏等多个功能。大家如果想要录制抖音里的小视频,这款安卓录屏软件是一个不错的选择。

  操作步骤:
  1、首先在我们的手机软件商城中下载这款软件。
技术分享图片
  2、打开这款软件之后在我们的手机上打开这款软件,点击“我的”进入主页面,店家“立即登录”可以选择微信、qq授权直接登录。
技术分享图片
  3、登陆完成之后就可以录制视频了,点击投屏进入设置界面。按照下面的提示打开电脑端的“迅捷录屏大师”,启动程序窗口会自动生成二维码。点击“扫一扫投屏”按钮,扫描电脑端的二维码进行投屏,根据当前网络环境等待不同时长。
技术分享图片
  4、二维码成功后手机画面会投屏到电脑上面,这个时候就可以随意切换手机界面,这个时候电脑会同步显示,手机和电脑显示的画面是一样的。
技术分享图片
  5、如果想要全屏观看的话点击电脑端的放大按钮全屏观看就好了。
技术分享图片

  怎么样?是不是觉得像小编说的一样好用呢?感兴趣的宝宝们可以去试试看!

以上是关于为啥 Windows 上的第三方软件对高清屏支持这么差的主要内容,如果未能解决你的问题,请参考以下文章

高分屏笔记本第三方chrome浏览器字体模糊怎么办

为啥 [UIScreen mainScreen].bounds] 没有返回全屏尺寸?

两台笔记本电脑怎样共享屏幕

为啥win10锁屏壁纸会自动变成Windows聚焦?

电脑如何录制视频?

为啥我在录屏时会出现无声?