高分屏电脑开发的winforms软件如何确保在低分屏显示正常

高分屏电脑通常我们会设置缩放比例, 比如我的开发电脑为4K屏, 设置的缩放比例为150%, 即每英寸显示点数DPI为144个, 这样Windows显示效果最好; 对于低分屏, 通常的缩放比例为100%, 即每英寸显示点DPI为96个.

我们在高分屏上设计winforms软件窗体布局, 不做特意处理, 将来软件运行在低分屏电脑上, 窗体布局和文字显示很可能会错位.
这里介绍两种做法:

  1. 将软件做成 dpiAware, 这个做法需要考虑非常多的情况, 窗体大小/布局/控件大小/字体大小, 做的完美开发成本很高. 优点是, 系统如果部署在比开发机更高DPI的机器上, 显示效果依然很好.
  2. 软件不启用 dpiAware. VS的窗体设计器不不启用缩放模式, 同时软件也不启用dpiAware, 将来在低分屏上运行, 窗体/控件尺寸和字体大小都和设计时一样.

如果要采用第一种做法, 可以按照本文的参考文档进行实践, 我这里使用的就是第2种做法, 下面是要点:

Visual studio 禁用自动缩放功能

启动命令行为 devenv.exe /noscale , 这样可保证UI 设计的样子没有缩放效果, 和将来在低分屏运行的尺寸一样. 缺点是VS中的字体有些模糊.
在这种模式下, Visual Studio 总是提示我们目前处于禁用缩放模式, 是否要开启的通知。 可以通过下面的设置关闭通知提示:
选择“工具”>“选项”,打开“选项”对话框 。在“选项”对话框中,选择“Windows 窗体设计器”>“常规”,然后将“DPI 缩放通知”设置为“False”。

项目增加 app.manifest 文件

将 dpiAware 设置为false, 禁用 dpiAware

<application xmlns="urn:schemas-microsoft-com:asm.v3">
		<windowsSettings>
			<dpiAware xmlns="http://schemas.microsoft.com/SMI/2005/WindowsSettings">false</dpiAware>
			<longPathAware xmlns="http://schemas.microsoft.com/SMI/2016/WindowsSettings">true</longPathAware>
		</windowsSettings>
	</application>

编辑 app.cnfig 文件

将 EnableWindowsFormsHighDpiAutoResizing 设置为false, 否则即使在禁用 dpiAware 情况下, 窗体的位置也会变化.

<!-- DpiAwareness 设置为效果更好的 PerMonitorV2 模式  -->
	<System.Windows.Forms.ApplicationConfigurationSection>
		<add key="DpiAwareness" value="PerMonitorV2" />
	</System.Windows.Forms.ApplicationConfigurationSection>
	<appSettings>
		<add key="EnableWindowsFormsHighDpiAutoResizing" value="false" />
	</appSettings>

更多 dpiAware 资料

  1. telerik 厂商的说明 https://www.telerik.com/blogs/winforms-scaling-at-large-dpi-settings-is-it-even-possible-
  2. devexpress 厂商的说明 <>https://docs.devexpress.com/WindowsForms/116666/common-features/high-dpi-support>
  3. SOUI 组件的说明 https://www.cnblogs.com/setoutsoft/p/16425917.html
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值