using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using DW5S.DTO;
using DW5S.Entity;
using DW5S.KxcApi;
using DW5S.Repostory;
using DW5S.WebApi;
using Microsoft.AspNetCore.Mvc;
using Serilog;
namespace DW5S.Controllers
{
///
/// 星历推算功能相关接口
///
public class XlController : BaseController
{
ILogger logger { get; set; }
IUnitOfWork unitOfWork { get; set; }
///
/// 导入Tle星历文件
///
/// 星历导入参数
///
[HttpPost]
public async Task> ImportTleAsync(XlImportDto dto)
{
//https://www.space-track.org/documentation#tle网站上有星历文件格式说明
string line = null;
try
{
var count = await Task.Run(async () =>
{
var lines = System.IO.File.ReadAllLines(GetLocalFile(dto.File)).ToList();
lines.RemoveAll(p => string.IsNullOrWhiteSpace(p));
List tmp = new List();
for (int i = 0; i < lines.Count; i += 3)
{
line = lines[i];
var satName = lines[i].Trim();
if (satName.StartsWith("0 "))
satName = satName.Substring(2).Trim();
if (satName.StartsWith("TBA"))//待发布的卫星
continue;
var line1 = lines[i + 1];
var line2 = lines[i + 2];
if (line1.Length != 69 || line2.Length != 69)
{
throw new Exception("星历文件内容错误格式");
}
XlInfo xl = new XlInfo()
{
SatName = satName,
Line1 = line1,
Line2 = line2,
SatCode = Convert.ToInt32(line1.Substring(2, 5))
};
var timeStr = line1.Substring(18, 14).Replace(" ", "");//https://www.space-track.org/documentation#tle星历接口中说这里面可以接受空格
var yearStr = timeStr.Substring(0, 2);
var dayStr = timeStr.Substring(2, timeStr.Length - 2);
var day = Convert.ToDouble(dayStr);
var year = 2000 + Convert.ToInt32(yearStr);
DateTime dt = new DateTime(year, 1, 1, 0, 0, 0);
dt = dt.AddDays(day - 1);
xl.TimeUTC = dt;
tmp.Add(xl);
}
var repsXl = unitOfWork.Of();
await repsXl.AddOrUpdateAsync(tmp);
return tmp.Count;
});
logger.Information($"星历导入成功,共{count}条");
return Success(new RecordRes(count));
}
catch (Exception ex)
{
string msg = $"{line}星历导入异常,不支持的格式";
logger.Error(ex, msg);
return Error(msg);
}
}
///
/// 推算某个时间点XYZ星历
///
/// 推算参数
///
[HttpPost]
public AjaxResult Calc(XlCalcDto dto)
{
try
{
var p = EphHelper.Calc(dto.tleStr, dto.SigTime.ToUtc());
return Success(new SatEphResDto()
{
SatId = p.SatId,
SatTime = p.SatTime.ToLocal(),
TleTime = p.TleTime.ToLocal(),
Lon = p.Lon,
X = p.X,
Y = p.Y,
Z = p.Z,
VX = p.VX,
VY = p.VY,
VZ = p.VZ,
});
}
catch (Exception ex)
{
return Error(ex.Message);
}
}
///
/// 推算某个时间段XYZ星星历
///
/// 推算参数
///
[HttpPost]
public AjaxResult> CalcMult(XlCalcMultDto dto)
{
try
{
var eph = EphHelper.CalcMult(dto.tleStr, dto.startTime.ToUtc(), dto.endTime.ToUtc(), dto.spanSeconds);
return Success(eph.Select(p => new EphResDto()
{
SatId = p.SatId,
SatTime = p.SatTime.ToLocal(),
TleTime = p.TleTime.ToLocal(),
Lon = p.Lon,
X = p.X,
Y = p.Y,
Z = p.Z,
VX = p.VX,
VY = p.VY,
VZ = p.VZ,
}).ToList());
}
catch (Exception ex)
{
return Error>(ex.Message);
}
}
///
/// 推算卫星某个时间点XYZ星历
///
/// 推算参数
///
[HttpPost]
public async Task> XLCalcAsync(SatDto dto)
{
try
{
var repsXl = unitOfWork.Of() as XlRepository;
var xl1 = await repsXl.GetLatestAsync(dto.SatCode, dto.SigTime);
if (xl1 == null)
{
string msg = $"系统缺少编号{dto.SatCode}卫星的星历!";
logger.Error(msg);
return Error(msg);
}
var p = await Task.Run(() =>
{
return EphHelper.Calc(xl1.TwoLine, dto.SigTime.ToUtc());
});
return Success(new SatEphResDto()
{
SatId = p.SatId,
SatTime = p.SatTime.ToLocal(),
TleTime = p.TleTime.ToLocal(),
Lon = p.Lon,
X = p.X,
Y = p.Y,
Z = p.Z,
VX = p.VX,
VY = p.VY,
VZ = p.VZ,
}); ;
}
catch (Exception ex)
{
return Error(ex.Message);
}
}
}
}