namespace HStation.Service
{
///
/// Revit Json辅助类
///
public class RevitJsonHelper
{
///
/// 从json字符串中解析
///
public static HStation.Model.RevitModel FromJsonString
(
string revitJsonString,
string revitOthersJsonString,
out string msg
)
{
msg = string.Empty;
if (string.IsNullOrEmpty(revitJsonString))
{
msg = "Revit json 字符串为空";
return default;
}
try
{
var model = new Model.RevitModel();
//解析结构json
var jarray = JArray.Parse(revitJsonString);
for (int i = 0; i < jarray.Count; i++)
{
var jobject = JObject.Parse(jarray[i].ToString());
var catalog = jobject[RevitJsonProp.Catalog].ToString();
switch (catalog)
{
case RevitJsonCatalog.Reservoir:
{
var reservoir = ParseReservoir(jobject);
if (reservoir != null)
{
model.Reservoirs.Add(reservoir);
}
}
break;
case RevitJsonCatalog.Tank:
{
var tank = ParseTank(jobject);
if (tank != null)
{
model.Tanks.Add(tank);
}
}
break;
case RevitJsonCatalog.Waterbox:
{
var waterbox = ParseWaterbox(jobject);
if (waterbox != null)
{
model.Waterboxs.Add(waterbox);
}
}
break;
case RevitJsonCatalog.Junction:
{
var junction = ParseJunction(jobject);
if (junction != null)
{
model.Junctions.Add(junction);
}
}
break;
case RevitJsonCatalog.Blunthead:
{
var blunthead = ParseBlunthead(jobject);
if (blunthead != null)
{
model.Bluntheads.Add(blunthead);
}
}
break;
case RevitJsonCatalog.Elbow:
{
var elbow = ParseElbow(jobject);
if (elbow != null)
{
model.Elbows.Add(elbow);
}
}
break;
case RevitJsonCatalog.Threelink:
{
var threelink = ParseThreelink(jobject);
if (threelink != null)
{
model.Threelinks.Add(threelink);
}
}
break;
case RevitJsonCatalog.Fourlink:
{
var fourlink = ParseFourlink(jobject);
if (fourlink != null)
{
model.Fourlinks.Add(fourlink);
}
}
break;
case RevitJsonCatalog.Meter:
{
var meter = ParseMeter(jobject);
if (meter != null)
{
model.Meters.Add(meter);
}
}
break;
case RevitJsonCatalog.Flowmeter:
{
var flowmeter = ParseFlowmeter(jobject);
if (flowmeter != null)
{
model.Flowmeters.Add(flowmeter);
}
}
break;
case RevitJsonCatalog.Pressmeter:
{
var pressmeter = ParsePressmeter(jobject);
if (pressmeter != null)
{
model.Pressmeters.Add(pressmeter);
}
}
break;
case RevitJsonCatalog.Nozzle:
{
var nozzle = ParseNozzle(jobject);
if (nozzle != null)
{
model.Nozzles.Add(nozzle);
}
}
break;
case RevitJsonCatalog.Hydrant:
{
var hydrant = ParseHydrant(jobject);
if (hydrant != null)
{
model.Hydrants.Add(hydrant);
}
}
break;
case RevitJsonCatalog.Pipe:
{
var pipe = ParsePipe(jobject);
if (pipe != null)
{
model.Pipes.Add(pipe);
}
}
break;
case RevitJsonCatalog.Translation:
{
var translation = ParseTranslation(jobject);
if (translation != null)
{
model.Translations.Add(translation);
}
}
break;
case RevitJsonCatalog.Exchanger:
{
var exchanger = ParseExchanger(jobject);
if (exchanger != null)
{
model.Exchangers.Add(exchanger);
}
}
break;
case RevitJsonCatalog.Pump:
{
var pump = ParsePump(jobject);
if (pump != null)
{
model.Pumps.Add(pump);
}
}
break;
case RevitJsonCatalog.Valve:
{
var valve = ParseValve(jobject);
if (valve != null)
{
model.Valves.Add(valve);
}
}
break;
case RevitJsonCatalog.Other:
{
var decorator = ParseDecorator(jobject);
if (decorator != null)
{
if (!string.IsNullOrEmpty(decorator.Id))
{
model.Decorators.Add(decorator);
}
}
}
break;
default: break;
}
}
//解析其他json
var jothersArray = JArray.Parse(revitOthersJsonString);
if (jothersArray != null && jothersArray.Count > 0)
{
var allParterList = model.GetAllParters();
for (int i = 0; i < jothersArray.Count; i++)
{
var jobject = jothersArray[i];
var id = jobject[RevitOthersJsonProp.Id]?.ToString();
if (string.IsNullOrEmpty(id))
{
continue;
}
if (allParterList.Exists(x => x.Id == id))
{
continue;
}
if (model.Decorators.Exists(x => x.Id == id))
{
continue;
}
var decorator = new Model.RevitDecorator();
decorator.Id = id;
decorator.Code = id;
decorator.Name = jobject[RevitOthersJsonProp.Name]?.ToString();
decorator.Category = jobject[RevitOthersJsonProp.CategoryName]?.ToString();
decorator.Decoration = jobject[RevitOthersJsonProp.CategoryID]?.ToString();
model.Decorators.Add(decorator);
}
}
return model;
}
catch (Exception ex)
{
msg = ex.Message;
return default;
}
}
///
/// 从json文件中解析
///
public static Model.RevitModel FromJsonFile
(
string revitJsonFile,
string revitOthersJsonFile,
out string msg
)
{
if (!File.Exists(revitJsonFile))
{
msg = "Json 文件不存在";
return default;
}
var revitJson = File.ReadAllText(revitJsonFile);
var revitOthersJson = string.Empty;
if (File.Exists(revitOthersJsonFile))
{
revitOthersJson = File.ReadAllText(revitOthersJsonFile);
}
var revitModel = FromJsonString(revitJson, revitOthersJson, out msg);
if (revitModel == null)
{
return default;
}
revitModel.Name = Path.GetFileNameWithoutExtension(revitJsonFile);
revitModel.Description = $"解析【{Path.GetFileName(revitJsonFile)}】文件";
return revitModel;
}
//解析连接节点
private static HStation.Model.RevitJunction ParseJunction(JToken jobject)
{
if (jobject == null)
{
return default;
}
var junction = new Model.RevitJunction();
#region Id
if (jobject.ParseString(RevitJsonProp.Id, out string id))
{
junction.Id = id;
}
else
{
junction.AppendOrUpdatePropStatus(nameof(junction.Id), ePropStatus.Error, "缺少[构件编码]");
}
#endregion
#region Code
if (jobject.ParseString(RevitJsonProp.Code, out string code))
{
junction.Code = code;
if (string.IsNullOrEmpty(junction.Code))
{
junction.Code = junction.Id;
junction.AppendOrUpdatePropStatus(nameof(junction.Code), ePropStatus.Lack, "使用[构件编码]赋值");
}
}
else
{
junction.AppendOrUpdatePropStatus(nameof(junction.Code), ePropStatus.Error, "缺少[编码]");
}
#endregion
#region Name
if (jobject.ParseString(RevitJsonProp.Name, out string name))
{
junction.Name = name;
junction.AppendOrUpdatePropStatus(nameof(junction.Name), ePropStatus.Lack, "[名称]缺省");
}
else
{
junction.AppendOrUpdatePropStatus(nameof(junction.Name), ePropStatus.Error, "缺少 [名称]");
}
#endregion
#region ModelType
if (jobject.ParseString(RevitJsonProp.ModelType, out string modelType))
{
junction.ModelType = modelType;
if (string.IsNullOrEmpty(junction.ModelType))
{
junction.AppendOrUpdatePropStatus(nameof(junction.ModelType), ePropStatus.Lack, "[型号信息]缺省");
}
}
else
{
junction.AppendOrUpdatePropStatus(nameof(junction.ModelType), ePropStatus.Error, "缺少[型号信息]");
}
#endregion
#region Flags
if (jobject.ParseString(RevitJsonProp.Flags, out string flags))
{
junction.Flags = Yw.Untity.FlagsHelper.ToList(flags);
if (!string.IsNullOrEmpty(flags))
{
if (junction.Flags == null || junction.Flags.Count < 1)
{
junction.AppendOrUpdatePropStatus(nameof(junction.Flags), ePropStatus.Abnormal, "[标签]格式错误");
}
}
}
else
{
junction.AppendOrUpdatePropStatus(nameof(junction.Flags), ePropStatus.Error, "缺少[标签]");
}
#endregion
#region Description
if (jobject.ParseString(RevitJsonProp.Description, out string description))
{
junction.Description = description;
}
else
{
junction.AppendOrUpdatePropStatus(nameof(junction.Description), ePropStatus.Error, "缺少[说明信息]");
}
#endregion
#region ConnectList
if (jobject.ParseString(RevitJsonProp.Connects, out string connectString))
{
var connectList = JsonHelper.Json2Object>(connectString);
junction.ConnectList = connectList?.Select(x => new Model.RevitConnect()
{
Id = x.ConnectId,
Direction = x.Dirction,
Position = new Model.RevitPosition()
{
X = x.Point.X / 1000f,
Y = x.Point.Y / 1000f,
Z = x.Point.Z / 1000f
}
}).ToList();
if (junction.ConnectList == null || junction.ConnectList.Count < 1)
{
junction.AppendOrUpdatePropStatus(nameof(junction.ConnectList), ePropStatus.Error, "[连接列表]解析失败");
}
}
else
{
junction.AppendOrUpdatePropStatus(nameof(junction.ConnectList), ePropStatus.Error, "缺少[连接列表]");
}
#endregion
#region Quality
if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
{
junction.Quality = quality;
if (junction.Quality <= 0)
{
junction.AppendOrUpdatePropStatus(nameof(junction.Quality), ePropStatus.Lack, "[初始水质]缺省");
}
}
else
{
junction.AppendOrUpdatePropStatus(nameof(junction.Quality), ePropStatus.Abnormal, "[初始水质]异常,可能是缺少或格式错误");
}
#endregion
#region Position
junction.Position = junction.ConnectList?.GetCenterPosition();
if (junction.Position == null)
{
junction.AppendOrUpdatePropStatus(nameof(junction.Position), ePropStatus.Lack, "[位置]缺省,可能是受[连接列表]解析失败影响");
}
#endregion
#region Elev
if (jobject[RevitJsonProp.Elev].MatchNumeric(out double elev))
{
junction.Elev = elev / 1000f;
}
else
{
junction.AppendOrUpdatePropStatus(nameof(junction.Elev), ePropStatus.Abnormal, "[标高信息]缺少或者格式错误");
}
if (junction.Elev <= 0)
{
if (jobject[RevitJsonProp.ElevOfElevation].MatchNumeric(out double elevOfElevation))
{
junction.Elev = elevOfElevation / 1000f;
}
else
{
junction.AppendOrUpdatePropStatus(nameof(junction.Elev), ePropStatus.Abnormal, "[标高中的高程]缺少或者格式错误");
}
}
if (junction.Elev <= 0)
{
//通过z轴自动计算
if (junction.Position == null)
{
junction.AppendOrUpdatePropStatus(nameof(junction.Elev), ePropStatus.Lack, "[标高]缺省,受[位置]影响,无法通过Z轴自动计算");
}
else
{
junction.Elev = junction.Position.Z;
junction.AppendOrUpdatePropStatus(nameof(junction.Elev), ePropStatus.Lack, "[标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region Demand
if (jobject[RevitJsonProp.Demand].MatchNumeric(out double demand))
{
junction.Demand = demand;
}
else
{
junction.AppendOrUpdatePropStatus(nameof(junction.Demand), ePropStatus.Abnormal, "[需水量]缺少或者数据格式错误");
}
#endregion
#region DemandPattern
if (jobject.ParseString(RevitJsonProp.DemandPattern, out string demandPattern))
{
junction.DemandPattern = demandPattern;
if (string.IsNullOrEmpty(junction.DemandPattern))
{
junction.AppendOrUpdatePropStatus(nameof(junction.DemandPattern), ePropStatus.Lack, "[需水模式]缺省");
}
}
else
{
junction.AppendOrUpdatePropStatus(nameof(junction.DemandPattern), ePropStatus.Abnormal, "缺少[需水模式]");
}
#endregion
return junction;
}
//解析喷头
private static HStation.Model.RevitNozzle ParseNozzle(JToken jobject)
{
if (jobject == null)
{
return default;
}
var nozzle = new Model.RevitNozzle();
#region Id
if (jobject.ParseString(RevitJsonProp.Id, out string id))
{
nozzle.Id = id;
}
else
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.Id), ePropStatus.Error, "缺少[构件编码]");
}
#endregion
#region Code
if (jobject.ParseString(RevitJsonProp.Code, out string code))
{
nozzle.Code = code;
if (string.IsNullOrEmpty(nozzle.Code))
{
nozzle.Code = nozzle.Id;
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.Code), ePropStatus.Lack, "使用[构件编码]赋值");
}
}
else
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.Code), ePropStatus.Error, "缺少[编码]");
}
#endregion
#region Name
if (jobject.ParseString(RevitJsonProp.Name, out string name))
{
nozzle.Name = name;
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.Name), ePropStatus.Lack, "[名称]缺省");
}
else
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.Name), ePropStatus.Error, "缺少 [名称]");
}
#endregion
#region ModelType
if (jobject.ParseString(RevitJsonProp.ModelType, out string modelType))
{
nozzle.ModelType = modelType;
if (string.IsNullOrEmpty(nozzle.ModelType))
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.ModelType), ePropStatus.Lack, "[型号信息]缺省");
}
}
else
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.ModelType), ePropStatus.Error, "缺少[型号信息]");
}
#endregion
#region Flags
if (jobject.ParseString(RevitJsonProp.Flags, out string flags))
{
nozzle.Flags = Yw.Untity.FlagsHelper.ToList(flags);
if (!string.IsNullOrEmpty(flags))
{
if (nozzle.Flags == null || nozzle.Flags.Count < 1)
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.Flags), ePropStatus.Abnormal, "[标签]格式错误");
}
}
}
else
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.Flags), ePropStatus.Error, "缺少[标签]");
}
#endregion
#region Description
if (jobject.ParseString(RevitJsonProp.Description, out string description))
{
nozzle.Description = description;
}
else
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.Description), ePropStatus.Error, "缺少[说明信息]");
}
#endregion
#region ConnectList
if (jobject.ParseString(RevitJsonProp.Connects, out string connectString))
{
var connectList = JsonHelper.Json2Object>(connectString);
nozzle.ConnectList = connectList?.Select(x => new Model.RevitConnect()
{
Id = x.ConnectId,
Direction = x.Dirction,
Position = new Model.RevitPosition()
{
X = x.Point.X / 1000f,
Y = x.Point.Y / 1000f,
Z = x.Point.Z / 1000f
}
}).ToList();
if (nozzle.ConnectList == null || nozzle.ConnectList.Count < 1)
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.ConnectList), ePropStatus.Error, "[连接列表]解析失败");
}
}
else
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.ConnectList), ePropStatus.Error, "缺少[连接列表]");
}
#endregion
#region Quality
if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
{
nozzle.Quality = quality;
if (nozzle.Quality <= 0)
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.Quality), ePropStatus.Lack, "[初始水质]缺省");
}
}
else
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.Quality), ePropStatus.Abnormal, "[初始水质]异常,可能是缺少或格式错误");
}
#endregion
#region Position
nozzle.Position = nozzle.ConnectList?.GetCenterPosition();
if (nozzle.Position == null)
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.Position), ePropStatus.Lack, "[位置]缺省,可能是受[连接列表]解析失败影响");
}
#endregion
#region Elev
if (jobject[RevitJsonProp.Elev].MatchNumeric(out double elev))
{
nozzle.Elev = elev / 1000f;
}
else
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.Elev), ePropStatus.Abnormal, "[标高信息]缺少或者格式错误");
}
if (nozzle.Elev <= 0)
{
if (jobject[RevitJsonProp.ElevOfElevation].MatchNumeric(out double elevOfElevation))
{
nozzle.Elev = elevOfElevation / 1000f;
}
else
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.Elev), ePropStatus.Abnormal, "[标高中的高程]缺少或者格式错误");
}
}
if (nozzle.Elev <= 0)
{
//通过z轴自动计算
if (nozzle.Position == null)
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.Elev), ePropStatus.Lack, "[标高]缺省,受[位置]影响,无法通过Z轴自动计算");
}
else
{
nozzle.Elev = nozzle.Position.Z;
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.Elev), ePropStatus.Lack, "[标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region Demand
if (jobject[RevitJsonProp.Demand].MatchNumeric(out double demand))
{
nozzle.Demand = demand;
}
else
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.Demand), ePropStatus.Abnormal, "[需水量]缺少或者数据格式错误");
}
#endregion
#region DemandPattern
if (jobject.ParseString(RevitJsonProp.DemandPattern, out string demandPattern))
{
nozzle.DemandPattern = demandPattern;
if (string.IsNullOrEmpty(nozzle.DemandPattern))
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.DemandPattern), ePropStatus.Lack, "[需水模式]缺省");
}
}
else
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.DemandPattern), ePropStatus.Abnormal, "缺少[需水模式]");
}
#endregion
#region Coefficient
if (jobject[RevitJsonProp.CoefficientP].MatchNumeric(out double coeffientp))
{
nozzle.Coefficient = coeffientp;
if (nozzle.Coefficient <= 0)
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.Coefficient), ePropStatus.Lack, "[喷射系数]缺省");
}
}
else
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.Coefficient), ePropStatus.Abnormal, "[喷射系数]缺少或者格式错误");
if (jobject[RevitJsonProp.CoefficientF].MatchNumeric(out double coeffientf))
{
nozzle.Coefficient = coeffientf;
if (nozzle.Coefficient <= 0)
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.Coefficient), ePropStatus.Lack, "[流量系数]缺省");
}
}
}
if (nozzle.Coefficient < 1)
{
nozzle.AppendOrUpdatePropStatus(nameof(nozzle.Coefficient), ePropStatus.Lack, "[喷射系数]缺省,使用默认值(163)进行修正");
}
#endregion
return nozzle;
}
//解析消火栓
private static HStation.Model.RevitHydrant ParseHydrant(JToken jobject)
{
if (jobject == null)
{
return default;
}
var hydrant = new Model.RevitHydrant();
#region Id
if (jobject.ParseString(RevitJsonProp.Id, out string id))
{
hydrant.Id = id;
}
else
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.Id), ePropStatus.Error, "缺少[构件编码]");
}
#endregion
#region Code
if (jobject.ParseString(RevitJsonProp.Code, out string code))
{
hydrant.Code = code;
if (string.IsNullOrEmpty(hydrant.Code))
{
hydrant.Code = hydrant.Id;
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.Code), ePropStatus.Lack, "使用[构件编码]赋值");
}
}
else
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.Code), ePropStatus.Error, "缺少[编码]");
}
#endregion
#region Name
if (jobject.ParseString(RevitJsonProp.Name, out string name))
{
hydrant.Name = name;
if (string.IsNullOrEmpty(hydrant.Name))
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.Name), ePropStatus.Lack, "[名称]缺省");
}
}
else
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.Name), ePropStatus.Error, "缺少 [名称]");
}
#endregion
#region ModelType
if (jobject.ParseString(RevitJsonProp.ModelType, out string modelType))
{
hydrant.ModelType = modelType;
if (string.IsNullOrEmpty(hydrant.ModelType))
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.ModelType), ePropStatus.Lack, "[型号信息]缺省");
}
}
else
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.ModelType), ePropStatus.Error, "缺少[型号信息]");
}
#endregion
#region Flags
if (jobject.ParseString(RevitJsonProp.Flags, out string flags))
{
hydrant.Flags = Yw.Untity.FlagsHelper.ToList(flags);
if (!string.IsNullOrEmpty(flags))
{
if (hydrant.Flags == null || hydrant.Flags.Count < 1)
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.Flags), ePropStatus.Abnormal, "[标签]格式错误");
}
}
}
else
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.Flags), ePropStatus.Error, "缺少[标签]");
}
#endregion
#region Description
if (jobject.ParseString(RevitJsonProp.Description, out string description))
{
hydrant.Description = description;
}
else
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.Description), ePropStatus.Error, "缺少[说明信息]");
}
#endregion
#region ConnectList
if (jobject.ParseString(RevitJsonProp.Connects, out string connectString))
{
var connectList = JsonHelper.Json2Object>(connectString);
hydrant.ConnectList = connectList?.Select(x => new Model.RevitConnect()
{
Id = x.ConnectId,
Direction = x.Dirction,
Position = new Model.RevitPosition()
{
X = x.Point.X / 1000f,
Y = x.Point.Y / 1000f,
Z = x.Point.Z / 1000f
}
}).ToList();
if (hydrant.ConnectList == null || hydrant.ConnectList.Count < 1)
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.ConnectList), ePropStatus.Error, "[连接列表]解析失败");
}
}
else
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.ConnectList), ePropStatus.Error, "缺少[连接列表]");
}
#endregion
#region Quality
if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
{
hydrant.Quality = quality;
if (hydrant.Quality <= 0)
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.Quality), ePropStatus.Lack, "[初始水质]缺省");
}
}
else
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.Quality), ePropStatus.Abnormal, "[初始水质]异常,可能是缺少或格式错误");
}
#endregion
#region Position
hydrant.Position = hydrant.ConnectList?.GetCenterPosition();
if (hydrant.Position == null)
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.Position), ePropStatus.Lack, "[位置]缺省,可能是受[连接列表]解析失败影响");
}
#endregion
#region Elev
if (jobject[RevitJsonProp.Elev].MatchNumeric(out double elev))
{
hydrant.Elev = elev / 1000f;
}
else
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.Elev), ePropStatus.Abnormal, "[标高信息]缺少或者格式错误");
}
if (hydrant.Elev <= 0)
{
if (jobject[RevitJsonProp.ElevOfElevation].MatchNumeric(out double elevOfElevation))
{
hydrant.Elev = elevOfElevation / 1000f;
}
else
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.Elev), ePropStatus.Abnormal, "[标高中的高程]缺少或者格式错误");
}
}
if (hydrant.Elev <= 0)
{
//通过z轴自动计算
if (hydrant.Position == null)
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.Elev), ePropStatus.Lack, "[标高]缺省,受[位置]影响,无法通过Z轴自动计算");
}
else
{
hydrant.Elev = hydrant.Position.Z;
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.Elev), ePropStatus.Lack, "[标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region Demand
if (jobject[RevitJsonProp.Demand].MatchNumeric(out double demand))
{
hydrant.Demand = demand;
}
else
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.Demand), ePropStatus.Abnormal, "[需水量]缺少或者数据格式错误");
}
#endregion
#region DemandPattern
if (jobject.ParseString(RevitJsonProp.DemandPattern, out string demandPattern))
{
hydrant.DemandPattern = demandPattern;
if (string.IsNullOrEmpty(hydrant.DemandPattern))
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.DemandPattern), ePropStatus.Lack, "[需水模式]缺省");
}
}
else
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.DemandPattern), ePropStatus.Abnormal, "缺少[需水模式]");
}
#endregion
#region Coefficient
if (jobject[RevitJsonProp.CoefficientP].MatchNumeric(out double coeffientp))
{
hydrant.Coefficient = coeffientp;
if (hydrant.Coefficient <= 0)
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.Coefficient), ePropStatus.Lack, "[喷射系数]缺省");
}
}
else
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.Coefficient), ePropStatus.Abnormal, "[喷射系数]缺少或者格式错误");
if (jobject[RevitJsonProp.CoefficientF].MatchNumeric(out double coeffientf))
{
hydrant.Coefficient = coeffientf;
if (hydrant.Coefficient <= 0)
{
hydrant.AppendOrUpdatePropStatus(nameof(hydrant.Coefficient), ePropStatus.Lack, "[流量系数]缺省");
}
}
}
#endregion
return hydrant;
}
//解析闷头
private static HStation.Model.RevitBlunthead ParseBlunthead(JToken jobject)
{
if (jobject == null)
{
return default;
}
var blunthead = new Model.RevitBlunthead();
#region Id
if (jobject.ParseString(RevitJsonProp.Id, out string id))
{
blunthead.Id = id;
}
else
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.Id), ePropStatus.Error, "缺少[构件编码]");
}
#endregion
#region Code
if (jobject.ParseString(RevitJsonProp.Code, out string code))
{
blunthead.Code = code;
if (string.IsNullOrEmpty(blunthead.Code))
{
blunthead.Code = blunthead.Id;
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.Code), ePropStatus.Lack, "使用[构件编码]赋值");
}
}
else
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.Code), ePropStatus.Error, "缺少[编码]");
}
#endregion
#region Name
if (jobject.ParseString(RevitJsonProp.Name, out string name))
{
blunthead.Name = name;
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.Name), ePropStatus.Lack, "[名称]缺省");
}
else
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.Name), ePropStatus.Error, "缺少 [名称]");
}
#endregion
#region ModelType
if (jobject.ParseString(RevitJsonProp.ModelType, out string modelType))
{
blunthead.ModelType = modelType;
if (string.IsNullOrEmpty(blunthead.ModelType))
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.ModelType), ePropStatus.Lack, "[型号信息]缺省");
}
}
else
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.ModelType), ePropStatus.Error, "缺少[型号信息]");
}
#endregion
#region Flags
if (jobject.ParseString(RevitJsonProp.Flags, out string flags))
{
blunthead.Flags = Yw.Untity.FlagsHelper.ToList(flags);
if (!string.IsNullOrEmpty(flags))
{
if (blunthead.Flags == null || blunthead.Flags.Count < 1)
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.Flags), ePropStatus.Abnormal, "[标签]格式错误");
}
}
}
else
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.Flags), ePropStatus.Error, "缺少[标签]");
}
#endregion
#region Description
if (jobject.ParseString(RevitJsonProp.Description, out string description))
{
blunthead.Description = description;
}
else
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.Description), ePropStatus.Error, "缺少[说明信息]");
}
#endregion
#region ConnectList
if (jobject.ParseString(RevitJsonProp.Connects, out string connectString))
{
var connectList = JsonHelper.Json2Object>(connectString);
blunthead.ConnectList = connectList?.Select(x => new Model.RevitConnect()
{
Id = x.ConnectId,
Direction = x.Dirction,
Position = new Model.RevitPosition()
{
X = x.Point.X / 1000f,
Y = x.Point.Y / 1000f,
Z = x.Point.Z / 1000f
}
}).ToList();
if (blunthead.ConnectList == null || blunthead.ConnectList.Count < 1)
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.ConnectList), ePropStatus.Error, "[连接列表]解析失败");
}
}
else
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.ConnectList), ePropStatus.Error, "缺少[连接列表]");
}
#endregion
#region Quality
if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
{
blunthead.Quality = quality;
if (blunthead.Quality <= 0)
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.Quality), ePropStatus.Lack, "[初始水质]缺省");
}
}
else
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.Quality), ePropStatus.Abnormal, "[初始水质]异常,可能是缺少或格式错误");
}
#endregion
#region Position
blunthead.Position = blunthead.ConnectList?.GetCenterPosition();
if (blunthead.Position == null)
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.Position), ePropStatus.Lack, "[位置]缺省,可能是受[连接列表]解析失败影响");
}
#endregion
#region Elev
if (jobject[RevitJsonProp.Elev].MatchNumeric(out double elev))
{
blunthead.Elev = elev / 1000f;
}
else
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.Elev), ePropStatus.Abnormal, "[标高信息]缺少或者格式错误");
}
if (blunthead.Elev <= 0)
{
if (jobject[RevitJsonProp.ElevOfElevation].MatchNumeric(out double elevOfElevation))
{
blunthead.Elev = elevOfElevation / 1000f;
}
else
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.Elev), ePropStatus.Abnormal, "[标高中的高程]缺少或者格式错误");
}
}
if (blunthead.Elev <= 0)
{
//通过z轴自动计算
if (blunthead.Position == null)
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.Elev), ePropStatus.Lack, "[标高]缺省,受[位置]影响,无法通过Z轴自动计算");
}
else
{
blunthead.Elev = blunthead.Position.Z;
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.Elev), ePropStatus.Lack, "[标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region Demand
if (jobject[RevitJsonProp.Demand].MatchNumeric(out double demand))
{
blunthead.Demand = demand;
}
else
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.Demand), ePropStatus.Abnormal, "[需水量]缺少或者数据格式错误");
}
#endregion
#region DemandPattern
if (jobject.ParseString(RevitJsonProp.DemandPattern, out string demandPattern))
{
blunthead.DemandPattern = demandPattern;
if (string.IsNullOrEmpty(blunthead.DemandPattern))
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.DemandPattern), ePropStatus.Lack, "[需水模式]缺省");
}
}
else
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.DemandPattern), ePropStatus.Abnormal, "缺少[需水模式]");
}
#endregion
#region Material
if (jobject.ParseString(RevitJsonProp.Material, out string material))
{
blunthead.Material = material;
if (string.IsNullOrEmpty(blunthead.Material))
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.Material), ePropStatus.Lack, "[材质]缺省");
}
}
else
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.Material), ePropStatus.Abnormal, "缺少[材质]");
}
#endregion
#region Caliber
if (jobject[RevitJsonProp.Caliber].MatchNumeric(out double caliber))
{
blunthead.Caliber = caliber;
}
else
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.Caliber), ePropStatus.Abnormal, "[口径]缺少或者数据格式错误");
}
#endregion
#region MinorLoss
if (jobject[RevitJsonProp.MinorLoss].MatchNumeric(out double minorLoss))
{
blunthead.MinorLoss = minorLoss;
}
else
{
blunthead.AppendOrUpdatePropStatus(nameof(blunthead.MinorLoss), ePropStatus.Abnormal, "[局部阻力系数]缺少或者数据格式错误");
}
#endregion
return blunthead;
}
//解析弯头
private static HStation.Model.RevitElbow ParseElbow(JToken jobject)
{
if (jobject == null)
{
return default;
}
var elbow = new Model.RevitElbow();
#region Id
if (jobject.ParseString(RevitJsonProp.Id, out string id))
{
elbow.Id = id;
}
else
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.Id), ePropStatus.Error, "缺少[构件编码]");
}
#endregion
#region Code
if (jobject.ParseString(RevitJsonProp.Code, out string code))
{
elbow.Code = code;
if (string.IsNullOrEmpty(elbow.Code))
{
elbow.Code = elbow.Id;
elbow.AppendOrUpdatePropStatus(nameof(elbow.Code), ePropStatus.Lack, "使用[构件编码]赋值");
}
}
else
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.Code), ePropStatus.Error, "缺少[编码]");
}
#endregion
#region Name
if (jobject.ParseString(RevitJsonProp.Name, out string name))
{
elbow.Name = name;
elbow.AppendOrUpdatePropStatus(nameof(elbow.Name), ePropStatus.Lack, "[名称]缺省");
}
else
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.Name), ePropStatus.Error, "缺少 [名称]");
}
#endregion
#region ModelType
if (jobject.ParseString(RevitJsonProp.ModelType, out string modelType))
{
elbow.ModelType = modelType;
if (string.IsNullOrEmpty(elbow.ModelType))
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.ModelType), ePropStatus.Lack, "[型号信息]缺省");
}
}
else
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.ModelType), ePropStatus.Error, "缺少[型号信息]");
}
#endregion
#region Flags
if (jobject.ParseString(RevitJsonProp.Flags, out string flags))
{
elbow.Flags = Yw.Untity.FlagsHelper.ToList(flags);
if (!string.IsNullOrEmpty(flags))
{
if (elbow.Flags == null || elbow.Flags.Count < 1)
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.Flags), ePropStatus.Abnormal, "[标签]格式错误");
}
}
}
else
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.Flags), ePropStatus.Error, "缺少[标签]");
}
#endregion
#region Description
if (jobject.ParseString(RevitJsonProp.Description, out string description))
{
elbow.Description = description;
}
else
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.Description), ePropStatus.Error, "缺少[说明信息]");
}
#endregion
#region ConnectList
if (jobject.ParseString(RevitJsonProp.Connects, out string connectString))
{
var connectList = JsonHelper.Json2Object>(connectString);
elbow.ConnectList = connectList?.Select(x => new Model.RevitConnect()
{
Id = x.ConnectId,
Direction = x.Dirction,
Position = new Model.RevitPosition()
{
X = x.Point.X / 1000f,
Y = x.Point.Y / 1000f,
Z = x.Point.Z / 1000f
}
}).ToList();
if (elbow.ConnectList == null || elbow.ConnectList.Count < 1)
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.ConnectList), ePropStatus.Error, "[连接列表]解析失败");
}
}
else
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.ConnectList), ePropStatus.Error, "缺少[连接列表]");
}
#endregion
#region Quality
if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
{
elbow.Quality = quality;
if (elbow.Quality <= 0)
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.Quality), ePropStatus.Lack, "[初始水质]缺省");
}
}
else
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.Quality), ePropStatus.Abnormal, "[初始水质]异常,可能是缺少或格式错误");
}
#endregion
#region Position
elbow.Position = elbow.ConnectList?.GetCenterPosition();
if (elbow.Position == null)
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.Position), ePropStatus.Lack, "[位置]缺省,可能是受[连接列表]解析失败影响");
}
#endregion
#region Elev
if (jobject[RevitJsonProp.Elev].MatchNumeric(out double elev))
{
elbow.Elev = elev / 1000f;
}
else
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.Elev), ePropStatus.Abnormal, "[标高信息]缺少或者格式错误");
}
if (elbow.Elev <= 0)
{
if (jobject[RevitJsonProp.ElevOfElevation].MatchNumeric(out double elevOfElevation))
{
elbow.Elev = elevOfElevation / 1000f;
}
else
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.Elev), ePropStatus.Abnormal, "[标高中的高程]缺少或者格式错误");
}
}
if (elbow.Elev <= 0)
{
//通过z轴自动计算
if (elbow.Position == null)
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.Elev), ePropStatus.Lack, "[标高]缺省,受[位置]影响,无法通过Z轴自动计算");
}
else
{
elbow.Elev = elbow.Position.Z;
elbow.AppendOrUpdatePropStatus(nameof(elbow.Elev), ePropStatus.Lack, "[标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region Demand
if (jobject[RevitJsonProp.Demand].MatchNumeric(out double demand))
{
elbow.Demand = demand;
}
else
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.Demand), ePropStatus.Abnormal, "[需水量]缺少或者数据格式错误");
}
#endregion
#region DemandPattern
if (jobject.ParseString(RevitJsonProp.DemandPattern, out string demandPattern))
{
elbow.DemandPattern = demandPattern;
if (string.IsNullOrEmpty(elbow.DemandPattern))
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.DemandPattern), ePropStatus.Lack, "[需水模式]缺省");
}
}
else
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.DemandPattern), ePropStatus.Abnormal, "缺少[需水模式]");
}
#endregion
#region Material
if (jobject.ParseString(RevitJsonProp.Material, out string material))
{
elbow.Material = material;
if (string.IsNullOrEmpty(elbow.Material))
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.Material), ePropStatus.Lack, "[材质]缺省");
}
}
else
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.Material), ePropStatus.Abnormal, "缺少[材质]");
}
#endregion
#region Caliber
if (jobject[RevitJsonProp.Caliber].MatchNumeric(out double caliber))
{
elbow.Caliber = caliber;
}
else
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.Caliber), ePropStatus.Abnormal, "[口径]缺少或者数据格式错误");
}
#endregion
#region MinorLoss
if (jobject[RevitJsonProp.MinorLoss].MatchNumeric(out double minorLoss))
{
elbow.MinorLoss = minorLoss;
}
else
{
elbow.AppendOrUpdatePropStatus(nameof(elbow.MinorLoss), ePropStatus.Abnormal, "[局部阻力系数]缺少或者数据格式错误");
}
#endregion
return elbow;
}
//解析三通
private static HStation.Model.RevitThreelink ParseThreelink(JToken jobject)
{
if (jobject == null)
{
return default;
}
var threelink = new Model.RevitThreelink();
#region Id
if (jobject.ParseString(RevitJsonProp.Id, out string id))
{
threelink.Id = id;
}
else
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.Id), ePropStatus.Error, "缺少[构件编码]");
}
#endregion
#region Code
if (jobject.ParseString(RevitJsonProp.Code, out string code))
{
threelink.Code = code;
if (string.IsNullOrEmpty(threelink.Code))
{
threelink.Code = threelink.Id;
threelink.AppendOrUpdatePropStatus(nameof(threelink.Code), ePropStatus.Lack, "使用[构件编码]赋值");
}
}
else
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.Code), ePropStatus.Error, "缺少[编码]");
}
#endregion
#region Name
if (jobject.ParseString(RevitJsonProp.Name, out string name))
{
threelink.Name = name;
threelink.AppendOrUpdatePropStatus(nameof(threelink.Name), ePropStatus.Lack, "[名称]缺省");
}
else
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.Name), ePropStatus.Error, "缺少 [名称]");
}
#endregion
#region ModelType
if (jobject.ParseString(RevitJsonProp.ModelType, out string modelType))
{
threelink.ModelType = modelType;
if (string.IsNullOrEmpty(threelink.ModelType))
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.ModelType), ePropStatus.Lack, "[型号信息]缺省");
}
}
else
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.ModelType), ePropStatus.Error, "缺少[型号信息]");
}
#endregion
#region Flags
if (jobject.ParseString(RevitJsonProp.Flags, out string flags))
{
threelink.Flags = Yw.Untity.FlagsHelper.ToList(flags);
if (!string.IsNullOrEmpty(flags))
{
if (threelink.Flags == null || threelink.Flags.Count < 1)
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.Flags), ePropStatus.Abnormal, "[标签]格式错误");
}
}
}
else
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.Flags), ePropStatus.Error, "缺少[标签]");
}
#endregion
#region Description
if (jobject.ParseString(RevitJsonProp.Description, out string description))
{
threelink.Description = description;
}
else
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.Description), ePropStatus.Error, "缺少[说明信息]");
}
#endregion
#region ConnectList
if (jobject.ParseString(RevitJsonProp.Connects, out string connectString))
{
var connectList = JsonHelper.Json2Object>(connectString);
threelink.ConnectList = connectList?.Select(x => new Model.RevitConnect()
{
Id = x.ConnectId,
Direction = x.Dirction,
Position = new Model.RevitPosition()
{
X = x.Point.X / 1000f,
Y = x.Point.Y / 1000f,
Z = x.Point.Z / 1000f
}
}).ToList();
if (threelink.ConnectList == null || threelink.ConnectList.Count < 1)
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.ConnectList), ePropStatus.Error, "[连接列表]解析失败");
}
}
else
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.ConnectList), ePropStatus.Error, "缺少[连接列表]");
}
#endregion
#region Quality
if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
{
threelink.Quality = quality;
if (threelink.Quality <= 0)
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.Quality), ePropStatus.Lack, "[初始水质]缺省");
}
}
else
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.Quality), ePropStatus.Abnormal, "[初始水质]异常,可能是缺少或格式错误");
}
#endregion
#region Position
threelink.Position = threelink.ConnectList?.GetCenterPosition();
if (threelink.Position == null)
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.Position), ePropStatus.Lack, "[位置]缺省,可能是受[连接列表]解析失败影响");
}
#endregion
#region Elev
if (jobject[RevitJsonProp.Elev].MatchNumeric(out double elev))
{
threelink.Elev = elev / 1000f;
}
else
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.Elev), ePropStatus.Abnormal, "[标高信息]缺少或者格式错误");
}
if (threelink.Elev <= 0)
{
if (jobject[RevitJsonProp.ElevOfElevation].MatchNumeric(out double elevOfElevation))
{
threelink.Elev = elevOfElevation / 1000f;
}
else
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.Elev), ePropStatus.Abnormal, "[标高中的高程]缺少或者格式错误");
}
}
if (threelink.Elev <= 0)
{
//通过z轴自动计算
if (threelink.Position == null)
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.Elev), ePropStatus.Lack, "[标高]缺省,受[位置]影响,无法通过Z轴自动计算");
}
else
{
threelink.Elev = threelink.Position.Z;
threelink.AppendOrUpdatePropStatus(nameof(threelink.Elev), ePropStatus.Lack, "[标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region Demand
if (jobject[RevitJsonProp.Demand].MatchNumeric(out double demand))
{
threelink.Demand = demand;
}
else
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.Demand), ePropStatus.Abnormal, "[需水量]缺少或者数据格式错误");
}
#endregion
#region DemandPattern
if (jobject.ParseString(RevitJsonProp.DemandPattern, out string demandPattern))
{
threelink.DemandPattern = demandPattern;
if (string.IsNullOrEmpty(threelink.DemandPattern))
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.DemandPattern), ePropStatus.Lack, "[需水模式]缺省");
}
}
else
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.DemandPattern), ePropStatus.Abnormal, "缺少[需水模式]");
}
#endregion
#region Material
if (jobject.ParseString(RevitJsonProp.Material, out string material))
{
threelink.Material = material;
if (string.IsNullOrEmpty(threelink.Material))
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.Material), ePropStatus.Lack, "[材质]缺省");
}
}
else
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.Material), ePropStatus.Abnormal, "缺少[材质]");
}
#endregion
#region Caliber
if (jobject[RevitJsonProp.Caliber].MatchNumeric(out double caliber))
{
threelink.Caliber = caliber;
}
else
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.Caliber), ePropStatus.Abnormal, "[口径]缺少或者数据格式错误");
}
#endregion
#region MinorLoss
if (jobject[RevitJsonProp.MinorLoss].MatchNumeric(out double minorLoss))
{
threelink.MinorLoss = minorLoss;
}
else
{
threelink.AppendOrUpdatePropStatus(nameof(threelink.MinorLoss), ePropStatus.Abnormal, "[局部阻力系数]缺少或者数据格式错误");
}
#endregion
return threelink;
}
//解析四通
private static HStation.Model.RevitFourlink ParseFourlink(JToken jobject)
{
if (jobject == null)
{
return default;
}
var fourlink = new Model.RevitFourlink();
#region Id
if (jobject.ParseString(RevitJsonProp.Id, out string id))
{
fourlink.Id = id;
}
else
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.Id), ePropStatus.Error, "缺少[构件编码]");
}
#endregion
#region Code
if (jobject.ParseString(RevitJsonProp.Code, out string code))
{
fourlink.Code = code;
if (string.IsNullOrEmpty(fourlink.Code))
{
fourlink.Code = fourlink.Id;
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.Code), ePropStatus.Lack, "使用[构件编码]赋值");
}
}
else
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.Code), ePropStatus.Error, "缺少[编码]");
}
#endregion
#region Name
if (jobject.ParseString(RevitJsonProp.Name, out string name))
{
fourlink.Name = name;
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.Name), ePropStatus.Lack, "[名称]缺省");
}
else
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.Name), ePropStatus.Error, "缺少 [名称]");
}
#endregion
#region ModelType
if (jobject.ParseString(RevitJsonProp.ModelType, out string modelType))
{
fourlink.ModelType = modelType;
if (string.IsNullOrEmpty(fourlink.ModelType))
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.ModelType), ePropStatus.Lack, "[型号信息]缺省");
}
}
else
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.ModelType), ePropStatus.Error, "缺少[型号信息]");
}
#endregion
#region Flags
if (jobject.ParseString(RevitJsonProp.Flags, out string flags))
{
fourlink.Flags = Yw.Untity.FlagsHelper.ToList(flags);
if (!string.IsNullOrEmpty(flags))
{
if (fourlink.Flags == null || fourlink.Flags.Count < 1)
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.Flags), ePropStatus.Abnormal, "[标签]格式错误");
}
}
}
else
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.Flags), ePropStatus.Error, "缺少[标签]");
}
#endregion
#region Description
if (jobject.ParseString(RevitJsonProp.Description, out string description))
{
fourlink.Description = description;
}
else
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.Description), ePropStatus.Error, "缺少[说明信息]");
}
#endregion
#region ConnectList
if (jobject.ParseString(RevitJsonProp.Connects, out string connectString))
{
var connectList = JsonHelper.Json2Object>(connectString);
fourlink.ConnectList = connectList?.Select(x => new Model.RevitConnect()
{
Id = x.ConnectId,
Direction = x.Dirction,
Position = new Model.RevitPosition()
{
X = x.Point.X / 1000f,
Y = x.Point.Y / 1000f,
Z = x.Point.Z / 1000f
}
}).ToList();
if (fourlink.ConnectList == null || fourlink.ConnectList.Count < 1)
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.ConnectList), ePropStatus.Error, "[连接列表]解析失败");
}
}
else
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.ConnectList), ePropStatus.Error, "缺少[连接列表]");
}
#endregion
#region Quality
if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
{
fourlink.Quality = quality;
if (fourlink.Quality <= 0)
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.Quality), ePropStatus.Lack, "[初始水质]缺省");
}
}
else
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.Quality), ePropStatus.Abnormal, "[初始水质]异常,可能是缺少或格式错误");
}
#endregion
#region Position
fourlink.Position = fourlink.ConnectList?.GetCenterPosition();
if (fourlink.Position == null)
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.Position), ePropStatus.Lack, "[位置]缺省,可能是受[连接列表]解析失败影响");
}
#endregion
#region Elev
if (jobject[RevitJsonProp.Elev].MatchNumeric(out double elev))
{
fourlink.Elev = elev / 1000f;
}
else
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.Elev), ePropStatus.Abnormal, "[标高信息]缺少或者格式错误");
}
if (fourlink.Elev <= 0)
{
if (jobject[RevitJsonProp.ElevOfElevation].MatchNumeric(out double elevOfElevation))
{
fourlink.Elev = elevOfElevation / 1000f;
}
else
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.Elev), ePropStatus.Abnormal, "[标高中的高程]缺少或者格式错误");
}
}
if (fourlink.Elev <= 0)
{
//通过z轴自动计算
if (fourlink.Position == null)
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.Elev), ePropStatus.Lack, "[标高]缺省,受[位置]影响,无法通过Z轴自动计算");
}
else
{
fourlink.Elev = fourlink.Position.Z;
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.Elev), ePropStatus.Lack, "[标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region Demand
if (jobject[RevitJsonProp.Demand].MatchNumeric(out double demand))
{
fourlink.Demand = demand;
}
else
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.Demand), ePropStatus.Abnormal, "[需水量]缺少或者数据格式错误");
}
#endregion
#region DemandPattern
if (jobject.ParseString(RevitJsonProp.DemandPattern, out string demandPattern))
{
fourlink.DemandPattern = demandPattern;
if (string.IsNullOrEmpty(fourlink.DemandPattern))
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.DemandPattern), ePropStatus.Lack, "[需水模式]缺省");
}
}
else
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.DemandPattern), ePropStatus.Abnormal, "缺少[需水模式]");
}
#endregion
#region Material
if (jobject.ParseString(RevitJsonProp.Material, out string material))
{
fourlink.Material = material;
if (string.IsNullOrEmpty(fourlink.Material))
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.Material), ePropStatus.Lack, "[材质]缺省");
}
}
else
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.Material), ePropStatus.Abnormal, "缺少[材质]");
}
#endregion
#region Caliber
if (jobject[RevitJsonProp.Caliber].MatchNumeric(out double caliber))
{
fourlink.Caliber = caliber;
}
else
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.Caliber), ePropStatus.Abnormal, "[口径]缺少或者数据格式错误");
}
#endregion
#region MinorLoss
if (jobject[RevitJsonProp.MinorLoss].MatchNumeric(out double minorLoss))
{
fourlink.MinorLoss = minorLoss;
}
else
{
fourlink.AppendOrUpdatePropStatus(nameof(fourlink.MinorLoss), ePropStatus.Abnormal, "[局部阻力系数]缺少或者数据格式错误");
}
#endregion
return fourlink;
}
//解析水表
private static HStation.Model.RevitMeter ParseMeter(JToken jobject)
{
if (jobject == null)
{
return default;
}
var meter = new Model.RevitMeter();
#region Id
if (jobject.ParseString(RevitJsonProp.Id, out string id))
{
meter.Id = id;
}
else
{
meter.AppendOrUpdatePropStatus(nameof(meter.Id), ePropStatus.Error, "缺少[构件编码]");
}
#endregion
#region Code
if (jobject.ParseString(RevitJsonProp.Code, out string code))
{
meter.Code = code;
if (string.IsNullOrEmpty(meter.Code))
{
meter.Code = meter.Id;
meter.AppendOrUpdatePropStatus(nameof(meter.Code), ePropStatus.Lack, "使用[构件编码]赋值");
}
}
else
{
meter.AppendOrUpdatePropStatus(nameof(meter.Code), ePropStatus.Error, "缺少[编码]");
}
#endregion
#region Name
if (jobject.ParseString(RevitJsonProp.Name, out string name))
{
meter.Name = name;
meter.AppendOrUpdatePropStatus(nameof(meter.Name), ePropStatus.Lack, "[名称]缺省");
}
else
{
meter.AppendOrUpdatePropStatus(nameof(meter.Name), ePropStatus.Error, "缺少 [名称]");
}
#endregion
#region ModelType
if (jobject.ParseString(RevitJsonProp.ModelType, out string modelType))
{
meter.ModelType = modelType;
if (string.IsNullOrEmpty(meter.ModelType))
{
meter.AppendOrUpdatePropStatus(nameof(meter.ModelType), ePropStatus.Lack, "[型号信息]缺省");
}
}
else
{
meter.AppendOrUpdatePropStatus(nameof(meter.ModelType), ePropStatus.Error, "缺少[型号信息]");
}
#endregion
#region Flags
if (jobject.ParseString(RevitJsonProp.Flags, out string flags))
{
meter.Flags = Yw.Untity.FlagsHelper.ToList(flags);
if (!string.IsNullOrEmpty(flags))
{
if (meter.Flags == null || meter.Flags.Count < 1)
{
meter.AppendOrUpdatePropStatus(nameof(meter.Flags), ePropStatus.Abnormal, "[标签]格式错误");
}
}
}
else
{
meter.AppendOrUpdatePropStatus(nameof(meter.Flags), ePropStatus.Error, "缺少[标签]");
}
#endregion
#region Description
if (jobject.ParseString(RevitJsonProp.Description, out string description))
{
meter.Description = description;
}
else
{
meter.AppendOrUpdatePropStatus(nameof(meter.Description), ePropStatus.Error, "缺少[说明信息]");
}
#endregion
#region ConnectList
if (jobject.ParseString(RevitJsonProp.Connects, out string connectString))
{
var connectList = JsonHelper.Json2Object>(connectString);
meter.ConnectList = connectList?.Select(x => new Model.RevitConnect()
{
Id = x.ConnectId,
Direction = x.Dirction,
Position = new Model.RevitPosition()
{
X = x.Point.X / 1000f,
Y = x.Point.Y / 1000f,
Z = x.Point.Z / 1000f
}
}).ToList();
if (meter.ConnectList == null || meter.ConnectList.Count < 1)
{
meter.AppendOrUpdatePropStatus(nameof(meter.ConnectList), ePropStatus.Error, "[连接列表]解析失败");
}
}
else
{
meter.AppendOrUpdatePropStatus(nameof(meter.ConnectList), ePropStatus.Error, "缺少[连接列表]");
}
#endregion
#region Quality
if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
{
meter.Quality = quality;
if (meter.Quality <= 0)
{
meter.AppendOrUpdatePropStatus(nameof(meter.Quality), ePropStatus.Lack, "[初始水质]缺省");
}
}
else
{
meter.AppendOrUpdatePropStatus(nameof(meter.Quality), ePropStatus.Abnormal, "[初始水质]异常,可能是缺少或格式错误");
}
#endregion
#region Position
meter.Position = meter.ConnectList?.GetCenterPosition();
if (meter.Position == null)
{
meter.AppendOrUpdatePropStatus(nameof(meter.Position), ePropStatus.Lack, "[位置]缺省,可能是受[连接列表]解析失败影响");
}
#endregion
#region Elev
if (jobject[RevitJsonProp.Elev].MatchNumeric(out double elev))
{
meter.Elev = elev / 1000f;
}
else
{
meter.AppendOrUpdatePropStatus(nameof(meter.Elev), ePropStatus.Abnormal, "[标高信息]缺少或者格式错误");
}
if (meter.Elev <= 0)
{
if (jobject[RevitJsonProp.ElevOfElevation].MatchNumeric(out double elevOfElevation))
{
meter.Elev = elevOfElevation / 1000f;
}
else
{
meter.AppendOrUpdatePropStatus(nameof(meter.Elev), ePropStatus.Abnormal, "[标高中的高程]缺少或者格式错误");
}
}
if (meter.Elev <= 0)
{
//通过z轴自动计算
if (meter.Position == null)
{
meter.AppendOrUpdatePropStatus(nameof(meter.Elev), ePropStatus.Lack, "[标高]缺省,受[位置]影响,无法通过Z轴自动计算");
}
else
{
meter.Elev = meter.Position.Z;
meter.AppendOrUpdatePropStatus(nameof(meter.Elev), ePropStatus.Lack, "[标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region Demand
if (jobject[RevitJsonProp.Demand].MatchNumeric(out double demand))
{
meter.Demand = demand;
}
else
{
meter.AppendOrUpdatePropStatus(nameof(meter.Demand), ePropStatus.Abnormal, "[需水量]缺少或者数据格式错误");
}
#endregion
#region DemandPattern
if (jobject.ParseString(RevitJsonProp.DemandPattern, out string demandPattern))
{
meter.DemandPattern = demandPattern;
if (string.IsNullOrEmpty(meter.DemandPattern))
{
meter.AppendOrUpdatePropStatus(nameof(meter.DemandPattern), ePropStatus.Lack, "[需水模式]缺省");
}
}
else
{
meter.AppendOrUpdatePropStatus(nameof(meter.DemandPattern), ePropStatus.Abnormal, "缺少[需水模式]");
}
#endregion
return meter;
}
//解析流量计
private static HStation.Model.RevitFlowmeter ParseFlowmeter(JToken jobject)
{
if (jobject == null)
{
return default;
}
var flowmeter = new Model.RevitFlowmeter();
#region Id
if (jobject.ParseString(RevitJsonProp.Id, out string id))
{
flowmeter.Id = id;
}
else
{
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.Id), ePropStatus.Error, "缺少[构件编码]");
}
#endregion
#region Code
if (jobject.ParseString(RevitJsonProp.Code, out string code))
{
flowmeter.Code = code;
if (string.IsNullOrEmpty(flowmeter.Code))
{
flowmeter.Code = flowmeter.Id;
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.Code), ePropStatus.Lack, "使用[构件编码]赋值");
}
}
else
{
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.Code), ePropStatus.Error, "缺少[编码]");
}
#endregion
#region Name
if (jobject.ParseString(RevitJsonProp.Name, out string name))
{
flowmeter.Name = name;
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.Name), ePropStatus.Lack, "[名称]缺省");
}
else
{
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.Name), ePropStatus.Error, "缺少 [名称]");
}
#endregion
#region ModelType
if (jobject.ParseString(RevitJsonProp.ModelType, out string modelType))
{
flowmeter.ModelType = modelType;
if (string.IsNullOrEmpty(flowmeter.ModelType))
{
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.ModelType), ePropStatus.Lack, "[型号信息]缺省");
}
}
else
{
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.ModelType), ePropStatus.Error, "缺少[型号信息]");
}
#endregion
#region Flags
if (jobject.ParseString(RevitJsonProp.Flags, out string flags))
{
flowmeter.Flags = Yw.Untity.FlagsHelper.ToList(flags);
if (!string.IsNullOrEmpty(flags))
{
if (flowmeter.Flags == null || flowmeter.Flags.Count < 1)
{
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.Flags), ePropStatus.Abnormal, "[标签]格式错误");
}
}
}
else
{
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.Flags), ePropStatus.Error, "缺少[标签]");
}
#endregion
#region Description
if (jobject.ParseString(RevitJsonProp.Description, out string description))
{
flowmeter.Description = description;
}
else
{
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.Description), ePropStatus.Error, "缺少[说明信息]");
}
#endregion
#region ConnectList
if (jobject.ParseString(RevitJsonProp.Connects, out string connectString))
{
var connectList = JsonHelper.Json2Object>(connectString);
flowmeter.ConnectList = connectList?.Select(x => new Model.RevitConnect()
{
Id = x.ConnectId,
Direction = x.Dirction,
Position = new Model.RevitPosition()
{
X = x.Point.X / 1000f,
Y = x.Point.Y / 1000f,
Z = x.Point.Z / 1000f
}
}).ToList();
if (flowmeter.ConnectList == null || flowmeter.ConnectList.Count < 1)
{
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.ConnectList), ePropStatus.Error, "[连接列表]解析失败");
}
}
else
{
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.ConnectList), ePropStatus.Error, "缺少[连接列表]");
}
#endregion
#region Quality
if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
{
flowmeter.Quality = quality;
if (flowmeter.Quality <= 0)
{
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.Quality), ePropStatus.Lack, "[初始水质]缺省");
}
}
else
{
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.Quality), ePropStatus.Abnormal, "[初始水质]异常,可能是缺少或格式错误");
}
#endregion
#region Position
flowmeter.Position = flowmeter.ConnectList?.GetCenterPosition();
if (flowmeter.Position == null)
{
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.Position), ePropStatus.Lack, "[位置]缺省,可能是受[连接列表]解析失败影响");
}
#endregion
#region Elev
if (jobject[RevitJsonProp.Elev].MatchNumeric(out double elev))
{
flowmeter.Elev = elev / 1000f;
}
else
{
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.Elev), ePropStatus.Abnormal, "[标高信息]缺少或者格式错误");
}
if (flowmeter.Elev <= 0)
{
if (jobject[RevitJsonProp.ElevOfElevation].MatchNumeric(out double elevOfElevation))
{
flowmeter.Elev = elevOfElevation / 1000f;
}
else
{
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.Elev), ePropStatus.Abnormal, "[标高中的高程]缺少或者格式错误");
}
}
if (flowmeter.Elev <= 0)
{
//通过z轴自动计算
if (flowmeter.Position == null)
{
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.Elev), ePropStatus.Lack, "[标高]缺省,受[位置]影响,无法通过Z轴自动计算");
}
else
{
flowmeter.Elev = flowmeter.Position.Z;
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.Elev), ePropStatus.Lack, "[标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region Demand
if (jobject[RevitJsonProp.Demand].MatchNumeric(out double demand))
{
flowmeter.Demand = demand;
}
else
{
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.Demand), ePropStatus.Abnormal, "[需水量]缺少或者数据格式错误");
}
#endregion
#region DemandPattern
if (jobject.ParseString(RevitJsonProp.DemandPattern, out string demandPattern))
{
flowmeter.DemandPattern = demandPattern;
if (string.IsNullOrEmpty(flowmeter.DemandPattern))
{
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.DemandPattern), ePropStatus.Lack, "[需水模式]缺省");
}
}
else
{
flowmeter.AppendOrUpdatePropStatus(nameof(flowmeter.DemandPattern), ePropStatus.Abnormal, "缺少[需水模式]");
}
#endregion
return flowmeter;
}
//解析压力表
private static HStation.Model.RevitPressmeter ParsePressmeter(JToken jobject)
{
if (jobject == null)
{
return default;
}
var pressmeter = new Model.RevitPressmeter();
#region Id
if (jobject.ParseString(RevitJsonProp.Id, out string id))
{
pressmeter.Id = id;
}
else
{
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.Id), ePropStatus.Error, "缺少[构件编码]");
}
#endregion
#region Code
if (jobject.ParseString(RevitJsonProp.Code, out string code))
{
pressmeter.Code = code;
if (string.IsNullOrEmpty(pressmeter.Code))
{
pressmeter.Code = pressmeter.Id;
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.Code), ePropStatus.Lack, "使用[构件编码]赋值");
}
}
else
{
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.Code), ePropStatus.Error, "缺少[编码]");
}
#endregion
#region Name
if (jobject.ParseString(RevitJsonProp.Name, out string name))
{
pressmeter.Name = name;
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.Name), ePropStatus.Lack, "[名称]缺省");
}
else
{
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.Name), ePropStatus.Error, "缺少 [名称]");
}
#endregion
#region ModelType
if (jobject.ParseString(RevitJsonProp.ModelType, out string modelType))
{
pressmeter.ModelType = modelType;
if (string.IsNullOrEmpty(pressmeter.ModelType))
{
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.ModelType), ePropStatus.Lack, "[型号信息]缺省");
}
}
else
{
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.ModelType), ePropStatus.Error, "缺少[型号信息]");
}
#endregion
#region Flags
if (jobject.ParseString(RevitJsonProp.Flags, out string flags))
{
pressmeter.Flags = Yw.Untity.FlagsHelper.ToList(flags);
if (!string.IsNullOrEmpty(flags))
{
if (pressmeter.Flags == null || pressmeter.Flags.Count < 1)
{
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.Flags), ePropStatus.Abnormal, "[标签]格式错误");
}
}
}
else
{
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.Flags), ePropStatus.Error, "缺少[标签]");
}
#endregion
#region Description
if (jobject.ParseString(RevitJsonProp.Description, out string description))
{
pressmeter.Description = description;
}
else
{
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.Description), ePropStatus.Error, "缺少[说明信息]");
}
#endregion
#region ConnectList
if (jobject.ParseString(RevitJsonProp.Connects, out string connectString))
{
var connectList = JsonHelper.Json2Object>(connectString);
pressmeter.ConnectList = connectList?.Select(x => new Model.RevitConnect()
{
Id = x.ConnectId,
Direction = x.Dirction,
Position = new Model.RevitPosition()
{
X = x.Point.X / 1000f,
Y = x.Point.Y / 1000f,
Z = x.Point.Z / 1000f
}
}).ToList();
if (pressmeter.ConnectList == null || pressmeter.ConnectList.Count < 1)
{
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.ConnectList), ePropStatus.Error, "[连接列表]解析失败");
}
}
else
{
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.ConnectList), ePropStatus.Error, "缺少[连接列表]");
}
#endregion
#region Quality
if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
{
pressmeter.Quality = quality;
if (pressmeter.Quality <= 0)
{
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.Quality), ePropStatus.Lack, "[初始水质]缺省");
}
}
else
{
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.Quality), ePropStatus.Abnormal, "[初始水质]异常,可能是缺少或格式错误");
}
#endregion
#region Position
pressmeter.Position = pressmeter.ConnectList?.GetCenterPosition();
if (pressmeter.Position == null)
{
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.Position), ePropStatus.Lack, "[位置]缺省,可能是受[连接列表]解析失败影响");
}
#endregion
#region Elev
if (jobject[RevitJsonProp.Elev].MatchNumeric(out double elev))
{
pressmeter.Elev = elev / 1000f;
}
else
{
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.Elev), ePropStatus.Abnormal, "[标高信息]缺少或者格式错误");
}
if (pressmeter.Elev <= 0)
{
if (jobject[RevitJsonProp.ElevOfElevation].MatchNumeric(out double elevOfElevation))
{
pressmeter.Elev = elevOfElevation / 1000f;
}
else
{
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.Elev), ePropStatus.Abnormal, "[标高中的高程]缺少或者格式错误");
}
}
if (pressmeter.Elev <= 0)
{
//通过z轴自动计算
if (pressmeter.Position == null)
{
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.Elev), ePropStatus.Lack, "[标高]缺省,受[位置]影响,无法通过Z轴自动计算");
}
else
{
pressmeter.Elev = pressmeter.Position.Z;
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.Elev), ePropStatus.Lack, "[标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region Demand
if (jobject[RevitJsonProp.Demand].MatchNumeric(out double demand))
{
pressmeter.Demand = demand;
}
else
{
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.Demand), ePropStatus.Abnormal, "[需水量]缺少或者数据格式错误");
}
#endregion
#region DemandPattern
if (jobject.ParseString(RevitJsonProp.DemandPattern, out string demandPattern))
{
pressmeter.DemandPattern = demandPattern;
if (string.IsNullOrEmpty(pressmeter.DemandPattern))
{
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.DemandPattern), ePropStatus.Lack, "[需水模式]缺省");
}
}
else
{
pressmeter.AppendOrUpdatePropStatus(nameof(pressmeter.DemandPattern), ePropStatus.Abnormal, "缺少[需水模式]");
}
#endregion
return pressmeter;
}
//解析水库
private static HStation.Model.RevitReservoir ParseReservoir(JToken jobject)
{
if (jobject == null)
{
return default;
}
var reservoir = new Model.RevitReservoir();
#region Id
if (jobject.ParseString(RevitJsonProp.Id, out string id))
{
reservoir.Id = id;
}
else
{
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.Id), ePropStatus.Error, "缺少[构件编码]");
}
#endregion
#region Code
if (jobject.ParseString(RevitJsonProp.Code, out string code))
{
reservoir.Code = code;
if (string.IsNullOrEmpty(reservoir.Code))
{
reservoir.Code = reservoir.Id;
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.Code), ePropStatus.Lack, "使用[构件编码]赋值");
}
}
else
{
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.Code), ePropStatus.Error, "缺少[编码]");
}
#endregion
#region Name
if (jobject.ParseString(RevitJsonProp.Name, out string name))
{
reservoir.Name = name;
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.Name), ePropStatus.Lack, "[名称]缺省");
}
else
{
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.Name), ePropStatus.Error, "缺少[名称]");
}
#endregion
#region ModelType
if (jobject.ParseString(RevitJsonProp.ModelType, out string modelType))
{
reservoir.ModelType = modelType;
if (string.IsNullOrEmpty(reservoir.ModelType))
{
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.ModelType), ePropStatus.Lack, "[型号信息]缺省");
}
}
else
{
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.ModelType), ePropStatus.Error, "缺少[型号信息]");
}
#endregion
#region Flags
if (jobject.ParseString(RevitJsonProp.Flags, out string flags))
{
reservoir.Flags = Yw.Untity.FlagsHelper.ToList(flags);
if (!string.IsNullOrEmpty(flags))
{
if (reservoir.Flags == null || reservoir.Flags.Count < 1)
{
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.Flags), ePropStatus.Abnormal, "[标签]格式错误");
}
}
}
else
{
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.Flags), ePropStatus.Error, "缺少[标签]");
}
#endregion
#region Description
if (jobject.ParseString(RevitJsonProp.Description, out string description))
{
reservoir.Description = description;
}
else
{
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.Description), ePropStatus.Error, "缺少[说明信息]");
}
#endregion
#region ConnectList
if (jobject.ParseString(RevitJsonProp.Connects, out string connectString))
{
var connectList = JsonHelper.Json2Object>(connectString);
reservoir.ConnectList = connectList?.Select(x => new Model.RevitConnect()
{
Id = x.ConnectId,
Direction = x.Dirction,
Position = new Model.RevitPosition()
{
X = x.Point.X / 1000f,
Y = x.Point.Y / 1000f,
Z = x.Point.Z / 1000f
}
}).ToList();
if (reservoir.ConnectList == null || reservoir.ConnectList.Count < 1)
{
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.ConnectList), ePropStatus.Error, "[连接列表]解析失败");
}
}
else
{
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.ConnectList), ePropStatus.Error, "缺少[连接列表]");
}
#endregion
#region Quality
if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
{
reservoir.Quality = quality;
if (reservoir.Quality <= 0)
{
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.Quality), ePropStatus.Lack, "[初始水质]缺省");
}
}
else
{
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.Quality), ePropStatus.Abnormal, "[初始水质]异常,可能是缺少或格式错误");
}
#endregion
#region Position
reservoir.Position = reservoir.ConnectList?.GetCenterPosition();
if (reservoir.Position == null)
{
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.Position), ePropStatus.Lack, "[位置]缺省,可能是受[连接列表]解析失败影响");
}
#endregion
#region PoolElev
if (jobject[RevitJsonProp.PoolElev].MatchNumeric(out double poolElev))
{
reservoir.PoolElev = poolElev / 1000f;
}
else
{
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.PoolElev), ePropStatus.Abnormal, "[池底标高]缺少或者格式错误");
}
if (reservoir.PoolElev <= 0)
{
if (jobject[RevitJsonProp.ElevOfElevation].MatchNumeric(out double elevOfElevation))
{
reservoir.PoolElev = elevOfElevation / 1000f;
}
else
{
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.PoolElev), ePropStatus.Abnormal, "[标高中的高程]缺少或者格式错误");
}
}
if (reservoir.PoolElev <= 0)
{
//通过z轴自动计算
if (reservoir.Position == null)
{
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.PoolElev), ePropStatus.Lack, "[池底标高]缺省,受[位置]影响,无法通过Z轴自动计算");
}
else
{
reservoir.PoolElev = reservoir.Position.Z;
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.PoolElev), ePropStatus.Lack, "[池底标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region Head
if (jobject[RevitJsonProp.Head].MatchNumeric(out double head))
{
reservoir.Head = head;
}
else
{
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.Head), ePropStatus.Abnormal, "[总水头]缺少或者数据格式错误");
}
#endregion
#region HeadPattern
if (jobject.ParseString(RevitJsonProp.HeadPattern, out string headPattern))
{
reservoir.HeadPattern = headPattern;
if (string.IsNullOrEmpty(reservoir.HeadPattern))
{
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.HeadPattern), ePropStatus.Lack, "[水头模式]缺省");
}
}
else
{
reservoir.AppendOrUpdatePropStatus(nameof(reservoir.HeadPattern), ePropStatus.Abnormal, "缺少[水头模式]");
}
#endregion
return reservoir;
}
//解析水池
private static HStation.Model.RevitTank ParseTank(JToken jobject)
{
if (jobject == null)
{
return default;
}
var tank = new Model.RevitTank();
#region Id
if (jobject.ParseString(RevitJsonProp.Id, out string id))
{
tank.Id = id;
}
else
{
tank.AppendOrUpdatePropStatus(nameof(tank.Id), ePropStatus.Error, "缺少[构件编码]");
}
#endregion
#region Code
if (jobject.ParseString(RevitJsonProp.Code, out string code))
{
tank.Code = code;
if (string.IsNullOrEmpty(tank.Code))
{
tank.Code = tank.Id;
tank.AppendOrUpdatePropStatus(nameof(tank.Code), ePropStatus.Lack, "使用[构件编码]赋值");
}
}
else
{
tank.AppendOrUpdatePropStatus(nameof(tank.Code), ePropStatus.Error, "缺少[编码]");
}
#endregion
#region Name
if (jobject.ParseString(RevitJsonProp.Name, out string name))
{
tank.Name = name;
tank.AppendOrUpdatePropStatus(nameof(tank.Name), ePropStatus.Lack, "[名称]缺省");
}
else
{
tank.AppendOrUpdatePropStatus(nameof(tank.Name), ePropStatus.Error, "缺少[名称]");
}
#endregion
#region ModelType
if (jobject.ParseString(RevitJsonProp.ModelType, out string modelType))
{
tank.ModelType = modelType;
if (string.IsNullOrEmpty(tank.ModelType))
{
tank.AppendOrUpdatePropStatus(nameof(tank.ModelType), ePropStatus.Lack, "[型号信息]缺省");
}
}
else
{
tank.AppendOrUpdatePropStatus(nameof(tank.ModelType), ePropStatus.Error, "缺少[型号信息]");
}
#endregion
#region Flags
if (jobject.ParseString(RevitJsonProp.Flags, out string flags))
{
tank.Flags = Yw.Untity.FlagsHelper.ToList(flags);
if (!string.IsNullOrEmpty(flags))
{
if (tank.Flags == null || tank.Flags.Count < 1)
{
tank.AppendOrUpdatePropStatus(nameof(tank.Flags), ePropStatus.Abnormal, "[标签]格式错误");
}
}
}
else
{
tank.AppendOrUpdatePropStatus(nameof(tank.Flags), ePropStatus.Error, "缺少[标签]");
}
#endregion
#region Description
if (jobject.ParseString(RevitJsonProp.Description, out string description))
{
tank.Description = description;
}
else
{
tank.AppendOrUpdatePropStatus(nameof(tank.Description), ePropStatus.Error, "缺少[说明信息]");
}
#endregion
#region ConnectList
if (jobject.ParseString(RevitJsonProp.Connects, out string connectString))
{
var connectList = JsonHelper.Json2Object>(connectString);
tank.ConnectList = connectList?.Select(x => new Model.RevitConnect()
{
Id = x.ConnectId,
Direction = x.Dirction,
Position = new Model.RevitPosition()
{
X = x.Point.X / 1000f,
Y = x.Point.Y / 1000f,
Z = x.Point.Z / 1000f
}
}).ToList();
if (tank.ConnectList == null || tank.ConnectList.Count < 1)
{
tank.AppendOrUpdatePropStatus(nameof(tank.ConnectList), ePropStatus.Error, "[连接列表]解析失败");
}
}
else
{
tank.AppendOrUpdatePropStatus(nameof(tank.ConnectList), ePropStatus.Error, "缺少[连接列表]");
}
#endregion
#region Quality
if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
{
tank.Quality = quality;
if (tank.Quality <= 0)
{
tank.AppendOrUpdatePropStatus(nameof(tank.Quality), ePropStatus.Lack, "[初始水质]缺省");
}
}
else
{
tank.AppendOrUpdatePropStatus(nameof(tank.Quality), ePropStatus.Abnormal, "[初始水质]异常,可能是缺少或格式错误");
}
#endregion
#region Position
tank.Position = tank.ConnectList?.GetCenterPosition();
if (tank.Position == null)
{
tank.AppendOrUpdatePropStatus(nameof(tank.Position), ePropStatus.Lack, "[位置]缺省,可能是受[连接列表]解析失败影响");
}
#endregion
#region PoolElev
if (jobject[RevitJsonProp.PoolElev].MatchNumeric(out double poolElev))
{
tank.PoolElev = poolElev / 1000f;
}
else
{
tank.AppendOrUpdatePropStatus(nameof(tank.PoolElev), ePropStatus.Abnormal, "[池底标高]缺少或者格式错误");
}
if (tank.PoolElev <= 0)
{
if (jobject[RevitJsonProp.ElevOfElevation].MatchNumeric(out double elevOfElevation))
{
tank.PoolElev = elevOfElevation / 1000f;
}
else
{
tank.AppendOrUpdatePropStatus(nameof(tank.PoolElev), ePropStatus.Abnormal, "[标高中的高程]缺少或者格式错误");
}
}
if (tank.PoolElev <= 0)
{
//通过z轴自动计算
if (tank.Position == null)
{
tank.AppendOrUpdatePropStatus(nameof(tank.PoolElev), ePropStatus.Lack, "[池底标高]缺省,受[位置]影响,无法通过Z轴自动计算");
}
else
{
tank.PoolElev = tank.Position.Z;
tank.AppendOrUpdatePropStatus(nameof(tank.PoolElev), ePropStatus.Lack, "[池底标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region InitLevel
if (jobject[RevitJsonProp.InitLevel].MatchNumeric(out double initLevel))
{
tank.InitLevel = initLevel;
tank.AppendOrUpdatePropStatus(nameof(tank.InitLevel), ePropStatus.Lack, "[初始水位]缺省");
}
else
{
tank.AppendOrUpdatePropStatus(nameof(tank.InitLevel), ePropStatus.Abnormal, "[初始水位]缺少或者数据格式错误");
}
#endregion
#region MinLevel
if (jobject[RevitJsonProp.MinLevel].MatchNumeric(out double minLevel))
{
tank.MinLevel = minLevel;
tank.AppendOrUpdatePropStatus(nameof(tank.MinLevel), ePropStatus.Lack, "[最低水位]缺省");
}
else
{
tank.AppendOrUpdatePropStatus(nameof(tank.MinLevel), ePropStatus.Abnormal, "[最低水位]缺少或者数据格式错误");
}
#endregion
#region MaxLevel
if (jobject[RevitJsonProp.MaxLevel].MatchNumeric(out double maxLevel))
{
tank.MaxLevel = maxLevel;
tank.AppendOrUpdatePropStatus(nameof(tank.MaxLevel), ePropStatus.Lack, "[最高水位]缺省");
}
else
{
tank.AppendOrUpdatePropStatus(nameof(tank.MaxLevel), ePropStatus.Abnormal, "[最高水位]缺少或者数据格式错误");
}
#endregion
#region DN
if (jobject[RevitJsonProp.DN].MatchNumeric(out double dn))
{
tank.DN = dn / 1000f;
tank.AppendOrUpdatePropStatus(nameof(tank.DN), ePropStatus.Lack, "[公称直径]缺省");
}
else
{
tank.AppendOrUpdatePropStatus(nameof(tank.DN), ePropStatus.Abnormal, "[公称直径]缺少或者数据格式错误");
}
#endregion
#region MinVol
if (jobject[RevitJsonProp.MinVol].MatchNumeric(out double minVol))
{
tank.MinVol = minVol;
tank.AppendOrUpdatePropStatus(nameof(tank.MinVol), ePropStatus.Lack, "[最小容积]缺省");
}
else
{
tank.AppendOrUpdatePropStatus(nameof(tank.MinVol), ePropStatus.Abnormal, "[最小容积]缺少或者数据格式错误");
}
#endregion
#region VolCurve
if (jobject.ParseString(RevitJsonProp.VolCurve, out string volCurve))
{
tank.VolCurve = volCurve;
if (string.IsNullOrEmpty(tank.VolCurve))
{
tank.AppendOrUpdatePropStatus(nameof(tank.VolCurve), ePropStatus.Lack, "[容积曲线]缺省");
}
}
else
{
tank.AppendOrUpdatePropStatus(nameof(tank.VolCurve), ePropStatus.Abnormal, "缺少[容积曲线]");
}
#endregion
return tank;
}
//解析水箱
private static HStation.Model.RevitWaterbox ParseWaterbox(JToken jobject)
{
if (jobject == null)
{
return default;
}
var waterbox = new Model.RevitWaterbox();
#region Id
if (jobject.ParseString(RevitJsonProp.Id, out string id))
{
waterbox.Id = id;
}
else
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.Id), ePropStatus.Error, "缺少[构件编码]");
}
#endregion
#region Code
if (jobject.ParseString(RevitJsonProp.Code, out string code))
{
waterbox.Code = code;
if (string.IsNullOrEmpty(waterbox.Code))
{
waterbox.Code = waterbox.Id;
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.Code), ePropStatus.Lack, "使用[构件编码]赋值");
}
}
else
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.Code), ePropStatus.Error, "缺少[编码]");
}
#endregion
#region Name
if (jobject.ParseString(RevitJsonProp.Name, out string name))
{
waterbox.Name = name;
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.Name), ePropStatus.Lack, "[名称]缺省");
}
else
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.Name), ePropStatus.Error, "缺少[名称]");
}
#endregion
#region ModelType
if (jobject.ParseString(RevitJsonProp.ModelType, out string modelType))
{
waterbox.ModelType = modelType;
if (string.IsNullOrEmpty(waterbox.ModelType))
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.ModelType), ePropStatus.Lack, "[型号信息]缺省");
}
}
else
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.ModelType), ePropStatus.Error, "缺少[型号信息]");
}
#endregion
#region Flags
if (jobject.ParseString(RevitJsonProp.Flags, out string flags))
{
waterbox.Flags = Yw.Untity.FlagsHelper.ToList(flags);
if (!string.IsNullOrEmpty(flags))
{
if (waterbox.Flags == null || waterbox.Flags.Count < 1)
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.Flags), ePropStatus.Abnormal, "[标签]格式错误");
}
}
}
else
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.Flags), ePropStatus.Error, "缺少[标签]");
}
#endregion
#region Description
if (jobject.ParseString(RevitJsonProp.Description, out string description))
{
waterbox.Description = description;
}
else
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.Description), ePropStatus.Error, "缺少[说明信息]");
}
#endregion
#region ConnectList
if (jobject.ParseString(RevitJsonProp.Connects, out string connectString))
{
var connectList = JsonHelper.Json2Object>(connectString);
waterbox.ConnectList = connectList?.Select(x => new Model.RevitConnect()
{
Id = x.ConnectId,
Direction = x.Dirction,
Position = new Model.RevitPosition()
{
X = x.Point.X / 1000f,
Y = x.Point.Y / 1000f,
Z = x.Point.Z / 1000f
}
}).ToList();
if (waterbox.ConnectList == null || waterbox.ConnectList.Count < 1)
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.ConnectList), ePropStatus.Error, "[连接列表]解析失败");
}
}
else
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.ConnectList), ePropStatus.Error, "缺少[连接列表]");
}
#endregion
#region Quality
if (jobject[RevitJsonProp.Quality].MatchNumeric(out double quality))
{
waterbox.Quality = quality;
if (waterbox.Quality <= 0)
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.Quality), ePropStatus.Lack, "[初始水质]缺省");
}
}
else
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.Quality), ePropStatus.Abnormal, "[初始水质]异常,可能是缺少或格式错误");
}
#endregion
#region Position
waterbox.Position = waterbox.ConnectList?.GetCenterPosition();
if (waterbox.Position == null)
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.Position), ePropStatus.Lack, "[位置]缺省,可能是受[连接列表]解析失败影响");
}
#endregion
#region PoolElev
if (jobject[RevitJsonProp.PoolElev].MatchNumeric(out double poolElev))
{
waterbox.PoolElev = poolElev / 1000f;
}
else
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.PoolElev), ePropStatus.Abnormal, "[池底标高]缺少或者格式错误");
}
if (waterbox.PoolElev <= 0)
{
if (jobject[RevitJsonProp.ElevOfElevation].MatchNumeric(out double elevOfElevation))
{
waterbox.PoolElev = elevOfElevation / 1000f;
}
else
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.PoolElev), ePropStatus.Abnormal, "[标高中的高程]缺少或者格式错误");
}
}
if (waterbox.PoolElev <= 0)
{
//通过z轴自动计算
if (waterbox.Position == null)
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.PoolElev), ePropStatus.Lack, "[池底标高]缺省,受[位置]影响,无法通过Z轴自动计算");
}
else
{
waterbox.PoolElev = waterbox.Position.Z;
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.PoolElev), ePropStatus.Lack, "[池底标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region InitLevel
if (jobject[RevitJsonProp.InitLevel].MatchNumeric(out double initLevel))
{
waterbox.InitLevel = initLevel;
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.InitLevel), ePropStatus.Lack, "[初始水位]缺省");
}
else
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.InitLevel), ePropStatus.Abnormal, "[初始水位]缺少或者数据格式错误");
}
#endregion
#region MinLevel
if (jobject[RevitJsonProp.MinLevel].MatchNumeric(out double minLevel))
{
waterbox.MinLevel = minLevel;
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.MinLevel), ePropStatus.Lack, "[最低水位]缺省");
}
else
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.MinLevel), ePropStatus.Abnormal, "[最低水位]缺少或者数据格式错误");
}
#endregion
#region MaxLevel
if (jobject[RevitJsonProp.MaxLevel].MatchNumeric(out double maxLevel))
{
waterbox.MaxLevel = maxLevel;
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.MaxLevel), ePropStatus.Lack, "[最高水位]缺省");
}
else
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.MaxLevel), ePropStatus.Abnormal, "[最高水位]缺少或者数据格式错误");
}
#endregion
#region DN
if (jobject[RevitJsonProp.DN].MatchNumeric(out double dn))
{
waterbox.DN = dn / 1000f;
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.DN), ePropStatus.Lack, "[公称直径]缺省");
}
else
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.DN), ePropStatus.Abnormal, "[公称直径]缺少或者数据格式错误");
}
#endregion
#region MinVol
if (jobject[RevitJsonProp.MinVol].MatchNumeric(out double minVol))
{
waterbox.MinVol = minVol;
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.MinVol), ePropStatus.Lack, "[最小容积]缺省");
}
else
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.MinVol), ePropStatus.Abnormal, "[最小容积]缺少或者数据格式错误");
}
#endregion
#region VolCurve
if (jobject.ParseString(RevitJsonProp.VolCurve, out string volCurve))
{
waterbox.VolCurve = volCurve;
if (string.IsNullOrEmpty(waterbox.VolCurve))
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.VolCurve), ePropStatus.Lack, "[容积曲线]缺省");
}
}
else
{
waterbox.AppendOrUpdatePropStatus(nameof(waterbox.VolCurve), ePropStatus.Abnormal, "缺少[容积曲线]");
}
#endregion
return waterbox;
}
//解析管道
private static HStation.Model.RevitPipe ParsePipe(JToken jobject)
{
if (jobject == null)
{
return default;
}
var pipe = new Model.RevitPipe();
#region Id
if (jobject.ParseString(RevitJsonProp.Id, out string id))
{
pipe.Id = id;
}
else
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.Id), ePropStatus.Error, "缺少[构件编码]");
}
#endregion
#region Code
if (jobject.ParseString(RevitJsonProp.Code, out string code))
{
pipe.Code = code;
if (string.IsNullOrEmpty(pipe.Code))
{
pipe.Code = pipe.Id;
pipe.AppendOrUpdatePropStatus(nameof(pipe.Code), ePropStatus.Lack, "使用[构件编码]赋值");
}
}
else
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.Code), ePropStatus.Error, "缺少[编码]");
}
#endregion
#region Name
if (jobject.ParseString(RevitJsonProp.Name, out string name))
{
pipe.Name = name;
pipe.AppendOrUpdatePropStatus(nameof(pipe.Name), ePropStatus.Lack, "[名称]缺省");
}
else
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.Name), ePropStatus.Error, "缺少[名称]");
}
#endregion
#region ModelType
if (jobject.ParseString(RevitJsonProp.ModelType, out string modelType))
{
pipe.ModelType = modelType;
if (string.IsNullOrEmpty(pipe.ModelType))
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.ModelType), ePropStatus.Lack, "[型号信息]缺省");
}
}
else
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.ModelType), ePropStatus.Error, "缺少[型号信息]");
}
#endregion
#region Flags
if (jobject.ParseString(RevitJsonProp.Flags, out string flags))
{
pipe.Flags = Yw.Untity.FlagsHelper.ToList(flags);
if (!string.IsNullOrEmpty(flags))
{
if (pipe.Flags == null || pipe.Flags.Count < 1)
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.Flags), ePropStatus.Abnormal, "[标签]格式错误");
}
}
}
else
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.Flags), ePropStatus.Error, "缺少[标签]");
}
#endregion
#region Description
if (jobject.ParseString(RevitJsonProp.Description, out string description))
{
pipe.Description = description;
}
else
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.Description), ePropStatus.Error, "缺少[说明信息]");
}
#endregion
#region ConnectList
if (jobject.ParseString(RevitJsonProp.Connects, out string connectString))
{
var connectList = JsonHelper.Json2Object>(connectString);
pipe.ConnectList = connectList?.Select(x => new Model.RevitConnect()
{
Id = x.ConnectId,
Direction = x.Dirction,
Position = new Model.RevitPosition()
{
X = x.Point.X / 1000f,
Y = x.Point.Y / 1000f,
Z = x.Point.Z / 1000f
}
}).ToList();
if (pipe.ConnectList == null || pipe.ConnectList.Count < 1)
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.ConnectList), ePropStatus.Error, "[连接列表]解析失败");
}
}
else
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.ConnectList), ePropStatus.Error, "缺少[连接列表]");
}
#endregion
#region StartCode/StartPosition
var startConnect = pipe.ConnectList?.GetStartConnect();
pipe.StartCode = startConnect?.Id;
if (string.IsNullOrEmpty(pipe.StartCode))
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.StartCode), ePropStatus.Error, "[上游构件]受[连接列表]影响解析错误");
}
pipe.StartPosition = startConnect?.Position;
if (pipe.StartPosition == null)
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.StartPosition), ePropStatus.Error, "[上游构件位置]受[连接列表]影响解析错误");
}
#endregion
#region EndCode/EndPosition
var endConnect = pipe.ConnectList?.GetEndConnect();
pipe.EndCode = endConnect?.Id;
if (string.IsNullOrEmpty(pipe.EndCode))
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.EndCode), ePropStatus.Error, "[下游构件]受[连接列表]影响解析错误");
}
pipe.EndPosition = endConnect?.Position;
if (pipe.EndPosition == null)
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.EndPosition), ePropStatus.Error, "[下游构件位置]受[连接列表]影响解析错误");
}
#endregion
#region LinkStatus
if (jobject.ParseString(RevitJsonProp.LinkStatusPipe, out string linkStatus))
{
pipe.LinkStatus = linkStatus;
if (string.IsNullOrEmpty(pipe.LinkStatus))
{
pipe.LinkStatus = PipeStatus.Open;
pipe.AppendOrUpdatePropStatus(nameof(pipe.LinkStatus), ePropStatus.Lack, "[管道状态]缺省");
}
else
{
if (!PipeStatus.Contains(pipe.LinkStatus))
{
pipe.LinkStatus = PipeStatus.Open;
pipe.AppendOrUpdatePropStatus(nameof(pipe.LinkStatus), ePropStatus.Abnormal, "[管道状态]设置错误");
}
}
}
else
{
pipe.LinkStatus = PipeStatus.Open;
pipe.AppendOrUpdatePropStatus(nameof(pipe.LinkStatus), ePropStatus.Abnormal, "[管道状态]缺少或格式错误,使用默认值(Open)进行修正");
}
#endregion
#region StartElev
if (jobject[RevitJsonProp.StartElev].MatchNumeric(out double startElev))
{
pipe.StartElev = startElev / 1000f;
}
else
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.StartElev), ePropStatus.Abnormal, "[上游标高]缺少或格式错误");
}
if (pipe.StartElev <= 0)
{
//通过z轴自动计算
if (pipe.StartPosition == null)
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.StartElev), ePropStatus.Lack, "[上游标高]缺省,受[上游构件位置]影响,无法通过Z轴自动计算");
}
else
{
pipe.StartElev = pipe.StartPosition.Z;
pipe.AppendOrUpdatePropStatus(nameof(pipe.StartElev), ePropStatus.Lack, "[上游标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region EndElev
if (jobject[RevitJsonProp.EndElev].MatchNumeric(out double endElev))
{
pipe.EndElev = endElev / 1000f;
}
else
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.EndElev), ePropStatus.Abnormal, "[下游标高]缺少或格式错误");
}
if (pipe.EndElev <= 0)
{
//通过z轴自动计算
if (pipe.EndPosition == null)
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.EndElev), ePropStatus.Lack, "[下游标高]缺省,受[下游构件位置]影响,无法通过Z轴自动计算");
}
else
{
pipe.EndElev = pipe.EndPosition.Z;
pipe.AppendOrUpdatePropStatus(nameof(pipe.EndElev), ePropStatus.Lack, "[下游标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region StartQuality
if (jobject[RevitJsonProp.StartQuality].MatchNumeric(out double startQuality))
{
pipe.StartQuality = startQuality;
if (pipe.StartQuality <= 0)
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.StartQuality), ePropStatus.Lack, "[上游初始水质]缺省");
}
}
else
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.StartQuality), ePropStatus.Abnormal, "[上游初始水质]缺少或者格式错误");
}
#endregion
#region EndQuality
if (jobject[RevitJsonProp.EndQuality].MatchNumeric(out double endQuality))
{
pipe.EndQuality = endQuality;
if (pipe.EndQuality <= 0)
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.EndQuality), ePropStatus.Lack, "[下游初始水质]缺省");
}
}
else
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.EndQuality), ePropStatus.Abnormal, "[下游初始水质]缺少或者格式错误");
}
#endregion
#region Material
if (jobject.ParseString(RevitJsonProp.Material, out string material))
{
pipe.Material = material;
if (string.IsNullOrEmpty(pipe.Material))
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.Material), ePropStatus.Lack, "[材质]缺省");
}
}
else
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.Material), ePropStatus.Abnormal, "缺少[材质]");
}
#endregion
#region Diameter
if (jobject[RevitJsonProp.Diameter].MatchNumeric(out double diameter))
{
pipe.Diameter = diameter;
}
else
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.Diameter), ePropStatus.Abnormal, "[直径]缺少或者格式错误");
}
if (pipe.Diameter < 1)
{
if (jobject[RevitJsonProp.InternalDiameter].MatchNumeric(out double internalDiameter))
{
pipe.Diameter = internalDiameter;
pipe.AppendOrUpdatePropStatus(nameof(pipe.Diameter), ePropStatus.Lack, "[直径]通过[内径]进行修复]");
}
else
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.Diameter), ePropStatus.Abnormal, "[直径]无法通过[内径]进行修复]");
}
}
if (pipe.Diameter < 1)
{
if (jobject[RevitJsonProp.DN].MatchNumeric(out double dn))
{
pipe.Diameter = dn;
pipe.AppendOrUpdatePropStatus(nameof(pipe.Diameter), ePropStatus.Lack, "[直径]通过[公称直径]进行修复]");
}
else
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.Diameter), ePropStatus.Abnormal, "[直径]无法通过[公称直径]进行修复]");
}
}
if (pipe.Diameter < 1)
{
pipe.Diameter = 500;
pipe.AppendOrUpdatePropStatus(nameof(pipe.Diameter), ePropStatus.Lack, "[直径][内径]解析错误,使用默认值(500mm)修正]");
}
#endregion
#region Length
if (jobject[RevitJsonProp.Length].MatchNumeric(out double length))
{
pipe.Length = length / 1000f;
}
else
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.Length), ePropStatus.Abnormal, "[长度]缺少或者格式错误");
}
if (pipe.Length <= 0)
{
if (pipe.StartPosition != null && pipe.EndPosition != null)
{
pipe.Length = pipe.StartPosition.Distance(pipe.EndPosition);
pipe.AppendOrUpdatePropStatus(nameof(pipe.Length), ePropStatus.Lack, "[长度]缺省,通过位置自动计算");
}
else
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.Length), ePropStatus.Abnormal, "[长度]受[连接列表]影响无法自动计算");
}
}
#endregion
#region Roughness
if (jobject[RevitJsonProp.Roughness].MatchNumeric(out double roughness))
{
pipe.Roughness = roughness;
}
else
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.Roughness), ePropStatus.Abnormal, "[粗糙系数]缺少或者数据格式错误");
}
if (pipe.Roughness < 0.1)
{
pipe.Roughness = 110;
pipe.AppendOrUpdatePropStatus(nameof(pipe.Roughness), ePropStatus.Lack, "[粗糙系数]解析错误,通过默认值(110)进行修正");
}
#endregion
#region MinorLoss
if (jobject[RevitJsonProp.MinorLoss].MatchNumeric(out double minorLoss))
{
pipe.MinorLoss = minorLoss;
}
else
{
pipe.AppendOrUpdatePropStatus(nameof(pipe.MinorLoss), ePropStatus.Abnormal, "[局部阻力系数]缺少或者数据格式错误");
}
#endregion
return pipe;
}
//解析过渡件
private static HStation.Model.RevitTranslation ParseTranslation(JToken jobject)
{
if (jobject == null)
{
return default;
}
var translation = new Model.RevitTranslation();
#region Id
if (jobject.ParseString(RevitJsonProp.Id, out string id))
{
translation.Id = id;
}
else
{
translation.AppendOrUpdatePropStatus(nameof(translation.Id), ePropStatus.Error, "缺少[构件编码]");
}
#endregion
#region Code
if (jobject.ParseString(RevitJsonProp.Code, out string code))
{
translation.Code = code;
if (string.IsNullOrEmpty(translation.Code))
{
translation.Code = translation.Id;
translation.AppendOrUpdatePropStatus(nameof(translation.Code), ePropStatus.Lack, "使用[构件编码]赋值");
}
}
else
{
translation.AppendOrUpdatePropStatus(nameof(translation.Code), ePropStatus.Error, "缺少[编码]");
}
#endregion
#region Name
if (jobject.ParseString(RevitJsonProp.Name, out string name))
{
translation.Name = name;
translation.AppendOrUpdatePropStatus(nameof(translation.Name), ePropStatus.Lack, "[名称]缺省");
}
else
{
translation.AppendOrUpdatePropStatus(nameof(translation.Name), ePropStatus.Error, "缺少[名称]");
}
#endregion
#region ModelType
if (jobject.ParseString(RevitJsonProp.ModelType, out string modelType))
{
translation.ModelType = modelType;
if (string.IsNullOrEmpty(translation.ModelType))
{
translation.AppendOrUpdatePropStatus(nameof(translation.ModelType), ePropStatus.Lack, "[型号信息]缺省");
}
}
else
{
translation.AppendOrUpdatePropStatus(nameof(translation.ModelType), ePropStatus.Error, "缺少[型号信息]");
}
#endregion
#region Flags
if (jobject.ParseString(RevitJsonProp.Flags, out string flags))
{
translation.Flags = Yw.Untity.FlagsHelper.ToList(flags);
if (!string.IsNullOrEmpty(flags))
{
if (translation.Flags == null || translation.Flags.Count < 1)
{
translation.AppendOrUpdatePropStatus(nameof(translation.Flags), ePropStatus.Abnormal, "[标签]格式错误");
}
}
}
else
{
translation.AppendOrUpdatePropStatus(nameof(translation.Flags), ePropStatus.Error, "缺少[标签]");
}
#endregion
#region Description
if (jobject.ParseString(RevitJsonProp.Description, out string description))
{
translation.Description = description;
}
else
{
translation.AppendOrUpdatePropStatus(nameof(translation.Description), ePropStatus.Error, "缺少[说明信息]");
}
#endregion
#region ConnectList
if (jobject.ParseString(RevitJsonProp.Connects, out string connectString))
{
var connectList = JsonHelper.Json2Object>(connectString);
translation.ConnectList = connectList?.Select(x => new Model.RevitConnect()
{
Id = x.ConnectId,
Direction = x.Dirction,
Position = new Model.RevitPosition()
{
X = x.Point.X / 1000f,
Y = x.Point.Y / 1000f,
Z = x.Point.Z / 1000f
}
}).ToList();
if (translation.ConnectList == null || translation.ConnectList.Count < 1)
{
translation.AppendOrUpdatePropStatus(nameof(translation.ConnectList), ePropStatus.Error, "[连接列表]解析失败");
}
}
else
{
translation.AppendOrUpdatePropStatus(nameof(translation.ConnectList), ePropStatus.Error, "缺少[连接列表]");
}
#endregion
#region StartCode/StartPosition
var startConnect = translation.ConnectList?.GetStartConnect();
translation.StartCode = startConnect?.Id;
if (string.IsNullOrEmpty(translation.StartCode))
{
translation.AppendOrUpdatePropStatus(nameof(translation.StartCode), ePropStatus.Error, "[上游构件]受[连接列表]影响解析错误");
}
translation.StartPosition = startConnect?.Position;
if (translation.StartPosition == null)
{
translation.AppendOrUpdatePropStatus(nameof(translation.StartPosition), ePropStatus.Error, "[上游构件位置]受[连接列表]影响解析错误");
}
#endregion
#region EndCode/EndPosition
var endConnect = translation.ConnectList?.GetEndConnect();
translation.EndCode = endConnect?.Id;
if (string.IsNullOrEmpty(translation.EndCode))
{
translation.AppendOrUpdatePropStatus(nameof(translation.EndCode), ePropStatus.Error, "[下游构件]受[连接列表]影响解析错误");
}
translation.EndPosition = endConnect?.Position;
if (translation.EndPosition == null)
{
translation.AppendOrUpdatePropStatus(nameof(translation.EndPosition), ePropStatus.Error, "[下游构件位置]受[连接列表]影响解析错误");
}
#endregion
#region LinkStatus
if (jobject.ParseString(RevitJsonProp.LinkStatusPipe, out string linkStatus))
{
translation.LinkStatus = linkStatus;
if (string.IsNullOrEmpty(translation.LinkStatus))
{
translation.LinkStatus = PipeStatus.Open;
translation.AppendOrUpdatePropStatus(nameof(translation.LinkStatus), ePropStatus.Lack, "[管道状态]缺省");
}
else
{
if (!PipeStatus.Contains(translation.LinkStatus))
{
translation.LinkStatus = PipeStatus.Open;
translation.AppendOrUpdatePropStatus(nameof(translation.LinkStatus), ePropStatus.Abnormal, "[管道状态]设置错误");
}
}
}
else
{
translation.LinkStatus = PipeStatus.Open;
translation.AppendOrUpdatePropStatus(nameof(translation.LinkStatus), ePropStatus.Abnormal, "[管道状态]缺少或格式错误");
}
#endregion
#region StartElev
if (jobject[RevitJsonProp.StartElev].MatchNumeric(out double startElev))
{
translation.StartElev = startElev / 1000f;
}
else
{
translation.AppendOrUpdatePropStatus(nameof(translation.StartElev), ePropStatus.Abnormal, "[上游标高]缺少或格式错误");
}
if (translation.StartElev <= 0)
{
//通过z轴自动计算
if (translation.StartPosition == null)
{
translation.AppendOrUpdatePropStatus(nameof(translation.StartElev), ePropStatus.Lack, "[上游标高]缺省,受[上游构件位置]影响,无法通过Z轴自动计算");
}
else
{
translation.StartElev = translation.StartPosition.Z;
translation.AppendOrUpdatePropStatus(nameof(translation.StartElev), ePropStatus.Lack, "[上游标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region EndElev
if (jobject[RevitJsonProp.EndElev].MatchNumeric(out double endElev))
{
translation.EndElev = endElev / 1000f;
}
else
{
translation.AppendOrUpdatePropStatus(nameof(translation.EndElev), ePropStatus.Abnormal, "[下游标高]缺少或格式错误");
}
if (translation.EndElev <= 0)
{
//通过z轴自动计算
if (translation.EndPosition == null)
{
translation.AppendOrUpdatePropStatus(nameof(translation.EndElev), ePropStatus.Lack, "[下游标高]缺省,受[下游构件位置]影响,无法通过Z轴自动计算");
}
else
{
translation.EndElev = translation.EndPosition.Z;
translation.AppendOrUpdatePropStatus(nameof(translation.EndElev), ePropStatus.Lack, "[下游标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region StartQuality
if (jobject[RevitJsonProp.StartQuality].MatchNumeric(out double startQuality))
{
translation.StartQuality = startQuality;
if (translation.StartQuality <= 0)
{
translation.AppendOrUpdatePropStatus(nameof(translation.StartQuality), ePropStatus.Lack, "[上游初始水质]缺省");
}
}
else
{
translation.AppendOrUpdatePropStatus(nameof(translation.StartQuality), ePropStatus.Abnormal, "[上游初始水质]缺少或者格式错误");
}
#endregion
#region EndQuality
if (jobject[RevitJsonProp.EndQuality].MatchNumeric(out double endQuality))
{
translation.EndQuality = endQuality;
if (translation.EndQuality <= 0)
{
translation.AppendOrUpdatePropStatus(nameof(translation.EndQuality), ePropStatus.Lack, "[下游初始水质]缺省");
}
}
else
{
translation.AppendOrUpdatePropStatus(nameof(translation.EndQuality), ePropStatus.Abnormal, "[下游初始水质]缺少或者格式错误");
}
#endregion
#region Material
if (jobject.ParseString(RevitJsonProp.Material, out string material))
{
translation.Material = material;
if (string.IsNullOrEmpty(translation.Material))
{
translation.AppendOrUpdatePropStatus(nameof(translation.Material), ePropStatus.Lack, "[材质]缺省");
}
}
else
{
translation.AppendOrUpdatePropStatus(nameof(translation.Material), ePropStatus.Abnormal, "缺少[材质]");
}
#endregion
#region Diameter
if (jobject[RevitJsonProp.Diameter].MatchNumeric(out double diameter))
{
translation.Diameter = diameter;
}
else
{
translation.AppendOrUpdatePropStatus(nameof(translation.Diameter), ePropStatus.Abnormal, "[直径]缺少或者格式错误");
}
if (translation.Diameter < 1)
{
if (jobject[RevitJsonProp.InternalDiameter].MatchNumeric(out double internalDiameter))
{
translation.Diameter = internalDiameter;
translation.AppendOrUpdatePropStatus(nameof(translation.Diameter), ePropStatus.Lack, "[直径]通过[内径]进行修复]");
}
else
{
translation.AppendOrUpdatePropStatus(nameof(translation.Diameter), ePropStatus.Abnormal, "[直径]无法通过[内径]进行修复]");
}
}
if (translation.Diameter < 1)
{
if (jobject[RevitJsonProp.DN].MatchNumeric(out double dn))
{
translation.Diameter = dn;
translation.AppendOrUpdatePropStatus(nameof(translation.Diameter), ePropStatus.Lack, "[直径]通过[公称直径]进行修复]");
}
else
{
translation.AppendOrUpdatePropStatus(nameof(translation.Diameter), ePropStatus.Abnormal, "[直径]无法通过[公称直径]进行修复]");
}
}
if (translation.Diameter < 1)
{
translation.Diameter = 150;
translation.AppendOrUpdatePropStatus(nameof(translation.Diameter), ePropStatus.Lack, "[直径][内径]解析错误,使用默认值(500mm)修正]");
}
#endregion
#region Length
if (jobject[RevitJsonProp.Length].MatchNumeric(out double length))
{
translation.Length = length / 1000f;
}
else
{
translation.AppendOrUpdatePropStatus(nameof(translation.Length), ePropStatus.Abnormal, "[长度]缺少或者格式错误");
}
if (translation.Length <= 0)
{
if (translation.StartPosition != null && translation.EndPosition != null)
{
translation.Length = translation.StartPosition.Distance(translation.EndPosition);
translation.AppendOrUpdatePropStatus(nameof(translation.Length), ePropStatus.Lack, "[长度]缺省,通过位置自动计算");
}
else
{
translation.AppendOrUpdatePropStatus(nameof(translation.Length), ePropStatus.Abnormal, "[长度]受[连接列表]影响无法自动计算");
}
}
#endregion
#region Roughness
if (jobject[RevitJsonProp.Roughness].MatchNumeric(out double roughness))
{
translation.Roughness = roughness;
}
else
{
translation.AppendOrUpdatePropStatus(nameof(translation.Roughness), ePropStatus.Abnormal, "[粗糙系数]缺少或者数据格式错误");
}
if (translation.Roughness < 0.1)
{
translation.Roughness = 110;
translation.AppendOrUpdatePropStatus(nameof(translation.Roughness), ePropStatus.Lack, "[粗糙系数]解析错误,通过默认值(110)进行修正");
}
#endregion
#region MinorLoss
if (jobject[RevitJsonProp.MinorLoss].MatchNumeric(out double minorLoss))
{
translation.MinorLoss = minorLoss;
}
else
{
translation.AppendOrUpdatePropStatus(nameof(translation.MinorLoss), ePropStatus.Abnormal, "[局部阻力系数]缺少或者数据格式错误");
}
#endregion
return translation;
}
//解析换热器
private static HStation.Model.RevitExchanger ParseExchanger(JToken jobject)
{
if (jobject == null)
{
return default;
}
var exchanger = new Model.RevitExchanger();
#region Id
if (jobject.ParseString(RevitJsonProp.Id, out string id))
{
exchanger.Id = id;
}
else
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Id), ePropStatus.Error, "[换热器]缺少[构件编码]");
}
#endregion
#region Code
if (jobject.ParseString(RevitJsonProp.Code, out string code))
{
exchanger.Code = code;
if (string.IsNullOrEmpty(exchanger.Code))
{
exchanger.Code = exchanger.Id;
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Code), ePropStatus.Lack, "[换热器][编码]缺省,使用[构件编码]赋值");
}
}
else
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Code), ePropStatus.Error, "[换热器]缺少[编码]");
}
#endregion
#region Name
if (jobject.ParseString(RevitJsonProp.Name, out string name))
{
exchanger.Name = name;
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Name), ePropStatus.Lack, "[换热器][名称]缺省");
}
else
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Name), ePropStatus.Error, "[换热器]缺少[名称]");
}
#endregion
#region ModelType
if (jobject.ParseString(RevitJsonProp.ModelType, out string modelType))
{
exchanger.ModelType = modelType;
if (string.IsNullOrEmpty(exchanger.ModelType))
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.ModelType), ePropStatus.Lack, "[换热器][型号信息]缺省");
}
}
else
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.ModelType), ePropStatus.Error, "[换热器]缺少[型号信息]");
}
#endregion
#region Flags
if (jobject.ParseString(RevitJsonProp.Flags, out string flags))
{
exchanger.Flags = Yw.Untity.FlagsHelper.ToList(flags);
if (!string.IsNullOrEmpty(flags))
{
if (exchanger.Flags == null || exchanger.Flags.Count < 1)
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Flags), ePropStatus.Abnormal, "[换热器][标签]格式错误");
}
}
}
else
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Flags), ePropStatus.Error, "[换热器]缺少[标签]");
}
#endregion
#region Description
if (jobject.ParseString(RevitJsonProp.Description, out string description))
{
exchanger.Description = description;
}
else
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Description), ePropStatus.Error, "[换热器]缺少[说明信息]");
}
#endregion
#region ConnectList
if (jobject.ParseString(RevitJsonProp.Connects, out string connectString))
{
var connectList = JsonHelper.Json2Object>(connectString);
exchanger.ConnectList = connectList?.Select(x => new Model.RevitConnect()
{
Id = x.ConnectId,
Direction = x.Dirction,
Position = new Model.RevitPosition()
{
X = x.Point.X / 1000f,
Y = x.Point.Y / 1000f,
Z = x.Point.Z / 1000f
}
}).ToList();
if (exchanger.ConnectList == null || exchanger.ConnectList.Count < 1)
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.ConnectList), ePropStatus.Error, "[换热器][连接列表]解析失败");
}
}
else
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.ConnectList), ePropStatus.Error, "[换热器]缺少[连接列表]");
}
#endregion
#region StartCode/StartPosition
var startConnect = exchanger.ConnectList?.GetStartConnect();
exchanger.StartCode = startConnect?.Id;
if (string.IsNullOrEmpty(exchanger.StartCode))
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.StartCode), ePropStatus.Error, "[换热器][上游构件]受[连接列表]影响解析错误");
}
exchanger.StartPosition = startConnect?.Position;
if (exchanger.StartPosition == null)
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.StartPosition), ePropStatus.Error, "[换热器][上游构件位置]受[连接列表]影响解析错误");
}
#endregion
#region EndCode/EndPosition
var endConnect = exchanger.ConnectList?.GetEndConnect();
exchanger.EndCode = endConnect?.Id;
if (string.IsNullOrEmpty(exchanger.EndCode))
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.EndCode), ePropStatus.Error, "[换热器][下游构件]受[连接列表]影响解析错误");
}
exchanger.EndPosition = endConnect?.Position;
if (exchanger.EndPosition == null)
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.EndPosition), ePropStatus.Error, "[换热器][下游构件位置]受[连接列表]影响解析错误");
}
#endregion
#region LinkStatus
if (jobject.ParseString(RevitJsonProp.LinkStatusPipe, out string linkStatus))
{
exchanger.LinkStatus = linkStatus;
if (string.IsNullOrEmpty(exchanger.LinkStatus))
{
exchanger.LinkStatus = PipeStatus.Open;
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.LinkStatus), ePropStatus.Lack, "[换热器][管道状态]缺省");
}
else
{
if (!PipeStatus.Contains(exchanger.LinkStatus))
{
exchanger.LinkStatus = PipeStatus.Open;
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.LinkStatus), ePropStatus.Abnormal, "[换热器][管道状态]设置错误");
}
}
}
else
{
exchanger.LinkStatus = PipeStatus.Open;
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.LinkStatus), ePropStatus.Abnormal, "[换热器][管道状态]缺少或格式错误");
}
#endregion
#region StartElev
if (jobject[RevitJsonProp.StartElev].MatchNumeric(out double startElev))
{
exchanger.StartElev = startElev / 1000f;
}
else
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.StartElev), ePropStatus.Abnormal, "[换热器][上游标高]缺少或格式错误");
}
if (exchanger.StartElev <= 0)
{
//通过z轴自动计算
if (exchanger.StartPosition == null)
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.StartElev), ePropStatus.Lack, "[换热器][上游标高]缺省,受[上游构件位置]影响,无法通过Z轴自动计算");
}
else
{
exchanger.StartElev = exchanger.StartPosition.Z;
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.StartElev), ePropStatus.Lack, "[换热器][上游标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region EndElev
if (jobject[RevitJsonProp.EndElev].MatchNumeric(out double endElev))
{
exchanger.EndElev = endElev / 1000f;
}
else
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.EndElev), ePropStatus.Abnormal, "[换热器][下游标高]缺少或格式错误");
}
if (exchanger.EndElev <= 0)
{
//通过z轴自动计算
if (exchanger.EndPosition == null)
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.EndElev), ePropStatus.Lack, "[换热器][下游标高]缺省,受[下游构件位置]影响,无法通过Z轴自动计算");
}
else
{
exchanger.EndElev = exchanger.EndPosition.Z;
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.EndElev), ePropStatus.Lack, "[换热器][下游标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region StartQuality
if (jobject[RevitJsonProp.StartQuality].MatchNumeric(out double startQuality))
{
exchanger.StartQuality = startQuality;
if (exchanger.StartQuality <= 0)
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.StartQuality), ePropStatus.Lack, "[换热器][上游初始水质]缺省");
}
}
else
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.StartQuality), ePropStatus.Abnormal, "[换热器][上游初始水质]缺少或者格式错误");
}
#endregion
#region EndQuality
if (jobject[RevitJsonProp.EndQuality].MatchNumeric(out double endQuality))
{
exchanger.EndQuality = endQuality;
if (exchanger.EndQuality <= 0)
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.EndQuality), ePropStatus.Lack, "[换热器][下游初始水质]缺省");
}
}
else
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.EndQuality), ePropStatus.Abnormal, "[换热器][下游初始水质]缺少或者格式错误");
}
#endregion
#region Material
if (jobject.ParseString(RevitJsonProp.Material, out string material))
{
exchanger.Material = material;
if (string.IsNullOrEmpty(exchanger.Material))
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Material), ePropStatus.Lack, "[换热器][材质]缺省");
}
}
else
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Material), ePropStatus.Abnormal, "[换热器]缺少[材质]");
}
#endregion
#region Diameter
if (jobject[RevitJsonProp.Diameter].MatchNumeric(out double diameter))
{
exchanger.Diameter = diameter;
}
else
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Diameter), ePropStatus.Abnormal, "[换热器][直径]缺少或者格式错误");
}
if (exchanger.Diameter < 1)
{
if (jobject[RevitJsonProp.InternalDiameter].MatchNumeric(out double internalDiameter))
{
exchanger.Diameter = internalDiameter;
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Diameter), ePropStatus.Lack, "[换热器][直径]通过[内径]进行修复]");
}
else
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Diameter), ePropStatus.Abnormal, "[换热器][直径]无法通过[内径]进行修复]");
}
}
if (exchanger.Diameter < 1)
{
if (jobject[RevitJsonProp.DN].MatchNumeric(out double dn))
{
exchanger.Diameter = dn;
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Diameter), ePropStatus.Lack, "[换热器][直径]通过[公称直径]进行修复]");
}
else
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Diameter), ePropStatus.Abnormal, "[换热器][直径]无法通过[公称直径]进行修复]");
}
}
if (exchanger.Diameter < 1)
{
exchanger.Diameter = 1000;
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Diameter), ePropStatus.Lack, "[换热器][直径][内径]解析错误,使用默认值(1000mm)修正]");
}
#endregion
#region Length
if (jobject[RevitJsonProp.Length].MatchNumeric(out double length))
{
exchanger.Length = length / 1000f;
}
else
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Length), ePropStatus.Abnormal, "[换热器][长度]缺少或者格式错误");
}
if (exchanger.Length <= 0)
{
if (exchanger.StartPosition != null && exchanger.EndPosition != null)
{
exchanger.Length = exchanger.StartPosition.Distance(exchanger.EndPosition);
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Length), ePropStatus.Lack, "[换热器][长度]缺省,通过位置自动计算");
}
else
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Length), ePropStatus.Abnormal, "[换热器][长度]受[连接列表]影响无法自动计算");
}
}
#endregion
#region Roughness
if (jobject[RevitJsonProp.Roughness].MatchNumeric(out double roughness))
{
exchanger.Roughness = roughness;
}
else
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Roughness), ePropStatus.Abnormal, "[换热器][粗糙系数]缺少或者数据格式错误");
}
if (exchanger.Roughness < 0.1)
{
exchanger.Roughness = 110;
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.Roughness), ePropStatus.Lack, "[换热器][粗糙系数]解析错误,通过默认值(110)进行修正");
}
#endregion
#region MinorLoss
if (jobject[RevitJsonProp.MinorLoss].MatchNumeric(out double minorLoss))
{
exchanger.MinorLoss = minorLoss;
}
else
{
exchanger.AppendOrUpdatePropStatus(nameof(exchanger.MinorLoss), ePropStatus.Abnormal, "[换热器][局部阻力系数]缺少或者数据格式错误");
}
#endregion
return exchanger;
}
//解析水泵
private static HStation.Model.RevitPump ParsePump(JToken jobject)
{
if (jobject == null)
{
return default;
}
var pump = new Model.RevitPump();
#region Id
if (jobject.ParseString(RevitJsonProp.Id, out string id))
{
pump.Id = id;
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.Id), ePropStatus.Error, "缺少[构件编码]");
}
#endregion
#region Code
if (jobject.ParseString(RevitJsonProp.Code, out string code))
{
pump.Code = code;
if (string.IsNullOrEmpty(pump.Code))
{
pump.Code = pump.Id;
pump.AppendOrUpdatePropStatus(nameof(pump.Code), ePropStatus.Lack, "使用[构件编码]赋值");
}
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.Code), ePropStatus.Error, "缺少[编码]");
}
#endregion
#region Name
if (jobject.ParseString(RevitJsonProp.Name, out string name))
{
pump.Name = name;
pump.AppendOrUpdatePropStatus(nameof(pump.Name), ePropStatus.Lack, "[名称]缺省");
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.Name), ePropStatus.Error, "缺少[名称]");
}
#endregion
#region ModelType
if (jobject.ParseString(RevitJsonProp.ModelType, out string modelType))
{
pump.ModelType = modelType;
if (string.IsNullOrEmpty(pump.ModelType))
{
pump.AppendOrUpdatePropStatus(nameof(pump.ModelType), ePropStatus.Lack, "[型号信息]缺省");
}
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.ModelType), ePropStatus.Error, "缺少[型号信息]");
}
#endregion
#region Flags
if (jobject.ParseString(RevitJsonProp.Flags, out string flags))
{
pump.Flags = Yw.Untity.FlagsHelper.ToList(flags);
if (!string.IsNullOrEmpty(flags))
{
if (pump.Flags == null || pump.Flags.Count < 1)
{
pump.AppendOrUpdatePropStatus(nameof(pump.Flags), ePropStatus.Abnormal, "[标签]格式错误");
}
}
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.Flags), ePropStatus.Error, "缺少[标签]");
}
#endregion
#region Description
if (jobject.ParseString(RevitJsonProp.Description, out string description))
{
pump.Description = description;
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.Description), ePropStatus.Error, "缺少[说明信息]");
}
#endregion
#region ConnectList
if (jobject.ParseString(RevitJsonProp.Connects, out string connectString))
{
var connectList = JsonHelper.Json2Object>(connectString);
pump.ConnectList = connectList?.Select(x => new Model.RevitConnect()
{
Id = x.ConnectId,
Direction = x.Dirction,
Position = new Model.RevitPosition()
{
X = x.Point.X / 1000f,
Y = x.Point.Y / 1000f,
Z = x.Point.Z / 1000f
}
}).ToList();
if (pump.ConnectList == null || pump.ConnectList.Count < 1)
{
pump.AppendOrUpdatePropStatus(nameof(pump.ConnectList), ePropStatus.Error, "[连接列表]解析失败");
}
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.ConnectList), ePropStatus.Error, "缺少[连接列表]");
}
#endregion
#region StartCode/StartPosition
var startConnect = pump.ConnectList?.GetStartConnect();
pump.StartCode = startConnect?.Id;
if (string.IsNullOrEmpty(pump.StartCode))
{
pump.AppendOrUpdatePropStatus(nameof(pump.StartCode), ePropStatus.Error, "[上游构件]受[连接列表]影响解析错误");
}
pump.StartPosition = startConnect?.Position;
if (pump.StartPosition == null)
{
pump.AppendOrUpdatePropStatus(nameof(pump.StartPosition), ePropStatus.Error, "[上游构件位置]受[连接列表]影响解析错误");
}
#endregion
#region EndCode/EndPosition
var endConnect = pump.ConnectList?.GetEndConnect();
pump.EndCode = endConnect?.Id;
if (string.IsNullOrEmpty(pump.EndCode))
{
pump.AppendOrUpdatePropStatus(nameof(pump.EndCode), ePropStatus.Error, "[下游构件]受[连接列表]影响解析错误");
}
pump.EndPosition = endConnect?.Position;
if (pump.EndPosition == null)
{
pump.AppendOrUpdatePropStatus(nameof(pump.EndPosition), ePropStatus.Error, "[下游构件位置]受[连接列表]影响解析错误");
}
#endregion
#region LinkStatus
if (jobject.ParseString(RevitJsonProp.LinkStatusPump, out string linkStatus))
{
pump.LinkStatus = linkStatus;
if (string.IsNullOrEmpty(pump.LinkStatus))
{
pump.LinkStatus = PumpStatus.Open;
pump.AppendOrUpdatePropStatus(nameof(pump.LinkStatus), ePropStatus.Lack, "[水泵状态]缺省");
}
else
{
if (!PumpStatus.Contains(pump.LinkStatus))
{
pump.LinkStatus = PipeStatus.Open;
pump.AppendOrUpdatePropStatus(nameof(pump.LinkStatus), ePropStatus.Abnormal, "[水泵状态]设置错误");
}
}
}
else
{
pump.LinkStatus = PipeStatus.Open;
pump.AppendOrUpdatePropStatus(nameof(pump.LinkStatus), ePropStatus.Abnormal, "[水泵状态]缺少或格式错误");
}
#endregion
#region StartElev
if (jobject[RevitJsonProp.StartElev].MatchNumeric(out double startElev))
{
pump.StartElev = startElev / 1000f;
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.StartElev), ePropStatus.Abnormal, "[上游标高]缺少或格式错误");
}
if (pump.StartElev <= 0)
{
//通过z轴自动计算
if (pump.StartPosition == null)
{
pump.AppendOrUpdatePropStatus(nameof(pump.StartElev), ePropStatus.Lack, "[上游标高]缺省,受[上游构件位置]影响,无法通过Z轴自动计算");
}
else
{
pump.StartElev = pump.StartPosition.Z;
pump.AppendOrUpdatePropStatus(nameof(pump.StartElev), ePropStatus.Lack, "[上游标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region EndElev
if (jobject[RevitJsonProp.EndElev].MatchNumeric(out double endElev))
{
pump.EndElev = endElev / 1000f;
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.EndElev), ePropStatus.Abnormal, "[下游标高]缺少或格式错误");
}
if (pump.EndElev <= 0)
{
//通过z轴自动计算
if (pump.EndPosition == null)
{
pump.AppendOrUpdatePropStatus(nameof(pump.EndElev), ePropStatus.Lack, "[下游标高]缺省,受[下游构件位置]影响,无法通过Z轴自动计算");
}
else
{
pump.EndElev = pump.EndPosition.Z;
pump.AppendOrUpdatePropStatus(nameof(pump.EndElev), ePropStatus.Lack, "[下游标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region StartQuality
if (jobject[RevitJsonProp.StartQuality].MatchNumeric(out double startQuality))
{
pump.StartQuality = startQuality;
if (pump.StartQuality <= 0)
{
pump.AppendOrUpdatePropStatus(nameof(pump.StartQuality), ePropStatus.Lack, "[上游初始水质]缺省");
}
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.StartQuality), ePropStatus.Abnormal, "[上游初始水质]缺少或者格式错误");
}
#endregion
#region EndQuality
if (jobject[RevitJsonProp.EndQuality].MatchNumeric(out double endQuality))
{
pump.EndQuality = endQuality;
if (pump.EndQuality <= 0)
{
pump.AppendOrUpdatePropStatus(nameof(pump.EndQuality), ePropStatus.Lack, "[下游初始水质]缺省");
}
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.EndQuality), ePropStatus.Abnormal, "[下游初始水质]缺少或者格式错误");
}
#endregion
#region RatedP
if (jobject[RevitJsonProp.RatedP].MatchNumeric(out double ratedP))
{
pump.RatedP = ratedP;
if (pump.RatedP < 1)
{
pump.AppendOrUpdatePropStatus(nameof(pump.RatedP), ePropStatus.Lack, "[额定功率]缺省");
}
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.RatedP), ePropStatus.Abnormal, "[额定功率]缺少或者格式错误");
}
#endregion
#region RatedQ
if (jobject[RevitJsonProp.RatedQ].MatchNumeric(out double ratedQ))
{
pump.RatedQ = ratedQ;
if (pump.RatedQ < 1)
{
pump.AppendOrUpdatePropStatus(nameof(pump.RatedQ), ePropStatus.Lack, "[额定流量]缺省");
}
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.RatedQ), ePropStatus.Abnormal, "[额定流量]缺少或者格式错误");
}
#endregion
#region RatedH
if (jobject[RevitJsonProp.RatedH].MatchNumeric(out double ratedH))
{
pump.RatedH = ratedH;
if (pump.RatedH < 1)
{
pump.AppendOrUpdatePropStatus(nameof(pump.RatedH), ePropStatus.Lack, "[额定扬程]缺省");
}
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.RatedH), ePropStatus.Abnormal, "[额定扬程]缺少或者格式错误");
}
#endregion
#region RatedN
if (jobject[RevitJsonProp.RatedN].MatchNumeric(out double ratedN))
{
pump.RatedN = ratedN;
if (pump.RatedN < 1)
{
pump.AppendOrUpdatePropStatus(nameof(pump.RatedN), ePropStatus.Lack, "[额定转速]缺省");
}
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.RatedN), ePropStatus.Abnormal, "[额定转速]缺少或者格式错误");
}
#endregion
#region RatedHz
if (jobject[RevitJsonProp.RatedHz].MatchNumeric(out double ratedHz))
{
pump.RatedHz = ratedHz;
if (pump.RatedHz < 1)
{
pump.AppendOrUpdatePropStatus(nameof(pump.RatedHz), ePropStatus.Lack, "[额定频率]缺省");
}
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.RatedHz), ePropStatus.Abnormal, "[额定频率]缺少或者格式错误");
}
if (pump.RatedHz < 1)
{
pump.RatedHz = 50;
pump.AppendOrUpdatePropStatus(nameof(pump.RatedHz), ePropStatus.Lack, "[额定频率]缺省,使用默认值(50Hz)进行修正");
}
#endregion
#region CurveQH
if (jobject.ParseString(RevitJsonProp.CurveQH, out string curveqh))
{
pump.CurveQH = curveqh;
if (string.IsNullOrEmpty(pump.CurveQH))
{
pump.AppendOrUpdatePropStatus(nameof(pump.CurveQH), ePropStatus.Lack, "[流量扬程曲线]缺省");
}
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.CurveQH), ePropStatus.Abnormal, "缺少[流量扬程曲线]");
}
if (string.IsNullOrEmpty(pump.CurveQH))
{
pump.AppendOrUpdatePropStatus(nameof(pump.CurveQH), ePropStatus.Lack, "[流量扬程曲线]缺省,使用默认值(PumpDefault)进行修正");
}
#endregion
#region CurveQP
if (jobject.ParseString(RevitJsonProp.CurveQP, out string curveqp))
{
pump.CurveQP = curveqp;
if (string.IsNullOrEmpty(pump.CurveQP))
{
pump.AppendOrUpdatePropStatus(nameof(pump.CurveQP), ePropStatus.Lack, "[流量功率曲线]缺省");
}
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.CurveQP), ePropStatus.Abnormal, "缺少[流量功率曲线]");
}
#endregion
#region CurveQE
if (jobject.ParseString(RevitJsonProp.CurveQE, out string curveqe))
{
pump.CurveQE = curveqe;
if (string.IsNullOrEmpty(pump.CurveQE))
{
pump.AppendOrUpdatePropStatus(nameof(pump.CurveQE), ePropStatus.Lack, "[流量效率曲线]缺省");
}
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.CurveQE), ePropStatus.Abnormal, "缺少[流量效率曲线]");
}
#endregion
#region SpeedRatio
if (jobject[RevitJsonProp.SpeedRatio].MatchNumeric(out double speedRatio))
{
pump.SpeedRatio = speedRatio;
}
else
{
pump.SpeedRatio = 1;
pump.AppendOrUpdatePropStatus(nameof(pump.SpeedRatio), ePropStatus.Abnormal, "[转速比]缺省,使用默认值(1)修正");
}
#endregion
#region SpeedRatioPattern
if (jobject.ParseString(RevitJsonProp.SpeedRatioPattern, out string speedRatioPattern))
{
pump.SpeedRatioPattern = speedRatioPattern;
if (string.IsNullOrEmpty(pump.SpeedRatioPattern))
{
pump.AppendOrUpdatePropStatus(nameof(pump.SpeedRatioPattern), ePropStatus.Lack, "[转速比模式]缺省");
}
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.SpeedRatioPattern), ePropStatus.Abnormal, "缺少[转速比模式]");
}
#endregion
#region Price
if (jobject[RevitJsonProp.Price].MatchNumeric(out double price))
{
pump.Price = price;
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.Price), ePropStatus.Abnormal, "缺少[能耗价格]");
}
#endregion
#region PricePattern
if (jobject.ParseString(RevitJsonProp.PricePattern, out string pricePattern))
{
pump.PricePattern = pricePattern;
if (string.IsNullOrEmpty(pump.PricePattern))
{
pump.AppendOrUpdatePropStatus(nameof(pump.PricePattern), ePropStatus.Lack, "[价格模式]缺省");
}
}
else
{
pump.AppendOrUpdatePropStatus(nameof(pump.PricePattern), ePropStatus.Abnormal, "缺少[价格模式]");
}
#endregion
return pump;
}
//解析阀门
private static HStation.Model.RevitValve ParseValve(JToken jobject)
{
if (jobject == null)
{
return default;
}
var valve = new Model.RevitValve();
#region Id
if (jobject.ParseString(RevitJsonProp.Id, out string id))
{
valve.Id = id;
}
else
{
valve.AppendOrUpdatePropStatus(nameof(valve.Id), ePropStatus.Error, "缺少[构件编码]");
}
#endregion
#region Code
if (jobject.ParseString(RevitJsonProp.Code, out string code))
{
valve.Code = code;
if (string.IsNullOrEmpty(valve.Code))
{
valve.Code = valve.Id;
valve.AppendOrUpdatePropStatus(nameof(valve.Code), ePropStatus.Lack, "使用[构件编码]赋值");
}
}
else
{
valve.AppendOrUpdatePropStatus(nameof(valve.Code), ePropStatus.Error, "缺少[编码]");
}
#endregion
#region Name
if (jobject.ParseString(RevitJsonProp.Name, out string name))
{
valve.Name = name;
valve.AppendOrUpdatePropStatus(nameof(valve.Name), ePropStatus.Lack, "[名称]缺省");
}
else
{
valve.AppendOrUpdatePropStatus(nameof(valve.Name), ePropStatus.Error, "缺少[名称]");
}
#endregion
#region ModelType
if (jobject.ParseString(RevitJsonProp.ModelType, out string modelType))
{
valve.ModelType = modelType;
if (string.IsNullOrEmpty(valve.ModelType))
{
valve.AppendOrUpdatePropStatus(nameof(valve.ModelType), ePropStatus.Lack, "[型号信息]缺省");
}
}
else
{
valve.AppendOrUpdatePropStatus(nameof(valve.ModelType), ePropStatus.Error, "缺少[型号信息]");
}
#endregion
#region Flags
if (jobject.ParseString(RevitJsonProp.Flags, out string flags))
{
valve.Flags = Yw.Untity.FlagsHelper.ToList(flags);
if (!string.IsNullOrEmpty(flags))
{
if (valve.Flags == null || valve.Flags.Count < 1)
{
valve.AppendOrUpdatePropStatus(nameof(valve.Flags), ePropStatus.Abnormal, "[标签]格式错误");
}
}
}
else
{
valve.AppendOrUpdatePropStatus(nameof(valve.Flags), ePropStatus.Error, "缺少[标签]");
}
#endregion
#region Description
if (jobject.ParseString(RevitJsonProp.Description, out string description))
{
valve.Description = description;
}
else
{
valve.AppendOrUpdatePropStatus(nameof(valve.Description), ePropStatus.Error, "缺少[说明信息]");
}
#endregion
#region ConnectList
if (jobject.ParseString(RevitJsonProp.Connects, out string connectString))
{
var connectList = JsonHelper.Json2Object>(connectString);
valve.ConnectList = connectList?.Select(x => new Model.RevitConnect()
{
Id = x.ConnectId,
Direction = x.Dirction,
Position = new Model.RevitPosition()
{
X = x.Point.X / 1000f,
Y = x.Point.Y / 1000f,
Z = x.Point.Z / 1000f
}
}).ToList();
if (valve.ConnectList == null || valve.ConnectList.Count < 1)
{
valve.AppendOrUpdatePropStatus(nameof(valve.ConnectList), ePropStatus.Error, "[连接列表]解析失败");
}
}
else
{
valve.AppendOrUpdatePropStatus(nameof(valve.ConnectList), ePropStatus.Error, "缺少[连接列表]");
}
#endregion
#region StartCode/StartPosition
var startConnect = valve.ConnectList?.GetStartConnect();
valve.StartCode = startConnect?.Id;
if (string.IsNullOrEmpty(valve.StartCode))
{
valve.AppendOrUpdatePropStatus(nameof(valve.StartCode), ePropStatus.Error, "[上游构件]受[连接列表]影响解析错误");
}
valve.StartPosition = startConnect?.Position;
if (valve.StartPosition == null)
{
valve.AppendOrUpdatePropStatus(nameof(valve.StartPosition), ePropStatus.Error, "[上游构件位置]受[连接列表]影响解析错误");
}
#endregion
#region EndCode/EndPosition
var endConnect = valve.ConnectList?.GetEndConnect();
valve.EndCode = endConnect?.Id;
if (string.IsNullOrEmpty(valve.EndCode))
{
valve.AppendOrUpdatePropStatus(nameof(valve.EndCode), ePropStatus.Error, "[下游构件]受[连接列表]影响解析错误");
}
valve.EndPosition = endConnect?.Position;
if (valve.EndPosition == null)
{
valve.AppendOrUpdatePropStatus(nameof(valve.EndPosition), ePropStatus.Error, "[下游构件位置]受[连接列表]影响解析错误");
}
#endregion
#region LinkStatus
if (jobject.ParseString(RevitJsonProp.LinkStatusValve, out string linkStatus))
{
valve.LinkStatus = linkStatus;
if (string.IsNullOrEmpty(valve.LinkStatus))
{
valve.LinkStatus = ValveStatus.Open;
valve.AppendOrUpdatePropStatus(nameof(valve.LinkStatus), ePropStatus.Lack, "[阀门状态]缺省");
}
else
{
if (!ValveStatus.Contains(valve.LinkStatus))
{
valve.LinkStatus = ValveStatus.Open;
valve.AppendOrUpdatePropStatus(nameof(valve.LinkStatus), ePropStatus.Abnormal, "[阀门状态]设置错误");
}
}
}
else
{
valve.LinkStatus = ValveStatus.Open;
valve.AppendOrUpdatePropStatus(nameof(valve.LinkStatus), ePropStatus.Abnormal, "[阀门状态]缺少或格式错误");
}
#endregion
#region StartElev
if (jobject[RevitJsonProp.StartElev].MatchNumeric(out double startElev))
{
valve.StartElev = startElev / 1000f;
}
else
{
valve.AppendOrUpdatePropStatus(nameof(valve.StartElev), ePropStatus.Abnormal, "[上游标高]缺少或格式错误");
}
if (valve.StartElev <= 0)
{
//通过z轴自动计算
if (valve.StartPosition == null)
{
valve.AppendOrUpdatePropStatus(nameof(valve.StartElev), ePropStatus.Lack, "[上游标高]缺省,受[上游构件位置]影响,无法通过Z轴自动计算");
}
else
{
valve.StartElev = valve.StartPosition.Z;
valve.AppendOrUpdatePropStatus(nameof(valve.StartElev), ePropStatus.Lack, "[上游标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region EndElev
if (jobject[RevitJsonProp.EndElev].MatchNumeric(out double endElev))
{
valve.EndElev = endElev / 1000f;
}
else
{
valve.AppendOrUpdatePropStatus(nameof(valve.EndElev), ePropStatus.Abnormal, "[下游标高]缺少或格式错误");
}
if (valve.EndElev <= 0)
{
//通过z轴自动计算
if (valve.EndPosition == null)
{
valve.AppendOrUpdatePropStatus(nameof(valve.EndElev), ePropStatus.Lack, "[下游标高]缺省,受[下游构件位置]影响,无法通过Z轴自动计算");
}
else
{
valve.EndElev = valve.EndPosition.Z;
valve.AppendOrUpdatePropStatus(nameof(valve.EndElev), ePropStatus.Lack, "[下游标高]缺省,通过Z轴自动计算");
}
}
#endregion
#region StartQuality
if (jobject[RevitJsonProp.StartQuality].MatchNumeric(out double startQuality))
{
valve.StartQuality = startQuality;
if (valve.StartQuality <= 0)
{
valve.AppendOrUpdatePropStatus(nameof(valve.StartQuality), ePropStatus.Lack, "[上游初始水质]缺省");
}
}
else
{
valve.AppendOrUpdatePropStatus(nameof(valve.StartQuality), ePropStatus.Abnormal, "[上游初始水质]缺少或者格式错误");
}
#endregion
#region EndQuality
if (jobject[RevitJsonProp.EndQuality].MatchNumeric(out double endQuality))
{
valve.EndQuality = endQuality;
if (valve.EndQuality <= 0)
{
valve.AppendOrUpdatePropStatus(nameof(valve.EndQuality), ePropStatus.Lack, "[下游初始水质]缺省");
}
}
else
{
valve.AppendOrUpdatePropStatus(nameof(valve.EndQuality), ePropStatus.Abnormal, "[下游初始水质]缺少或者格式错误");
}
#endregion
#region Diameter
if (jobject[RevitJsonProp.Diameter].MatchNumeric(out double diameter))
{
valve.Diameter = diameter;
}
else
{
valve.AppendOrUpdatePropStatus(nameof(valve.Diameter), ePropStatus.Abnormal, "[直径]缺少或者格式错误");
}
if (valve.Diameter < 1)
{
if (jobject[RevitJsonProp.InternalDiameter].MatchNumeric(out double internalDiameter))
{
valve.Diameter = internalDiameter;
valve.AppendOrUpdatePropStatus(nameof(valve.Diameter), ePropStatus.Lack, "[直径]通过[内径]进行修复]");
}
else
{
valve.AppendOrUpdatePropStatus(nameof(valve.Diameter), ePropStatus.Abnormal, "[直径]无法通过[内径]进行修复]");
}
}
if (valve.Diameter < 1)
{
if (jobject[RevitJsonProp.DN].MatchNumeric(out double dn))
{
valve.Diameter = dn;
valve.AppendOrUpdatePropStatus(nameof(valve.Diameter), ePropStatus.Lack, "[直径]通过[公称直径]进行修复]");
}
else
{
valve.AppendOrUpdatePropStatus(nameof(valve.Diameter), ePropStatus.Abnormal, "[直径]无法通过[公称直径]进行修复]");
}
}
if (valve.Diameter < 1)
{
valve.Diameter = 500;
valve.AppendOrUpdatePropStatus(nameof(valve.Diameter), ePropStatus.Lack, "[直径][内径]解析错误,使用默认值(500mm)修正]");
}
#endregion
#region MinorLoss
if (jobject[RevitJsonProp.MinorLoss].MatchNumeric(out double minorLoss))
{
valve.MinorLoss = minorLoss;
}
else
{
valve.AppendOrUpdatePropStatus(nameof(valve.MinorLoss), ePropStatus.Abnormal, "[局部阻力系数]缺少或者数据格式错误");
}
#endregion
#region ValveType
if (jobject.ParseString(RevitJsonProp.ValveType, out string valveType))
{
valve.ValveType = valveType;
if (string.IsNullOrEmpty(valve.ValveType))
{
valve.ValveType = ValveType.GPV;
valve.AppendOrUpdatePropStatus(nameof(valve.ValveType), ePropStatus.Lack, "[阀门类型]缺省,使用默认值(GPV)进行修正");
}
else
{
if (!ValveType.Contains(valve.ValveType))
{
valve.ValveType = ValveType.GPV;
valve.AppendOrUpdatePropStatus(nameof(valve.ValveType), ePropStatus.Abnormal, "[阀门类型]设置错误,使用默认值(GPV)进行修正");
}
}
}
else
{
valve.ValveType = ValveType.GPV;
valve.AppendOrUpdatePropStatus(nameof(valve.ValveType), ePropStatus.Abnormal, "[阀门类型]缺少或格式错误,使用默认值(GPV)进行修正");
}
#endregion
#region ValveSetting
if (jobject.ParseString(RevitJsonProp.ValveSetting, out string valveSetting))
{
valve.ValveSetting = valveSetting;
}
else
{
valve.AppendOrUpdatePropStatus(nameof(valve.ValveSetting), ePropStatus.Abnormal, "[阀门设置]缺少或格式错误");
}
if (string.IsNullOrEmpty(valve.ValveSetting))
{
if (valve.ValveType == ValveType.GPV)
{
valve.ValveSetting = "GPVDefault";
valve.AppendOrUpdatePropStatus(nameof(valve.ValveSetting), ePropStatus.Lack, "[阀门设置]缺省,使用默认值(GPVDefault)进行修正");
}
}
#endregion
return valve;
}
//解析装饰件
private static HStation.Model.RevitDecorator ParseDecorator(JToken jobject)
{
if (jobject == null)
{
return default;
}
var decorator = new Model.RevitDecorator();
#region Id
if (jobject.ParseString(RevitJsonProp.Id, out string id))
{
decorator.Id = id;
}
#endregion
#region Code
if (jobject.ParseString(RevitJsonProp.Code, out string code))
{
decorator.Code = code;
}
if (string.IsNullOrEmpty(decorator.Code))
{
decorator.Code = decorator.Id;
}
#endregion
#region Name
decorator.Name = string.Empty;
#endregion
#region Category
var jobjectClanAndType = jobject[RevitJsonProp.ClanAndType];
if (jobjectClanAndType != null)
{
var jobjectClanName = jobjectClanAndType[RevitJsonProp.ClanName];
if (jobjectClanName != null)
{
decorator.Category = jobjectClanName.ToString();
}
}
if (string.IsNullOrEmpty(decorator.Category))
{
decorator.Category = "未知";
}
#endregion
#region Decoration
decorator.Decoration = string.Empty;
#endregion
return decorator;
}
}
}