Khan's Notebook GCC/GNU/Linux Delphi/Window Java/Anywhere

路漫漫,长修远,我们不能没有钱

昨天开始打算写cmpp3.0的网关,于是拿了华为的demo反编译了一下,发现n多汉字都编程了unicode编码,于是自己写了一个unicode转汉字的程序,share给大家

几个转码的函数 unicode string utf8 anscii 之间的转换 delphi

/** 主程序,包含几个转码的函数

*   作者:刘昆

*   最后修改日期:  2004-11-18 

*   以上代码免费,若直接引用一下代码请告知,并保留此注释

*   作为一名程序员应该有最基本的职业道德*/

unit MainForm;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, ExtCtrls;

type
  TFormMain = class(TForm)
    Panel1: TPanel;
    Memo1: TMemo;
    ComboBox1: TComboBox;
    Button1: TButton;
    Memo2: TMemo;
    procedure Button1Click(Sender: TObject);
  private
    function StrToUTF8(str: WideString): string;
    function StrToASC(Str: string): string;
    function GB2Unicode(Str: WideString): string; overload;
    //function GB2Unicode(Str: string): string; overload;
    function U2GB(Str: string): string;
    function UTF8ToStr(const str: UTF8String): string;
    function HexToInt(const Str: string): integer;
    function HexIndex(const c: Char): Integer;
    { Private declarations }
  public
    { Public declarations }
  end;

var
  FormMain: TFormMain;

implementation

{$R *.dfm}

{ TFormMain }

function TFormMain.StrToASC(Str: string): string;
var
  TmpStr: string;
  TmpPchar: Pchar;
  i: integer;
begin
  result := '';
  TmpStr := '';
  TmpPchar := pchar(Str);
  for i := 0 to length(TmpPchar) - 1 do
    TmpStr := TmpStr + format('%2.2x', [ord(TmpPchar[i])]);

  result := TmpStr;
end;

function TFormMain.StrToUTF8(str: WideString): string;
var
  s: pchar;
  i: integer;
  tmp: string;
begin
  tmp := '';
  result := '';
  s := pchar(Utf8encode(str));
  for i := 0 to strlen(s) do begin
    tmp := tmp + format('%2.2x', [ord(s[i])]);
  end;
  result := tmp;
end;


function TFormMain.UTF8ToStr(const str: UTF8String): string;
var
  s: pchar;
  i: integer;
  tmp: string;
begin
  tmp := '';
  result := '';
  s := PChar(str);
  i := 0;
  while i < length(s) do begin
    tmp := tmp + chr(HexToInt(s[i] + s[i + 1]));
    inc(i, 2);
  end;
  result := Utf8Decode(tmp);
end;

function TFormMain.GB2Unicode(Str: WideString): string;
var
  i: Integer;
begin
  Result := '';
  for i := 1 to Length(Str) do
    Result := Result + Format('%4.4x', [ord(Str[i])]);
end;


procedure TFormMain.Button1Click(Sender: TObject);
begin
  case ComboBox1.ItemIndex of
    0: memo2.Lines.Add(GB2Unicode(memo1.Lines.Text));
    1: memo2.Lines.Add(StrToUTF8(memo1.Lines.Text));
    2: memo2.Lines.Add(UTF8ToStr(memo1.Lines.Text));
    3: memo2.Lines.Add(U2GB(StringReplace(memo1.Lines.Text, '\u', '', [rfReplaceAll])));
    4: memo2.Lines.Add(StrToASC(memo1.Lines.Text));
  end;
end;

function TFormMain.HexToInt(const Str: string): integer;
var p: pchar;

begin
  result := -1;
  if length(str) > 2 then exit;
  p := pchar(str);

  if (HexIndex(p[0]) <> -1) and (HexIndex(p[1]) <> -1) then
    result := HexIndex(p[0]) * $10 + HexIndex(p[1]);
end;

function TFormMain.HexIndex(const c: Char): Integer;
const Digits: array[0..15] of Char = ('0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F');
var i: integer;
begin
  result := -1;
  if (not (UpCase(c) in ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'])) then
    exit;

  for i := 0 to high(digits) do
    if Digits[i] = UpCase(c) then begin
      result := i;
      break;
    end;
end;


function TFormMain.U2GB(Str: string): string;
var s: pchar;
  i: integer;
  tmp: string;
begin
  tmp := '';
  result := '';
  s := PChar(str);
  i := 0;
  while i < length(s) do begin
    tmp := tmp + chr(HexToInt(s[i + 2] + s[i + 3])) + chr(HexToInt(s[i] + s[i + 1]));//unicode转换时,高低位互换
    inc(i, 4);
  end;
  result := widechartostring(pWideChar(tmp + #0#0#0#0));
end;

end.


posted on 2004-11-19 05:44 Khan 阅读(1375) 评论(0)  编辑 收藏 引用 所属分类: Delphi


只有注册用户登录后才能发表评论。
【推荐】超50万行VC++源码: 大型组态工控、电力仿真CAD与GIS源码库
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理


<2008年6月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
293012345

导航

统计

公告

短信大全 for android 1.5
豌豆荚一键安装

现在时刻

IM在线情况:
点击这里给我发消息

常用链接

留言簿(33)

随笔分类(218)

随笔档案(163)

相册

技术

友情链接

最新随笔

搜索

积分与排名

最新随笔

最新评论

阅读排行榜

评论排行榜