LGPL License.
The ApplicationHost project is a prototype implementation for hosting .NET applications in a user control.
The idea for implementing this functionality came from the roozz hosted LINQPad instance. Roozz provides a mechanism for running .NET applications inside a Google Chrome page. The ApplicationHost project attempts to replicate this functionality, but instead of hosting the application inside a Google Chrome tab, it hosts it in a user control.
Using the ApplicationHost user control involves two steps:
- Place the AppHost control on a form;
- Call the StartApplication method with the path to the executable to execute.
These basic steps are enough to get yourself up and running. For a more comprehensive example, see MainForm.cs of the demo application.
The demo application shows how to run a .NET application inside the application host. To use the demo application, download e.g. LINQPad, place it in a location where it can be found by the demo application and uncomment the StartApplication line in the MainForm_Shown method in MainForm.cs.
ApplicationHost works by hooking into Windows and watching for newly created windows. When the application host finds a new window, it transforms so that it is hosted in the user control instead of like a normal application. This mechanism is implemented using window filters. A window filter is a class that derives from the WindowFilter class. An implementation provides logic for matching a newly created window against some criteria. When it is matched, the filter will be used to attach the window to the application host, resize it and detach it from the application host.
The current implementation has been tested with Reflector and LINQPad. When you want to host an application which is not properly handled by the default filters, you can implement your own window filter by deriving from the WindowFilter class. Refer to the existing implementations for information on how to implement a custom WindowFilter.
The primary mechanism with which windows are matched is by WindowStyle and WindowStyleEx. The easiest way to discover the styles of a window is to use Spy++. This should be installed automatically with your Visual Studio installation.
To use a custom WindowFilter, add an instance of your custom filter to the WindowFilters collection before starting the application.
ApplicationHost is licensed under the LGPL 3.