Click here to Skip to main content
12,621,380 members (32,158 online)
Click here to Skip to main content
Add your own
alternative version

Tagged as

Stats

126.4K views
18.8K downloads
172 bookmarked
Posted

Zeta HTML Edit Control

, 9 Jul 2013 CPOL
Rate this:
Please Sign up or sign in to vote.
A small wrapper class around the Windows Forms 2.0 WebBrowser control

Introduction 

This article presents you a small wrapper class around the Windows Forms 2.0 WebBrowser control.

Features

The wrapper is no rocket science but provides some features I struggled with in the past. We use the control in several of our own (internal and external) applications, e.g. our Test Management tool

Some of the features include:

  • Enable the setting of text even when the control is not yet fully initialized
  • Allow pasting of images from the clipboard
  • Allows for resizing the images within the editor with the mouse 
  • Provide an alternative context menu for applying formatting options
  • Optionally directly edit the underlying HTML source code
  • Translated resources in English and German
  • Interface IExternalInformationProvider for externally persisting and restoring settings
  • Provide standard CSS in the control; usually you do not need to define your own CSS

Using the Code

To include the code in your own project, simply include the "ZetaHtmlEditControl.dll" assembly into your project.

Add the assembly to your Visual Studio .NET 2008 Windows Forms Designer Toolbox if you want to be able to drag the ExtendedWebBrowser control to your forms. Alternatively create and initialize an instance of the ExtendedWebBrowser control by code.

Setting HTML

To put HTML from your code into the control, assign the HTML code to the ExtendedWebBrowser.DocumentText property. You do not have to pass a complete HTML document with HEAD and BODY tags but only the actual content that you would write inside the BODY tag.

Getting the HTML 

To read out the HTML from the control, call the ExtendedWebBrowser.GetDocumentText(string folderPath) method. The method takes one parameter "folderPath" that tells the control where to store newly passed images from the clipboard. 

Summary

This article quickly introduced a wrapper around the Windows Forms 2.0 WebBrowser control that adds some extra functions to make it more usable in a real-world-application. Feel free to copy, modify or extend the control to match your own requirements.

To ask questions, suggest features or provide other comments, please use the comments section at the bottom of this article.

History

  • 2013-07-09 - You now also find the project on GitHub
  • 2013-05-20 - Images inside the edit control can now be resized proportionally to make them smaller. When persisting the images, they are actually resized on disk, too.
  • 2011-06-02 - Added support for inserting and editing tables. Added new user control that has a toolbar (see screenshot) that you can switch on and off from code.
  • 2011-03-16 - Updated for and tested with the latest Internet Explorer 9 (RTM). If you do experience AccessViolation exceptions when working with this control, please read this MSDN blog posting that suggests to add a custom build step
    "$(DevEnvDir)..\tools\vsvars32.bat"
    editbin.exe /NXCOMPAT:NO "$(TargetPath)"
  • 2011-02-26 - Update to (hopefully) make the control work with Internet Explorer 9 RC work again. See this Stack Overflow posting for details. I've included a mini web server with the control to serve the texts from this server, instead of setting it directly. It should be 100% transparent to the user of the code.
  • 2009-11-18 - First public release to CodeProject.com

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

Share

About the Author

Uwe Keim
Chief Technology Officer Zeta Producer Desktop CMS
Germany Germany
Uwe does programming since 1989 with experiences in Assembler, C++, MFC and lots of web- and database stuff and now uses ASP.NET and C# extensively, too. He has also teached programming to students at the local university.

In his free time, he does climbing, running and mountain biking. Recently he became a father of a cute boy.

Some cool, free software from us:

German Developer Community  
Free Test Management Software - Intuitive, competitive, Test Plans. Download now!  
Homepage erstellen - Intuitive, very easy to use. Download now!  
Send large Files online for free by Email
Offline-Homepage-Baukasten

You may also be interested in...

Pro
Pro

