Click here to Skip to main content
14,297,585 members

Word Control for .NET

Rate this:
4.85 (50 votes)
Please Sign up or sign in to vote.
4.85 (50 votes)
28 Jan 2003GPL3
Writing a control to use MS-Word in your own Application like a windows-form.

Sample Image - winwordcontrol.jpg


This control allows you to use MS Word 2000 in your own projects such as a windows form. Of course that's a little "dirty trick". But if you have some documentation to display and you want to use Word for it, here is the solution.


I was working on an internal research project and we developed a tool to teach C++, and there was a problem about how to display the exercises. The main problem was, I had difficult formulas in these descriptions so the only possible solution was to convert the files to PDF or to another file format. With PDF I had a problem, because I couldn't edit the documents afterwards. So, I was looking for an ActiveX or .NET control for MS Word. Finally, I couldn't find one. So I decided to write one for .NET.

How to use the control?

It's almost too easy to use the form. You just need to add a link to the winwordcontrol.dll.  The steps are:

  1. Goto your Toolbox.

    Visual Studio Toolbox

  2. Click right. Select "Customize Toolbox".

    Toolbox Cutomizing

  3. Select the ".NET Components" tab.
  4. Select the winwordcontrol.dll using the file browse dialog. Click OK. After that you will find a new form in your toolbox called "winwordcontrol".

    Toolbox winwordcontrol/winwordcontrol

Drag and drop it just like any other form. The only thing you should know is how to control it. At this moment, there are four methods:

winwordcontrolinstance.LoadDocument(<string path>); 
With LoadDocument you can load all files Word can handle. Please specify the complete path! This is the only method that is probably useful for everyone. All the other methods are not necessary for normal use.
This method closes the actual document. This is mostly not necessary because LoadDocument() can handle multiple calls without calling CloseControl() before.
Preloading. This method should be used if you don't want to wait in the main program until Word is finished starting.
Reactivates all the Menubars.

The control will automatically start Word if it's not already open and it will display the document.

How does this work?

The basic idea is to instantiate the Word application, as everybody knows, with:

wordInstance = new Word.Application();
Now we have the Word application in a separate window. How do we get this window in our control? The answer is ... Win32 API. We need to import some API functions from user32.dll as shown here:
public static extern int FindWindow(string strclassName, string strWindowName);

static extern int SetParent(int hWndChild, int hWndNewParent);

