Windows Mobile上的HTML解析器

    Matjaž Prtenjak提出这个移动设备上HTML解析器、并表现在HTML Label上的最初目的,就是为了能够在界面上实时地改变一些控件上的文字内容和位置、字体大小、字体颜色等等。作者根据Jeff Heaton的《'Parsing HTML in Microsoft C#'》写了HTML解析器,使其变得更加小巧,适合于移动平台上使用。

  作者提供了一个控件的源代码和控件使用Demo的源代码,使用控件的方法也很简单,只要用visual studio新建一个工程,加入控件源代码HTMLLabel.csHTMLParser.cs,编译就可以了。利用该HTML控件,我们可以实现以下功能:

1. 展示一些简单的带有<b>, <i>, <u>, <pre>, <br>, <font><p>等标记的HTML代码,除此之外,它还支持<label>标记。

2. 替代许多不同的<label>标记,或者将它们合在一起。

3. 缩短InitializeComponent()函数的执行时间。

4. 具有Click事件,在.NET CF中是没有的。

  解释一些HTML标记如下:<b>表示粗体;<i>表示斜体;<u>表示下划线;<p>表示段落,其属性align表示对其方式;<font>表示字体,name属性表示字体类别size属性表示字体大小,color表示字体颜色;<pre>表示连接上文。

  看看其字体解析的效果吧,如下HTML代码:

ContractedBlock.gif ExpandedBlockStart.gif Code
<font size='8' name='Tahoma' color='red'>Tahoma, 8, red</font>

<font size='12' name='Courier new' color='blue'>Courier new, 12, blue</font>

<font size='8' name='Tahoma' color='green'>Tahoma, 8, green, <b>bold</b></font>

  运行效果如下图1所示:

1:字体运行效果

  对齐方式的HTML代码如下:

ContractedBlock.gif ExpandedBlockStart.gif Code
<align='left'>left</p>

<align='center'>center</p>

<align='right'>right</p>

  其效果如图2所示:

2:对齐方式效果

  另外,使用label标记的HTML代码如下:

ContractedBlock.gif ExpandedBlockStart.gif Code
<font size='{0}'>

This text box 
<label id='TextBox1' width='{1}' height='{2}'> will be positioned on the right place even if text changes. 

So as this 
<label id='Button1' width='{3}' height='{4}'> and this <label id='Button2' width='{5}' height='{6}'> button. 

<font color='red'>The value written in text box will be visible <b><label id='outText' width='70'></b> here.</font>

</font>

  我们还可以修改其label中的内容,并实时刷新,如下图3所示:

3Label效果图

  要完全研究其中的代码,我们可以去这里查看并下载:An HTML Label for the .NET CF

 

参考链接:

An HTML Label for the .NET CF

'Parsing HTML in Microsoft C#'

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值