card_car.cpp 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229
  1. #include <sstream>
  2. #include "card_car.h"
  3. #include "card_message_handle.h"
  4. #include "his_location.h"
  5. #include "area.h"
  6. #include "mine.h"
  7. #include "three_rates.h"
  8. #include "select_tool.h"
  9. #include "websocket/ws_common.h"
  10. #include "special_area.h"
  11. #include "common_tool.h"
  12. #include "tool_time.h"
  13. #include "mine_business.h"
  14. #include "loc_point.h"
  15. #include "module_service/module_call.h"
  16. #include "ya_setting.h"
  17. #include "event.h"
  18. car::car(const std::string&type,uint32_t cardid,uint16_t needdisplay,int16_t t,int32_t deptid,
  19. int32_t categoryid, int type_id,int32_t level_id,uint32_t cid)
  20. :card_location_base(type,cardid,needdisplay,t,deptid,level_id,cid)
  21. ,m_vehicle_category_id(categoryid)
  22. ,m_vehicle_type_id(type_id)
  23. {
  24. m_message_handle.reset(new card_message_handle(this));
  25. //m_his_location_card.reset(new location_vehicle(m_id,m_type,cid));
  26. }
  27. car::~car(){}
  28. std::shared_ptr<mine_tool> car::get_mine_tool()
  29. {
  30. return m_mine_tool;
  31. }
  32. void car::set_area_info(int mapid,double scale,int areaid,uint64_t t,int type)
  33. {
  34. m_area_tool->set_area_info(mapid,scale,areaid,*this,t,type);
  35. }
  36. void car::do_business(const std::shared_ptr<site>&site,const point &pt,double acc)
  37. {
  38. m_acc=acc;
  39. m_area_tool->on_point(shared_from_this(),pt);
  40. m_timeval = m_time;
  41. //log_info("[anti_coll] m_id = %d, m_timeval = %lld", m_id, m_timeval);
  42. handle_three_rates(pt);
  43. handle_traffic_light(pt);
  44. if(m_enable_anti_collision){
  45. handle_anti_coll(pt, site->m_id);
  46. }
  47. uint64_t id=tool_other::type_id_to_u64(m_type,m_id);
  48. mine_business::inst()->make_arg(id,pt,m_time);
  49. }
  50. int car::get_vehicle_type_id()
  51. {
  52. return m_vehicle_type_id;
  53. }
  54. void car::handle_anti_coll(const point& pt, const int& sid)
  55. {
  56. //log_info("[anti_coll] handle anti collision");
  57. // 车卡下发最紧急的呼叫类型
  58. std::map<int, float> cd; // 人卡与车卡的距离,key为人卡id,value为距离
  59. std::map<int, call_card> cards;
  60. auto tmp_cards = card_list::instance()->m_map;
  61. double min_d = 9999999.9;
  62. double cur_v = 0.0;
  63. for(auto k : CYaSetting::m_sys_setting.mp_anti_collision){
  64. log_info("[anti_coll] key=%d, value=%.2f", k.first, k.second);
  65. for(auto& c : tmp_cards)
  66. {
  67. if(c.second->m_type == CT_VEHICLE){
  68. continue;
  69. }
  70. bool s = false;
  71. int d = (c.second->m_timeval >= m_timeval ? (c.second->m_timeval - m_timeval) : (m_timeval - c.second->m_timeval)) / 1000.0;
  72. s = ((c.second->m_timeval >= m_timeval ? (c.second->m_timeval - m_timeval) : (m_timeval - c.second->m_timeval)) /1000.0 <= 30);
  73. float dist = pt.dist(*c.second);
  74. if(dist < k.second && s){
  75. int call_level = 5 - k.first;
  76. log_info("[anti_coll] distance=%.3f, level=%d, thre_value=%.3f, time_diff=%d", dist, call_level, k.second, d);
  77. if(min_d > k.second){
  78. min_d = k.second;
  79. cur_v = dist;
  80. }
  81. auto itc = cd.find(c.second->m_id);
  82. if(itc == cd.end()){
  83. cd.insert(std::make_pair(c.second->m_id, dist));
  84. }else{
  85. itc->second = dist;
  86. }
  87. auto it = cards.find(c.second->m_id);
  88. if(it != cards.end()){
  89. if(c.second->m_call_level > call_level){
  90. c.second->m_call_level = call_level;
  91. }
  92. }else{
  93. cards.insert(std::make_pair(c.second->m_id, call_card(c.second->m_id, c.second->m_type, call_level, CCT_CALL_APOINT, sid)));
  94. }
  95. log_info("[anti_coll] card_id=%d, ctype=%d, call_level=%d, call_type_id=%d, site_id=%d",c.second->m_id, c.second->m_type, call_level, CCT_CALL_APOINT, sid);
  96. }
  97. }
  98. }
  99. std::string desc = "";
  100. if(cards.size() == 0){
  101. // delete event from event_list
  102. event_tool::instance()->handle_event(OT_CARD, ET_PERSON_VEHICLE_ANTI_COLLISION, m_id, 0, 0, false);
  103. }else{
  104. size_t i = 0;
  105. for(auto c : cd)
  106. {
  107. desc += std::to_string(c.first);
  108. std::ostringstream buf;
  109. buf<<c.second;
  110. desc += "," + buf.str();
  111. if(i != (cards.size() - 1)){
  112. desc += ";";
  113. }
  114. ++i;
  115. }
  116. log_info("[anti_coll] the distance's list between person and vehicle : %s", desc.c_str());
  117. event_tool::instance()->handle_event(OT_CARD, ET_PERSON_VEHICLE_ANTI_COLLISION, m_id, min_d, cur_v, true, DT_COMMON, desc);
  118. }
  119. if(cards.size() > 0){
  120. // find the best emengency call
  121. int call_level = 6;
  122. for(auto c : cards){
  123. if(c.second.call_level_id < call_level){
  124. call_level = c.second.call_level_id;
  125. }
  126. }
  127. cards.insert(std::make_pair(m_id, call_card(m_id, 2, call_level, CCT_CALL_APOINT, sid)));
  128. }else{
  129. log_info("[anti_coll] no card trigger anti collision rules.");
  130. return;
  131. }
  132. module_call::instance()->send_anti_collision(cards);
  133. }
  134. void car::handle_three_rates(const point &pt)
  135. {
  136. card_pos cp;
  137. m_biz_stat = get_stat();
  138. cp.biz_stat = m_biz_stat;
  139. cp.x = pt.x;
  140. cp.y = pt.y;
  141. cp.z = pt.z;
  142. //const auto lm = m_area_tool->getLandmark();
  143. //cp.enter_time = std::get<0>(lm)*1000;
  144. //cp.area_id = std::get<3>(lm);
  145. cp.map_id = m_area_tool->get_mapid();
  146. cp.vibration = m_acc;
  147. put_three_rates(cp);
  148. }
  149. void car::handle_traffic_light(const point& p)
  150. {
  151. card_pos cp;
  152. cp.x = p.x;
  153. cp.y = p.y;
  154. cp.z = p.z;
  155. cp.biz_stat = get_stat();
  156. cp.map_id = m_area_tool->get_mapid();
  157. cp.vibration = m_acc;
  158. put_traffic_light(cp);
  159. }
  160. void car::on_timer()
  161. {
  162. if(!empty())
  163. make_package();
  164. }
  165. int car::get_area()
  166. {
  167. int status = m_biz_stat;
  168. int special_id = -1;
  169. if(status == STATUS_LOST)
  170. {
  171. special_id = special_area_list::instance()->get_special_id(m_id,*this,m_vehicle_category_id);
  172. log_info("enter_special_area:%.2f,%2.f,id:%d,special_area_id:%d",x,y,m_id,special_id);
  173. }
  174. return special_id;
  175. }
  176. void car::make_package()
  177. {
  178. YA::_CARD_POS_ cp;
  179. loc_point pt = getSmoothPoint();
  180. cp.area_info = m_area_tool->m_area_info;
  181. cp.map_id = m_area_tool->get_mapid();
  182. cp.biz_stat = get_stat();
  183. cp.down_time = m_mine_tool->get_down_time();
  184. cp.work_time = m_mine_tool->get_work_time();
  185. cp.is_on_duty= m_mine_tool->is_on_duty();
  186. upt_card_pos(cp,pt);
  187. make_his_location(pt.m_time,pt);
  188. uint64_t _now=tool_time::now_to_ms();
  189. uint64_t t=_now>m_timeval?_now-m_timeval:m_timeval-_now;
  190. if(t>10*1000)
  191. {
  192. m_area_tool->on_point(shared_from_this(),pt);
  193. m_biz_stat=get_stat();
  194. }
  195. }
  196. void car::get_card(bool f)
  197. {
  198. if(f)
  199. mine_business::inst()->put(shared_from_this());
  200. }
  201. loc_point car::getSmoothPoint()
  202. {
  203. loc_point lp = m_smo_tool->smooth_strategy();
  204. m_speed = lp.m_speed;
  205. m_stat = lp.m_stat;
  206. lp.y = -lp.y;
  207. return lp;
  208. }