在论坛上发了贴子关于如何在RTF里把插入的图片转化成自定义的表情代码
并可逆.
http://community.csdn.net/Expert/topic/3874/3874035.xml?temp=.2201197
首先非常感谢那些提出建议的朋友也感谢帮我顶的朋友.由于时间比较急,问题算是解决了.现在与大家分享一下.
记得在richtextbox里插入图片有N多种方法,在实际上在richtextbox 里只有两种方式,一种是以pict开头的直接在richtextbox里插入,二种是以object开头的以ole的方式嵌入.我们讨论前种,由于代码比较多,我直接提供代码工程给大家下载.这种只谈谈一些解决的思路
RTF没有可用的标志来标识图片(目前还没有找到J),所以要把图片转成表情代码,只能根据图片的特征码来定位图片,但是71张图片来查找其特征码实在是太麻烦了, 所以先找到71张图片的最小特征码, 为简单起见我们选图片生成十六进制后,选前N个字节,此N能表示71张不同的图片.方法是逐个比较(可用选择排序法)r找出此N. 然后我们生成可序化文件smile.bin,包含每张图片的完整图片,图片特征码以及此图片代表的表情代码.
正向转化: 当要发送含有表情图片的消息时,由于包含图片,此RTF非常庞大.我们需要把图片部分的代码转成自定义的表情代码,比如 图片为”^-^” --à” : ) “.
在RTF里图片以pict开头我们可以把这部分的代码去掉并插入我们自定义的表情代码.方法是找出pict的前500个字节(500是N,我这里图片的)与smile.bin中的图片特征码进行比较,奇怪是同一张图片两次生成的图片代码居然有些不一样(不知richtextbox搞什么鬼),所以引用的一个模糊因子,此因子为28,不同的图片可能不一样.这样进行匹配后,可找到表情代码了.
反向转化:就是把表情代码转化成图像,这转化比正向简单,只要在RTF里找出我们自定义的表情代码根据smile.bin来找到相应的图像文件,但是这里有个问题,不能直接显示的richtextbox里插入表情代码前的rtf代码,因为这不完整,会引异常,必须要完整,这样在转化的过程必须借向一个richtextbox来负责图片的转化.
其实如果RTF直接我们自定义的标签,那就不用这么麻烦了.但是直接给richtextbox赋值后,它会去掉这些它认为无用的标签(苦)
如果您有更好的方法请告诉我.
效果如下: