private ContourLine[] ReadVersion0(FileStream fs, BinaryReader br, out ContourPersist.enumCoordType coordType, out ContourLine.ContourEnvelope envelope, out string spatialRef) { int cntCount = br.ReadInt32(); coordType = (enumCoordType)br.ReadByte(); envelope = ReadEnvelope(br); int spLen = br.ReadInt32(); spatialRef = ReadSpatialRef(br, spLen); double[] contourValues = ReadContourValues(br, cntCount); long[] offsets = ReadOffsets(br, cntCount); List <ContourLine> cntLines = new List <ContourLine>(cntCount); for (int i = 0; i < cntCount; i++) { ContourLine cntLine = ReadCntLine(br, contourValues[i]); cntLines.Add(cntLine); } return(cntLines.Count > 0 ? cntLines.ToArray() : null); }
public ContourLine[] Read(string fname, out ContourPersist.enumCoordType coordType, out ContourLine.ContourEnvelope envelope, out string spatialRef) { coordType = 0; envelope = null; spatialRef = null; if (string.IsNullOrEmpty(fname) || !File.Exists(fname)) { return(null); } using (FileStream fs = new FileStream(fname, FileMode.Open, FileAccess.Read)) { using (BinaryReader br = new BinaryReader(fs, Encoding.Unicode)) { char[] fileId = br.ReadChars(FILE_IDENTIFY.Length); FileIdentifyIsError(fileId); byte version = br.ReadByte(); if (version == 0) { return(ReadVersion0(fs, br, out coordType, out envelope, out spatialRef)); } } } throw new NotSupportedException("等值线文件版本号错误!"); }
public unsafe void Write(ContourLine[] cntLines, ContourPersist.enumCoordType coordType, ContourLine.ContourEnvelope envelope, string spatialRef, string fname) { if (cntLines == null || cntLines.Length == 0) { return; } int cntCount = cntLines.Length; byte version = 0; using (FileStream fs = new FileStream(fname, FileMode.Create, FileAccess.Write)) { using (BinaryWriter bw = new BinaryWriter(fs, Encoding.Unicode)) { bw.Write(FILE_IDENTIFY); bw.Write(version); bw.Write(cntCount); bw.Write((byte)coordType); //envelope WriteEnvelope(bw, envelope); //spatial ref char[] spRefChars; int spLen = GetSpatialRefLen(spatialRef, out spRefChars); bw.Write(spLen); if (spRefChars != null && spRefChars.Length > 0) { bw.Write(spRefChars); } //contourValue long offset = fs.Position; for (int i = 0; i < cntCount; i++, offset += SIZE_OF_DOUBLE) { bw.Write(cntLines[i].ContourValue); } //index int cntLineHeader = SIZE_OF_ENVELOPE + SIZE_OF_INT + SIZE_OF_INT;//外包矩形+ 分类序号 + 点数 for (int i = 0; i < cntCount; i++) { bw.Write(offset); offset += (cntLineHeader + cntLines[i].Count * SIZE_OF_POINTF); } //contour lines ContourLine crtLine; for (int i = 0; i < cntCount; i++) { crtLine = cntLines[i]; WriteEnvelope(bw, crtLine.Envelope); bw.Write(crtLine.ClassIndex); bw.Write(crtLine.Count); fixed(PointF *ptr0 = crtLine.Points) { PointF *ptr = ptr0; int ptCount = crtLine.Count; for (int k = 0; k < ptCount; k++, ptr++) { bw.Write(ptr->X); bw.Write(ptr->Y); } } } } } }