1 Star 0 Fork 0

子弹大仙/kbengine_unity3d_plugins

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
MemoryStream.cs 7.27 KB
一键复制 编辑 原始数据 按行查看 历史
liquidx 提交于 2014-12-08 16:41 . up
namespace KBEngine
{
using UnityEngine;
using System;
using System.Net;
using System.Collections;
using System.Collections.Generic;
using System.Text;
using System.Threading;
using System.Runtime.InteropServices;
/*
二进制数据流模块
能够将一些基本类型序列化(writeXXX)成二进制流同时也提供了反序列化(readXXX)等操作
*/
public class MemoryStream
{
public const int BUFFER_MAX = 1460 * 4;
public int rpos = 0;
public int wpos = 0;
private byte[] datas_ = new byte[BUFFER_MAX];
private static System.Text.ASCIIEncoding _converter = new System.Text.ASCIIEncoding();
[StructLayout(LayoutKind.Explicit, Size = 4)]
struct PackFloatXType
{
[FieldOffset(0)]
public float fv;
[FieldOffset(0)]
public UInt32 uv;
[FieldOffset(0)]
public Int32 iv;
}
public byte[] data()
{
return datas_;
}
public void setData(byte[] data)
{
datas_ = data;
}
//---------------------------------------------------------------------------------
public SByte readInt8()
{
return (SByte)datas_[rpos++];
}
public Int16 readInt16()
{
rpos += 2;
return BitConverter.ToInt16(datas_, rpos - 2);
}
public Int32 readInt32()
{
rpos += 4;
return BitConverter.ToInt32(datas_, rpos - 4);
}
public Int64 readInt64()
{
rpos += 8;
return BitConverter.ToInt64(datas_, rpos - 8);
}
public Byte readUint8()
{
return datas_[rpos++];
}
public UInt16 readUint16()
{
rpos += 2;
return BitConverter.ToUInt16(datas_, rpos - 2);
}
public UInt32 readUint32()
{
rpos += 4;
return BitConverter.ToUInt32(datas_, rpos - 4);
}
public UInt64 readUint64()
{
rpos += 8;
return BitConverter.ToUInt64(datas_, rpos - 8);
}
public float readFloat()
{
rpos += 4;
return BitConverter.ToSingle(datas_, rpos - 4);
}
public double readDouble()
{
rpos += 8;
return BitConverter.ToDouble(datas_, rpos - 8);
}
public string readString()
{
int offset = rpos;
while(datas_[rpos++] != 0)
{
}
return _converter.GetString(datas_, offset, rpos - offset - 1);
}
public byte[] readBlob()
{
UInt32 size = readUint32();
byte[] buf = new byte[size];
Array.Copy(datas_, rpos, buf, 0, size);
rpos += (int)size;
return buf;
}
public Vector2 readPackXZ()
{
PackFloatXType xPackData;
PackFloatXType zPackData;
xPackData.fv = 0f;
zPackData.fv = 0f;
xPackData.uv = 0x40000000;
zPackData.uv = 0x40000000;
Byte v1 = readUint8();
Byte v2 = readUint8();
Byte v3 = readUint8();
UInt32 data = 0;
data |= ((UInt32)v1 << 16);
data |= ((UInt32)v2 << 8);
data |= (UInt32)v3;
xPackData.uv |= (data & 0x7ff000) << 3;
zPackData.uv |= (data & 0x0007ff) << 15;
xPackData.fv -= 2.0f;
zPackData.fv -= 2.0f;
xPackData.uv |= (data & 0x800000) << 8;
zPackData.uv |= (data & 0x000800) << 20;
Vector2 vec = new Vector2(xPackData.fv, zPackData.fv);
return vec;
}
public float readPackY()
{
PackFloatXType yPackData;
yPackData.fv = 0f;
yPackData.uv = 0x40000000;
UInt16 data = readUint16();
yPackData.uv |= ((UInt32)data & 0x7fff) << 12;
yPackData.fv -= 2f;
yPackData.uv |= ((UInt32)data & 0x8000) << 16;
return yPackData.fv;
}
//---------------------------------------------------------------------------------
public void writeInt8(SByte v)
{
datas_[wpos++] = (Byte)v;
}
public void writeInt16(Int16 v)
{
writeInt8((SByte)(v & 0xff));
writeInt8((SByte)(v >> 8 & 0xff));
}
public void writeInt32(Int32 v)
{
for(int i=0; i<4; i++)
writeInt8((SByte)(v >> i * 8 & 0xff));
}
public void writeInt64(Int64 v)
{
byte[] getdata = BitConverter.GetBytes(v);
for(int i=0; i<getdata.Length; i++)
{
datas_[wpos++] = getdata[i];
}
}
public void writeUint8(Byte v)
{
datas_[wpos++] = v;
}
public void writeUint16(UInt16 v)
{
writeUint8((Byte)(v & 0xff));
writeUint8((Byte)(v >> 8 & 0xff));
}
public void writeUint32(UInt32 v)
{
for(int i=0; i<4; i++)
writeUint8((Byte)(v >> i * 8 & 0xff));
}
public void writeUint64(UInt64 v)
{
byte[] getdata = BitConverter.GetBytes(v);
for(int i=0; i<getdata.Length; i++)
{
datas_[wpos++] = getdata[i];
}
}
public void writeFloat(float v)
{
byte[] getdata = BitConverter.GetBytes(v);
for(int i=0; i<getdata.Length; i++)
{
datas_[wpos++] = getdata[i];
}
}
public void writeDouble(double v)
{
byte[] getdata = BitConverter.GetBytes(v);
for(int i=0; i<getdata.Length; i++)
{
datas_[wpos++] = getdata[i];
}
}
public void writeBlob(byte[] v)
{
UInt32 size = (UInt32)v.Length;
if(size + 4 > space())
{
Dbg.ERROR_MSG("memorystream::writeBlob: no free!");
return;
}
writeUint32(size);
for(UInt32 i=0; i<size; i++)
{
datas_[wpos++] = v[i];
}
}
public void writeString(string v)
{
if(v.Length > space())
{
Dbg.ERROR_MSG("memorystream::writeString: no free!");
return;
}
byte[] getdata = System.Text.Encoding.ASCII.GetBytes(v);
for(int i=0; i<getdata.Length; i++)
{
datas_[wpos++] = getdata[i];
}
datas_[wpos++] = 0;
}
//---------------------------------------------------------------------------------
public void append(byte[] datas, UInt32 offset, UInt32 size)
{
UInt32 free = space();
if (free < size) {
byte[] newdatas = new byte[datas_.Length + size * 2];
Array.Copy(datas_, 0, newdatas, 0, wpos);
datas_ = newdatas;
}
Array.Copy(datas, offset, datas_, wpos, size);
wpos += (int)size;
}
//---------------------------------------------------------------------------------
public void readSkip(UInt32 v)
{
rpos += (int)v;
}
//---------------------------------------------------------------------------------
public UInt32 space()
{
return (UInt32)(data().Length - wpos);
}
//---------------------------------------------------------------------------------
public UInt32 length()
{
return (UInt32)(wpos - rpos);
}
//---------------------------------------------------------------------------------
public bool readEOF()
{
return (BUFFER_MAX - rpos) <= 0;
}
//---------------------------------------------------------------------------------
public void done()
{
rpos = wpos;
}
//---------------------------------------------------------------------------------
public void clear()
{
rpos = wpos = 0;
if(datas_.Length > BUFFER_MAX)
datas_ = new byte[BUFFER_MAX];
}
//---------------------------------------------------------------------------------
public byte[] getbuffer()
{
byte[] buf = new byte[length()];
Array.Copy(data(), rpos, buf, 0, length());
return buf;
}
//---------------------------------------------------------------------------------
public string toString()
{
string s = "";
int ii = 0;
byte[] buf = getbuffer();
for(int i=0; i<buf.Length; i++)
{
ii += 1;
if(ii >= 200)
{
// MyDebug.Dbg.Log(s);
s = "";
ii = 0;
}
s += buf[i];
s += " ";
}
// MyDebug.Dbg.Log(s);
return s;
}
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/BulletHermit/kbengine_unity3d_plugins.git
[email protected]:BulletHermit/kbengine_unity3d_plugins.git
BulletHermit
kbengine_unity3d_plugins
kbengine_unity3d_plugins
master

搜索帮助