Comments and Discussions

 
GeneralRe: Special characters Pin
giova28-Mar-13 11:47
membergiova28-Mar-13 11:47 
QuestionHow we can change font? Pin
karamih3-Oct-12 11:08
memberkaramih3-Oct-12 11:08 
GeneralMy vote of 5 Pin
Engone14-Dec-11 10:40
memberEngone14-Dec-11 10:40 
QuestionFont Change Pin
ezbUltra3-Nov-11 1:30
memberezbUltra3-Nov-11 1:30 
QuestionAssembly load issue Pin
Eric Legault13-Oct-11 6:51
memberEric Legault13-Oct-11 6:51 
AnswerRe: Assembly load issue Pin
Uwe Keim13-Oct-11 7:43
sitebuilderUwe Keim13-Oct-11 7:43 
Question2 Questions (httpserver.dll) Pin
Martin Poehler21-Jul-11 6:21
memberMartin Poehler21-Jul-11 6:21 
AnswerRe: 2 Questions (httpserver.dll) Pin
Uwe Keim22-Jul-11 22:29
sitebuilderUwe Keim22-Jul-11 22:29 
Hi Martin

Regarding 1.) Please see webserver.codeplex.com [^] for the original article of the web server.

Regarding 2.) The whole purpose of the article is to provide an HTML editor. If you do need an HTML viewer, simply use the built-in class [^] of Windows Forms.
Wollen Sie ganz einfach Ihre eigene Homepage erstellen, ohne HTML-Kenntnisse, einfach, professionell und mit viel Freude? Probieren Sie unser Desktop Content Management System (CMS) Zeta Producer für Windows aus. Komplett mit eigenem Shop, Gästebuch, Weblog, Bildergalerien, Integration von YouTube-Videos. Wir haben eine aktive Anwender-Community, schnellen Support, sympathische Support-Mitarbeiter.

GeneralSome questions about the control Pin
greg_quinn13-Jun-11 1:55
membergreg_quinn13-Jun-11 1:55 
GeneralRe: Some questions about the control Pin
Uwe Keim13-Jun-11 19:58
sitebuilderUwe Keim13-Jun-11 19:58 
GeneralRe: Some questions about the control Pin
greg_quinn15-Jun-11 3:59
membergreg_quinn15-Jun-11 3:59 
GeneralRe: Some questions about the control Pin
Uwe Keim18-Jun-11 4:02
sitebuilderUwe Keim18-Jun-11 4:02 
GeneralRe: Some questions about the control Pin
greg_quinn15-Jun-11 4:13
membergreg_quinn15-Jun-11 4:13 
QuestionHow to insert an image? Pin
seanzcan7-Jun-11 4:53
memberseanzcan7-Jun-11 4:53 
GeneralGo Zeta Go Pin
sam.hill2-Jun-11 11:27
membersam.hill2-Jun-11 11:27 
GeneralRe: Go Zeta Go Pin
Uwe Keim2-Jun-11 19:43
sitebuilderUwe Keim2-Jun-11 19:43 
GeneralMy vote of 5 Pin
Filip D'haene2-Jun-11 6:42
memberFilip D'haene2-Jun-11 6:42 
GeneralRe: My vote of 5 Pin
Uwe Keim2-Jun-11 6:43
sitebuilderUwe Keim2-Jun-11 6:43 
GeneralThis is cool Pin
Sacha Barber15-Mar-11 23:43
mvpSacha Barber15-Mar-11 23:43 
GeneralRe: This is cool Pin
Uwe Keim16-Mar-11 0:35
sitebuilderUwe Keim16-Mar-11 0:35 
QuestionWeb server overkill ? Pin
TrendyTim1-Mar-11 8:19
memberTrendyTim1-Mar-11 8:19 
AnswerRe: Web server overkill ? Pin
Uwe Keim1-Mar-11 8:41
sitebuilderUwe Keim1-Mar-11 8:41 
GeneralMy vote of 5 Pin
sam.hill26-Feb-11 8:12
membersam.hill26-Feb-11 8:12 
GeneralRe: My vote of 5 Pin
Uwe Keim26-Feb-11 10:41
sitebuilderUwe Keim26-Feb-11 10:41 
GeneralRe: My vote of 5 [modified] Pin
wknopf28-Feb-11 5:42
memberwknopf28-Feb-11 5:42 

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.

| Advertise | Privacy | Terms of Use | Mobile
Web01 | 2.8.161128.1 | Last Updated 9 Jul 2013
Article Copyright 2009 by Uwe Keim
Everything else Copyright © CodeProject, 1999-2016
Layout: fixed | fluid