在博客中显示不走样的代码

简介:
 在日常的代码开发中。习惯于在自己的代码编辑器里设置自己喜欢的代码字体及颜色。在写博客的过程中,有不可避免的要粘贴一些自己写的代码。问题就来了,往往在博客中提供的代码显示工具显示的代码格式和之前在代码编辑器里就发生了变化。虽不是什么大问题,但总是觉得有点不舒服。
  本人用的编辑器是VS系列。一次在无意中将代码复制后,贴到写字板中,发现格式没有发生变化,将文件保存后,用记事本打开,发现是保存为Rtf格式。也就是说,在VS中复制代码,实际内存中保存着该代码的Rtf格式,这样也就是保留了该代码的格式。那么接下来要做的事情就是写一段代码,将该Rtf格式的代码改写成Html格式的代码。由于两种格式之间相似度还是比较高的,所以写代码也不是一件很难的事。
  要注意的是,由于该代码用到了HttpUtility类,因此还得手动添加对System.Web的引用,而不仅仅是添加一句“Imports System.Web”。
  在调用的时候,启用clsFormatCode.CodeRtfToHtml(Clipboard.GetText(System.Windows.Forms.TextDataFormat.Rtf))这句代码就可以了。
  下面是代码,用的是VB2005。
 
Imports System.Web

Public  Class clsFormatCode
Private  Shared  Function CodeRtfToHtml( ByVal RtfCode  As  StringByVal DefaultFont  As  String)
Dim tS  As  New System.Text.StringBuilder

RtfCode = RtfCode.Replace(vbNewLine,  "")

tS.AppendLine( "<style>")

Dim I  As  Integer, J  As  Integer, K  As  Integer = 1

I = RtfCode.IndexOf( "{\colortbl;") + 11

Do  While RtfCode.Chars(I + 1) <>  "}"
      J = RtfCode.IndexOf( ";", I + 1)
tS.AppendLine( ".cf" & K &  " {color:" & GetColorHex(RtfCode.Substring(I + 1, J - I)) &  "}")
K += 1
I = J
Loop

    tS.AppendLine( "</style>")
tS.AppendLine(DefaultFont)

