2024-02-04 14:30:25 +00:00
|
|
|
|
import head
|
|
|
|
|
from datetime import datetime, timedelta
|
|
|
|
|
from flask import Flask, request, jsonify
|
|
|
|
|
from flask_cors import cross_origin
|
|
|
|
|
import ephem
|
|
|
|
|
|
|
|
|
|
app = Flask(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def local2utc(local_dtm):
|
|
|
|
|
# 本地时间转 UTC 时间( -8:00 )
|
|
|
|
|
return datetime.utcfromtimestamp(local_dtm.timestamp())
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@app.route("/pass", methods=['POST'])
|
|
|
|
|
@cross_origin()
|
|
|
|
|
def satpass():
|
|
|
|
|
sat = request.json.get('sat', '')
|
|
|
|
|
sat_line_1 = request.json.get('sat_line_1', '')
|
|
|
|
|
sat_line_2 = request.json.get('sat_line_2', '')
|
|
|
|
|
lat = request.json.get('lat', 0)
|
|
|
|
|
lng = request.json.get('lng', 0)
|
|
|
|
|
alt = request.json.get('alt', 0)
|
|
|
|
|
|
|
|
|
|
target_satellite, find_flag = head.FIND_SATE(sat_line_1, sat_line_2, sat)
|
|
|
|
|
pass_times, departure_times = head.CAL_PASS_TIME(target_satellite,
|
|
|
|
|
float(lat), float(lng),
|
|
|
|
|
float(alt))
|
|
|
|
|
|
|
|
|
|
return jsonify({
|
|
|
|
|
'code': 200,
|
|
|
|
|
'pass_times': pass_times,
|
|
|
|
|
'departure_times': departure_times
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@app.route("/doppler", methods=['POST'])
|
|
|
|
|
@cross_origin()
|
|
|
|
|
def doppler():
|
|
|
|
|
sat = request.json.get('sat', '')
|
|
|
|
|
sat_line_1 = request.json.get('sat_line_1', '')
|
|
|
|
|
sat_line_2 = request.json.get('sat_line_2', '')
|
|
|
|
|
lat = request.json.get('lat', 0)
|
|
|
|
|
lng = request.json.get('lng', 0)
|
|
|
|
|
alt = request.json.get('alt', 0)
|
|
|
|
|
tx = request.json.get('tx', 0)
|
|
|
|
|
rx = request.json.get('rx', 0)
|
|
|
|
|
format = "%Y-%m-%d %H:%M:%S"
|
|
|
|
|
pass_time = datetime.strptime(request.json.get('pass_time', ''), format)
|
|
|
|
|
departure_time = datetime.strptime(request.json.get('departure_time', ''),
|
|
|
|
|
format)
|
|
|
|
|
satellite = ephem.readtle(sat, sat_line_1, sat_line_2)
|
2024-02-04 14:37:56 +00:00
|
|
|
|
print(str(pass_time) + " " + str(local2utc(pass_time)))
|
2024-02-04 14:30:25 +00:00
|
|
|
|
shift_array = []
|
2024-02-04 16:19:34 +00:00
|
|
|
|
while pass_time < departure_time + timedelta(seconds=2):
|
2024-02-04 14:30:25 +00:00
|
|
|
|
AZ, EI, SHITF_UP, SHIFT_DOWN, DIS = head.CAL_DATA(
|
|
|
|
|
satellite, sat_line_1, sat_line_2, float(lng), float(lat),
|
|
|
|
|
float(alt), local2utc(pass_time),
|
|
|
|
|
float(tx) * 1000000,
|
|
|
|
|
float(rx) * 1000000)
|
|
|
|
|
shift_array.append([SHITF_UP, SHIFT_DOWN])
|
|
|
|
|
pass_time = pass_time + timedelta(seconds=2)
|
|
|
|
|
return jsonify({'code': 200, 'shift_array': shift_array})
|