wrjvideo.py 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. from fastapi import APIRouter, Request, Depends,Query,HTTPException
  4. from typing import Union
  5. from database import get_db
  6. from sqlalchemy.orm import Session
  7. from sqlalchemy import case,or_
  8. from sqlalchemy import text
  9. from utils import *
  10. from utils.ry_system_util import *
  11. from utils.video_util import *
  12. from common.security import valid_access_token
  13. from fastapi.responses import JSONResponse
  14. import traceback
  15. from datetime import datetime
  16. from common import WRJApi
  17. from config import settings
  18. router = APIRouter()
  19. # 获取无人机清单
  20. @router.get('/roughTimeStatus')
  21. async def roughTimeStatus(
  22. area: str = '',
  23. keyword: str = '',
  24. time: str = '',
  25. mode: str = '',
  26. type: str = '',
  27. status: str = '',
  28. db: Session = Depends(get_db)
  29. ):
  30. try:
  31. print('area:', area)
  32. print('keyword:', keyword)
  33. print('time:', time)
  34. print('mode:', mode)
  35. print('type:', type)
  36. print('status:', status)
  37. fly_data = WRJApi.flyUavInfo()
  38. data = WRJApi.roughTimeStatus()
  39. area_code = ''
  40. status_list = status.split(',')
  41. mode_list = mode.split(',')
  42. type_list = type.split(',')
  43. if area != '':
  44. row = db.query(GovdataArea).filter(GovdataArea.id == int(area)).first()
  45. area_code = row.area_code.rstrip('0')
  46. convertDict = { "0": "离线", "1": "待命", "2": "飞行中", "3": "管制中", "4": "维护中", "5": "执行任务" }
  47. wrj_list = []
  48. for n in data:
  49. if area_code != '' and n['addressAreaId'].startswith(area_code) == False:
  50. continue
  51. if keyword != '' and n['uavName'].find(keyword) == -1:
  52. continue
  53. # 调度响应时间 0-半小时内 1-1小时内 2-2小时内 3-4小时内 4-8小时内 5-24小时内 6-24小时外
  54. if time != '' and n['dispatchResponseTime'] != int(time):
  55. continue
  56. # 建设模式 0-财政资金采购 (硬件) 1-财政资金采购 (服务) 2-社会面资源 3-示范地区补点
  57. if mode != '' and str(n['constructionModel']) not in mode_list:
  58. continue
  59. # "isHangarControl": 1 // 配置机巢/机库/基站控制 0-否 1-是
  60. if type != '' and str(n['isHangarControl']) not in type_list:
  61. continue
  62. # "convertCode": null, // // 第三方机库的状态 0-离线、1-待命中、2-飞行中、3-管制中、4-维护中、5-执行任务
  63. if status != '' and str(n['convertCode']) not in status_list:
  64. continue
  65. n['status_text'] = convertDict[str(n['convertCode'])]
  66. item = {
  67. "id": n['id'],
  68. "drone_name": n['uavName'],
  69. "status": n['convertCode'],
  70. "status_text": n['status_text'],
  71. "time": n['dispatchResponseTime'],
  72. "mode": n['constructionModel'],
  73. "type": n['isHangarControl'],
  74. "fly_url": n['mediaPullStreamAddress'] if n['mediaPullStreamAddress'] is not None else "", # 飞机视频流
  75. "nest_url": n['nestOutMediaPullStreamAddress'] if n['nestOutMediaPullStreamAddress'] is not None else "", # 机巢视频流
  76. }
  77. # 测试数据
  78. if n['id'] == '1725080256731168770' and settings.IS_PROD == False:
  79. item['status'] = 2
  80. item['status_text'] = '飞行中'
  81. item['fly_info'] = {
  82. "lng": '111.58967074364558', # 当前经度(WGS84)
  83. "lat": '21.5870035628497', # 当前纬度(WGS84)
  84. "windSpeed": '3.0', # 无人机当前接触到的风速(米/ 秒)
  85. "nestSeed": '1.1', # 当前机库所在地风速
  86. "temperature": '34.099998474121094', # 无人机目前舱内温度
  87. "environmentTemperature": '30.4', # 无人机所在地的环境温度
  88. "batteryPerce": '66.0', # 电池电量(%)
  89. "rainFall": '0' # 无人机所在地天气情况 0:无雨 1: 小雨 2: 中雨 3: 大雨
  90. }
  91. # 飞行中的附加信息
  92. if str(n['convertCode']) == '2':
  93. fly_info = get_fly_info(n['id'], fly_data)
  94. print('fly_info:', fly_info)
  95. if fly_info is not None:
  96. item['fly_info'] = fly_info
  97. wrj_list.append(item)
  98. return {
  99. "code": 200,
  100. "msg": "操作成功",
  101. "data": {
  102. "list": wrj_list
  103. }
  104. }
  105. except Exception as e:
  106. traceback.print_exc()
  107. return {
  108. "code": 500,
  109. "msg": "操作失败"
  110. }
  111. def get_fly_info(id: str, data: list):
  112. for n in data:
  113. if n['id'] == id:
  114. return {
  115. "lng": str(n['lng']),
  116. "lat": str(n['lat']),
  117. "windSpeed": str(n['windSpeed']),
  118. "nestSeed": str(n['nestSpeed']),
  119. "temperature": str(n['temperature']),
  120. "environmentTemperature": str(n['environmentTemperature']),
  121. "batteryPerce": str(n['batteryPerce']),
  122. "rainFall": str(n['rainFall'])
  123. }
  124. return None
  125. '''
  126. # 获取飞行中无人机清单
  127. @router.get('/flyUavInfo')
  128. async def flyUavInfo(
  129. db: Session = Depends(get_db),
  130. body=Depends(remove_xss_json)
  131. ):
  132. return {
  133. "code": 200,
  134. "data": [{
  135. "id": "1721437235041120259", # ⽆⼈机ID,⽤于唯⼀标识⼀台⽆⼈机
  136. "uavId": "1720311986430930944", # 三方平台⽆⼈机ID,⽤于唯⼀标识 ⼀台⽆⼈机
  137. "thirdName": None, # 第三方平台名称
  138. "lng": 111.58967074364558, # 当前经度(WGS84)
  139. "lat": 21.5870035628497, # 当前纬度(WGS84)
  140. "flyingTime": None, # ⻜⾏时⻓(秒)
  141. "flyingDistance": 1319.85205078125, # ⻜⾏距离(⽶)
  142. "homeDistance": 1319.85205078125, # 无人机离机库直线距离(⽶)
  143. "height": 149.9, # 相对⾼度/对地⾼度(⽶)
  144. "altitude": 165.49883117675782, # 海拔⾼度(⽶)
  145. "realtimeStatus": 2, # 实时状态。 0:离线 1:待命 2:⻜⾏中
  146. "batteryPerce": 66.0, # 电池电量(%)
  147. "uavHSpeed": 14.85193590075045, # ⽔平速度(⽶/秒)
  148. "uavVSpeed": 0.0, # 垂直速度(⽶/秒)
  149. "pitchAngle": -30.0, # 俯仰⻆
  150. "yawAngle": -149.79347930213842, # 偏航⻆
  151. "hangarStatus": 1, # 机库状态,机库无⼈机必填 0:离线 1:在线
  152. "netWorkRate": 560.0, # 第三方无人机与其平台的网络通 信质量(kb/秒)
  153. "rainFall": 0, # 无人机所在地天气情况 0:无雨 1: 小雨 2: 中雨 3: 大雨
  154. "windSpeed": None, # 无人机当前接触到的风速(米/ 秒)
  155. "nestSpeed": 0.0, # 当前机库所在地风速
  156. "temperature": 34.099998474121094, # 无人机目前舱内温度(unit:℃)
  157. "environmentTemperature": 30.4, # 无人机所在地的环境温度(unit: ℃)
  158. "upQuality": 80.0, # 无人机与平台的通信质量(unit:%)
  159. "downQuality": 80.0, # 平台与无人机的通信质量(unit:%)
  160. "statusInfoTime": 1728544749103, # 实时消息对应时间
  161. "thirdPartId": "9b627ed9f7704e109fe22356d72b14ca" # 平台ID,只用于平台内部传值,不用于对外
  162. }],
  163. "msg": "操作成功"
  164. }
  165. try:
  166. data = WRJApi.flyUavInfo()
  167. return {
  168. "code": 200,
  169. "msg": "操作成功",
  170. "data": data
  171. }
  172. except Exception as e:
  173. return {
  174. "code": 500,
  175. "msg": "操作失败"
  176. }
  177. # 获取无人机实时飞行信息
  178. @router.get('/getRealInfo')
  179. async def getRealInfo(
  180. sn: str,
  181. db: Session = Depends(get_db),
  182. body = Depends(remove_xss_json)
  183. ):
  184. return {
  185. "code": 200,
  186. "data": {
  187. "id": "",
  188. "thirdPartformUavId": "第三方平台无人机id【sn】",
  189. "thirdPlartformId": "第三方平台id",
  190. "thirdName": "第三方平台名称",
  191. "flyingTime": "飞行时长",
  192. "flyingDistance":"飞行距离",
  193. "uavName": "无人机名称",
  194. "uavBrand": "无人机品牌",
  195. "realtimeStatus": "无人机实时状态",
  196. "height": "高度",
  197. "horizontalSpeed":"水平速度",
  198. "verticalSpeed":"垂直速度",
  199. "orgId":"所属单位",
  200. "orgName":"所属单位名称",
  201. "orgPath":"所属单位层级全路径",
  202. "orgTypeId":"单位类型id",
  203. "orgTypeName":"单位类型名称",
  204. "areaId":"所属行政辖区",
  205. "areaName":"所属行政辖区名称",
  206. "dataSource":"数据来源 1.本地创建 2.第三方平台",
  207. "addressLongitude":"常驻地址经度",
  208. "addressLatitude":"常驻地址维度",
  209. "latitude":"实时纬度",
  210. "longitude":"实时经度",
  211. "currentLocation":"当前位置信息",
  212. "addressLocation":"常驻地位置信息",
  213. "constructionModel":"建设模式 0-财政资金采购 (硬件) 1-财政资金采购 (服务) 2-社会资源",
  214. "dispatchResponseTime":"调度响应时间 0-15分钟内 1-2小时内 2-半天内 3-1天以上",
  215. "isHangarControl":"配置机巢/机库/基站控制 0-否 1-是",
  216. "thirdPullStreamAddress":"第三方平台流媒体拉流地址",
  217. "mediaPullStreamAddress":"流媒体拉流地址",
  218. "mediaPullType":"流媒体拉流方式 (rtmp、rtsp、flv、gb28181)",
  219. "nestOutMediaPullStreamAddress":"机舱外流媒体拉流地址",
  220. "nestOutMediaPullType": "机舱外流媒体拉流拉流方式:rtmp、rtsp、flv、gb28181",
  221. "thirdNestOutPullStreamAddress":"第三方平台机巢外部视频拉流地址"
  222. },
  223. "msg": "操作成功"
  224. }
  225. try:
  226. data = WRJApi.getRealInfo(sn)
  227. return {
  228. "code": 200,
  229. "msg": "操作成功",
  230. "data": data
  231. }
  232. except Exception as e:
  233. return {
  234. "code": 500,
  235. "msg": "操作失败"
  236. }'
  237. '''