Click here to Skip to main content
6,629,885 members and growing! (21,717 online)
Email Password   helpLost your password?
Platforms, Frameworks & Libraries » Windows Presentation Foundation » Controls     Beginner License: The GNU Lesser General Public License

WPF Html supported TextBlock

By Leung Yat Chun

This Article describes HtmlTextBlock, which is a WPF TextBlock that can parse limited set of html tags and display them.
C#, Windows, WPF, Architect, Dev, Design
Version:2 (See All)
Posted:7 Feb 2009
Views:9,175
Bookmarked:12 times
Unedited contribution
Announcements
Loading...
 
Search    
Advanced Search
Add to IE Search
printPrint   add Share
      Discuss Discuss   Broken Article?Report  
0 votes for this article
mainscreen.jpg

Introduction

This Article describes HtmlTextBlock, which is a WPF TextBlock that can parse limited set of html tags and display them.

Background

I was working on a custom progress dialog, which contains a Header, Message, Progress and some action button,
To make it look better, I want the message to support some text format, and I want it to be changeable at runtime, but it seems impossible using TextBlock.

background.jpg


I then googled how to use html in wpf but most solutions told me to use WebBrowser, which is a bit overkill for my purpose. 

Then I remembered an abondoned project I wrote few years ago (mostly because I moved to WPF) , which tried to recreate FlowDocument in dotNet2, and load Html to that flow document (my main purpose, the component was named QzMiniHtml2).

Surprisingly, with very few modifications (mostly using import), this dotNet2 project work nicely with WPF, just as you look above.

Because of this, the original project is also included as well.

How to use? 

The control is similar to TextBlock except you set the Html property instead of Text.
Remember to use [ ] bracket instead of < >.
<Window x:Class="HtmlTextBlockTestProj.Window1"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:uc="http://www.quickzip.org/UserControls"
    Title="HtmlTextBlockTest" Height="250" Width="450">
    <DockPanel>
        <uc:HtmlTextBlock Html="{Binding Text, ElementName=tb}"  
                 DockPanel.Dock="Top" Loaded="HtmlTextBlock_Loaded" />
        <TextBlock Text="[b] [i] [u] [a href=xx] [br] supported." 
                 DockPanel.Dock="Bottom" />
        <TextBox TextWrapping="Wrap" AcceptsReturn="True" 
                  VerticalScrollBarVisibility="Visible"
                  x:Name="tb" 
        Text="The [i][u]quick brown fox[/i][/u] jumps over the [b]lazy dog[/b]" />
    </DockPanel>
</Window>		 

How it works? 

The component actually included a html parsing engine inside, which translate html string to WPF's Bold, Italic, Underline, Hyperlink, LineBreak Inline
(more can be added in future, you can do it yourself easily, see below)

The conversion part is simple.

1) private Inline UpdateElement(HtmlTag aTag)
2) {
3)   Inline retVal = null;
			
4)   switch (aTag.Name)
5)   {
6)     case "text" : 
7)       retVal = new Run(aTag["value"]);			
8)       if (currentState.Bold) retVal = new Bold(retVal);
9)       if (currentState.Italic) retVal = new Italic(retVal);
0)       if (currentState.Underline) retVal = new Underline(retVal);
A)       break;
B)     case "br" : 
C)       retVal = new LineBreak();
D)       break;
E)   }

F)   if (currentState.HyperLink != null && currentState.HyperLink != "")
G)   {
H)     Hyperlink link = new Hyperlink(retVal);
I)     link.NavigateUri = new Uri(currentState.HyperLink);
J)     retVal = link;
K)   }			
L)    return retVal;
M) }		 
First, please note that
  • The input (aTag) is a Text or LineBreak(br), if the tag is a text, Tag["value"] is the text it holds.
    Bold, Italic etc can also be represented by HtmlTag, but they wont be executed here.
  • CurrentState hold the style affecting the TextTag etc
So if the tag is text (line 6),
  • it will generate a Run (which can contain format or unformat text, and unformat in this case) (line 7)
  • if it's bold, italic and underline, it will construct them, and using last Inline (Abstract class, Run, Bold etc inherited from it), so it contain the property.
When the Inline is returned (Line L)
  • It will be added to your HtmlTextBlock.Inlines collection. 

History

08-02-09 Initial version 

License

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

About the Author

Leung Yat Chun


Member

Location: Hong Kong Hong Kong

Other popular Windows Presentation Foundation articles:

Article Top
You must Sign In to use this message board.
FAQ FAQ 
 
Noise Tolerance  Layout  Per page   
 Msgs 1 to 16 of 16 (Total in Forum: 16) (Refresh)FirstPrevNext
Generalimage in text block Pinmemberpathurun22:35 8 Sep '09  
GeneralRe: image in text block PinmemberLeung Yat Chun1:56 15 Sep '09  
GeneralDoes not work if Html Text is assigned to the HtmlTextBlock during Binding Pinmemberazamsharp11:09 1 Jul '09  
GeneralRe: Does not work if Html Text is assigned to the HtmlTextBlock during Binding PinmemberLeung Yat Chun8:06 2 Jul '09  
Generalextensions PinmemberLee_Nover16:11 20 Mar '09  
GeneralRe: extensions PinmemberLeung Yat Chun21:35 20 Mar '09  
GeneralRe: extensions PinmemberLee_Nover5:14 23 Mar '09  
GeneralRe: extensions PinmemberLeung Yat Chun11:20 23 Mar '09  
GeneralRe: extensions PinmemberLee_Nover4:45 24 Mar '09  
GeneralRe: extensions PinmemberLeung Yat Chun10:20 25 Mar '09  
GeneralRe: extensions PinmemberBob Ranck10:26 4 Apr '09  
GeneralRe: extensions PinmemberLeung Yat Chun21:45 5 Apr '09  
GeneralFlow document? PinmemberMember 178098922:32 7 Feb '09  
GeneralRe: Flow document? PinmemberLeung Yat Chun23:39 7 Feb '09  
GeneralRe: Flow document? PinmemberMember 178098923:38 8 Feb '09  
GeneralRe: Flow document? PinmemberLeung Yat Chun10:04 9 Feb '09  

General General    News News    Question Question    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

PermaLink | Privacy | Terms of Use
Last Updated: 7 Feb 2009
Editor:
Copyright 2009 by Leung Yat Chun
Everything else Copyright © CodeProject, 1999-2009
Web10 | Advertise on the Code Project