WP&Win10开发: RichTextBlock实现富文本并处理换行

思路
1.构建字典。
2.在字符串中匹配字典的key,将匹配到的key转换成对应的value
3.将替换后的字符串,转化成xaml形式,加载该xaml以实现富文本。

代码如下

private Paragraph getRichText(string richText)
        {
            var r = new Regex(builder.ToString()); //获取正则。
            var mc = r.Matches(richText); //匹配富文本,获取匹配到的集合。
            foreach (Match m in mc) //遍历集合将richText中所有的值转换成xaml的形式。
            {
                //string.Format 中的内容不要出现换行符,否则会出现换行出错。
                richText = richText.Replace(m.Value, string.Format(@"<InlineUIContainer><Border><Image Source=""ms-appx:///Assets/Emoji/{0}.png"" Width=""30"" Height=""30""/></Border></InlineUIContainer>", emojiDict[m.Value]));
            }
            richText = richText.Replace("\r\n", "<LineBreak/>"); //将换行符转换成<LineBreak/>,用于实现换行。

            //生成xaml
            var xaml = string.Format(@"<Paragraph 
                                        xmlns=""http://schemas.microsoft.com/winfx/2006/xaml/presentation""
                                        xmlns:x=""http://schemas.microsoft.com/winfx/2006/xaml"">
                                    <Paragraph.Inlines>
                                    <Run></Run>
                                      {0}
                                    </Paragraph.Inlines>
                                </Paragraph>", richText);
            var p = (Paragraph)XamlReader.Load(xaml);
            p.Foreground = new SolidColorBrush(Color.FromArgb(255, 255, 255, 255));
            return p;
        }

 


Demo分享链接:http://pan.baidu.com/s/1hqGVOcW

运行图如下


有问题请加群:53078485

posted @ 2015-09-01 14:26  Clever-he  阅读(1113)  评论(0编辑  收藏  举报