基本信息
源码名称:WP 富文本框例子源码下载(支持表情、链接等)
源码大小:1.83M
文件格式:.zip
开发语言:C#
更新时间:2016-02-04
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 2 元×
微信扫码支付:2 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Text; using System.Text.RegularExpressions; using System.Windows; using System.Windows.Controls; using System.Windows.Documents; using System.Windows.Markup; namespace RichTextDemo { public class RichTextBoxExt : RichTextBox { #region 富文本Text public static readonly DependencyProperty TextProperty = DependencyProperty.Register( "Text", typeof(string), typeof(RichTextBoxExt), new PropertyMetadata(default(string), TextChangedCallback)); private static void TextChangedCallback(DependencyObject dependencyObject, DependencyPropertyChangedEventArgs dependencyPropertyChangedEventArgs) { var richTextBox = (RichTextBoxExt)dependencyObject; var text = (string)dependencyPropertyChangedEventArgs.NewValue; var p = richTextBox.ConvertToElement(text); richTextBox.Blocks.Clear(); richTextBox.Blocks.Add(p); } public string Text { get { return (string)GetValue(TextProperty); } set { SetValue(TextProperty, value); } } #endregion //1、由于RichTextBox的Xaml属性不支持图片,所以没办法直接通过RichTextBox的Xaml属性直接处理 // 这里通过构造XAML并使用XamlReader进行读取转换达到富文本的目的 // 富文本包括:文本,图片,链接三种元素 // 我们只需要分别对图片和链接进行处理就可以 /// <summary> /// 将文字转为富文本(文字 图片表情 链接) /// </summary> public Paragraph ConvertToElement(string input) { if (input == null) { return new Paragraph(); } //匹配普通链接(遇到空格或非Ascii字符则停止) var mc = Regex.Matches(input, @"http://[\x21-\x7e-[\s]] |http://[\x21-\x7e-[\s]] |http://[\x21-\x7e-[\s]] $"); //记录是否重复 var matchs = new List<string>(); foreach (Match m in mc) { if (matchs.Contains(m.Value)) { //如果有重复匹配项,则跳过 continue; } //这里链接用蓝色显示,不加下划线(注意,这里使用系统的浏览器IE打开) input = input.Replace(m.Value.Substring(0, m.Value.Length), string.Format(@"<Hyperlink NavigateUri=""{0}"" MouseOverTextDecorations=""None"" MouseOverForeground=""Blue"" Foreground=""Blue"" TargetName=""_blank"" >{0}</Hyperlink>", m.Value)); matchs.Add(m.Value); } matchs.Clear(); //匹配安全连接 mc = Regex.Matches(input, @"https://[\x21-\x7e-[\s]] |https://[\x21-\x7e-[\s]] |https://[\x21-\x7e-[\s]] $"); foreach (Match m in mc) { if (matchs.Contains(m.Value)) { //如果有重复匹配项,则跳过 continue; } input = input.Replace(m.Value.Substring(0, m.Value.Length), string.Format(@"<Hyperlink NavigateUri=""{0}"" MouseOverTextDecorations=""None"" MouseOverForeground=""Blue"" Foreground=""Blue"" TargetName=""_blank"" >{0}</Hyperlink>", m.Value)); matchs.Add(m.Value); } //表情字典 var dict = EmotionDictionary; //构造正则模式串(匹配表情) var builder = new StringBuilder(); foreach (var key in dict.Keys) { builder.Append(key.Replace("[", @"\[").Replace("]", @"\]").Replace("{", @"\{").Replace("}", @"\}")); builder.Append("|"); } //定义一个Regex对象实例 var r = new Regex(builder.ToString().Substring(0, builder.Length - 1)); mc = r.Matches(input); foreach (Match m in mc) { //表情替换图片 input = input.Replace(m.Value, string.Format(@" <InlineUIContainer> <Border> <Image Source=""/Assets/Emotions/{0}"" Width=""30"" Height=""30""/> </Border> </InlineUIContainer> ", dict[m.Value])); } 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>", input); return (Paragraph)XamlReader.Load(xaml); } #region 表情字典 private static Dictionary<string, string> emotionDictionary; public static Dictionary<string, string> EmotionDictionary { get { if (emotionDictionary == null) { emotionDictionary = new Dictionary<string, string>(); var files = new[] { "sina", "emoji" }; foreach (var file in files) { using (var stream = Application.GetResourceStream( new Uri(string.Format("Assets/Emotions/{0}.txt", file), UriKind.Relative)).Stream) { using (var reader = new StreamReader(stream)) { var line = reader.ReadLine(); while (line != null) { var res = line.Split(','); emotionDictionary.Add(res[1], res[0]); line = reader.ReadLine(); } } } } } return emotionDictionary; } } #endregion } }