[Silverlight 4 RC]RichTextBox概览

2018-01-16 11:35:03 浏览数 (1)

我们知道在silverlight 4 beta的时候增加了RichTextArea的控件。做过RIA开发的朋友富媒体在动态文本的表现渲染方面是很弱的。我们看到的很多富媒体网站比如新闻模块,如果想要图文混排的板式的话很多都是新开一个Html页面来做的展示。

这里来看看silverlight 4 RC都带来了什么。

首先RichTextArea更名为RichTextBox。

RichTextBox他定义在“System.Windows.Controls”,这也就是说RichTextBox是silverlight内置的一个控件了,你并不需要再去添加“Silverlight Toolkit”的引用。

这里添加一个RichTextBox

代码语言:javascript复制
<grid x:name="LayoutRoot" background="White">
    <richtextbox>
</richtextbox></grid>

RichTextBox支持了一种“模块”内容。这里模块可以包含“段落”元素(Paragraph elements)。这里段落元素有可以包含内嵌元素比如:粗体、链接、下划线。通过Inline的UI容器他还能包含图像元素、按钮控件等。

代码语言:javascript复制
<richtextbox x:name="RTB">
    <paragraph>
        RichTextBox包含<bold>粗体</bold>内容.
    </paragraph>
</richtextbox>

这里在增加一段Paragraph

代码语言:javascript复制
<richtextbox x:name="RTB">
    <paragraph>
        RichTextBox包含<bold>粗体</bold>内容.
    </paragraph>
    <paragraph>
       显示链接<hyperlink navigateuri="http://nasa.cnblogs.com">《我和未来有约会》</hyperlink> .
    </paragraph>
</richtextbox>

加入图形元素

代码语言:javascript复制
<richtextbox x:name="RTB">
    <paragraph>
        RichTextBox包含<bold>粗体</bold>内容.
    </paragraph>
    <paragraph>
       显示链接<hyperlink navigateuri="http://nasa.cnblogs.com">《我和未来有约会》</hyperlink> .
    </paragraph>
    <paragraph>
        显示图形
        <inlineuicontainer>
            <img source="./doodler.png" height="50" width="50">
        </inlineuicontainer>
    </paragraph>
</richtextbox>

另外RichTextBox还有只读属性用来做显示。

其次RichTextBox增加了很多的API,比如:当前光标位置position、当前选中文本selection等等......

一个简单的Demo

代码语言:javascript复制
private void BtnBold_Click(object sender, System.Windows.RoutedEventArgs e)
{
    object o = RTB.Selection.GetPropertyValue(TextElement.FontWeightProperty);
    if (o.ToString() != "Bold")
        RTB.Selection.ApplyPropertyValue(TextElement.FontWeightProperty, FontWeights.Bold);
}
 
private void BtnItalic_Click(object sender, System.Windows.RoutedEventArgs e)
{
    object o = RTB.Selection.GetPropertyValue(TextElement.FontWeightProperty);
    if (o.ToString() != "Italic")
        RTB.Selection.ApplyPropertyValue(TextElement.FontStyleProperty, FontStyles.Italic);
}
 
private void BtnUnderline_Click(object sender, System.Windows.RoutedEventArgs e)
{
    RTB.Selection.ApplyPropertyValue(Inline.TextDecorationsProperty, TextDecorations.Underline);
}

0 人点赞