当前位置: 首页 > news >正文

winform嵌入excel 设置父窗体分辨率不是100% 嵌入excel分辨率变成双倍大小

在WinForms应用程序中嵌入Excel时,遇到分辨率问题可能是由于DPI缩放导致的。Windows 10及更高版本默认启用了DPI缩放,以便在高分辨率显示器上显示更清晰的内容。这可能会导致嵌入的应用程序(如Excel)看起来变大或变小。

 解决方案

1. **设置WinForms应用程序为DPI感知**:确保你的WinForms应用程序对高DPI显示器进行正确处理。

2. **禁用嵌入Excel窗口的DPI缩放**:通过修改Excel进程的DPI感知属性来避免其在高DPI环境中进行缩放。

 具体步骤

 1. 设置WinForms应用程序为DPI感知

在你的WinForms应用程序的App.config文件中,添加以下内容:

xml

<?xml version="1.0" encoding="utf-8" ?>
<configuration><startup><supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.7.2" /></startup><system.windows.forms.applicationConfiguration><add key="DpiAwareness" value="PerMonitorV2" /></system.windows.forms.applicationConfiguration>
</configuration>


 2. 禁用嵌入Excel窗口的DPI缩放

在嵌入Excel的代码中,通过调用Windows API来设置Excel进程的DPI感知属性。

你需要引入以下命名空间和P/Invoke声明:csharp

using System;
using System.Diagnostics;
using System.Runtime.InteropServices;
using System.Windows.Forms;public class ExcelEmbedder
{[DllImport("user32.dll")]private static extern IntPtr SetParent(IntPtr hWndChild, IntPtr hWndNewParent);[DllImport("user32.dll", SetLastError = true)][return: MarshalAs(UnmanagedType.Bool)]private static extern bool SetProcessDPIAware();[DllImport("user32.dll", SetLastError = true)]private static extern bool SetProcessDpiAwarenessContext(int dpiFlag);private const int DPI_AWARENESS_CONTEXT_PER_MONITOR_AWARE_V2 = -4;public static void EmbedExcel(Control ctrl){// 启动Excelvar excelApp = new Microsoft.Office.Interop.Excel.Application{Visible = true};var process = Process.GetProcessesByName("EXCEL")[0];// 设置Excel进程为DPI感知SetProcessDpiAwarenessContext(DPI_AWARENESS_CONTEXT_PER_MONITOR_AWARE_V2);// 将Excel窗口嵌入到WinForms控件中SetParent(process.MainWindowHandle, ctrl.Handle);}
}


注意:

- SetProcessDPIAware函数用于将整个应用程序设置为DPI感知,但已被推荐的SetProcessDpiAwarenessContext取代。
- SetProcessDpiAwarenessContext函数设置当前进程的DPI感知上下文,这里我们设置为PER_MONITOR_AWARE_V2,这是最适合在多显示器高DPI环境中使用的模式。

 使用示例

在你的WinForms应用程序中,调用EmbedExcel方法来嵌入Excel:

csharp
private void Form1_Load(object sender, EventArgs e)
{
    ExcelEmbedder.EmbedExcel(this.panel1); // 假设panel1是你希望嵌入Excel的控件
}


 总结

通过设置WinForms应用程序和嵌入的Excel窗口为DPI感知,可以解决在高分辨率显示器上嵌入Excel时出现的大小问题。确保你的应用程序正确处理DPI缩放,以提供一致的用户体验。

http://www.lryc.cn/news/350627.html

相关文章:

  • 前端系列-4 promise与async/await与fetch/axios使用方式
  • 微信公众号自定义分销商城小程序源码系统 带完整的安装代码吧以及系统部署搭建教程
  • 在另外一个页面,让另外一个页面弹框显示操作(调佣公共的弹框)vue
  • 羊毛-百度Comate领50京东E卡
  • kafka安装部署
  • VBA直连SAP RFC 接口实例
  • 2024如何挑选开放式蓝牙耳机?热门爆款熬夜整理六个点!
  • 3D数据格式转换工具HOOPS Exchange在PLM系统中的5大应用优势
  • 友元是一种允许某些外部函数或类访问另一个类的成员的机制
  • 儿童护眼台灯哪个牌子好,适合儿童使用的护眼台灯推荐
  • 在电脑本地运行llama3-8b模型
  • 深入理解 House of Cat
  • 【Linux玩物志】Linux环境开发基本工具使用(1)——vim
  • Lora训练Windows[笔记]
  • nuget局域网在线包制作,nuget打包,nuget打自己的包
  • Ubuntu 24 换国内源及原理 (阿里源)
  • python学习-使用pandas库分析excel表,并导出所需的表
  • Python中使用C扩展详解
  • llama使用tutorial微调(windows版本)
  • MyBatis操作数据库(动态SQL)
  • python发票真伪查验开发文档、票据OCR、数电票查验
  • Unity构建详解(12)——自动构建
  • 中文编程降低了中文环境下编程入门的门槛
  • 通过内网穿透免费部署我们的springboot+vue项目 实现跟服务器一样的效果
  • SMB攻击利用之-mimikatz上传/下载流量数据包逆向分析
  • Mysql常见数据类型探索
  • 2024 年第四届长三角高校数学建模竞赛赛题B题超详细解题思路+问题一二代码分享
  • 干货速学!1+X电子商务数据分析:电子商务数据分析的流程
  • 618好物推荐大赏:2024年必囤好物一网打尽,购物攻略助你抢购无忧!
  • 【MySQL】基础操作(DDL,DML,DCL,DQL)