card_base.cpp 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. #include <memory>
  2. #include <message.h>
  3. #include "card_message_handle.h"
  4. #include "card_person.h"
  5. #include "card_car.h"
  6. #include "config_file.h"
  7. #include "select_tool.h"
  8. #include "module_service/module_mgr.h"
  9. #include "websocket/wsClientMgr.h"
  10. #include "websocket/wsTimerThread.h"
  11. #include "three_rates.h"
  12. #include "his_location.h"
  13. #include"event.h"
  14. #include"module_service/module_call.h"
  15. #include"mine.h"
  16. #include"common_tool.h"
  17. extern config_file config;
  18. card_location_base::card_location_base(std::string type,uint32_t id,uint16_t dis,int16_t t,int32_t deptid,int32_t level_id,uint32_t cid)
  19. :card(id,dis,t,deptid,level_id,cid)
  20. {
  21. select_tool_manage::instance()->create_tool(type,m_sel_tool,m_smo_tool);
  22. }
  23. void card_location_base::do_status(int st)
  24. {
  25. module_mgr::do_status((STATUS_CARD)st, m_id, m_type);
  26. }
  27. void card_location_base::on_location(const std::vector<point>&vp,const std::vector<loc_message> &lm )
  28. {
  29. loc_point pt = m_sel_tool->select_solution(vp,lm);
  30. pt.y=-pt.y;
  31. if(pt.m_useless)
  32. {
  33. x = tool_other::round(pt.x,3);
  34. y = tool_other::round(pt.y,3);
  35. //Msg m;
  36. //m.type=m_type;m.x=(int)x;m.y=(int)y;m.cmd=CMD_HANDLE;m.cardid=m_type<<32|m_id;
  37. //cardMgr::instance()->tryPut(m);
  38. double acc = lm[0].m_acc;
  39. m_acc = lm[0].m_acc;
  40. log_info("useful:card_id:%d,ct:%d,timestamp:%llu, loc_point,x:%f,y:%f acc:%.2f",m_id,m_ct,m_time,x,y,acc);
  41. do_business(lm.front().m_sit, pt, acc);
  42. }
  43. }
  44. void card_location_base::on_message(zloop<task*> * loop,const message_locinfo&loc,bool is_history)
  45. {
  46. m_ct = loc.m_card_ct;
  47. m_time = loc.m_time_stamp;
  48. m_message_handle->on_message(loop,loc,is_history);
  49. }
  50. //前端推送位置函数.
  51. void card_location_base::upt_card_pos(YA::_CARD_POS_&cp, point &pt)
  52. {
  53. // YA::_CARD_POS_ cp;
  54. point _p;
  55. if(pt.empty())
  56. {
  57. _p=*this;
  58. pt=_p;
  59. }
  60. else
  61. _p=pt;
  62. cp.x = tool_other::round(_p.x,3);
  63. cp.y = tool_other::round(_p.y,3);
  64. //cp.z = pt.z;
  65. cp.Type=m_type;
  66. cp.ID = m_id;
  67. cp.speed = abs(ceil(m_speed));
  68. cp.running_stat = m_stat;
  69. cp.dept_id = m_deptid;
  70. cp.display=m_display;
  71. cp.rec_time=m_time;
  72. cp.level_id = m_level_id;
  73. swsTimerThrd.upt_card_pos(cp);
  74. }
  75. void card_location_base::del_card_pos()
  76. {
  77. YA::_CARD_POS_ cp;
  78. cp.ID = m_id;
  79. cp.Type=m_type;
  80. swsTimerThrd.del_card_pos(cp);
  81. }
  82. int card_location_base::get_stat()
  83. {
  84. //盲区>呼救>呼叫>超时>超速>正常
  85. uint64_t now = time(0)*1000;
  86. if(now-m_time>CARD_LOST_TIME_OUT)
  87. {
  88. return STATUS_LOST;
  89. }
  90. else if(auto ev_ptr = event_list::instance()->get_event_card(m_id, m_type, ET_CARD_HELP))
  91. {
  92. return (ES_DEAL_HELP == ev_ptr->m_status) ? STATUS_HELP_DEALED : STATUS_HELP;
  93. }
  94. else if(CALL_NONE != get_mine_tool()->m_status_call)
  95. {
  96. return STATUS_CALL;
  97. }
  98. else if(event_list::instance()->get_event_card(m_id, m_type,
  99. is_person()? ET_CARD_AREA_OVER_TIME_PERSON: ET_CARD_AREA_OVER_TIME_VEHICLE))
  100. {
  101. return STATUS_AREA_OVER_TIME;
  102. }
  103. else if(event_list::instance()->get_event_card(m_id, m_type, ET_CARD_OVER_SPEED))
  104. {
  105. return STATUS_OVER_SPEED;
  106. }
  107. return STATUS_NORMAL;
  108. }
  109. void card_location_base::clear()
  110. {
  111. // uint16_t m_display; //1显示0不显示,往前端推送
  112. m_speed=0; //速度
  113. m_is_attendance=0; //井上井下状态 0初始状态 1 井上 2 井下
  114. m_stat=0; //运动静止状态
  115. //m_ct; //ct
  116. m_time=0; //时间戳
  117. }
  118. void card_location_base::put_three_rates(card_pos & cp)
  119. {
  120. cp.rec_time=m_time;cp.type=m_type;cp.id=m_id;
  121. cp.identifier_id=m_cid;cp.running_stat=m_stat;cp.final_v=m_speed;
  122. cp.dpt_id = m_deptid;
  123. log_info("three_rates:type:%d,id:%d,cid:%d",cp.type,cp.id,cp.identifier_id);
  124. three_rates::get_instance()->put(cp);
  125. }
  126. bool card_location_base::is_person() const
  127. {
  128. return tool_other::is_person(m_type);
  129. }
  130. bool card_location_base::is_vehicle() const
  131. {
  132. return tool_other::is_vehicle(m_type);
  133. }
  134. card_location_base::~card_location_base()
  135. {
  136. }
  137. std::shared_ptr<card_location_base> card_location_base::make_person(const std::string&type,uint32_t cardid,uint16_t needdisplay,int16_t t,
  138. int32_t deptid,int32_t level_id,uint32_t cid,int wl,const std::string &sname,const std::string & dname,int worktype_id)
  139. {
  140. return std::make_shared<person>(type,cardid,needdisplay,t, deptid,level_id,cid,wl,sname,dname,worktype_id);
  141. }
  142. std::shared_ptr<card_location_base> card_location_base::make_car(const std::string&type,uint32_t cardid,uint16_t needdisplay,int16_t t,
  143. int32_t deptid, int32_t categoryid, int type_id,int32_t level_id,uint32_t cid)
  144. {
  145. return std::make_shared<car>(type,cardid,needdisplay,t, deptid, categoryid, type_id,level_id,cid);
  146. }