Mar*_*tuc 10 wpf interop winforms
我有一个WinForms用户控件,其中包含一个WPF自定义列表框.在WinForms用户控件被禁用然后重新启用后,WinForms用户控件中的WPF控件没有响应.还有其他人经历过这个吗?
每次控件被禁用/启用以修复问题时,我们必须破解灵魂去除并重新添加元素主机.
wpfControl.Enabled = false;
...
wpfControl.Enabled = true;
Run Code Online (Sandbox Code Playgroud)
用于修复用户控件的WinForms EnabledChanged方法的Hack
if ( Enabled )
{
ElementHost oldEh = ctlElementHost;
ElementHost eh = new ElementHost();
eh.Name = oldEh.Name;
oldEh.Child = null;
eh.Child = wpfControl;
this.Controls.Remove( ctlElementHost );
this.Controls.Add( eh );
eh.Dock = DockStyle.Fill;
oldEh.Dispose();
ctlElementHost = eh;
}
Run Code Online (Sandbox Code Playgroud)
在托管WinForms用户控件的父窗体关闭之前,似乎存在内存泄漏,其中已处理的元素主机仍然存在.
我的一位同事(感谢KwB)设法找到了解决此问题的方法:http://support.microsoft.com/kb/955753
它涉及继承ElementHost并手动告诉窗口区域启用:
public class MyElementHost : ElementHost
{
protected override void OnEnabledChanged(EventArgs e)
{
SynchChildEnableState();
base.OnEnabledChanged(e);
}
private void SynchChildEnableState()
{
IntPtr childHandle = GetWindow(Handle, GW_CHILD);
if (childHandle != IntPtr.Zero)
{
EnableWindow(childHandle, Enabled);
}
}
private const uint GW_CHILD = 5;
[DllImport("user32.dll")]
private extern static IntPtr GetWindow(IntPtr hWnd, uint uCmd);
[DllImport("user32.dll")]
private extern static bool EnableWindow(IntPtr hWnd, bool bEnable);
}
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
2635 次 |
最近记录: |