Событие Form.HandleCreated никогда не происходит - PullRequest
1 голос
/ 13 мая 2011

Как было запрошено, я установил небольшой внутренний просмотрщик журналов для одного из моих проектов с открытым исходным кодом (самоописательное изображение ниже). При этом у меня возникла очень странная проблема, когда событие 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 .

1 Ответ

2 голосов
/ 14 мая 2011
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...