Почему событие DocumentComplete COM-объекта WebBrowser срабатывает до загрузки страницы?Я думал, что это событие вызывается только когда страница полностью отображается в окне браузера.
это моя реализация BHO:
[ComVisible(true),
Guid("5a954357-44bd-4660-9570-17bb1b71eeaa"),
ClassInterface(ClassInterfaceType.None)]
public class BHO : IObjectWithSite
{
private WebBrowser browser;
private DateTime startTime;
private DateTime endTime;
private object _pUnkSite;
public void OnDocumentComplete(object pDisp, ref object URL)
{
if (!ReferenceEquals(pDisp, _pUnkSite))
{
return;
}
using (StreamWriter sw = File.AppendText("log_path"))
{
endTime = DateTime.Now;
TimeSpan ts = endTime.Subtract(startTime);
sw.WriteLine("completed in {0}.{1}", ts.Seconds, ts.Milliseconds);
}
}
public void OnBeforeNavigate2(object pDisp, ref object URL, ref object Flags, ref object TargetFrameName, ref object PostData, ref object Headers, ref bool Cancel)
{
if (!ReferenceEquals(pDisp, _pUnkSite))
{
return;
}
startTime = DateTime.Now;
}
public int SetSite(object site)
{
if (site != null)
{
_pUnkSite = site;
browser = (WebBrowser)site;
browser.DocumentComplete += new DWebBrowserEvents2_DocumentCompleteEventHandler(this.OnDocumentComplete);
browser.BeforeNavigate2 += new DWebBrowserEvents2_BeforeNavigate2EventHandler(this.OnBeforeNavigate2);
}
else
{
browser.DocumentComplete -= new DWebBrowserEvents2_DocumentCompleteEventHandler(this.OnDocumentComplete);
browser.BeforeNavigate2 -= new DWebBrowserEvents2_BeforeNavigate2EventHandler(this.OnBeforeNavigate2);
browser = null;
}
return 0;
}
public int GetSite(ref Guid guid, out IntPtr ppvSite)
{
IntPtr punk = Marshal.GetIUnknownForObject(browser);
int hr = Marshal.QueryInterface(punk, ref guid, out ppvSite);
Marshal.Release(punk);
return hr;
}
}