如何在 Excel VSTO 插件中将 WPF 窗口居中

2024-02-20

问题是 WPF 窗口仅采用 system.form.window,因此我无法将 Excel 设置为 VSTO 应用程序中的所有者对象,因为 VSTO 插件仅公开 Excel 的 hwnd 或其活动窗口作为本机窗口,因为它是COM。这意味着当 WindowStartUpLoadation 设置为中心所有者时,它不起作用。所以我被迫解决这个问题。

读完后到目前为止我想到了什么这个网站 http://blogs.msdn.com/b/wpfsdk/archive/2007/04/03/centering-wpf-windows-with-wpf-and-non-wpf-owner-windows.aspx是尝试手动使窗口居中,但即使使用他的简单示例,我的窗口也永远不会居中。

 private static void CenterWpfWindowInExcel(WpfParameterDialog wpfDialog)
    {
        WindowInteropHelper helper = new WindowInteropHelper(wpfDialog);
        helper.Owner = new IntPtr(Globals.ExcelAddin.Application.Hwnd);


        // Manually calculate Top/Left to appear centered
        double nonWpfOwnerLeft = Globals.ExcelAddin.Application.ActiveWindow.Left; // Get non-WPF owner’s Left
        double nonWpfOwnerWidth = Globals.ExcelAddin.Application.ActiveWindow.Width; // Get non-WPF owner’s Width
        double nonWpfOwnerTop = Globals.ExcelAddin.Application.ActiveWindow.Top; // Get non-WPF owner’s Top
        double nonWpfOwnerHeight = Globals.ExcelAddin.Application.ActiveWindow.Height; // Get non-WPF owner’s Height
        wpfDialog.WindowStartupLocation = WindowStartupLocation.Manual;
        wpfDialog.Left = nonWpfOwnerLeft + (nonWpfOwnerWidth - wpfDialog.Width)/2;
        wpfDialog.Top = nonWpfOwnerTop + (nonWpfOwnerHeight - wpfDialog.Height)/2;
    }

有任何想法吗?


我能够通过使用获取主 Excel 窗口的矩形来解决这个问题user32.dll

[DllImport("user32.dll", SetLastError = true)]
[return: MarshalAs(UnmanagedType.Bool)]
static extern bool GetWindowRect(IntPtr hWnd, ref RECT lpRect);
[StructLayout(LayoutKind.Sequential)]
private struct RECT
{
    public int Left;
    public int Top;
    public int Right;
    public int Bottom;
}

看来 Globals.ExcelAddin.Application.ActiveWindow 没有给我返回我期望的尺寸。我认为它给了我 Ribbon Addin 的尺寸,而不是 Excel 的主窗口。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

如何在 Excel VSTO 插件中将 WPF 窗口居中 的相关文章

随机推荐