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)
    {
        // 启动Excel
        var 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缩放,以提供一致的用户体验。

  • 7
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值