/// <summary> /// Saves point plate data to the given file. /// </summary> /// <param name="fileName">File to open.</param> /// <param name="pointPlateData">Data to save.</param> public static void SavePointPlateData(string fileName, int[,] pointPlateData) { var plateCount = 0; for (int x = 0; x < pointPlateData.GetLength(0); x++) { for (int y = 0; y < pointPlateData.GetLength(1); y++) { if (pointPlateData[x, y] > plateCount) { plateCount = pointPlateData[x, y]; } } } CheapBinaryIO.Write(fileName + plateNumberExtension, pointPlateData, plateCount); }
/// <summary> /// Saves point data to the given file. /// </summary> /// <param name="fileName">File to open.</param> /// <param name="rules">Rules for how data will be written.</param> /// <param name="pointData">Data to save.</param> public static void SavePointData(string fileName, GeneralRules rules, PlatePoint[,] pointData) { var plateNumbers = new int[2 * rules.xHalfSize, rules.ySize]; var xBirthPlace = new int[2 * rules.xHalfSize, rules.ySize]; var yBirthPlace = new int[2 * rules.xHalfSize, rules.ySize]; var birthDate = new int[2 * rules.xHalfSize, rules.ySize]; var isContinental = new bool[2 * rules.xHalfSize, rules.ySize]; var continentalBuildup = new int[2 * rules.xHalfSize, rules.ySize]; var continentalRecency = new int[2 * rules.xHalfSize, rules.ySize]; var oceanicBuildup = new int[2 * rules.xHalfSize, rules.ySize]; var oceanicRecency = new int[2 * rules.xHalfSize, rules.ySize]; for (int x = 0; x < 2 * rules.xHalfSize; x++) { for (int y = 0; y < rules.ySize; y++) { plateNumbers[x, y] = pointData[x, y].PlateNumber; xBirthPlace[x, y] = pointData[x, y]._birthPlace.X; yBirthPlace[x, y] = pointData[x, y]._birthPlace.Y; birthDate[x, y] = pointData[x, y]._birthDate; isContinental[x, y] = pointData[x, y].IsContinental; continentalBuildup[x, y] = pointData[x, y].History.ContinentalBuildup; continentalRecency[x, y] = pointData[x, y].History.ContinentalRecency; oceanicBuildup[x, y] = pointData[x, y].History.OceanicBuildup; oceanicRecency[x, y] = pointData[x, y].History.OceanicRecency; } } CheapBinaryIO.Write(fileName + plateNumberExtension, plateNumbers, rules.plateCount); CheapBinaryIO.Write(fileName + xBirthPlaceExtension, xBirthPlace, 2 * rules.xHalfSize); CheapBinaryIO.Write(fileName + yBirthPlaceExtension, yBirthPlace, rules.ySize); CheapBinaryIO.Write(fileName + birthTimeExtension, birthDate, rules.ySize); CheapBinaryIO.WriteBinary(fileName + isContinentalExtension, isContinental); CheapBinaryIO.Write(fileName + continentalBuildupExtension, continentalBuildup, rules.maxBuildup); CheapBinaryIO.Write(fileName + continentalRecencyExtension, continentalRecency, rules.currentTime); CheapBinaryIO.Write(fileName + oceanicBuildupExtension, oceanicBuildup, rules.maxBuildup); CheapBinaryIO.Write(fileName + oceanicRecencyExtension, oceanicRecency, rules.currentTime); }