Share via


Windows Forms and Unmanaged Applications Overview

Windows Forms applications and controls can interoperate with unmanaged applications, with some caveats. The following sections describe the scenarios and configurations that Windows Forms applications and controls support and those that they do not support.

Windows Forms Controls and ActiveX Applications

With the exception of Microsoft Internet Explorer and Microsoft Foundation Classes (MFC), Windows Forms controls are not supported in applications designed to host ActiveX controls. Other applications and development tools that are capable of hosting ActiveX controls, including the ActiveX test containers from versions of Visual Studio that are earlier than Visual Studio .NET 2003, are not supported hosts for Windows Forms controls.

These constraints also apply to the use of Windows Forms controls through Component Object Model COM interop. The use of a Windows Forms control through a COM callable wrapper (CCW) is supported only in Internet Explorer. For more information about COM interop, see

COM Interop and Advanced COM Interoperability.

The following table shows the available ActiveX hosting support for Windows Forms controls.

Windows Forms version Support

.NET Framework version 1.0

Internet Explorer 5.01 and later versions

.NET Framework version 1.1 and later

Internet Explorer 5.01 and later versions

Microsoft Foundation Classes (MFC) 7.0 and later

Hosting Windows Forms components as ActiveX controls

In the .NET Framework 1.1, support was extended to include MFC 7.0 and later versions. This support includes any container that is fully compatible with the MFC 7.0 and later ActiveX control container.

However, registration of Windows Forms controls as ActiveX controls is not supported. Also, calling the com.ms.win32.Ole32.CoCreateInstance method for Windows Forms controls is not supported. Only managed activation of Windows Forms controls is supported. Once you create a Windows Forms control, you can host it in an MFC application just as with an ActiveX control.

To use Windows Forms controls in your unmanaged application, you must either host the CLR using the unmanaged CLR hosting APIs or use the C++ interop features. Using the C++ interop features is the recommended solution.

Windows Forms in COM client applications

When you open a Windows Form from a COM client application, such as a Visual Basic 6.0 application or an MFC application, the form may behave unexpectedly. For example, when you press the TAB key, the focus does not change from one control to another control. When you press the ENTER key while a command button has focus, the button's Click event is not raised. You may also experience unexpected behavior for keystrokes or mouse activity.

This behavior occurs because the unmanaged application does not implement the message loop support that Windows Forms requires to work correctly. The message loop provided by the COM client application is fundamentally different from the Windows Forms message loop.

An application's message loop is an internal program loop that retrieves messages from a thread's message queue, translates them, and then sends them to the application to be handled. The message loop for a Windows Form does not have the same architecture as message loops that earlier applications, such as Visual Basic 6.0 applications and MFC applications, provide. The window messages that are posted to the message loop may be handled differently than the Windows Form expects. Therefore, unexpected behavior may occur. Some keystroke combinations may not work, some mouse activity may not work, or some events may not be raised as expected.

Resolving Interoperability Issues

You can resolve these problems by displaying the form on a .NET Framework message loop, which is created by using the System.Windows.Forms.Application.Run method.

To make a Windows Form work correctly from a COM client application, you must run it on a Windows Forms message loop. To do this, use one of the following approaches:

See Also

Tasks

How to: Support COM Interop by Displaying a Windows Form with the ShowDialog Method
How to: Support COM Interop by Displaying Each Windows Form on Its Own Thread
How to: Support COM Interop by Displaying Windows Forms on a Shared Thread

Reference

Windows Forms ActiveX Control Importer (Aximp.exe)

Concepts

Exposing .NET Framework Components to COM
Packaging an Assembly for COM
Registering Assemblies with COM

Other Resources

Windows Forms and Unmanaged Applications
COM Interop
Advanced COM Interoperability
COM Interoperability in .NET Framework Applications
COM Interoperability Samples