本文整理汇总了C#中System.Text.ASCIIEncoding.GetChars方法的典型用法代码示例。如果您正苦于以下问题:C# System.Text.ASCIIEncoding.GetChars方法的具体用法?C# System.Text.ASCIIEncoding.GetChars怎么用?C# System.Text.ASCIIEncoding.GetChars使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类System.Text.ASCIIEncoding
的用法示例。
在下文中一共展示了System.Text.ASCIIEncoding.GetChars方法的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: ReadObject
// read object
internal static ObjectManager.StaticObject ReadObject(string FileName, System.Text.Encoding Encoding, ObjectManager.ObjectLoadMode LoadMode, bool ForceTextureRepeatX, bool ForceTextureRepeatY) {
byte[] Data = System.IO.File.ReadAllBytes(FileName);
if (Data.Length < 16 || Data[0] != 120 | Data[1] != 111 | Data[2] != 102 | Data[3] != 32) {
// not an x object
Interface.AddMessage(Interface.MessageType.Error, false, "Invalid X object file encountered in " + FileName);
return null;
}
if (Data[4] != 48 | Data[5] != 51 | Data[6] != 48 | Data[7] != 50 & Data[7] != 51) {
// unrecognized version
System.Text.ASCIIEncoding Ascii = new System.Text.ASCIIEncoding();
string s = new string(Ascii.GetChars(Data, 4, 4));
Interface.AddMessage(Interface.MessageType.Error, false, "Unsupported X object file version " + s + " encountered in " + FileName);
}
// floating-point format
int FloatingPointSize;
if (Data[12] == 48 & Data[13] == 48 & Data[14] == 51 & Data[15] == 50) {
FloatingPointSize = 32;
} else if (Data[12] == 48 & Data[13] == 48 & Data[14] == 54 & Data[15] == 52) {
FloatingPointSize = 64;
} else {
Interface.AddMessage(Interface.MessageType.Error, false, "Unsupported floating point format encountered in X object file " + FileName);
return null;
}
// supported floating point format
if (Data[8] == 116 & Data[9] == 120 & Data[10] == 116 & Data[11] == 32) {
// textual flavor
return LoadTextualX(FileName, System.IO.File.ReadAllText(FileName), Encoding, LoadMode, ForceTextureRepeatX, ForceTextureRepeatY);
} else if (Data[8] == 98 & Data[9] == 105 & Data[10] == 110 & Data[11] == 32) {
// binary flavor
return LoadBinaryX(FileName, Data, 16, Encoding, FloatingPointSize, LoadMode, ForceTextureRepeatX, ForceTextureRepeatY);
} else if (Data[8] == 116 & Data[9] == 122 & Data[10] == 105 & Data[11] == 112) {
// compressed textual flavor
#if !DEBUG
try {
#endif
byte[] Uncompressed = Decompress(Data);
string Text = Encoding.GetString(Uncompressed);
return LoadTextualX(FileName, Text, Encoding, LoadMode, ForceTextureRepeatX, ForceTextureRepeatY);
#if !DEBUG
} catch (Exception ex) {
Interface.AddMessage(Interface.MessageType.Error, false, "An unexpected error occured (" + ex.Message + ") while attempting to decompress the binary X object file encountered in " + FileName);
return null;
}
#endif
} else if (Data[8] == 98 & Data[9] == 122 & Data[10] == 105 & Data[11] == 112) {
// compressed binary flavor
#if !DEBUG
try {
#endif
byte[] Uncompressed = Decompress(Data);
return LoadBinaryX(FileName, Uncompressed, 0, Encoding, FloatingPointSize, LoadMode, ForceTextureRepeatX, ForceTextureRepeatY);
#if !DEBUG
} catch (Exception ex) {
Interface.AddMessage(Interface.MessageType.Error, false, "An unexpected error occured (" + ex.Message + ") while attempting to decompress the binary X object file encountered in " + FileName);
return null;
}
#endif
} else {
// unsupported flavor
Interface.AddMessage(Interface.MessageType.Error, false, "Unsupported X object file encountered in " + FileName);
return null;
}
}
示例2: PreprocessChrRndSub
//.........这里部分代码省略.........
if (value > number) {
chosenIndex = ia;
break;
}
}
Expression[] expr;
string[] lines = System.IO.File.ReadAllLines(files[chosenIndex], Encoding);
PreprocessSplitIntoExpressions(files[chosenIndex], IsRW, lines, Encoding, out expr, false, offsets[chosenIndex] + Expressions[i].TrackPositionOffset);
int length = Expressions.Length;
if (expr.Length == 0) {
for (int ia = i; ia < Expressions.Length - 1; ia++) {
Expressions[ia] = Expressions[ia + 1];
}
Array.Resize<Expression>(ref Expressions, length - 1);
} else {
Array.Resize<Expression>(ref Expressions, length + expr.Length - 1);
for (int ia = Expressions.Length - 1; ia >= i + expr.Length; ia--) {
Expressions[ia] = Expressions[ia - expr.Length + 1];
}
for (int ia = 0; ia < expr.Length; ia++) {
Expressions[i + ia] = expr[ia];
}
}
i--;
continueWithNextExpression = true;
}
}
break;
case "$chr":
{
int x;
if (Interface.TryParseIntVb6(s, out x)) {
if (x > 0 & x < 128) {
Expressions[i].Text = Expressions[i].Text.Substring(0, j) + new string(Encoding.GetChars(new byte[] { (byte)x })) + Expressions[i].Text.Substring(h + 1);
} else {
continueWithNextExpression = true;
Interface.AddMessage(Interface.MessageType.Error, false, "Index does not correspond to a valid ASCII character in " + t + Epilog);
}
} else {
continueWithNextExpression = true;
Interface.AddMessage(Interface.MessageType.Error, false, "Index is invalid in " + t + Epilog);
}
} break;
case "$rnd":
{
int m = s.IndexOf(";", StringComparison.Ordinal);
if (m >= 0) {
string s1 = s.Substring(0, m).TrimEnd();
string s2 = s.Substring(m + 1).TrimStart();
int x; if (Interface.TryParseIntVb6(s1, out x)) {
int y; if (Interface.TryParseIntVb6(s2, out y)) {
int z = x + (int)Math.Floor(Program.RandomNumberGenerator.NextDouble() * (double)(y - x + 1));
Expressions[i].Text = Expressions[i].Text.Substring(0, j) + z.ToString(Culture) + Expressions[i].Text.Substring(h + 1);
} else {
continueWithNextExpression = true;
Interface.AddMessage(Interface.MessageType.Error, false, "Index2 is invalid in " + t + Epilog);
}
} else {
continueWithNextExpression = true;
Interface.AddMessage(Interface.MessageType.Error, false, "Index1 is invalid in " + t + Epilog);
}
} else {
continueWithNextExpression = true;
Interface.AddMessage(Interface.MessageType.Error, false, "Two arguments are expected in " + t + Epilog);
}
} break;
示例3: ReadBinaryTemplate
//.........这里部分代码省略.........
return false;
}
} break;
case TOKEN_OBRACE:
Interface.AddMessage(Interface.MessageType.Error, false, "Unexpected token TOKEN_OBRACE encountered at position 0x" + Reader.BaseStream.Position.ToString("X", Culture) + " in binary X object file " + FileName);
return false;
case TOKEN_CBRACE:
if (Level == 0) return true;
Level--;
break;
default:
Interface.AddMessage(Interface.MessageType.Error, false, "Unknown token encountered at position 0x" + Reader.BaseStream.Position.ToString("X", Culture) + " in binary X object file " + FileName);
return false;
} m--;
} else if (Template.Members[m] == "[...]") {
// any template
if (Cache.IntegersRemaining != 0) {
Interface.AddMessage(Interface.MessageType.Error, false, "An integer list was not depleted at position 0x" + Reader.BaseStream.Position.ToString("X", Culture) + " in binary X object file " + FileName);
} else if (Cache.FloatsRemaining != 0) {
Interface.AddMessage(Interface.MessageType.Error, false, "A float list was not depleted at position 0x" + Reader.BaseStream.Position.ToString("X", Culture) + " in binary X object file " + FileName);
}
if (Template.Name.Length == 0 && Reader.BaseStream.Position == Reader.BaseStream.Length) {
// end of file
return true;
}
short Token = Reader.ReadInt16();
switch (Token) {
case TOKEN_NAME:
int n = Reader.ReadInt32();
if (n < 1) {
Interface.AddMessage(Interface.MessageType.Error, false, "count is invalid in TOKEN_NAME at position 0x" + Reader.BaseStream.Position.ToString("X", Culture) + " in binary X object file " + FileName);
return false;
}
string Name = new string(Ascii.GetChars(Reader.ReadBytes(n)));
Token = Reader.ReadInt16();
if (Token != TOKEN_OBRACE) {
Interface.AddMessage(Interface.MessageType.Error, false, "TOKEN_OBRACE expected at position 0x" + Reader.BaseStream.Position.ToString("X", Culture) + " in binary X object file " + FileName);
return false;
}
Structure o;
if (!ReadBinaryTemplate(FileName, Reader, FloatingPointSize, GetTemplate(Name), false, ref Cache, out o)) {
return false;
}
Array.Resize<object>(ref Structure.Data, Structure.Data.Length + 1);
Structure.Data[Structure.Data.Length - 1] = o;
break;
case TOKEN_CBRACE:
if (Template.Name.Length == 0) {
Interface.AddMessage(Interface.MessageType.Error, false, "Unexpected TOKEN_CBRACE encountered at position 0x" + Reader.BaseStream.Position.ToString("X", Culture) + " in binary X object file " + FileName);
return false;
}
m++;
break;
default:
Interface.AddMessage(Interface.MessageType.Error, false, "TOKEN_NAME or TOKEN_CBRACE expected at position 0x" + Reader.BaseStream.Position.ToString("X", Culture) + " in binary X object file " + FileName);
return false;
} m--;
} else if (Template.Members[m].EndsWith("]", StringComparison.Ordinal)) {
// inlined array expected
string r = Template.Members[m].Substring(0, Template.Members[m].Length - 1);
int h = r.IndexOf('[');
if (h >= 0) {
string z = r.Substring(h + 1, r.Length - h - 1);
r = r.Substring(0, h);
if (!int.TryParse(z, System.Globalization.NumberStyles.Integer, System.Globalization.CultureInfo.InvariantCulture, out h)) {
Interface.AddMessage(Interface.MessageType.Error, false, "The internal format description for a template array is invalid in template " + Template.Name + " in binary X object file " + FileName);
示例4: PreprocessChrRndSub
// preprocess chrrndsub
private static void PreprocessChrRndSub(string FileName, ref Expression[] Expressions)
{
System.Globalization.CultureInfo Culture = System.Globalization.CultureInfo.InvariantCulture;
System.Text.Encoding Encoding = new System.Text.ASCIIEncoding();
string[] Subs = new string[16];
for (int i = 0; i < Expressions.Length; i++) {
string Epilog = " at line " + Expressions[i].Line.ToString(Culture) + ", column " + Expressions[i].Column.ToString(Culture) + " in file " + FileName;
bool err = false;
for (int j = Expressions[i].Text.Length - 1; j >= 0; j--) {
if (Expressions[i].Text[j] == '$') {
int k;
for (k = j + 1; k < Expressions[i].Text.Length; k++) {
if (Expressions[i].Text[k] == '(') break;
}
if (k <= Expressions[i].Text.Length) {
string t = Expressions[i].Text.Substring(j, k - j).TrimEnd();
int l = 1, h;
for (h = k + 1; h < Expressions[i].Text.Length; h++) {
switch (Expressions[i].Text[h]) {
case '(':
l++;
break;
case ')':
l--;
if (l < 0) {
err = true; Interface.AddMessage(Interface.MessageType.Error, false, "Invalid parenthesis structure in " + t + Epilog);
}
break;
}
if (l <= 0) break;
}
if (err) break;
if (l != 0) {
Interface.AddMessage(Interface.MessageType.Error, false, "Invalid parenthesis structure in " + t + Epilog);
err = true; break;
}
string s = Expressions[i].Text.Substring(k + 1, h - k - 1).Trim();
switch (t.ToLowerInvariant()) {
case "$chr":
{
int x; if (Interface.TryParseIntVb6(s, out x)) {
if (x > 0 & x < 128) {
Expressions[i].Text = Expressions[i].Text.Substring(0, j) + new string(Encoding.GetChars(new byte[] { (byte)x })) + Expressions[i].Text.Substring(h + 1);
} else {
err = true; Interface.AddMessage(Interface.MessageType.Error, false, "Index does not correspond to a valid ASCII character in " + t + Epilog);
}
} else {
err = true; Interface.AddMessage(Interface.MessageType.Error, false, "Index is invalid in " + t + Epilog);
}
} break;
case "$rnd":
{
int m = s.IndexOf(";", StringComparison.Ordinal);
if (m >= 0) {
string s1 = s.Substring(0, m).TrimEnd();
string s2 = s.Substring(m + 1).TrimStart();
int x; if (Interface.TryParseIntVb6(s1, out x)) {
int y; if (Interface.TryParseIntVb6(s2, out y)) {
int z = x + (int)Math.Floor(Game.Generator.NextDouble() * (double)(y - x + 1));
Expressions[i].Text = Expressions[i].Text.Substring(0, j) + z.ToString(Culture) + Expressions[i].Text.Substring(h + 1);
} else {
err = true; Interface.AddMessage(Interface.MessageType.Error, false, "Index2 is invalid in " + t + Epilog);
}
} else {
err = true; Interface.AddMessage(Interface.MessageType.Error, false, "Index1 is invalid in " + t + Epilog);
}
} else {
err = true; Interface.AddMessage(Interface.MessageType.Error, false, "Two arguments are expected in " + t + Epilog);
}
} break;
case "$sub":
{
l = 0;
bool f = false;
int m;
for (m = h + 1; m < Expressions[i].Text.Length; m++) {
switch (Expressions[i].Text[m]) {
case '(': l++; break;
case ')': l--; break;
case '=': if (l == 0) {
f = true;
}
break;
default:
if (!char.IsWhiteSpace(Expressions[i].Text[m])) l = -1;
break;
}
if (f | l < 0) break;
}
if (f) {
l = 0;
int n;
for (n = m + 1; n < Expressions[i].Text.Length; n++) {
switch (Expressions[i].Text[n]) {
case '(': l++; break;
case ')': l--; break;
}
if (l < 0) break;
}
//.........这里部分代码省略.........
示例5: parse
public bool parse()
{
byte[] token = new byte[4096];
int lapg_head = 0, group = 0, lapg_i, lapg_size, chr;
lapg_symbol[] lapg_m = new lapg_symbol[1024];
lapg_symbol lapg_n;
System.Text.ASCIIEncoding AE = new System.Text.ASCIIEncoding();
lapg_place lapg_current;
lapg_current.offset = 0;
lapg_current.line = 1;
lapg_m[0].state = 0; lapg_n.lexem = lapg_n.state = 0;
chr = buff[l++];
do {
lapg_n.pos = lapg_current;
for( lapg_size = 0, lapg_i = group; lapg_i >= 0; ) {
if( lapg_size < 4096-1 ) token[lapg_size++] = (byte)chr;
lapg_i = lapg_lexem[lapg_i,lapg_char2no[chr]];
if( lapg_i >= -1 && chr != 0 ) {
lapg_current.offset++;
if( chr == '\n' ) lapg_current.line++;
chr = buff[l++];
}
}
lapg_n.endpos = lapg_current;
token[lapg_size] = 0;
if( lapg_i == -1 ) {
error( System.String.Format( "invalid lexem at line {0}: `{1}`, skipped", lapg_n.pos.line, new System.String(AE.GetChars(token,0,lapg_size)) ) );
continue;
}
token[lapg_size-1] = 0;
lapg_n.lexem = -lapg_i-2;
lapg_n.sym = null;
switch( lapg_n.lexem ) {
case 1:
#line 22 "syntax"
lapg_n.sym = new System.String(AE.GetChars(token,0,lapg_size-1)); break;
case 2:
#line 26 "syntax"
lapg_n.sym = new System.String(AE.GetChars(token,0,lapg_size-1)); break;
case 3:
#line 30 "syntax"
lapg_n.sym = new System.String(AE.GetChars(token,0,lapg_size-1)); break;
case 4:
#line 33 "syntax"
lapg_n.sym = new System.String(AE.GetChars(token,0,lapg_size-1)); break;
case 5:
#line 34 "syntax"
lapg_n.sym = new System.String(AE.GetChars(token,0,lapg_size-1)); break;
case 6:
#line 38 "syntax"
lapg_n.sym = "abstract"; break;
case 7:
#line 39 "syntax"
lapg_n.sym = "as"; break;
case 8:
#line 40 "syntax"
lapg_n.sym = "base"; break;
case 9:
#line 41 "syntax"
lapg_n.sym = "bool"; break;
case 10:
#line 42 "syntax"
lapg_n.sym = "break"; break;
case 11:
#line 43 "syntax"
lapg_n.sym = "byte"; break;
case 12:
#line 44 "syntax"
lapg_n.sym = "case"; break;
case 13:
#line 45 "syntax"
lapg_n.sym = "catch"; break;
case 14:
#line 46 "syntax"
lapg_n.sym = "char"; break;
case 15:
#line 47 "syntax"
lapg_n.sym = "checked"; break;
case 16:
#line 48 "syntax"
lapg_n.sym = "class"; break;
case 17:
#line 49 "syntax"
lapg_n.sym = "const"; break;
case 18:
#line 50 "syntax"
lapg_n.sym = "continue"; break;
case 19:
#line 51 "syntax"
lapg_n.sym = "decimal"; break;
case 20:
#line 52 "syntax"
lapg_n.sym = "default"; break;
case 21:
#line 53 "syntax"
//.........这里部分代码省略.........
示例6: PreprocessFile
//
// File functions
//
public void PreprocessFile(int iIndex, String sFileName, string sRealName, bool bCheckPre, bool bForePreprocessing)
{
GPSSource gpsSource = (GPSSource)m_GpsTracker.m_gpsSourceList[iIndex];
#if !DEBUG
try
#endif
{
//check if preprocess exists
if( (File.Exists(sFileName + ".TrackAtOnce") || IsTrackAtOnce(sFileName)) &&
(bForePreprocessing==false || bCheckPre))
{
string sTAOFileName;
if (IsTrackAtOnce(sFileName))
sTAOFileName=sFileName;
else
sTAOFileName=sFileName + ".TrackAtOnce";
gpsSource.GpsPos.m_gpsTrack=null;
BinaryReader binReader = new BinaryReader(File.Open(sTAOFileName, FileMode.Open));
// If the file is not empty,
// read it
if(binReader.PeekChar() != -1)
{
gpsSource.GpsPos.m_gpsTrack=new GPSTrack();
string sSign="GPSTracker.TrackAtOnce";
char [] sSignature = binReader.ReadChars(sSign.Length);
string sSignCompare = new string(sSignature);
if (sSignCompare==sSign)
{
gpsSource.GpsPos.m_gpsTrack.m_uPointCount=binReader.ReadUInt32();
gpsSource.GpsPos.m_gpsTrack.SetSize(gpsSource.GpsPos.m_gpsTrack.m_uPointCount);
byte[] byData = new byte[gpsSource.GpsPos.m_gpsTrack.m_uPointCount*8];
byData=binReader.ReadBytes((int)gpsSource.GpsPos.m_gpsTrack.m_uPointCount*8);
System.Buffer.BlockCopy(byData , 0, gpsSource.GpsPos.m_gpsTrack.m_fLat, 0, (int)gpsSource.GpsPos.m_gpsTrack.m_uPointCount*8 );
byData=binReader.ReadBytes((int)gpsSource.GpsPos.m_gpsTrack.m_uPointCount*8);
System.Buffer.BlockCopy(byData , 0, gpsSource.GpsPos.m_gpsTrack.m_fLon, 0, (int)gpsSource.GpsPos.m_gpsTrack.m_uPointCount*8 );
byData=binReader.ReadBytes((int)gpsSource.GpsPos.m_gpsTrack.m_uPointCount*4);
System.Buffer.BlockCopy(byData , 0, gpsSource.GpsPos.m_gpsTrack.m_fAlt, 0, (int)gpsSource.GpsPos.m_gpsTrack.m_uPointCount*4 );
}
}
binReader.Close();
}
else
{
uint uProgress;
uint uMaxProgress;
StreamReader fsGpsFile = null;
String sGpsLine;
byte [] byNMEA;
char [] cNMEA=null;
char [] cNMEAMsg = new char[512];
System.Text.ASCIIEncoding asciiEncoder = new System.Text.ASCIIEncoding();
if(File.Exists(sFileName) && !IsTrackAtOnce(sFileName))
{
FileInfo fInfo = new FileInfo(sFileName);
uProgress=0;
uMaxProgress=(uint)fInfo.Length;
m_GpsTracker.m_gpsTrackerPlugin.pluginShowFixInfo("GPSTracker: Processing " + sRealName + ": " + Convert.ToString(uProgress) +" of " + Convert.ToString(uMaxProgress) + " bytes.");
fsGpsFile = File.OpenText(sFileName);
gpsSource.GpsPos.m_gpsTrack= new GPSTrack();
gpsSource.GpsPos.m_gpsTrack.SetSize(500); //set an initial array size for the track
uint uResizeArraySize=500;
while(true)
{
sGpsLine=fsGpsFile.ReadLine();
if (sGpsLine==null)
break;
uProgress+=(uint)sGpsLine.Length;
m_GpsTracker.m_gpsTrackerPlugin.pluginShowFixInfo("GPSTracker: Processing " + sRealName + ": " + Convert.ToString(uProgress) +" of " + Convert.ToString(uMaxProgress) + " bytes.");
byNMEA = asciiEncoder.GetBytes(sGpsLine);
cNMEA = asciiEncoder.GetChars(byNMEA);
cNMEA.CopyTo(cNMEAMsg,0);
if (m_GpsTracker.m_NMEA.ParseGPSMessage(cNMEAMsg,cNMEA.Length,false,iIndex)==true)
gpsSource.GpsPos.m_gpsTrack.AddPoint(gpsSource.GpsPos.m_fLat,gpsSource.GpsPos.m_fLon,gpsSource.GpsPos.m_fAlt);
//Keep resizing the track array as necessary
if (gpsSource.GpsPos.m_gpsTrack.m_uPointCount >= uResizeArraySize)
{
uResizeArraySize += 100;
gpsSource.GpsPos.m_gpsTrack.Resize(uResizeArraySize);
}
}
uProgress=(uint)fInfo.Length;
m_GpsTracker.m_gpsTrackerPlugin.pluginShowFixInfo("GPSTracker: Processing " + sRealName + ": " + Convert.ToString(uProgress) +" of " + Convert.ToString(uMaxProgress) + " bytes.");
fsGpsFile.Close();
//.........这里部分代码省略.........
示例7: threadFile
public void threadFile()
{
int iIndex= Int32.Parse(Thread.CurrentThread.Name);
GPSSource gpsSource = (GPSSource)m_GpsTracker.m_gpsSourceList[iIndex];
int iIndexFile;
int iIndexNext;
StreamReader fsGpsFile = null;
System.Text.ASCIIEncoding asciiEncoder = new System.Text.ASCIIEncoding();
String sGpsLine=null;
String sIndex;
byte [] byNMEA;
char [] cNMEA=null;
char [] cNMEAMsg = new char[512];
DateTime dtCurrent;
DateTime dtNext = new DateTime(0);
int iEnd=0;
bool bRestartTrack=false;
try
{
if(File.Exists(gpsSource.sFileNameSession))
{
while(m_GpsTracker.m_fCloseThreads==false)
{
bRestartTrack=true;
fsGpsFile = File.OpenText(gpsSource.sFileNameSession);
{
if (m_GpsTracker.m_fPlayback==true)
{
m_GpsTracker.LoadSettings(fsGpsFile,false);
iIndexFile=iIndex+1;
do
{
sIndex=fsGpsFile.ReadLine();
if (sIndex!=null)
iEnd=sIndex.IndexOf(",");
if (sIndex!=null && iEnd>0)
{
iIndexFile=Convert.ToInt32(sIndex.Substring(0,iEnd));
if (iIndexFile==iIndex && sIndex.Length>iEnd+1)
{
sGpsLine=sIndex.Substring(iEnd+1);
break;
}
}
else
break;
} while(m_GpsTracker.m_fCloseThreads==false);
}
else
{
sIndex="dummyindex";
iIndexFile=iIndex;
sGpsLine=fsGpsFile.ReadLine();
}
if (sGpsLine!=null)
{
byNMEA = asciiEncoder.GetBytes(sGpsLine);
cNMEA = asciiEncoder.GetChars(byNMEA);
cNMEA.CopyTo(cNMEAMsg,0);
if (m_GpsTracker.m_iPlaybackSpeed>0)
dtNext=m_GpsTracker.m_NMEA.GetNMEATime(-1,sGpsLine);
}
while(sIndex!=null && sGpsLine!=null && m_GpsTracker.m_fCloseThreads==false && iIndexFile==iIndex)
{
if (sGpsLine!="" && sIndex!="")
{
try
{
if (m_GpsTracker.m_MessageMonitor!=null)
m_GpsTracker.m_MessageMonitor.AddMessageFileRaw(sGpsLine);
}
catch (Exception)
{
m_GpsTracker.m_MessageMonitor=null;
}
if (m_GpsTracker.ShowGPSIcon(cNMEAMsg,cNMEA.Length,false,iIndex,bRestartTrack,true)==true)
{
if (bRestartTrack)
bRestartTrack=false;
//Get current NMEA msg time
dtCurrent=dtNext;
while(m_GpsTracker.m_fCloseThreads==false)
{
//Get next line from file
if (m_GpsTracker.m_fPlayback==true)
{
sIndex=fsGpsFile.ReadLine();
if (sIndex!=null)
{
iEnd=sIndex.IndexOf(",");
if (iEnd>0 && sIndex.Length>iEnd+1)
{
sGpsLine=sIndex.Substring(iEnd+1);
sIndex=sIndex.Substring(0,iEnd);
}
else
sIndex="";
}
//.........这里部分代码省略.........