card.cpp 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263
  1. #include <memory>
  2. #include <log.h>
  3. #include <zloop.h>
  4. #include "select_tool.h"
  5. #include "loc_tool.h"
  6. #include <area.h>
  7. #include <site_area.h>
  8. #include <card.h>
  9. #include "config_file.h"
  10. #include "db_api/CDBConnPool.h"
  11. #include "websocket/wsTimerThread.h"
  12. #include "websocket/wsClientMgr.h"
  13. #include "timestamp.h"
  14. #include "monkey_car/monkeycar_area.h"
  15. #include "monkey_car/monkeycar_person.h"
  16. #include "special_area.h"
  17. #include "cardMgr.h"
  18. #include "ant.h"
  19. #include "mine.h"
  20. #include "module_service/module_mgr.h"
  21. #include "visit.h"
  22. #include "his_location.h"
  23. #include "three_rates.h"
  24. extern config_file config;
  25. //一张卡一个ct的所有不同天线的信息
  26. struct one_ct_message_handle
  27. {
  28. static loc_tool_main m_loc_tool;
  29. ev::timer m_min_timer,m_max_timer;
  30. //loc_message.
  31. std::vector<loc_message> m_msg_list;
  32. card_location_base*m_card;
  33. const algo_config*m_ac=nullptr;
  34. int m_ct;
  35. bool m_min_timeout=false;
  36. ev::dynamic_loop * m_loop = nullptr;
  37. one_ct_message_handle(card_location_base*card)
  38. {
  39. m_card=card;
  40. m_ct=-1;
  41. }
  42. void reset()
  43. {
  44. m_ct=-1;
  45. m_min_timeout=false;
  46. m_msg_list.clear();
  47. }
  48. void on_min_timer()
  49. {
  50. m_min_timer.stop();
  51. if((int)m_msg_list.size()>=m_ac->best_msg_cnt)
  52. {
  53. m_max_timer.stop();
  54. calc_location();
  55. return;
  56. }
  57. m_min_timeout=true;
  58. }
  59. void on_max_timer()
  60. {
  61. m_max_timer.stop();
  62. calc_location();
  63. }
  64. void set(ev::dynamic_loop * loop)
  65. {
  66. m_loop = loop;
  67. m_min_timer.set(*m_loop);
  68. m_min_timer.set<one_ct_message_handle,&one_ct_message_handle::on_min_timer>(this);
  69. m_max_timer.set(*m_loop);
  70. m_max_timer.set<one_ct_message_handle,&one_ct_message_handle::on_max_timer>(this);
  71. }
  72. void on_message(ev::dynamic_loop *loop,const message_locinfo&loc)
  73. {
  74. if(m_loop == nullptr && loop!=nullptr)
  75. set(loop);
  76. else if(loop == nullptr)
  77. return;
  78. if(!m_msg_list.empty()&& m_ct!=loc.m_card_ct)
  79. {
  80. m_msg_list.clear();
  81. }
  82. auto sitPtr = sit_list::instance()->get(loc.m_site_id);
  83. if(sitPtr==nullptr)
  84. {
  85. log_warn("分站信息缺失,SitId:%d",loc.m_site_id);
  86. return;
  87. }
  88. const site &s=*(sit_list::instance()->get(loc.m_site_id));
  89. if(m_msg_list.empty())
  90. {
  91. m_ct=loc.m_card_ct;
  92. m_ac=&s.config();
  93. m_min_timeout=false;
  94. //这里构造loc_message 保存数据
  95. m_msg_list.push_back(loc_message(s,loc.m_tof,loc.m_time_stamp,loc.m_card_id,
  96. loc.m_card_ct,loc.m_card_type,loc.m_ant_id,loc.m_rav,loc.m_acc,
  97. loc.m_sync_ct,loc.m_rssi));
  98. //启动本CT的最小、最大两个定时器
  99. m_min_timer.start(m_ac->min_wait_time);
  100. m_max_timer.start(m_ac->min_wait_time);
  101. return;
  102. }
  103. m_msg_list.push_back(loc_message(s,loc.m_tof,loc.m_time_stamp,loc.m_card_id,
  104. loc.m_card_ct,loc.m_card_type,loc.m_ant_id,loc.m_rav,loc.m_acc,
  105. loc.m_sync_ct,loc.m_rssi));
  106. if(m_min_timeout && (int)m_msg_list.size()>=m_ac->best_msg_cnt)
  107. {
  108. calc_location();
  109. m_max_timer.stop();
  110. }
  111. }
  112. void calc_location()
  113. {
  114. auto v = m_msg_list;
  115. std::vector<point> rc=std::move(m_loc_tool.calc_location(v));
  116. if(!rc.empty()) m_card->on_location(std::move(rc),v);
  117. reset();
  118. }
  119. };
  120. struct card_message_handle
  121. {
  122. card_location_base*m_card;
  123. std::array<one_ct_message_handle*,16> m_ct_list;
  124. card_message_handle(card_location_base*card)
  125. {
  126. m_card=card;
  127. for(size_t i=0;i<m_ct_list.size();i++)
  128. {
  129. m_ct_list[i]=new one_ct_message_handle(card);
  130. }
  131. }
  132. ~card_message_handle()
  133. {
  134. for(auto&it:m_ct_list)
  135. {
  136. delete it;
  137. }
  138. }
  139. void on_message(zloop<task*> * loop,const message_locinfo&loc,bool is_history)
  140. {
  141. if(is_history)
  142. {
  143. log_warn("%s","当前代码没有处理历史消息记录。");
  144. return;
  145. }
  146. //
  147. m_card->site_hover(loc.m_site_id);
  148. if(loc.m_batty_status == 2)
  149. {
  150. m_card->do_status(STATUS_POWER_LOWER_SERIOUS);
  151. }
  152. else
  153. {
  154. m_card->do_status(STATUS_POWER_NOMARL);
  155. }
  156. if(loc.m_callinfo & 0x80)
  157. {
  158. m_card->do_status(STATUS_HELP);
  159. }
  160. if((loc.m_callinfo & 0x01) || (loc.m_callinfo & 0x02))
  161. {
  162. m_card->do_status(STATUS_CALL);
  163. }
  164. m_ct_list[loc.m_card_ct&(m_ct_list.size()-1)]->on_message(loop,loc);
  165. }
  166. };
  167. struct card_area
  168. {
  169. card_area()
  170. {
  171. m_site_area.reset(new site_area_hover);
  172. m_area_tool.reset(new area_tool);
  173. m_mine_tool.reset(new mine_tool);
  174. }
  175. std::shared_ptr<site_area_hover> m_site_area=nullptr;
  176. std::shared_ptr<area_tool> m_area_tool=nullptr;
  177. std::shared_ptr<mine_tool> m_mine_tool=nullptr;
  178. };
  179. struct person:card_location_base, card_area
  180. {
  181. std::weak_ptr<monkey_person> m_monkeyPerson;
  182. int m_workLine=0;
  183. person(std::string type,uint32_t cardid,uint16_t needdisplay,int16_t t,int32_t deptid,int32_t level_id,uint32_t cid,int wl)
  184. :card_location_base(type,cardid,needdisplay,t,deptid,level_id,cid)
  185. ,m_workLine(wl)
  186. {
  187. m_message_handle.reset(new card_message_handle(this));
  188. m_his_location_card.reset(new location_staff(m_id,m_type));
  189. }
  190. void on_message(zloop<task*> * loop,const message_locinfo&loc,bool is_history)
  191. {
  192. m_message_handle->on_message(loop,loc,is_history);
  193. }
  194. void clear()
  195. {
  196. log_info("__thread_id reset:%d,%x [%x]",m_id,std::this_thread::get_id(),m_site_area.get());
  197. //m_site_area.reset(new site_area_hover);
  198. m_area_tool.reset(new area_tool);
  199. m_mine_tool.reset(new mine_tool);
  200. card_location_base::clear();
  201. }
  202. virtual void site_hover(int sid)
  203. {
  204. if(m_time<=0)
  205. {
  206. return;
  207. }
  208. log_info("__thread_id site_hover:%d,%x [%x]",m_id,std::this_thread::get_id(),m_site_area.get());
  209. m_site_area->on_point(m_id,sid,nullptr, m_type);
  210. }
  211. virtual std::shared_ptr<area_hover> get_area_hover()
  212. {
  213. return m_area_tool->m_area_hover;
  214. }
  215. virtual std::shared_ptr<mine_tool> get_mine_tool()
  216. {
  217. return m_mine_tool;
  218. }
  219. virtual std::shared_ptr<site_area_hover> get_site_area()
  220. {
  221. return m_site_area;
  222. }
  223. virtual void do_business(const point &pt,double acc)
  224. {
  225. m_area_tool->on_point(m_id,pt,m_speed,m_type);
  226. m_site_area->on_point(m_id,0,this, m_type);
  227. handle_three_rates(pt);
  228. }
  229. void reset(std::shared_ptr<monkey_person> mp)
  230. {
  231. m_monkeyPerson = mp;
  232. }
  233. ~person(){}
  234. private:
  235. void handle_three_rates(const point & pt)
  236. {
  237. card_pos cp;
  238. cp.work_line=m_workLine;
  239. cp.biz_stat = get_stat();
  240. cp.x=pt.x;cp.y=pt.y;cp.z=pt.z;
  241. const auto lm = m_area_tool->getLandmark();
  242. cp.enter_time = std::get<0>(lm)*1000;
  243. cp.area_id = std::get<3>(lm);
  244. put_three_rates(cp);
  245. }
  246. void on_timer()
  247. {
  248. if(!m_mine_tool->is_attendance())
  249. return;
  250. YA::_CARD_POS_ cp;
  251. uint64_t _time=0;
  252. point pt = getSmoothPoint(_time);
  253. const auto lm = m_area_tool->getLandmark();
  254. cp.enter_area_time = std::get<0>(lm)*1000;
  255. cp.rec_time = std::get<1>(lm);
  256. int32_t map_id = std::get<2>(lm);
  257. int32_t area_id = std::get<3>(lm);
  258. cp.map_id=map_id;cp.area_id=area_id;
  259. cp.landmark_id = std::get<4>(lm);
  260. cp.lm_direction = std::get<5>(lm);
  261. cp.landmark_dis=std::get<6>(lm);
  262. cp.biz_stat = get_stat();
  263. cp.down_time = m_mine_tool->get_down_time();
  264. cp.work_time = m_mine_tool->get_work_time();
  265. cp.is_on_duty= m_mine_tool->is_on_duty();
  266. log_info("on_timer here ...%d,%lld,%.2f,%.2f,%d,%d",m_id,_time,pt.x,pt.y,area_id,map_id);
  267. m_his_location_card->push(_time,pt,area_id,map_id);
  268. upt_card_pos(cp,pt);
  269. }
  270. point getSmoothPoint(uint64_t& t)
  271. {
  272. point pt;
  273. loc_point lp = m_smo_tool->smooth_strategy();
  274. m_speed = lp.m_speed;
  275. m_stat = lp.m_stat;
  276. pt.x = lp.x;
  277. pt.y = -lp.y;
  278. t=lp.m_time;
  279. if(auto p = m_monkeyPerson.lock() )
  280. {
  281. if(p->is_on_bus())
  282. {
  283. m_stat = 7;
  284. pt = p->getPoint(t);
  285. log_info("getpoint_oncar:%d,%lld",m_id,t);
  286. }
  287. }
  288. return pt;
  289. }
  290. };
  291. struct car:card_location_base,card_area
  292. {
  293. int m_vehicle_category_id=0;
  294. int m_vehicle_type_id=0;
  295. double m_acc =0;
  296. car(std::string type,uint32_t cardid,uint16_t needdisplay,int16_t t,int32_t deptid,
  297. int32_t categoryid, int type_id,int32_t level_id,uint32_t cid)
  298. :card_location_base(type,cardid,needdisplay,t,deptid,level_id,cid)
  299. ,m_vehicle_category_id(categoryid)
  300. ,m_vehicle_type_id(type_id)
  301. {
  302. m_message_handle.reset(new card_message_handle(this));
  303. m_his_location_card.reset(new location_vehicle(m_id,m_type));
  304. }
  305. virtual void site_hover(int sid)
  306. {
  307. if(m_time<=0)
  308. {
  309. return;
  310. }
  311. m_site_area->on_point(m_id,sid,0, m_type);
  312. }
  313. virtual std::shared_ptr<area_hover> get_area_hover()
  314. {
  315. return m_area_tool->m_area_hover;
  316. }
  317. virtual std::shared_ptr<mine_tool> get_mine_tool()
  318. {
  319. return m_mine_tool;
  320. }
  321. virtual std::shared_ptr<site_area_hover> get_site_area()
  322. {
  323. return m_site_area;
  324. }
  325. virtual void do_business(const point &pt,double acc)
  326. {
  327. m_acc=acc;
  328. m_area_tool->on_point(m_id,pt,m_speed,m_type);
  329. m_site_area->on_point(m_id,0,this, m_type);
  330. m_mine_tool->on_point(m_id, m_type, m_vehicle_category_id);
  331. handle_three_rates(pt);
  332. }
  333. int get_vehicle_type_id()
  334. {
  335. return m_vehicle_type_id;
  336. }
  337. ~car(){}
  338. private:
  339. void handle_three_rates(const point &pt)
  340. {
  341. card_pos cp;
  342. cp.biz_stat = get_stat();
  343. cp.x=pt.x;cp.y=pt.y;cp.z=pt.z;
  344. const auto lm = m_area_tool->getLandmark();
  345. cp.enter_time = std::get<0>(lm)*1000;
  346. cp.area_id = std::get<3>(lm);
  347. cp.map_id = std::get<2>(lm);
  348. cp.vibration=m_acc;
  349. put_three_rates(cp);
  350. }
  351. void on_timer()
  352. {
  353. make_package();
  354. }
  355. int statbiz(int32_t special_id)
  356. {
  357. int status = get_stat();
  358. if(status == STATUS_LOST)
  359. {
  360. if(!m_area_tool->special_area())
  361. {
  362. special_id = special_area_list::instance()->get_special_id(m_id,*this,m_vehicle_category_id);
  363. log_info("enter_special_area:%.2f,%2.f,id:%d,special_area_id:%d",x,y,m_id,special_id);
  364. if(special_id != -1)
  365. m_area_tool->change_area(m_id,m_speed,m_type,special_id);//自动拖车
  366. }
  367. }
  368. return status;
  369. }
  370. void make_package()
  371. {
  372. int32_t special_id=-1;
  373. YA::_CARD_POS_ cp;
  374. loc_point pt = getSmoothPoint();
  375. const auto lm = m_area_tool->getLandmark();
  376. cp.enter_area_time = std::get<0>(lm);
  377. cp.rec_time = std::get<1>(lm);
  378. uint32_t map_id = std::get<2>(lm);
  379. uint32_t area_id = std::get<3>(lm);
  380. cp.map_id =map_id;cp.area_id=area_id;
  381. cp.landmark_id = std::get<4>(lm);
  382. cp.lm_direction = std::get<5>(lm);
  383. cp.landmark_dis=std::get<6>(lm);
  384. int32_t biz_stat=statbiz(special_id);
  385. cp.biz_stat=biz_stat;
  386. cp.down_time = m_mine_tool->get_down_time();
  387. cp.work_time = m_mine_tool->get_work_time();
  388. //for now
  389. cp.is_on_duty=m_mine_tool->is_on_duty();
  390. upt_card_pos(cp,pt);
  391. m_his_location_card->push(pt.m_time,pt,area_id,map_id);
  392. if(biz_stat==STATUS_LOST && special_id != -1 && m_display==1)
  393. {
  394. cp.area_id = special_id;
  395. swsClientMgr.SendSpecialAreaProcess(cp);
  396. }
  397. }
  398. loc_point getSmoothPoint()
  399. {
  400. loc_point lp = m_smo_tool->smooth_strategy();
  401. m_speed = lp.m_speed;
  402. m_stat = lp.m_stat;
  403. lp.y = -lp.y;
  404. return lp;
  405. }
  406. };
  407. loc_tool_main one_ct_message_handle::m_loc_tool;
  408. uint64_t card_list::getId(uint32_t cardid,uint64_t type)
  409. {
  410. return type<<32|cardid;
  411. }
  412. void card_list::init_staffer(int32_t id)
  413. {
  414. std::string strategy = config.get("person.strategy","person1");
  415. std::string sql = "SELECT staff_id, s.card_id, c.card_type_id, s.dept_id, s.group_id, s.occupation_id, \
  416. ol.occupation_level_id,s.worktype_id,s.need_display,s.work_line\
  417. FROM dat_staff_extend s \
  418. LEFT JOIN dat_card c ON s.card_id = c.card_id \
  419. LEFT JOIN dat_occupation o ON s.occupation_id = o.occupation_id \
  420. LEFT JOIN dat_occupation_level ol ON ol.occupation_level_id = o.occupation_level_id \
  421. WHERE c.card_type_id = 1 AND s.duty_id = 0 AND c.state_id = 0";
  422. int type = CT_PERSON;
  423. std::string card_id_str = card_list::to_id64_str(type, static_cast<uint32_t>(id));
  424. if(-1 == id)
  425. {
  426. sql.append(";");
  427. }
  428. else
  429. {
  430. sql.append(" AND s.card_id = '");
  431. sql.append(card_id_str);
  432. sql.append("';");
  433. std_debug("基础数据 增加或修改人卡 sql=%s", sql.c_str());
  434. log_info("基础数据 增加或修改人卡 sql=%s", sql.c_str());
  435. }
  436. std::string Error;
  437. YADB::CDBResultSet DBRes;
  438. sDBConnPool.Query(sql.c_str(),DBRes,Error);
  439. int nCount = DBRes.GetRecordCount( Error );
  440. if (nCount < 1)
  441. {
  442. log_error("增加或修改失败,数据库中找不到: card_id=%s", card_id_str.c_str());
  443. return ;
  444. }
  445. std::unordered_map<uint64_t,std::shared_ptr<card_location_base>> map;
  446. while ( DBRes.GetNextRecod(Error) )
  447. {
  448. unsigned int staff_id = 0;
  449. DBRes.GetField( "staff_id",staff_id, Error );
  450. std::string card_id;
  451. DBRes.GetField( "card_id",card_id, Error );
  452. uint32_t vsid = atoi(card_id.substr(3).c_str());
  453. unsigned int card_type_id = 0;
  454. DBRes.GetField( "card_type_id",card_type_id, Error );
  455. int dept_id = 0;
  456. DBRes.GetField( "dept_id",dept_id, Error );
  457. int group_id = 0;
  458. DBRes.GetField( "group_id",group_id, Error );
  459. int occupation_id = 0;
  460. DBRes.GetField( "occupation_id",occupation_id, Error );
  461. int occupation_level_id = 0;
  462. DBRes.GetField( "occupation_level_id",occupation_level_id, Error );
  463. int need_display = 0;
  464. DBRes.GetField( "need_display",need_display, Error );
  465. int work_line = 0;
  466. DBRes.GetField( "work_line",work_line, Error );
  467. //for now;
  468. //staff_id = vsid;
  469. if(-1 == id)
  470. {
  471. std::shared_ptr<card_location_base> clb =
  472. std::make_shared<person>(strategy,vsid,need_display,card_type_id,dept_id,occupation_level_id,staff_id,work_line);
  473. uint64_t cardid = getId(vsid,type);
  474. log_info("cardId:%llu,id:%d dept_id:%d,need_display:%d,card:%s:work_line:%d,staff_id:%d,type:%d",
  475. cardid,vsid,dept_id,need_display,card_id.c_str(),work_line,staff_id,card_type_id);
  476. map.insert({cardid,clb});
  477. }
  478. else
  479. {
  480. auto card_id64 = card_list::to_id64(type, static_cast<uint32_t>(id));
  481. auto card_ptr = card_list::instance()->get(card_id64);
  482. if(card_ptr)
  483. {
  484. person* tmp_ptr= static_cast<person*>(card_ptr.get());
  485. tmp_ptr->m_display = static_cast<uint16_t>(need_display);
  486. tmp_ptr->m_deptid = dept_id;
  487. //group_id
  488. //occ_id
  489. tmp_ptr->m_level_id = occupation_level_id;
  490. //worktype_id
  491. }
  492. else
  493. {
  494. auto clb = std::make_shared<person>(strategy,vsid,need_display,card_type_id,dept_id,occupation_level_id,staff_id,work_line);
  495. card_list::instance()->add(card_id64, clb);
  496. }
  497. log_info("基础数据 增加或修改人卡成功:卡id:%d,卡type:%d dept_id:%d,need_display:%d,occupation_level_id:%d",
  498. id,type,dept_id,need_display,occupation_level_id);
  499. std_debug("基础数据 增加或修改人卡成功:卡id:%d,卡type:%d dept_id:%d,need_display:%d,occupation_level_id:%d",
  500. id,type,dept_id,need_display,occupation_level_id);
  501. }
  502. }
  503. if(-1 == id)
  504. {
  505. log_info( "init_staffer. The record count=%d\n", nCount );
  506. card_list::instance()->add(map);
  507. }
  508. }
  509. void card_list::init_vehicle(int32_t id)
  510. {
  511. std::string strategy = config.get("car.strategy","car1");
  512. std::string sql = "SELECT ve.vehicle_id, ve.card_id, c.card_type_id, \
  513. ve.dept_id, ve.group_id, v.vehicle_type_id, vt.vehicle_level_id, \
  514. vt.is_railroad AS vt_is_railroad,ve.need_display ,ve.power_alarm,\
  515. vt.vehicle_category_id,v.bigger_car_flag,vc.over_speed \
  516. FROM dat_vehicle_extend ve \
  517. LEFT JOIN dat_vehicle v ON ve.vehicle_id = v.vehicle_id \
  518. LEFT JOIN dat_card c ON ve.card_id = c.card_id \
  519. LEFT JOIN dat_dept d ON ve.dept_id = d.dept_id \
  520. LEFT JOIN dat_group g ON ve.group_id = g.group_id \
  521. LEFT JOIN dat_vehicle_type vt ON v.vehicle_type_id = vt.vehicle_type_id \
  522. LEFT JOIN dat_vehicle_category vc ON vc.vehicle_category_id = vt.vehicle_category_id \
  523. WHERE c.card_type_id = 2 AND c.state_id = 0";
  524. int type = CT_VEHICLE;
  525. std::string card_id_str = card_list::to_id64_str(type, static_cast<uint32_t>(id));
  526. if(-1 == id)
  527. {
  528. sql.append(";");
  529. }
  530. else
  531. {
  532. sql.append(" AND ve.card_id ='");
  533. sql.append(card_id_str);
  534. sql.append("';");
  535. std_debug("基础数据 增加或修改车卡 sql=%s", sql.c_str());
  536. log_info("基础数据 增加或修改车卡 sql=%s", sql.c_str());
  537. }
  538. std::string Error;
  539. YADB::CDBResultSet DBRes;
  540. sDBConnPool.Query(sql.c_str(),DBRes,Error);
  541. int nCount = DBRes.GetRecordCount( Error );
  542. if (nCount < 1)
  543. {
  544. log_error("增加或修改失败,数据库中找不到: card_id=%s", card_id_str.c_str());
  545. return ;
  546. }
  547. std::unordered_map<uint64_t,std::shared_ptr<card_location_base>> map;
  548. while ( DBRes.GetNextRecod(Error) )
  549. {
  550. unsigned int vehicle_id = 0;
  551. DBRes.GetField( "vehicle_id",vehicle_id, Error );
  552. std::string card_id;
  553. DBRes.GetField( "card_id",card_id, Error );
  554. uint32_t vsid = atoi(card_id.substr(3).c_str());
  555. unsigned int card_type_id = 0;
  556. DBRes.GetField( "card_type_id",card_type_id, Error );
  557. int dept_id = 0;
  558. DBRes.GetField( "dept_id",dept_id, Error );
  559. int group_id = 0;
  560. DBRes.GetField( "group_id",group_id, Error );
  561. int vehicle_type_id = 0;
  562. DBRes.GetField( "vehicle_type_id",vehicle_type_id, Error );
  563. int vehicle_level_id = 0;
  564. DBRes.GetField( "vehicle_level_id",vehicle_level_id, Error );
  565. int need_display = 0;
  566. DBRes.GetField( "need_display",need_display, Error );
  567. int power_alarm = 0;
  568. DBRes.GetField( "power_alarm",power_alarm, Error );
  569. int vehicle_category_id = 0;
  570. DBRes.GetField( "vehicle_category_id",vehicle_category_id, Error );
  571. int bigger_car_flag= 0;
  572. DBRes.GetField( "bigger_car_flag",bigger_car_flag, Error );
  573. double over_speed= 0;
  574. DBRes.GetField( "over_speed",over_speed, Error );
  575. //for now
  576. //vehicle_id = vsid;
  577. if(-1 == id)
  578. {
  579. auto clb = std::make_shared<car>(strategy,vsid,need_display,card_type_id,
  580. dept_id,vehicle_category_id, vehicle_type_id,vehicle_level_id,vehicle_id);
  581. uint64_t cardid = getId(vsid,type);
  582. log_info("cardId:%llu,id:%d dept_id:%d,need_display:%d-cardid:%s,categoryid:%d,vchile_id:%d,type:%d",
  583. cardid,vsid,dept_id,need_display,card_id.c_str(),vehicle_category_id,vehicle_id,card_type_id);
  584. map.insert({cardid,clb});
  585. }
  586. else
  587. {
  588. auto card_id64 = card_list::to_id64(type, static_cast<uint32_t>(id));
  589. auto card_ptr = card_list::instance()->get(card_id64);
  590. if(card_ptr)
  591. {
  592. car* tmp_ptr= static_cast<car*>(card_ptr.get());
  593. tmp_ptr->m_display = static_cast<uint16_t>(need_display);
  594. tmp_ptr->m_deptid = dept_id;
  595. tmp_ptr->m_vehicle_category_id = vehicle_category_id;
  596. tmp_ptr->m_vehicle_type_id = vehicle_type_id;
  597. tmp_ptr->m_level_id = vehicle_level_id;
  598. }
  599. else
  600. {
  601. auto clb = std::make_shared<car>(strategy,vsid,need_display,card_type_id,dept_id,
  602. vehicle_category_id, vehicle_type_id,vehicle_level_id,vehicle_id);
  603. card_list::instance()->add(card_id64, clb);
  604. }
  605. log_info("基础数据 增加或修改车卡成功:卡id:%d,卡type:%d dept_id:%d,need_display:%d,categoryid:%d",
  606. vsid,type,dept_id,need_display,vehicle_category_id);
  607. std_debug("基础数据 增加或修改车卡成功:卡id:%d,卡type:%d dept_id:%d,need_display:%d,categoryid:%d",
  608. vsid,type,dept_id,need_display,vehicle_category_id);
  609. }
  610. }
  611. if(-1 == id)
  612. {
  613. log_info( "init_vehicle. The record count=%d\n", nCount );
  614. card_list::instance()->add(map);
  615. }
  616. }
  617. #if 0
  618. void card_list::init_vehicle()
  619. {
  620. std::unordered_map<uint64_t,std::shared_ptr<card_location_base>> map;
  621. std::string strategy = config.get("car.strategy","car1");
  622. const char *sql = "SELECT ve.vehicle_id, ve.card_id, c.card_type_id, \
  623. ve.dept_id, ve.group_id, v.vehicle_type_id, vt.vehicle_level_id, \
  624. vt.is_railroad AS vt_is_railroad,ve.need_display ,ve.power_alarm,\
  625. vt.vehicle_category_id,v.bigger_car_flag,vc.over_speed \
  626. FROM dat_vehicle_extend ve \
  627. LEFT JOIN dat_vehicle v ON ve.vehicle_id = v.vehicle_id \
  628. LEFT JOIN dat_card c ON ve.card_id = c.card_id \
  629. LEFT JOIN dat_dept d ON ve.dept_id = d.dept_id \
  630. LEFT JOIN dat_group g ON ve.group_id = g.group_id \
  631. LEFT JOIN dat_vehicle_type vt ON v.vehicle_type_id = vt.vehicle_type_id \
  632. LEFT JOIN dat_vehicle_category vc ON vc.vehicle_category_id = vt.vehicle_category_id \
  633. WHERE c.card_type_id = 2 AND c.state_id = 0;";
  634. std::string Error;
  635. YADB::CDBResultSet DBRes;
  636. sDBConnPool.Query(sql,DBRes,Error);
  637. int nCount = DBRes.GetRecordCount( Error );
  638. if (nCount > 0)
  639. {
  640. log_info( "init_vehicle. The record count=%d\n", nCount );
  641. while ( DBRes.GetNextRecod(Error) )
  642. {
  643. unsigned int vehicle_id = 0;
  644. DBRes.GetField( "vehicle_id",vehicle_id, Error );
  645. std::string card_id;
  646. DBRes.GetField( "card_id",card_id, Error );
  647. uint32_t vsid = atoi(card_id.substr(3).c_str());
  648. unsigned int card_type_id = 0;
  649. DBRes.GetField( "card_type_id",card_type_id, Error );
  650. int dept_id = 0;
  651. DBRes.GetField( "dept_id",dept_id, Error );
  652. int group_id = 0;
  653. DBRes.GetField( "group_id",group_id, Error );
  654. int vehicle_type_id = 0;
  655. DBRes.GetField( "vehicle_type_id",vehicle_type_id, Error );
  656. int vehicle_level_id = 0;
  657. DBRes.GetField( "vehicle_level_id",vehicle_level_id, Error );
  658. int need_display = 0;
  659. DBRes.GetField( "need_display",need_display, Error );
  660. int power_alarm = 0;
  661. DBRes.GetField( "power_alarm",power_alarm, Error );
  662. int vehicle_category_id = 0;
  663. DBRes.GetField( "vehicle_category_id",vehicle_category_id, Error );
  664. int bigger_car_flag= 0;
  665. DBRes.GetField( "bigger_car_flag",bigger_car_flag, Error );
  666. double over_speed= 0;
  667. DBRes.GetField( "over_speed",over_speed, Error );
  668. //for now
  669. vehicle_id = vsid;
  670. std::shared_ptr<card_location_base> clb = std::make_shared<car>(strategy,vehicle_id,
  671. need_display,card_type_id,dept_id,vehicle_category_id, vehicle_type_id,vehicle_level_id);
  672. uint64_t cardid = getId(vehicle_id,2);
  673. log_info("cardId:%llu,vehicle_id:%d dept_id:%d,need_display:%d---cardid:%s,categoryid:%d",cardid,vehicle_id,dept_id,need_display,card_id.c_str(),vehicle_category_id);
  674. map.insert({cardid,clb});
  675. }
  676. }
  677. card_list::instance()->add(map);
  678. }
  679. void card_list::init_staffer()
  680. {
  681. std::unordered_map<uint64_t,std::shared_ptr<card_location_base>> map;
  682. std::string strategy = config.get("person.strategy","person1");
  683. const char *sql = "SELECT staff_id, s.card_id, c.card_type_id, s.dept_id, s.group_id, s.occupation_id, \
  684. ol.occupation_level_id,s.worktype_id,s.need_display \
  685. FROM dat_staff_extend s \
  686. LEFT JOIN dat_card c ON s.card_id = c.card_id \
  687. LEFT JOIN dat_occupation o ON s.occupation_id = o.occupation_id \
  688. LEFT JOIN dat_occupation_level ol ON ol.occupation_level_id = o.occupation_level_id \
  689. WHERE c.card_type_id = 1 AND s.duty_id = 0 AND c.state_id = 0;";
  690. std::string Error;
  691. YADB::CDBResultSet DBRes;
  692. sDBConnPool.Query(sql,DBRes,Error);
  693. int nCount = DBRes.GetRecordCount( Error );
  694. if (nCount > 0)
  695. {
  696. log_info( "init_staffer. The record count=%d\n", nCount );
  697. while ( DBRes.GetNextRecod(Error) )
  698. {
  699. unsigned int staff_id = 0;
  700. DBRes.GetField( "staff_id",staff_id, Error );
  701. std::string card_id;
  702. DBRes.GetField( "card_id",card_id, Error );
  703. uint32_t vsid = atoi(card_id.substr(3).c_str());
  704. unsigned int card_type_id = 0;
  705. DBRes.GetField( "card_type_id",card_type_id, Error );
  706. int dept_id = 0;
  707. DBRes.GetField( "dept_id",dept_id, Error );
  708. int group_id = 0;
  709. DBRes.GetField( "group_id",group_id, Error );
  710. int occupation_id = 0;
  711. DBRes.GetField( "occupation_id",occupation_id, Error );
  712. int occupation_level_id = 0;
  713. DBRes.GetField( "occupation_level_id",occupation_level_id, Error );
  714. int need_display = 0;
  715. DBRes.GetField( "need_display",need_display, Error );
  716. //for now;
  717. staff_id = vsid;
  718. std::shared_ptr<card_location_base> clb = std::make_shared<person>(strategy,staff_id,need_display,card_type_id,dept_id,occupation_level_id);
  719. uint64_t cardid = getId(staff_id,1);
  720. log_info("cardId:%llu,staff_id:%d dept_id:%d,need_display:%d--c-ard:%s",cardid,staff_id,dept_id,need_display,card_id.c_str());
  721. map.insert({cardid,clb});
  722. }
  723. }
  724. card_list::instance()->add(map);
  725. }
  726. #endif
  727. void card_list::init_card_from_db()
  728. {
  729. init_staffer(-1);
  730. init_vehicle(-1);
  731. }
  732. void card_list::load_his_card_postion_from_db()
  733. {
  734. load_his_card_postion_vehicle();
  735. load_his_card_postion_staff();
  736. run();
  737. for(auto&iter: m_map)
  738. {
  739. auto card_ptr = iter.second;
  740. auto mine_tool_ptr = card_ptr->get_mine_tool();
  741. if(mine_tool_ptr->is_attendance())
  742. {
  743. auto str = tool_time::to_str_ex( tool_time::to_ms(mine_tool_ptr->m_attendance_start_time));
  744. std_debug("加载考勤,考勤开始时间: %s, 卡id=%d,卡type=%d", str.c_str(), card_ptr->m_id, card_ptr->m_type);
  745. log_info("加载考勤,考勤开始时间: %s, 卡id=%d,卡type=%d", str.c_str(), card_ptr->m_id, card_ptr->m_type);
  746. }
  747. }
  748. auto area_map = area_list::instance()->m_map;
  749. for(auto&iter: area_map)
  750. {
  751. auto area_ptr = iter.second;
  752. if(area_ptr->m_person_count)
  753. {
  754. std_debug("加载区域人数: 区域id=%d,区域人数=%d",area_ptr->m_id, area_ptr->m_person_count.load());
  755. log_info("加载区域人数: 区域id=%d,区域人数=%d",area_ptr->m_id, area_ptr->m_person_count.load());
  756. }
  757. if(area_ptr->m_vehicle_count)
  758. {
  759. std_debug("加载区域车数: 区域id=%d,区域车数=%d",area_ptr->m_id, area_ptr->m_vehicle_count.load());
  760. log_info("加载区域车数: 区域id=%d,区域车数=%d",area_ptr->m_id, area_ptr->m_vehicle_count.load());
  761. }
  762. }
  763. }
  764. void card_list::load_his_card_postion_vehicle()
  765. {
  766. const char *sql = "select l.card_id, l.cur_time, l.x, l.y, l.z, l.map_id, la.area_id, l.state, \
  767. case when l.cur_time >= date_sub(now(), interval 2 minute) then l.speed else 0 end as speed, \
  768. l.mileage, la.enter_time, att.start_time, \
  769. att.end_time, \
  770. l.landmark_id, l.direction_mapper_id, l.landmark_dist \
  771. from rt_location l, rt_location_area la, rt_att_vehicle att, dat_card c, dat_vehicle_extend v \
  772. where l.card_id = c.card_id and l.card_id = la.card_id and l.card_id = att.card_id and l.card_id=v.card_id \
  773. and c.state_id=0;";
  774. std::string Error;
  775. YADB::CDBResultSet DBRes;
  776. sDBConnPool.Query(sql,DBRes,Error);
  777. if(!Error.empty())
  778. log_error("load_his_card_postion_vehicle列表 Error,%s",Error.c_str());
  779. uint64_t nCount = DBRes.GetRecordCount( Error );
  780. if (nCount > 0)
  781. {
  782. log_info( "load_his_card_postion_vehicle. The record count=%ld\n", nCount );
  783. while ( DBRes.GetNextRecod(Error) )
  784. {
  785. std::string card_id = "";
  786. DBRes.GetField( "card_id",card_id, Error );
  787. uint32_t id = tool_other::id64_to_id(card_id);
  788. int type = tool_other::id64_to_type(card_id);
  789. auto temp_ptr = card_list::instance()->get(card_list::to_id64(type, id));
  790. if(!temp_ptr || !temp_ptr->is_vehicle())
  791. {
  792. log_error("全局卡列表中找不到卡,卡id=%d,卡type=%d", id, type);
  793. continue;
  794. }
  795. auto card_ptr = static_cast<car*>(temp_ptr.get());
  796. double x = 0;
  797. DBRes.GetField( "x",x, Error );
  798. double y = 0;
  799. DBRes.GetField( "y",y, Error );
  800. double z = 0;
  801. DBRes.GetField( "z",z, Error );
  802. int map_id = 0;
  803. DBRes.GetField( "map_id",map_id, Error );
  804. int area_id = 0;
  805. DBRes.GetField( "area_id",area_id, Error );
  806. int state = 0;
  807. DBRes.GetField( "state",state, Error );
  808. double speed = 0;
  809. DBRes.GetField( "speed",speed, Error );
  810. std::string enter_time = "";
  811. DBRes.GetField( "enter_time",enter_time, Error );
  812. std::string start_time = "";
  813. DBRes.GetField( "start_time",start_time, Error );
  814. std::string end_time = "";
  815. DBRes.GetField( "end_time",end_time, Error );
  816. int landmark_id = 0;
  817. DBRes.GetField( "landmark_id",landmark_id, Error );
  818. int direction_mapper_id = 0;
  819. DBRes.GetField( "direction_mapper_id",direction_mapper_id, Error );
  820. double landmark_dist = 0;
  821. DBRes.GetField( "landmark_dist",landmark_dist, Error );
  822. card_ptr->x = x;
  823. card_ptr->y = y;
  824. card_ptr->z = z;
  825. auto area = area_list::instance()->get(area_id);
  826. if(area == nullptr)
  827. {
  828. log_error("load_vehicle...area_list 找不到区域:区域id=%d", area_id);
  829. continue;
  830. }
  831. area->m_vehicle_count++;
  832. point pt = *card_ptr;
  833. card_ptr->m_area_tool->m_area_hover = std::make_shared<area_hover>( area, pt,speed);
  834. auto area_hover_ptr = card_ptr->get_area_hover();
  835. auto e_t = tool_time::to_time_ex(enter_time);
  836. area_hover_ptr->m_enter_time = std::chrono::system_clock::to_time_t(e_t);
  837. //int map_id = 0;
  838. //int state = 0;
  839. card_ptr->m_speed = speed;
  840. if(end_time.empty())
  841. {
  842. auto mine_tool_ptr = card_ptr->get_mine_tool();
  843. mine_tool_ptr->m_attendance_start_time = tool_time::to_time_ex(start_time);
  844. mine_tool_ptr->m_stat_attendance = AS_ATTENDANCE;
  845. }
  846. area_hover_ptr->landmark_id = landmark_id;
  847. area_hover_ptr->landmark_dir = direction_mapper_id;
  848. area_hover_ptr->landmark_dis = landmark_dist;
  849. card_ptr->m_time = tool_time::now_to_ms();
  850. }
  851. }
  852. }
  853. void card_list::load_his_card_postion_staff()
  854. {
  855. const char *sql = "select l.card_id, l.cur_time, l.x, l.y, l.z, l.map_id, la.area_id, l.state, \
  856. case when l.cur_time >= date_sub(now(), interval 2 minute) then l.speed else 0 end as speed, \
  857. l.mileage, la.enter_time, att.start_time, \
  858. att.end_time, \
  859. l.landmark_id, l.direction_mapper_id, l.landmark_dist \
  860. from rt_location l, rt_location_area la, rt_att_staff att, dat_card c, dat_staff_extend s \
  861. where l.card_id = c.card_id and l.card_id = la.card_id and l.card_id = att.card_id and l.card_id=s.card_id\
  862. and c.state_id=0;";
  863. std::string Error;
  864. YADB::CDBResultSet DBRes;
  865. sDBConnPool.Query(sql,DBRes,Error);
  866. if(!Error.empty())
  867. log_error("load_his_card_postion_vehicle列表 Error,%s",Error.c_str());
  868. uint64_t nCount = DBRes.GetRecordCount( Error );
  869. if (nCount > 0)
  870. {
  871. log_info( "load_his_card_postion_vehicle. The record count=%ld\n", nCount );
  872. while ( DBRes.GetNextRecod(Error) )
  873. {
  874. std::string end_time = "";
  875. DBRes.GetField( "end_time",end_time, Error );
  876. if(!end_time.empty()) // 已升井,不再读入
  877. {
  878. continue;
  879. }
  880. std::string card_id = "";
  881. DBRes.GetField( "card_id",card_id, Error );
  882. uint32_t id = tool_other::id64_to_id(card_id);
  883. int type = tool_other::id64_to_type(card_id);
  884. auto temp_ptr = card_list::instance()->get(card_list::to_id64(type, id));
  885. if(!temp_ptr || !temp_ptr->is_person())
  886. {
  887. log_error("全局卡列表中找不到卡,卡id=%d,卡type=%d", id, type);
  888. continue;
  889. }
  890. auto card_ptr = static_cast<car*>(temp_ptr.get());
  891. double x = 0;
  892. DBRes.GetField( "x",x, Error );
  893. double y = 0;
  894. DBRes.GetField( "y",y, Error );
  895. double z = 0;
  896. DBRes.GetField( "z",z, Error );
  897. int map_id = 0;
  898. DBRes.GetField( "map_id",map_id, Error );
  899. int area_id = 0;
  900. DBRes.GetField( "area_id",area_id, Error );
  901. int state = 0;
  902. DBRes.GetField( "state",state, Error );
  903. double speed = 0;
  904. DBRes.GetField( "speed",speed, Error );
  905. std::string enter_time = "";
  906. DBRes.GetField( "enter_time",enter_time, Error );
  907. std::string start_time = "";
  908. DBRes.GetField( "start_time",start_time, Error );
  909. int landmark_id = 0;
  910. DBRes.GetField( "landmark_id",landmark_id, Error );
  911. int direction_mapper_id = 0;
  912. DBRes.GetField( "direction_mapper_id",direction_mapper_id, Error );
  913. double landmark_dist = 0;
  914. DBRes.GetField( "landmark_dist",landmark_dist, Error );
  915. card_ptr->x = x;
  916. card_ptr->y = y;
  917. card_ptr->z = z;
  918. auto area = area_list::instance()->get(area_id);
  919. if(area == nullptr)
  920. {
  921. log_error("area_list 找不到区域:区域id=%d", area_id);
  922. continue;
  923. }
  924. area->m_person_count++;
  925. point pt = *card_ptr;
  926. card_ptr->m_area_tool->m_area_hover = std::make_shared<area_hover>(area,pt,speed);
  927. auto area_hover_ptr = card_ptr->get_area_hover();
  928. auto e_t = tool_time::to_time_ex(enter_time);
  929. area_hover_ptr->m_enter_time = std::chrono::system_clock::to_time_t(e_t);
  930. log_info("load_staff...%d,areaid:%d,mapid:%d",id,area->id(),area->mapid());
  931. //int map_id = 0;
  932. //int state = 0;
  933. card_ptr->m_speed = speed;
  934. if(end_time.empty())
  935. {
  936. auto mine_tool_ptr = card_ptr->get_mine_tool();
  937. mine_tool_ptr->m_attendance_start_time = tool_time::to_time_ex(start_time);
  938. mine_tool_ptr->m_stat_attendance = AS_ATTENDANCE;
  939. }
  940. area_hover_ptr->landmark_id = landmark_id;
  941. area_hover_ptr->landmark_dir = direction_mapper_id;
  942. area_hover_ptr->landmark_dis = landmark_dist;
  943. card_ptr->m_time = tool_time::now_to_ms();
  944. }
  945. }
  946. }
  947. void card_list::on_message(zloop<task*> *loop,const message_locinfo&loc,bool is_history)
  948. {
  949. //std::shared_ptr<card_location_base>c=get(loc.m_card_id);
  950. uint64_t cardid = getId(loc.m_card_id,loc.m_card_type);
  951. const auto c=get(cardid);
  952. if(c==nullptr)
  953. {
  954. log_warn("数据库中未定义该卡的信息,card_id=%d", loc.m_card_id);
  955. return;
  956. }
  957. log_info("card message:site=%d,ant=%d,card=%d,tof=%lld,rav=%02X,acc=%02X,rssi=%d,stamp=%llu",
  958. loc.m_site_id,loc.m_ant_id,loc.m_card_id,loc.m_tof,loc.m_rav,loc.m_acc,loc.m_rssi,loc.m_time_stamp);
  959. c->on_message(loop,loc,is_history);
  960. }
  961. struct local_visit:visitor<std::shared_ptr<card_location_base>>
  962. {
  963. bool visit(std::shared_ptr<card_location_base> c)
  964. {
  965. c->on_timer();
  966. return true;
  967. }
  968. };
  969. void card_list::onTimer()
  970. {
  971. local_visit lv;
  972. while(!m_bflag)
  973. {
  974. card_list::instance()->accept(lv);
  975. std::this_thread::sleep_for(std::chrono::seconds(1));
  976. }
  977. }
  978. //-----------------card_location_base..
  979. 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)
  980. :card(id,dis,t,deptid,level_id,cid)
  981. {
  982. select_tool_manage::instance()->create_tool(type,m_sel_tool,m_smo_tool);
  983. }
  984. void card_location_base::do_status(STATUS_CARD st)
  985. {
  986. module_mgr::do_status(st, m_id, m_type);
  987. }
  988. void card_location_base::on_location(const std::vector<point>&vp,const std::vector<loc_message> &lm )
  989. {
  990. //ct timestamp;
  991. //m_ct = lm[0].m_card_ct;
  992. //m_time = lm[0].m_loc_time;
  993. loc_point pt = m_sel_tool->select_solution(vp,lm);
  994. pt.y=-pt.y;
  995. if(pt.m_useless)
  996. {
  997. x = pt.x;
  998. y = pt.y;
  999. Msg m;
  1000. m.type=m_type;m.x=(int)x;m.y=(int)y;m.cmd=CMD_HANDLE;m.cardid=m_type<<32|m_id;
  1001. cardMgr::instance()->tryPut(m);
  1002. double acc = lm[0].m_acc;
  1003. log_info("useful:card_id:%d,ct:%d,timestamp:%llu, loc_point,x:%.2f,y:%.2f acc:%.2f",m_id,m_ct,m_time,pt.x,pt.y,acc);
  1004. do_business(pt,acc);
  1005. }
  1006. }
  1007. void card_location_base::on_message(zloop<task*> * loop,const message_locinfo&loc,bool is_history)
  1008. {
  1009. m_ct = loc.m_card_ct;
  1010. m_time = loc.m_time_stamp;
  1011. m_message_handle->on_message(loop,loc,is_history);
  1012. }
  1013. //前端推送位置函数
  1014. void card_location_base::upt_card_pos(YA::_CARD_POS_ &cp,const point &pt)
  1015. {
  1016. cp.x = pt.x;
  1017. cp.y = pt.y;
  1018. cp.z = pt.z;
  1019. cp.Type=m_type;
  1020. cp.ID = m_id;
  1021. cp.speed = abs(ceil(m_speed));
  1022. cp.running_stat = m_stat;
  1023. cp.dept_id = m_deptid;
  1024. cp.display=m_display;
  1025. cp.rec_time=m_time;
  1026. cp.level_id = m_level_id;
  1027. swsTimerThrd.upt_card_pos(cp);
  1028. }
  1029. void card_location_base::del_card_pos()
  1030. {
  1031. YA::_CARD_POS_ cp;
  1032. cp.ID = m_id;
  1033. cp.Type=m_type;
  1034. swsTimerThrd.del_card_pos(cp);
  1035. }
  1036. int card_location_base::get_stat()
  1037. {
  1038. //盲区>呼救>呼叫>超时>超速>正常
  1039. uint64_t now = time(0)*1000;
  1040. if(now-m_time>CARD_LOST_TIME_OUT)
  1041. {
  1042. return STATUS_LOST;
  1043. }
  1044. else if(auto ev_ptr = event_list::instance()->get_event_card(m_id, m_type, ET_CARD_HELP))
  1045. {
  1046. return (ES_DEAL_HELP == ev_ptr->m_status) ? STATUS_HELP_DEALED : STATUS_HELP;
  1047. }
  1048. else if(CALL_NONE != get_mine_tool()->m_status_call)
  1049. {
  1050. return STATUS_CALL;
  1051. }
  1052. else if(event_list::instance()->get_event_card(m_id, m_type,
  1053. is_person()? ET_CARD_AREA_OVER_TIME_PERSON: ET_CARD_AREA_OVER_TIME_VEHICLE))
  1054. {
  1055. return STATUS_AREA_OVER_TIME;
  1056. }
  1057. else if(event_list::instance()->get_event_card(m_id, m_type, ET_CARD_OVER_SPEED))
  1058. {
  1059. return STATUS_OVER_SPEED;
  1060. }
  1061. return STATUS_NORMAL;
  1062. }
  1063. void card_location_base::clear()
  1064. {
  1065. // uint16_t m_display; //1显示0不显示,往前端推送
  1066. m_speed=0; //速度
  1067. m_is_attendance=0; //井上井下状态 0初始状态 1 井上 2 井下
  1068. m_stat=0; //运动静止状态
  1069. //m_ct; //ct
  1070. m_time=0; //时间戳
  1071. }
  1072. void card_location_base::put_three_rates(card_pos & cp)
  1073. {
  1074. cp.rec_time=m_time;cp.type=m_type;cp.id=m_id;
  1075. cp.identifier_id=m_cid;cp.running_stat=m_stat;cp.final_v=m_speed;
  1076. log_info("three_rates:type:%d,id:%d,cid:%d",cp.type,cp.id,cp.identifier_id);
  1077. three_rates::get_instance()->put(cp);
  1078. }
  1079. card_location_base::~card_location_base()
  1080. {
  1081. }
  1082. template<> std::shared_ptr<card_list>
  1083. single_base<card_list, uint64_t, std::shared_ptr<card_location_base>>::m_instance=std::make_shared<card_list>();