3

在 Windows 7、.NET 4.0 上,我有一个问题可以通过将以下代码复制到 Visual Studio 生成的空白 WPF 应用程序中来重现:

    public MainWindow()
    {
        InitializeComponent();
        Loaded += new RoutedEventHandler(MainWindow_Loaded);
    }

    void MainWindow_Loaded(object sender, RoutedEventArgs e)
    {
        new Window() { Title = "Test", ShowInTaskbar = false, Owner = this }.Show();
    }
  1. 运行应用
  2. 激活辅助窗口
  3. Alt-Tab 到其他正在运行的应用程序
  4. 使用鼠标在任务栏中激活我们的 WPF 应用程序

现在 WPF 应用程序再次处于活动状态,辅助窗口已激活,主窗口已停用,这是预期(和期望)的行为。

现在改为执行此操作(仅第 4 步不同):

  1. 运行应用
  2. 激活辅助窗口
  3. Alt-Tab 到其他正在运行的应用程序
  4. Alt-Tab 返回我们的 WPF 应用程序

WPF 应用程序再次处于活动状态,但现在主窗口已激活。添加此代码

private void Application_Activated(object sender, EventArgs e)
{
    Windows[1].Activate();
}

到 App.xaml.cs 并不能解决问题,因为现在在第二种情况下,两个窗口都被激活。此外,单击辅助窗口不会停用主窗口。我必须再次单击(已激活)主窗口和辅助窗口才能实现此目的。

我怎样才能避免这种情况(在这两种情况下只有辅助窗口应该是活动的)?

4

2 回答 2

1

CodeProject 实际上在这里解决了这个问题,希望这就是你要找的。

结合Tamil Khason 的帖子,理论上您可以在全局级别上覆盖 OnFocus 事件,这样每次窗口聚焦时,它都会成为“主窗口”,然后将成为 ALT+TAB 的目标。

于 2013-05-21T15:10:06.710 回答
0

基于解决方案,以下代码可能(未经测试的喷气机)也可以解决问题

  protected override void OnStartup(StartupEventArgs e)
            {
                EventManager.RegisterClassHandler(typeof(Window), Window.LoadedEvent, new RoutedEventHandler(WindowLoaded));

                base.OnStartup(e);
            }

    void WindowLoaded(object sender, RoutedEventArgs e)
            {
                Window w = sender as Window;
                if (w != null)
                {
                   // this part works in my case very well
                    w.Owner =Application.Current.Windows.OfType<Window>().SingleOrDefault(x => x.IsActive);
                }
            }
于 2013-05-28T14:38:39.157 回答