【技术】彻底解决WinForms在高DPI下的设计问题
acmilan2016/04/06软件综合 IP:四川
已知问题:WinForms设计器在高DPI下,初始控件大小过小,如图所示:

Capture3.png

解决方案1:将sharpdevelop.exe程序资源manifest中的<ws:dpiAware>true</ws:dpiAware>注释掉,失败。

分析原因:启动后某些组件仍会调用SetProcessDPIAware函数,仍会导致DPI虚拟化被关闭。

解决方案2:将sharpdevelop.exe程序资源manifest中的<ws:dpiAware>true</ws:dpiAware>改为<ws:dpiAware>false</ws:dpiAware>,成功。

分析原因:DPI虚拟化级别只能设置一次,在manifest中设置后会屏蔽任何的SetProcessDPIAware调用。

【步骤】

1.安装最新版SharpDevelop(XXXXXXXXXXXXXXXXXXXXXXXXXt/OpenSource/SD/XXXXXXXXXXpx

2.从C:\Program Files (x86)\SharpDevelop\4.4\bin复制出SharpDevelop.exe

3.用十六进制编辑器打开这个文件,搜索dpiAware,如图所示:

Capture.png

4.用覆盖模式将<ws:dpiAware>true</ws:dpiAware>改为<ws:dpiAware>false</ws:dpiAware>,如图所示:

Capture2.png

5.将修改后的SharpDevelop.exe覆盖回C:\Program Files (x86)\SharpDevelop\4.4\bin,再次启动,尝试,控件初始大小正常!

Capture4.png

【更普遍的解决方法】

Windows还提供了一个注册表,可以让PE Loader优先使用外部的*.XXXXXXnifest文件,而不是内部的manifest资源:

1.按Win+R打开运行对话框,输入regedit回车,找到HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\SideBySide,新建DWORD值,名称为PreferExternalManifest,值设为1。

Capture5.png

2.将C:\Program Files (x86)\SharpDevelop\4.4\bin\SharpDevelop.exe复制到桌面,重命名SharpDevelop.txt,打开,搜索</assembly>。

Capture6.png

3.复制<?xml version="1.0" encoding="UTF-8" standalone="yes"?>到</assembly>的所有内容。

4.新建文本文档,将所有内容粘贴进去,修改<ws:dpiAware>true</ws:dpiAware>为false。

Capture7.png

5.将该文件保存为XXXXXXXXXXXXXXXXXXXnifest,文件类型选【所有文件 (*.*)】。

Capture8.png

6.把这个文件复制到C:\Program Files (x86)\SharpDevelop\4.4\bin文件夹下,再次启动,尝试,控件初始大小正常!

Capture4.png

[修改于 8年9个月前 - 2016/04/06 16:13:24]

来自:计算机科学 / 软件综合
3
已屏蔽 原因:{{ notice.reason }}已屏蔽
{{notice.noticeContent}}
~~空空如也
acmilan 作者
8年9个月前 修改于 8年9个月前 IP:四川
815246
VS2015和SharpDevelop的高DPI补丁:
attachment icon VS2015和SharpDevelop的高DPI补丁.rar 2.70KB RAR 38次下载

原版SharpDevelop(未打补丁):
attachment icon SharpDevelop_4.4.2.9749_Setup.rar 13.96MB RAR 38次下载
引用
评论
加载评论中,请稍候...
200字以内,仅用于支线交流,主线讨论请采用回复功能。
折叠评论
acmilan作者
8年9个月前 修改于 8年9个月前 IP:四川
815249
此方法适用于修复不兼容高DPI却关闭了DPI虚拟化的软件,如Photoshop CS6等。

注意:本帖所述方法只适用于Windows 8.1及以上版本的操作系统,对Windows 7无效。

原因:在Windows 7中设置dpiAware为false相当于什么都没做,而Windows 8.1中则相当于调用SetProcessDpiAwareness(0)。
引用
评论
加载评论中,请稍候...
200字以内,仅用于支线交流,主线讨论请采用回复功能。
折叠评论
acmilan作者
8年8个月前 IP:四川
816712
补充:Win8.1在126%+才会开启DPI虚拟化,因此如果屏幕是1080p,并且开启125%缩放,在Win10下使用本帖的方法才有效。在Win8.1下可以设置自定义缩放级别为126%来强制开启。
引用
评论
加载评论中,请稍候...
200字以内,仅用于支线交流,主线讨论请采用回复功能。
折叠评论

想参与大家的讨论?现在就 登录 或者 注册

所属专业
所属分类
上级专业
同级专业
acmilan
进士 学者 笔友
文章
461
回复
2934
学术分
4
2009/05/30注册,5年10个月前活动
暂无简介
主体类型:个人
所属领域:无
认证方式:邮箱
IP归属地:未同步
文件下载
加载中...
{{errorInfo}}
{{downloadWarning}}
你在 {{downloadTime}} 下载过当前文件。
文件名称:{{resource.defaultFile.name}}
下载次数:{{resource.hits}}
上传用户:{{uploader.username}}
所需积分:{{costScores}},{{holdScores}}下载当前附件免费{{description}}
积分不足,去充值
文件已丢失

当前账号的附件下载数量限制如下:
时段 个数
{{f.startingTime}}点 - {{f.endTime}}点 {{f.fileCount}}
视频暂不能访问,请登录试试
仅供内部学术交流或培训使用,请先保存到本地。本内容不代表科创观点,未经原作者同意,请勿转载。
音频暂不能访问,请登录试试
支持的图片格式:jpg, jpeg, png
插入公式
评论控制
加载中...
文号:{{pid}}
投诉或举报
加载中...
{{tip}}
请选择违规类型:
{{reason.type}}

空空如也

加载中...
详情
详情
推送到专栏从专栏移除
设为匿名取消匿名
查看作者
回复
只看作者
加入收藏取消收藏
收藏
取消收藏
折叠回复
置顶取消置顶
评学术分
鼓励
设为精选取消精选
管理提醒
编辑
通过审核
评论控制
退修或删除
历史版本
违规记录
投诉或举报
加入黑名单移除黑名单
查看IP
{{format('YYYY/MM/DD HH:mm:ss', toc)}}