2011-05-13 74 views
1

按照要求,我为我的一个开放源代码项目(下面的自描述图像)提供了一个小型内部日志查看器。在这样做的时候,我有一个非常奇怪的问题,那就是新创建的窗口的HandleCreated事件根本没有发生。我正在观看此事件,以确保在调用任何控件之前创建了句柄。Form.HandleCreated事件从不发生

NBug Internal Log Viewer

下面是有问题的代码(静态构造)。有没有人有这方面的解决方法,因为没有任何常用的技巧(如var a = form.Handle;)强制创建句柄根本没有任何帮助。

internal partial class InternalLogViewer : Form 
{ 
    static InternalLogViewer() 
    { 
     viewer = new InternalLogViewer(); 
     formShown = new ManualResetEvent(false); 
     viewer.HandleCreated += (sender, e) => formShown.Set(); 
     Task.Factory.StartNew(() => viewer.ShowDialog()); 
     formShown.WaitOne(); // ToDo: This needs a workaround as it waits for an eternity 
    } 

    private static InternalLogViewer viewer; 
    private static ManualResetEvent formShown; 

    public static void LogEntry(string message, LoggerCategory category) 
    { 
     viewer.Invoke((MethodInvoker)delegate 
     { 
      viewer.InternalLogEntry(message, category); 
     }); 
    } 

    internal InternalLogViewer() 
    { 
     InitializeComponent(); 
     this.Icon = Properties.Resources.NBug_icon_16; 
     this.notifyIcon.Icon = Properties.Resources.NBug_icon_16; 
    } 

    internal void InternalLogEntry(string message, LoggerCategory category) 
    { 
     this.loggerListView.Items.Add(new ListViewItem(new[] { category.ToString().Remove(0, 4), DateTime.Now.ToString("HH:mm:ss"), message })); 
    } 
} 

编辑:代码取自NBug库。

+4

可能与以下内容有关:http://blogs.msdn.com/b/pfxteam/archive/2011/05/03/10159682.aspx – Dmitry 2011-05-13 13:00:24

+0

哦,我将静态构造函数的内容移动到一个单独的函数中,并调用为初始化实际上工作。我真的无法想象这样的僵局! – 2011-05-13 13:15:48

+0

@Dmitry:看起来像您找到了解决方案,请将其作为下面的“答案”发布,以便读者知道这是一个很好的答案。 – 2011-05-13 23:12:06

回答