=================================
=================================
=================================
출처: https://github.com/lyokato/as3jcode
as3jcode I don't believe in ByteArray.readMultiByte/writeMultiByte = Author Lyo Kato, <lyo.kato@gmail.com> = License MIT-License = Usage import org.coderepos.text.encoding.Jcode; var utf8Bytes:ByteArray = new ByteArray(); utf8Bytes.writeUTFBytes("にほんご"); // convert to EUC-JP byte code var eucBytes:ByteArray = Jcode.utf8_euc(utf8Bytes); // convert to ISO-2022-JP byte code var jisBytes:ByteArray = Jcode.utf8_jis(utf8Bytes); // convert to Shift_JIS byte code var jisBytes:ByteArray = Jcode.utf8_sjis(utf8Bytes); // convert to UTF-16 byte code var utf16Bytes:ByteArray = Jcode.utf8_utf16(utf8Bytes); // with BOM that represents Big Endian var utf16Bytes:ByteArray = Jcode.utf8_utf16be(utf8Bytes); utf8Bytes = Jcode.euc_utf8(eucBytes); utf8nBytes = Jcode.euc_utf8n(eucBytes); utf8Bytes = Jcode.jis_utf8(jisBytes); utf8nBytes = Jcode.jis_utf8n(jisBytes); utf8Bytes = Jcode.sjis_utf8(sjisBytes); utf8nBytes = Jcode.sjis_utf8n(sjisBytes); utf8Bytes = Jcode.utf16_utf8(sjisBytes); utf8nBytes = Jcode.utf16_utf8n(sjisBytes); jisBytes = Jcode.euc_jis(eucBytes); sjisBytes = Jcode.euc_sjis(eucBytes); eucBytes = Jcode.jis_euc(jisBytes); sjisBytes = Jcode.jis_sjis(jisBytes); eucBytes = Jcode.sjis_euc(sjisBytes); jisBytes = Jcode.sjis_jis(sjisBytes); ** Short circuit *** Encoding from UTF-8 ActionScript native string var utf8Bytes:ByteArray = new ByteArray(); utf8Bytes.writeUTFBytes("日本語"); var eucBytes:ByteArray = Jcode.utf8_euc(utf8Bytes); instread of above 3 lines code, you can use to_xxx methods. var eucBytes:ByteArray = Jcode.to_euc("日本語"); var jisBytes:ByteArray = Jcode.to_jis("日本語"); var sjisBytes:ByteArray = Jcode.to_sjis("日本語"); *** Decoding to UTF-8 ActionScript native string var utf8String:String = Jcode.from_euc(eucBytes); var utf8String:String = Jcode.from_jis(jisBytes); var utf8String:String = Jcode.from_sjis(sjisBytes); ** Katakana Hankaku to Zenkaku var utf8String:String = Jcode.h2z("アイウエオ"); // utf8String should be "アイウエオ". var origin:String = Jcode.z2h(utf8String); // origin should be "アイウエオ"; ** Validation if (Jcode.is_hiragana(utf8string)) { } if (Jcode.is_zenkaku_katakana(utf8string)) { } if (Jcode.is_hankaku_katakana(utf8string)) { } // zenkaku and hankaku katakana if (Jcode.is_katakana(utf8string)) { } = TODO Zenkaku to Hankaku conversion (required?) Support UTF-16LE, UTF-32, (UTF-7)
//-------------------------------------------------------------------
bytearray
flash.utils.ByteArray.readMultiByte(length:uint, charSet:String):String
- Reads a multibyte string of specified length from the byte stream using the specified character set.
- Parameters:
- length The number of bytes from the byte stream to read.
- charSet The string denoting the character set to use to interpret the bytes. Possible character set strings include
"shift-jis"
,"cn-gb"
,"iso-8859-1"
, and others. For a complete list, see Supported Character Sets.Note: If the value for the
charSet
parameter is not recognized by the current system, the application uses the system's default code page as the character set. For example, a value for thecharSet
parameter, as inmyTest.readMultiByte(22, "iso-8859-01")
that uses01
instead of1
might work on your development machine, but not on another machine. On the other machine, the application will use the system's default code page. - Returns:
- UTF-8 encoded string.
- Throws:
- EOFError - There is not sufficient data available to read.
- Language Version:
- 3.0
- Player Version:
- Flash 9, AIR 1.0
=================================
=================================
=================================
'ADOBE > ActionScript' 카테고리의 다른 글
플래시 AS3.0 정수 - 2, 10, 16 진수 변환 (0) | 2012.02.28 |
---|---|
플래시 AS3.0 삼성 TV 스마트 허브 앱 만들때 AIR3.0 TextField 한글폰트 윗부분 잘릴때 해결방법 (0) | 2012.02.27 |
플래시 AS3.0 array sort 정렬 관련 (1) | 2012.02.07 |
[AS] 플래시 AS3.0 보안, 샌드박스 관련 (0) | 2012.02.02 |
플래시 AS3.0 TextField htmlText 에 html 스타일 적용 (0) | 2012.02.01 |