I = RtfCode.IndexOf( "\fs") + 3
K = I
Dim CurColor  As  String =  "\cf0"

    J = RtfCode.IndexOf( "\", I)
Do  While J <> -1
If RtfCode.Substring(J, 2) =  "\\"  Then
        I = J + 2
ElseIf RtfCode.Substring(J, 2) =  "\{"  Then
        I = J + 2
ElseIf RtfCode.Substring(J, 2) =  "\}"  Then
        I = J + 2
ElseIf RtfCode.Substring(J, 4) =  "\par"  Then
        tS.Append(GetText(RtfCode.Substring(K, J - K), CurColor))
I = J + 5
K = J + 5
tS.Append( "<br />" & vbNewLine)
ElseIf RtfCode.Substring(J, 3) =  "\cf"  Then
        tS.Append(GetText(RtfCode.Substring(K, J - K), CurColor))
K = RtfCode.IndexOf( " ", J + 1) - J
CurColor = RtfCode.Substring(J, K)
I = J + K + 1
K = I
Else
        I = J + 1
End  If
      J = RtfCode.IndexOf( "\", I)
Loop

    tS.Append(GetText(RtfCode.Substring(K, RtfCode.Length - K - 1), CurColor))

tS.AppendLine( "</div>")
Return tS.ToString
End  Function

   Public  Shared  Function CodeRtfToHtml( ByVal RtfCode  As  StringByVal Font  As  StringByVal FontSize  As  String)
Return CodeRtfToHtml(RtfCode,  String.Format( "<div style='color:black;font-family:{0};font-size:{1};'>", Font, FontSize))
End  Function

   Public  Shared  Function CodeRtfToHtml( ByVal RtfCode  As  StringAs  String
     Return CodeRtfToHtml(RtfCode,  "<div style='color:black;font-family:Verdana;font-size:12pt;'>")
End  Function

   Private  Shared  Function GetText( ByVal Text  As  StringByVal CurColor  As  StringAs  String
    Text = Text.Replace( "\\""\")
Text = Text.Replace( "\{""{")
Text = Text.Replace( "\}""}")
Text = Text.Replace( "  "" ")
If CurColor =  "\cf0"  Then
       Return HttpUtility.HtmlEncode(Text)
Else
       Return  "<span class='" & CurColor.Substring(1) &  "'>" & HttpUtility.HtmlEncode(Text) &  "</span>"
     End  If
   End  Function

   Private  Shared  Function GetColorHex( ByVal ColorText  As  StringAs  String
     Dim SR  As  Integer = ColorText.IndexOf( "\red")
Dim SG  As  Integer = ColorText.IndexOf( "\green")
Dim SB  As  Integer = ColorText.IndexOf( "\blue")

Dim R  As  Integer =  CInt(ColorText.Substring(SR + 4, SG - SR - 4))
Dim G  As  Integer =  CInt(ColorText.Substring(SG + 6, SB - SG - 6))
Dim B  As  Integer =  CInt(ColorText.Substring(SB + 5, ColorText.Length - 1 - SB - 5))

Return  "#" & R.ToString( "X2") & G.ToString( "X2") & B.ToString( "X2")
End  Function
End  Class

    本文转自万仓一黍博客园博客,原文链接: http://www.cnblogs.com/grenet/archive/2012/01/10/2317965.html ,如需转载请自行联系原作者

相关文章
|
11月前
|
存储 人工智能 运维
【01】做一个精美的打飞机小游戏,浅尝阿里云通义灵码python小游戏开发AI编程-之飞机大战小游戏上手实践-优雅草央千澈-用ai开发小游戏尝试-分享源代码和游戏包
【01】做一个精美的打飞机小游戏,浅尝阿里云通义灵码python小游戏开发AI编程-之飞机大战小游戏上手实践-优雅草央千澈-用ai开发小游戏尝试-分享源代码和游戏包
564 48
【01】做一个精美的打飞机小游戏,浅尝阿里云通义灵码python小游戏开发AI编程-之飞机大战小游戏上手实践-优雅草央千澈-用ai开发小游戏尝试-分享源代码和游戏包
|
11月前
|
前端开发 JavaScript
除了使用Polyfill,还有其他解决Promise.allSettled()兼容性问题的方法吗?
除了使用Polyfill,还有其他解决Promise.allSettled()兼容性问题的方法吗?
284 81
|
机器学习/深度学习 人工智能 大数据
量子计算的现状与未来:从实验室到商用
量子计算正从理论探索迈向实际应用,全球科技巨头和科研机构积极研发,已在特定任务上展现巨大优势。本文探讨量子计算的现状、挑战、发展趋势及商用潜力,涵盖药物研发、金融工程、大数据处理等领域,展望其未来对各行业的深远影响。
|
12月前
|
监控 数据可视化 数据挖掘
数据看板制作工具评测:这6款工具能如何提升企业的数据分析效率?
本文介绍了6款数据看板制作工具,包括板栗看板、Tableau、Power BI、Qlik Sense、Google Data Studio和Looker,从功能、适用场景等方面进行了详细对比,旨在帮助企业选择最合适的工具以实现高效的数据可视化和管理决策。
|
人工智能 安全 物联网
物联网技术的未来发展趋势
物联网技术的未来发展趋势
482 4
|
网络协议 算法 数据库
OSPF中的骨干区域详解
OSPF中的骨干区域详解
706 0
|
自然语言处理 测试技术 API
探索通义语音团队的创新之作 —— FunAudioLLM模型评测
随着人工智能技术的飞速发展,语音识别和语音合成技术在各个领域得到了广泛应用。阿里云推出的“通义语音大模型FunAudioLLM”作为最新的语音处理技术,备受业界关注。本次评测将深入探讨通义语音大模型的功能、性能及其在实际应用中的表现。
|
数据格式
如何绘制热图?ggplot2入门笔记
如何绘制热图?ggplot2入门笔记
|
Rust 安全 C++
游戏引擎的未来:是Rust成为新王,还是C++仍占鳌头?
【8月更文挑战第31天】随着游戏行业的快速发展,对高性能、安全且易维护的游戏引擎需求日益增长。虽然C++长期占据主导地位,但Rust语言凭借其内存安全和高性能的特点,逐渐成为游戏引擎开发的新选择。Rust通过所有权机制和强大的类型系统,在保证内存安全的同时实现了与C++相当的性能,有助于提前发现潜在错误。尽管Rust在生态系统成熟度和学习曲线上仍面临挑战,其在游戏引擎领域的潜力正逐渐被认可。随着Rust社区的发展和工具链的完善,Rust有望成为游戏引擎开发的重要选项。
603 0
|
机器学习/深度学习 人工智能 TensorFlow
如何将OpenCV与AI深度学习结合使用
如何将OpenCV与AI深度学习结合使用
632 1