Click here to Skip to main content
Licence CPOL
First Posted 26 Aug 2001
Views 239,989
Downloads 524
Bookmarked 51 times

HTML based dialog for the Pocket PC

By | 26 Aug 2001 | Article
A library that provides an easy wrapper that encapsulates most of work done with the HtmlView control in CE

Screenshot

Introduction

It seems to be a good idea to use a HTML based dialog in Pocket PC applications. Much of the work you have to do will be done by HTML engine. Pocket PC provides htmlview.dll that contains the HtmlView control. But a lot of developers find it difficult to use. The STHtmlDialog library provides an easy way to use a wrapper that encapsulates most of work done with the HtmlView control.

Using HTML in dialogs your can display a text using different fonts, colors and styles, use different HTML controls, display images, use links and many other features provided by HTML.

Keep also in mind that HTML provided by HtmlView control does not support some of the features you might expect as JavaScript, frames, etc.

What You Need

Background

To create a HtmlView control without the STHtmlDialog library you should:

  1. Add htmlview.lib library to your project. Call Project Settings dialog (Alt+F7), then go to the Link tab page and add htmlview.lib string to Object/library modules field.
  2. Include Htmlctrl.h files. Add  #include <Htmlctrl.h>  line to your StdAfx.h file.
  3. Load the HTML Viewer DLL by calling the LoadLibrary function. Specify Htmlview.dll in the lpLibFileName parameter.
  4. Register the HTML Viewer control class by calling the InitHTMLControl function.
  5. Create a window for the HTML Viewer control by calling the CreateWindow function. Specify DISPLAYNAME in the lpClassName parameter
  6. Rewrite WindowProc function and handle WM_NOTIFY messages. Here you should give images and handle links (NM_HOTSPOT and NM_INLINE_IMAGE codes).

Using STHtmlDialog library

To create an HTML dialog using the STHtmlDialog library you should:

  1. Insert the STHtmlDialog.h and STHtmlDialog.cpp files into your project (use Project\Add To Project\Files menu item).
  2. Add the htmlview.lib library to your project. Call Project Settings dialog (Alt+F7), then go to the Link tab page and add htmlview.lib string to Object/library modules field.
  3. Change the super class of your dialog form CDialog to CSTHtmlDialog.
  4. In the OnInitDialog method of your dialog you should add a call to the SetHtml function that sets the HTML text.

Handling HTML events

Links

When a user clicks a link in HTML, the OnLink virtual function of your dialog is called. To handle links you should override this function. The strHref parameter contains the href attribute of the link that was clicked.

Images

To use images in HTML first register them. Call the RegisterHtmlImage function during initialization for each image you are going to use in HTML. When you register an image you should specify a string that can be used in the HTML src attribute of img tag.

Conclusion

It's easy to create an HTML based dialog using STHtmlDialog library. CSTHtmlDialog wraps functionality of HtmlView control including images and links.

License

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

About the Author

Vassili Philippov



Russian Federation Russian Federation

Member



Sign Up to vote   Poor Excellent
Add a reason or comment to your vote: x
Votes of 3 or less require a comment

Comments and Discussions

 
You must Sign In to use this message board. (secure sign-in)
 
Search this forum  
 FAQ
    Noise  Layout  Per page   
  Refresh
Questionhelp me Pinmemberdongjieabc17:34 26 Sep '11  
QuestionI Cann't Get WM_NOTIFY message Pinmemberdongjieabc21:33 18 Sep '11  
QuestionHTML scroll event PinmemberTrurl28123:27 17 Jul '09  
AnswerRe: HTML scroll event PinmemberSinisa Hajnal21:20 14 Mar '11  
QuestionThe content cannot display on the dialog? Pinmembertitan31521:54 4 Feb '09  
AnswerRe: The content cannot display on the dialog? PinmemberRaNo993:28 22 Mar '09  
QuestionHow to show animation GIF ? Pinmemberkingdomkao23:10 1 Jul '08  
GeneralCompiling errors PinmemberAlexander Bonko20:36 19 Sep '07  
QuestionCan the HtmlView be embedded into other window Pinmemberorange525720:28 26 Aug '07  
QuestionWhat are HtmlWnd.[cpp|h] for? Pinmemberl_d_allan8:44 18 Aug '07  
Generalthere are 2 problems PinmemberBysakura23:06 19 Sep '06  
GeneralError with 'LPINLINEIMAGEINFO' Pinmember123snowsnow23:19 14 Mar '06  
GeneralRe: Error with 'LPINLINEIMAGEINFO' Pinmemberlininking74101719:33 20 Jun '06  
QuestionIs it possible working on the other platform? PinmemberDesperado.shlee20:15 20 Sep '05  
QuestionHow to read out Edit-fields or Option-buttons? Pinmemberderhexer4:19 22 Jul '05  
GeneralWin CE 4.2 Problem Pinmemberzikje3:26 31 May '05  
QuestionConflict with PocketIE? Pinmemberkesen22:00 9 Mar '05  
QuestionHow to COPY from HTMLView? PinmemberSvilen3330:00 7 Feb '05  
AnswerRe: How to COPY from HTMLView? PinmemberProudPrimate10:55 7 Mar '10  
GeneralLPINLINEIMAGEINFO not found Pinmemberriki_risnandar6:02 23 Jan '05  
GeneralHTML Control: probleme of memory Pinmembernoisette21:52 23 Aug '04  
QuestionHow to navigate? Pinmemberwqter4:33 25 Jul '04  
AnswerRe: How to navigate? PinmemberYongki C. A. Jong14:52 7 Nov '04  
QuestionHow to Navigate? Pinmemberwqter4:30 25 Jul '04  
GeneralHelp -- large load times PinmemberBenny1255:36 28 Jun '04  

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

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

Permalink | Advertise | Privacy | Mobile
Web02 | 2.5.120528.1 | Last Updated 27 Aug 2001
Article Copyright 2001 by Vassili Philippov
Everything else Copyright © CodeProject, 1999-2012
Terms of Use
Layout: fixed | fluid