[DllImport("user32.dll", EntryPoint = "SetWindowPos")]
static extern bool SetWindowPos(
	int hWnd,               // handle to window
	int hWndInsertAfter,    // placement-order handle
	int X,                  // horizontal position
	int Y,                  // vertical position
	int cx,                 // width
	int cy,                 // height
	uint uFlags             // window-positioning options
[DllImport("user32.dll", EntryPoint = "MoveWindow")]
static extern bool MoveWindow(
	int hWnd, 
	int X, 
	int Y, 
	int nWidth, 
	int nHeight, 
	bool bRepaint
const int SWP_DRAWFRAME = 0x20;
const int SWP_NOMOVE = 0x2;
const int SWP_NOSIZE = 0x1;
const int SWP_NOZORDER = 0x4;
This is the most complicated part... because it's NOT documented at all. We need a Pointer to the Word window, so we use FindWindow to find it. What's the name of the window? - "Opusapp" Actually, I don't know what this name means, but it works perfectly.
wordWnd = FindWindow( "Opusapp", null);
So, now we can define our control as a parent to Word:
SetWindowPos(wordWnd, this.Handle.ToInt32(), 0, 0,
	this.Bounds.Width-20, this.Bounds.Height-20,
Everything else should be pretty easy and it is well documented in the official documentation for the Word namespace.

Points of Interest

You may be interested in my other projects. Please visit my private homepage If you use this stuff or if you use just parts of it, I would appreciate if you mention my name. ;-)


  • 23.01.03 First release
  • 25.01.03 Update minor changes (performance enhancement)


This article, along with any associated source code and files, is licensed under The GNU General Public License (GPLv3)


About the Author

Matthias Hänel
Germany Germany
I am a developer with a Computer Science degree. I am programming Visual C ++ for over 7 year now and C# for about 3 years. If you want to know more about me please look at my homepage:

Comments and Discussions

GeneralSo much better then WebBrowserContol!! Pin
JMercado9-Feb-03 22:05
memberJMercado9-Feb-03 22:05 
GeneralRe: So much better then WebBrowserContol!! Pin
Matthias Hänel11-Feb-03 0:01
memberMatthias Hänel11-Feb-03 0:01 
Generalerrors building control Pin
antidemon5-Feb-03 3:15
memberantidemon5-Feb-03 3:15 
GeneralRe: errors building control Pin
Matthias Hänel5-Feb-03 10:58
memberMatthias Hänel5-Feb-03 10:58 
GeneralRe: errors building control Pin
antidemon5-Feb-03 22:27
memberantidemon5-Feb-03 22:27 
GeneralRe: errors building control Pin
Matthias Hänel6-Feb-03 2:40
memberMatthias Hänel6-Feb-03 2:40 
GeneralMethod not found: Office.CommandBars Pin
Chris Richner29-Jan-03 22:39
memberChris Richner29-Jan-03 22:39 
GeneralRe: Method not found: Office.CommandBars Pin
Matthias Hänel30-Jan-03 4:57
memberMatthias Hänel30-Jan-03 4:57 
GeneralRe: Method not found: Office.CommandBars Pin
Matthias Hänel30-Jan-03 12:42
memberMatthias Hänel30-Jan-03 12:42 
GeneralRe: Method not found: Office.CommandBars Pin
Chris Richner30-Jan-03 13:22
memberChris Richner30-Jan-03 13:22 
GeneralRe: Method not found: Office.CommandBars Pin
Matthias Hänel5-Feb-03 11:02
memberMatthias Hänel5-Feb-03 11:02 
GeneralRe: Method not found: Office.CommandBars Pin
Chris Richner5-Feb-03 11:22
memberChris Richner5-Feb-03 11:22 
GeneralRe: Method not found: Office.CommandBars Pin
ibaf3121-May-03 12:42
memberibaf3121-May-03 12:42 
GeneralAn alternative way Pin
Rama Krishna Vavilala29-Jan-03 11:13
memberRama Krishna Vavilala29-Jan-03 11:13 
GeneralRe: An alternative way Pin
Matthias Hänel29-Jan-03 20:45
memberMatthias Hänel29-Jan-03 20:45 
GeneralRe: An alternative way Pin
JMercado9-Feb-03 22:08
memberJMercado9-Feb-03 22:08 
GeneralRe: An alternative way Pin
Rama Krishna Vavilala10-Feb-03 3:13
memberRama Krishna Vavilala10-Feb-03 3:13 
GeneralRe: An alternative way Pin
JMercado10-Feb-03 20:05
memberJMercado10-Feb-03 20:05 
GeneralRe: An alternative way Pin
daisyshi14-Jun-03 22:37
memberdaisyshi14-Jun-03 22:37 
GeneralPath to dll, Pin
Chris Richner29-Jan-03 9:20
memberChris Richner29-Jan-03 9:20 
GeneralRe: Path to dll, Pin
Matthias Hänel29-Jan-03 20:36
memberMatthias Hänel29-Jan-03 20:36 
GeneralRe: Path to dll, Pin
Chris Richner29-Jan-03 22:34
memberChris Richner29-Jan-03 22:34 
GeneralRe: Path to dll, Pin
Matthias Hänel30-Jan-03 4:58
memberMatthias Hänel30-Jan-03 4:58 
GeneralNice, but... Pin
jmueller29-Jan-03 6:59
memberjmueller29-Jan-03 6:59 
GeneralRe: Nice, but... Pin
Matthias Hänel29-Jan-03 20:37
memberMatthias Hänel29-Jan-03 20:37 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

Posted 28 Jan 2003


194 bookmarked