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

  在日常的代码开发中。习惯于在自己的代码编辑器里设置自己喜欢的代码字体及颜色。在写博客的过程中,有不可避免的要粘贴一些自己写的代码。问题就来了,往往在博客中提供的代码显示工具显示的代码格式和之前在代码编辑器里就发生了变化。虽不是什么大问题,但总是觉得有点不舒服。

  本人用的编辑器是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 String, ByVal 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 String, ByVal Font As String, ByVal 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 String) As String
    Return CodeRtfToHtml(RtfCode, "<div style='color:black;font-family:Verdana;font-size:12pt;'>")
  End Function

  Private Shared Function GetText(ByVal Text As String, ByVal CurColor As String) As 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 String) As 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

时间: 2025-01-29 07:37:56

在博客中显示不走样的代码的相关文章

博客中添加日历的php代码

想不想在你得博客中添加日历啊?blue1000在这里跟大家简洁的分享一款PHP中博客日历实现代码,有需要的朋友参考一下,里面有一句是查询数据库的这个很简单,你只要修改一下字段名与你数据库相同就行了. 代码如下: function calendarnew($starttime = 0) { global $db, $tablepre, $timestamp, $site_timeoffset, $site_dateformat, $curtime; $starttime = $starttime

如何在博客中使用SublimeText风格的代码高亮样式

因为觉得博客园自带的代码高亮样式很单一,不符合作为前端的我的审美习惯,于是下定决心要想办法折腾出一个方法来应用上另外一套代码高亮样式. 虽然探索的过程是很痛苦的,但最后还是成功了,但也不枉付出的那些努力.近来有网友问及如何实现,现分享出来,看完本文后你也可以把自己博客的代码整得漂亮些,让别人看着舒服些了. 方法其实是很麻烦的,即使是写了好几篇博客了对这个过程我已经娴熟了,但其实也还是挻麻烦的.不过谁叫我有是个偏执狂呢,为了让页面漂亮我愿麻烦自己,舒服大家.如果你有更好的方法那当然更好. 安装su

github-请问Jekyll博客中如何用相对路径来加载图片

问题描述 请问Jekyll博客中如何用相对路径来加载图片 请教关于Jekyll博客写的markdown文件,博文中怎么插入图片? 在_post下再键一个目录用来放置对应博文的图片,md中用相对目录表示,可是实际才显示不出来 又不想用绝对路径,请问该如何解决 万分感谢----

如何在wordpress博客中添加炫酷的加载中动画特效

中介交易 http://www.aliyun.com/zixun/aggregation/6858.html">SEO诊断 淘宝客 云主机 技术大厅 一个优秀的博客不仅仅要给读者得到想要的知识或内容,也应该给予读者阅读时的享受.因为有些朋友的网速很慢,而博客中的图片等内容挺多的,所以在网页打开时往往需要等半天,如果此时能够显示一个漂亮的入场动画,也许可以缓解等待网页打开的无奈感.今天就来分享一下周叔博客的加载动画特效. 特效的实现并不麻烦,简单来说就是用几个层来遮罩页面,然后在这个层之上添

信息删除-菜鸟求教:csdn博客中的删除功能是如何实现的

问题描述 菜鸟求教:csdn博客中的删除功能是如何实现的 博客列表中的删除按钮放上时显示一个连接,点击能实现删除,但是为什么这个链接拷到地址栏后却无法实现删除,而且会报错,求大神指教

谷歌在博客中称:每个人都应该得到祝福

http://www.aliyun.com/zixun/aggregation/624.html">谷歌周二在Google++博客中宣布,Google+将添加生日提醒功能,并显示在Google.com页面上. 谷歌在博客中称:"在生日当天,每个人都应该得到祝福.因此,我们将允许谷歌用户及其好友在谷歌上庆祝这一天.从今天开始,每逢圈内好友生日,用户都会在Google.com页面上看到提醒." 谷歌表示,用户可以设置好自己的生日,以及自己想要分享生日的好友,系统将会在当天提

雅虎被收购后,Tumblr 前途未卜,准备在所有博客中引入广告

  7月25日,Verizon 以 4.82 亿美元收购了雅虎,一起被收购的还有雅虎多年前收购的轻博客应用 Tumblr.两次易主,Tumblr 的命运将会如何? 今天,Tumblr 默默在官方发布声明称,将会在网站上推出新的广告项目,所有用户的博客中都将出现广告.虽然 Tumblr 没有透露更多细节,但是这是早期 Creatrs 项目的扩展,Creatrs 直接将广告主和 Tumblr 用户联系起来,而不是将广告主与第三方影响者结合起来. Tumblr 表示所有的博主都有机会在自己的博客中运行

社会化营销新手段-企业从客座博客中收益的8大案例

本文介绍了8大知名公司如Intel,Evernote,奥美等案例,看他们是如何通过参与客座博客,帮助自己的企业与个人更好地在塑造品牌,迅速提升知名度和影响力的.作为逐渐兴起的社会化营销手段,可以帮助企业和个人更好地塑造品牌,迅速提升知名度和影响力.本文列举八个知名企业为达到不同目的使用客座博客的案例,旨在为读者认识这一社会化媒体工具提供一些新的视角和思路. 写在前面的话 客座博客是一把双刃剑.它十分有效,又频频遭到质疑.它同博客诞生于同一时期,却只在最近几年才开始受到关注.它真的是一种明智.双赢

如何使用C#实现网易博客中圈子用户数据的采集

新浪博客,网易博客,都是博客中的佼佼者,其中网易提供的圈子信息,更胜一筹,使得一般用户能够通过访问圈子进入相关的群组,或者获取相关圈子用户的信息等,以实现各种精准营销的目的.虽然新浪遮遮掩掩不提供圈子的相关信息,相对而言,网易博客提供圈子,能够使得更多的人.更多的程序支持,推高博客的知名度及实用性.网易博客可以通过地址http://q.163.com/ 访问,它是经过两级分类的,如下所示.    点击分类进入即可查看到每个子分类都有很多圈子,圈子累死QQ的群组,是某一兴趣团体的博客,里面收集很多