card.cpp 39 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273
  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. log_info("calc_location:%d begin",m_card->m_id);
  115. auto v = m_msg_list;
  116. std::vector<point> rc=std::move(m_loc_tool.calc_location(v));
  117. if(!rc.empty()) m_card->on_location(std::move(rc),v);
  118. reset();
  119. log_info("calc_location:%d end",m_card->m_id);
  120. }
  121. };
  122. struct card_message_handle
  123. {
  124. card_location_base*m_card;
  125. std::array<one_ct_message_handle*,16> m_ct_list;
  126. card_message_handle(card_location_base*card)
  127. {
  128. m_card=card;
  129. for(size_t i=0;i<m_ct_list.size();i++)
  130. {
  131. m_ct_list[i]=new one_ct_message_handle(card);
  132. }
  133. }
  134. ~card_message_handle()
  135. {
  136. for(auto&it:m_ct_list)
  137. {
  138. delete it;
  139. }
  140. }
  141. void on_message(zloop<task*> * loop,const message_locinfo&loc,bool is_history)
  142. {
  143. if(is_history)
  144. {
  145. log_warn("%s","当前代码没有处理历史消息记录。");
  146. return;
  147. }
  148. //
  149. m_card->site_hover(loc.m_site_id);
  150. if(loc.m_batty_status == 2)
  151. {
  152. m_card->do_status(STATUS_POWER_LOWER_SERIOUS);
  153. }
  154. else
  155. {
  156. m_card->do_status(STATUS_POWER_NOMARL);
  157. }
  158. if(loc.m_callinfo & 0x80)
  159. {
  160. m_card->do_status(STATUS_HELP);
  161. }
  162. if((loc.m_callinfo & 0x01) || (loc.m_callinfo & 0x02))
  163. {
  164. m_card->do_status(STATUS_CALL);
  165. }
  166. m_ct_list[loc.m_card_ct&(m_ct_list.size()-1)]->on_message(loop,loc);
  167. }
  168. };
  169. struct card_area
  170. {
  171. card_area()
  172. {
  173. m_site_area.reset(new site_area_hover);
  174. m_area_tool.reset(new area_tool);
  175. m_mine_tool.reset(new mine_tool);
  176. }
  177. std::shared_ptr<site_area_hover> m_site_area=nullptr;
  178. std::shared_ptr<area_tool> m_area_tool=nullptr;
  179. std::shared_ptr<mine_tool> m_mine_tool=nullptr;
  180. };
  181. struct person:card_location_base, card_area
  182. {
  183. std::weak_ptr<monkey_person> m_monkeyPerson;
  184. int m_workLine=0;
  185. 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)
  186. :card_location_base(type,cardid,needdisplay,t,deptid,level_id,cid)
  187. ,m_workLine(wl)
  188. {
  189. m_message_handle.reset(new card_message_handle(this));
  190. m_his_location_card.reset(new location_staff(m_id,m_type));
  191. }
  192. void on_message(zloop<task*> * loop,const message_locinfo&loc,bool is_history)
  193. {
  194. m_message_handle->on_message(loop,loc,is_history);
  195. }
  196. void clear()
  197. {
  198. //m_site_area.reset(new site_area_hover);
  199. m_area_tool.reset(new area_tool);
  200. m_mine_tool.reset(new mine_tool);
  201. card_location_base::clear();
  202. }
  203. virtual void site_hover(int sid)
  204. {
  205. if(m_time<=0)
  206. {
  207. return;
  208. }
  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(int64_t id64)
  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 s.duty_id = 0 AND c.state_id = 0";
  422. std::string card_id_str = tool_other::to13str(id64);
  423. if(-1 == id64)
  424. {
  425. sql.append(";");
  426. }
  427. else
  428. {
  429. sql.append(" AND s.card_id = '");
  430. sql.append(card_id_str);
  431. sql.append("';");
  432. std_debug("基础数据 增加或修改人卡 sql=%s", sql.c_str());
  433. log_info("基础数据 增加或修改人卡 sql=%s", sql.c_str());
  434. }
  435. std::string Error;
  436. YADB::CDBResultSet DBRes;
  437. sDBConnPool.Query(sql.c_str(),DBRes,Error);
  438. int nCount = DBRes.GetRecordCount( Error );
  439. if (nCount < 1)
  440. {
  441. log_error("增加或修改失败,数据库中找不到: card_id=%s", card_id_str.c_str());
  442. return ;
  443. }
  444. std::unordered_map<uint64_t,std::shared_ptr<card_location_base>> map;
  445. while ( DBRes.GetNextRecod(Error) )
  446. {
  447. unsigned int staff_id = 0;
  448. DBRes.GetField( "staff_id",staff_id, Error );
  449. std::string card_id;
  450. DBRes.GetField( "card_id",card_id, Error );
  451. uint32_t vsid = atoi(card_id.substr(3).c_str());
  452. unsigned int card_type_id = 0;
  453. DBRes.GetField( "card_type_id",card_type_id, Error );
  454. int dept_id = 0;
  455. DBRes.GetField( "dept_id",dept_id, Error );
  456. int group_id = 0;
  457. DBRes.GetField( "group_id",group_id, Error );
  458. int occupation_id = 0;
  459. DBRes.GetField( "occupation_id",occupation_id, Error );
  460. int occupation_level_id = 0;
  461. DBRes.GetField( "occupation_level_id",occupation_level_id, Error );
  462. int need_display = 0;
  463. DBRes.GetField( "need_display",need_display, Error );
  464. int work_line = 0;
  465. DBRes.GetField( "work_line",work_line, Error );
  466. //for now;
  467. //staff_id = vsid;
  468. if(-1 == id64)
  469. {
  470. std::shared_ptr<card_location_base> clb =
  471. std::make_shared<person>(strategy,vsid,need_display,card_type_id,dept_id,occupation_level_id,staff_id,work_line);
  472. uint64_t cardid = getId(vsid,card_type_id);
  473. log_info("cardId:%llu,id:%d dept_id:%d,need_display:%d,card:%s:work_line:%d,staff_id:%d,type:%d",
  474. cardid,vsid,dept_id,need_display,card_id.c_str(),work_line,staff_id,card_type_id);
  475. map.insert({cardid,clb});
  476. }
  477. else
  478. {
  479. auto card_id64 = card_list::to_id64(card_type_id, tool_other::id64_to_id(card_id));
  480. auto card_ptr = card_list::instance()->get(card_id64);
  481. if(card_ptr)
  482. {
  483. person* tmp_ptr= static_cast<person*>(card_ptr.get());
  484. tmp_ptr->m_display = static_cast<uint16_t>(need_display);
  485. tmp_ptr->m_deptid = dept_id;
  486. //group_id
  487. //occ_id
  488. tmp_ptr->m_level_id = occupation_level_id;
  489. //worktype_id
  490. }
  491. else
  492. {
  493. auto clb = std::make_shared<person>(strategy,vsid,need_display,card_type_id,dept_id,occupation_level_id,staff_id,work_line);
  494. card_list::instance()->add(card_id64, clb);
  495. }
  496. log_info("基础数据 增加或修改人卡成功:卡id:%ld, dept_id:%d,need_display:%d,occupation_level_id:%d",
  497. id64,dept_id,need_display,occupation_level_id);
  498. std_debug("基础数据 增加或修改人卡成功:卡id:%ld, dept_id:%d,need_display:%d,occupation_level_id:%d",
  499. id64,dept_id,need_display,occupation_level_id);
  500. }
  501. }
  502. if(-1 == id64)
  503. {
  504. log_info( "init_staffer. The record count=%d\n", nCount );
  505. card_list::instance()->add(map);
  506. }
  507. }
  508. void card_list::init_vehicle(int64_t id64)
  509. {
  510. std::string strategy = config.get("car.strategy","car1");
  511. std::string sql = "SELECT ve.vehicle_id, ve.card_id, c.card_type_id, \
  512. ve.dept_id, ve.group_id, v.vehicle_type_id, vt.vehicle_level_id, \
  513. vt.is_railroad AS vt_is_railroad,ve.need_display ,ve.power_alarm,\
  514. vt.vehicle_category_id,v.bigger_car_flag,vc.over_speed \
  515. FROM dat_vehicle_extend ve \
  516. LEFT JOIN dat_vehicle v ON ve.vehicle_id = v.vehicle_id \
  517. LEFT JOIN dat_card c ON ve.card_id = c.card_id \
  518. LEFT JOIN dat_dept d ON ve.dept_id = d.dept_id \
  519. LEFT JOIN dat_group g ON ve.group_id = g.group_id \
  520. LEFT JOIN dat_vehicle_type vt ON v.vehicle_type_id = vt.vehicle_type_id \
  521. LEFT JOIN dat_vehicle_category vc ON vc.vehicle_category_id = vt.vehicle_category_id \
  522. WHERE c.state_id = 0";
  523. std::string card_id_str = tool_other::to13str(id64);
  524. if(-1 == id64)
  525. {
  526. sql.append(";");
  527. }
  528. else
  529. {
  530. sql.append(" AND ve.card_id ='");
  531. sql.append(card_id_str);
  532. sql.append("';");
  533. std_debug("基础数据 增加或修改车卡 sql=%s", sql.c_str());
  534. log_info("基础数据 增加或修改车卡 sql=%s", sql.c_str());
  535. }
  536. std::string Error;
  537. YADB::CDBResultSet DBRes;
  538. sDBConnPool.Query(sql.c_str(),DBRes,Error);
  539. int nCount = DBRes.GetRecordCount( Error );
  540. if (nCount < 1)
  541. {
  542. log_error("增加或修改失败,数据库中找不到: card_id=%s", card_id_str.c_str());
  543. return ;
  544. }
  545. std::unordered_map<uint64_t,std::shared_ptr<card_location_base>> map;
  546. while ( DBRes.GetNextRecod(Error) )
  547. {
  548. unsigned int vehicle_id = 0;
  549. DBRes.GetField( "vehicle_id",vehicle_id, Error );
  550. std::string card_id;
  551. DBRes.GetField( "card_id",card_id, Error );
  552. uint32_t vsid = atoi(card_id.substr(3).c_str());
  553. unsigned int card_type_id = 0;
  554. DBRes.GetField( "card_type_id",card_type_id, Error );
  555. int dept_id = 0;
  556. DBRes.GetField( "dept_id",dept_id, Error );
  557. int group_id = 0;
  558. DBRes.GetField( "group_id",group_id, Error );
  559. int vehicle_type_id = 0;
  560. DBRes.GetField( "vehicle_type_id",vehicle_type_id, Error );
  561. int vehicle_level_id = 0;
  562. DBRes.GetField( "vehicle_level_id",vehicle_level_id, Error );
  563. int need_display = 0;
  564. DBRes.GetField( "need_display",need_display, Error );
  565. int power_alarm = 0;
  566. DBRes.GetField( "power_alarm",power_alarm, Error );
  567. int vehicle_category_id = 0;
  568. DBRes.GetField( "vehicle_category_id",vehicle_category_id, Error );
  569. int bigger_car_flag= 0;
  570. DBRes.GetField( "bigger_car_flag",bigger_car_flag, Error );
  571. double over_speed= 0;
  572. DBRes.GetField( "over_speed",over_speed, Error );
  573. //for now
  574. //vehicle_id = vsid;
  575. if(-1 == id64)
  576. {
  577. auto clb = std::make_shared<car>(strategy,vsid,need_display,card_type_id,
  578. dept_id,vehicle_category_id, vehicle_type_id,vehicle_level_id,vehicle_id);
  579. uint64_t cardid = getId(vsid,card_type_id);
  580. log_info("cardId:%llu,id:%d dept_id:%d,need_display:%d-cardid:%s,categoryid:%d,vchile_id:%d,type:%d",
  581. cardid,vsid,dept_id,need_display,card_id.c_str(),vehicle_category_id,vehicle_id,card_type_id);
  582. map.insert({cardid,clb});
  583. }
  584. else
  585. {
  586. auto card_id64 = card_list::to_id64(card_type_id, tool_other::id64_to_id(card_id));
  587. auto card_ptr = card_list::instance()->get(card_id64);
  588. if(card_ptr)
  589. {
  590. car* tmp_ptr= static_cast<car*>(card_ptr.get());
  591. tmp_ptr->m_display = static_cast<uint16_t>(need_display);
  592. tmp_ptr->m_deptid = dept_id;
  593. tmp_ptr->m_vehicle_category_id = vehicle_category_id;
  594. tmp_ptr->m_vehicle_type_id = vehicle_type_id;
  595. tmp_ptr->m_level_id = vehicle_level_id;
  596. }
  597. else
  598. {
  599. auto clb = std::make_shared<car>(strategy,vsid,need_display,card_type_id,dept_id,
  600. vehicle_category_id, vehicle_type_id,vehicle_level_id,vehicle_id);
  601. card_list::instance()->add(card_id64, clb);
  602. }
  603. log_info("基础数据 增加或修改车卡成功:卡id:%ld, dept_id:%d,need_display:%d,categoryid:%d",
  604. id64,dept_id,need_display,vehicle_category_id);
  605. std_debug("基础数据 增加或修改车卡成功:卡id:%ld, dept_id:%d,need_display:%d,categoryid:%d",
  606. id64,dept_id,need_display,vehicle_category_id);
  607. }
  608. }
  609. if(-1 == id64)
  610. {
  611. log_info( "init_vehicle. The record count=%d\n", nCount );
  612. card_list::instance()->add(map);
  613. }
  614. }
  615. #if 0
  616. void card_list::init_vehicle()
  617. {
  618. std::unordered_map<uint64_t,std::shared_ptr<card_location_base>> map;
  619. std::string strategy = config.get("car.strategy","car1");
  620. const char *sql = "SELECT ve.vehicle_id, ve.card_id, c.card_type_id, \
  621. ve.dept_id, ve.group_id, v.vehicle_type_id, vt.vehicle_level_id, \
  622. vt.is_railroad AS vt_is_railroad,ve.need_display ,ve.power_alarm,\
  623. vt.vehicle_category_id,v.bigger_car_flag,vc.over_speed \
  624. FROM dat_vehicle_extend ve \
  625. LEFT JOIN dat_vehicle v ON ve.vehicle_id = v.vehicle_id \
  626. LEFT JOIN dat_card c ON ve.card_id = c.card_id \
  627. LEFT JOIN dat_dept d ON ve.dept_id = d.dept_id \
  628. LEFT JOIN dat_group g ON ve.group_id = g.group_id \
  629. LEFT JOIN dat_vehicle_type vt ON v.vehicle_type_id = vt.vehicle_type_id \
  630. LEFT JOIN dat_vehicle_category vc ON vc.vehicle_category_id = vt.vehicle_category_id \
  631. WHERE c.card_type_id = 2 AND c.state_id = 0;";
  632. std::string Error;
  633. YADB::CDBResultSet DBRes;
  634. sDBConnPool.Query(sql,DBRes,Error);
  635. int nCount = DBRes.GetRecordCount( Error );
  636. if (nCount > 0)
  637. {
  638. log_info( "init_vehicle. The record count=%d\n", nCount );
  639. while ( DBRes.GetNextRecod(Error) )
  640. {
  641. unsigned int vehicle_id = 0;
  642. DBRes.GetField( "vehicle_id",vehicle_id, Error );
  643. std::string card_id;
  644. DBRes.GetField( "card_id",card_id, Error );
  645. uint32_t vsid = atoi(card_id.substr(3).c_str());
  646. unsigned int card_type_id = 0;
  647. DBRes.GetField( "card_type_id",card_type_id, Error );
  648. int dept_id = 0;
  649. DBRes.GetField( "dept_id",dept_id, Error );
  650. int group_id = 0;
  651. DBRes.GetField( "group_id",group_id, Error );
  652. int vehicle_type_id = 0;
  653. DBRes.GetField( "vehicle_type_id",vehicle_type_id, Error );
  654. int vehicle_level_id = 0;
  655. DBRes.GetField( "vehicle_level_id",vehicle_level_id, Error );
  656. int need_display = 0;
  657. DBRes.GetField( "need_display",need_display, Error );
  658. int power_alarm = 0;
  659. DBRes.GetField( "power_alarm",power_alarm, Error );
  660. int vehicle_category_id = 0;
  661. DBRes.GetField( "vehicle_category_id",vehicle_category_id, Error );
  662. int bigger_car_flag= 0;
  663. DBRes.GetField( "bigger_car_flag",bigger_car_flag, Error );
  664. double over_speed= 0;
  665. DBRes.GetField( "over_speed",over_speed, Error );
  666. //for now
  667. vehicle_id = vsid;
  668. std::shared_ptr<card_location_base> clb = std::make_shared<car>(strategy,vehicle_id,
  669. need_display,card_type_id,dept_id,vehicle_category_id, vehicle_type_id,vehicle_level_id);
  670. uint64_t cardid = getId(vehicle_id,2);
  671. 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);
  672. map.insert({cardid,clb});
  673. }
  674. }
  675. card_list::instance()->add(map);
  676. }
  677. void card_list::init_staffer()
  678. {
  679. std::unordered_map<uint64_t,std::shared_ptr<card_location_base>> map;
  680. std::string strategy = config.get("person.strategy","person1");
  681. const char *sql = "SELECT staff_id, s.card_id, c.card_type_id, s.dept_id, s.group_id, s.occupation_id, \
  682. ol.occupation_level_id,s.worktype_id,s.need_display \
  683. FROM dat_staff_extend s \
  684. LEFT JOIN dat_card c ON s.card_id = c.card_id \
  685. LEFT JOIN dat_occupation o ON s.occupation_id = o.occupation_id \
  686. LEFT JOIN dat_occupation_level ol ON ol.occupation_level_id = o.occupation_level_id \
  687. WHERE c.card_type_id = 1 AND s.duty_id = 0 AND c.state_id = 0;";
  688. std::string Error;
  689. YADB::CDBResultSet DBRes;
  690. sDBConnPool.Query(sql,DBRes,Error);
  691. int nCount = DBRes.GetRecordCount( Error );
  692. if (nCount > 0)
  693. {
  694. log_info( "init_staffer. The record count=%d\n", nCount );
  695. while ( DBRes.GetNextRecod(Error) )
  696. {
  697. unsigned int staff_id = 0;
  698. DBRes.GetField( "staff_id",staff_id, Error );
  699. std::string card_id;
  700. DBRes.GetField( "card_id",card_id, Error );
  701. uint32_t vsid = atoi(card_id.substr(3).c_str());
  702. unsigned int card_type_id = 0;
  703. DBRes.GetField( "card_type_id",card_type_id, Error );
  704. int dept_id = 0;
  705. DBRes.GetField( "dept_id",dept_id, Error );
  706. int group_id = 0;
  707. DBRes.GetField( "group_id",group_id, Error );
  708. int occupation_id = 0;
  709. DBRes.GetField( "occupation_id",occupation_id, Error );
  710. int occupation_level_id = 0;
  711. DBRes.GetField( "occupation_level_id",occupation_level_id, Error );
  712. int need_display = 0;
  713. DBRes.GetField( "need_display",need_display, Error );
  714. //for now;
  715. staff_id = vsid;
  716. std::shared_ptr<card_location_base> clb = std::make_shared<person>(strategy,staff_id,need_display,card_type_id,dept_id,occupation_level_id);
  717. uint64_t cardid = getId(staff_id,1);
  718. 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());
  719. map.insert({cardid,clb});
  720. }
  721. }
  722. card_list::instance()->add(map);
  723. }
  724. #endif
  725. void card_list::init_card_from_db()
  726. {
  727. init_staffer(-1);
  728. init_vehicle(-1);
  729. }
  730. void card_list::load_his_card_postion_from_db()
  731. {
  732. load_his_card_postion_vehicle();
  733. load_his_card_postion_staff();
  734. run();
  735. for(auto&iter: m_map)
  736. {
  737. auto card_ptr = iter.second;
  738. auto mine_tool_ptr = card_ptr->get_mine_tool();
  739. if(mine_tool_ptr->is_attendance())
  740. {
  741. auto str = tool_time::to_str_ex( tool_time::to_ms(mine_tool_ptr->m_attendance_start_time));
  742. std_debug("加载考勤,考勤开始时间: %s, 卡id=%d,卡type=%d", str.c_str(), card_ptr->m_id, card_ptr->m_type);
  743. log_info("加载考勤,考勤开始时间: %s, 卡id=%d,卡type=%d", str.c_str(), card_ptr->m_id, card_ptr->m_type);
  744. }
  745. }
  746. auto area_map = area_list::instance()->m_map;
  747. for(auto&iter: area_map)
  748. {
  749. auto area_ptr = iter.second;
  750. if(area_ptr->m_person_count)
  751. {
  752. std_debug("加载区域人数: 区域id=%d,区域人数=%d",area_ptr->m_id, area_ptr->m_person_count.load());
  753. log_info("加载区域人数: 区域id=%d,区域人数=%d",area_ptr->m_id, area_ptr->m_person_count.load());
  754. }
  755. if(area_ptr->m_vehicle_count)
  756. {
  757. std_debug("加载区域车数: 区域id=%d,区域车数=%d",area_ptr->m_id, area_ptr->m_vehicle_count.load());
  758. log_info("加载区域车数: 区域id=%d,区域车数=%d",area_ptr->m_id, area_ptr->m_vehicle_count.load());
  759. }
  760. }
  761. }
  762. void card_list::load_his_card_postion_vehicle()
  763. {
  764. const char *sql = "select l.card_id, l.cur_time, l.x, l.y, l.z, l.map_id, la.area_id, l.state, \
  765. case when l.cur_time >= date_sub(now(), interval 2 minute) then l.speed else 0 end as speed, \
  766. l.mileage, la.enter_time, att.start_time, \
  767. att.end_time, \
  768. l.landmark_id, l.direction_mapper_id, l.landmark_dist \
  769. from rt_location l, rt_location_area la, rt_att_vehicle att, dat_card c, dat_vehicle_extend v \
  770. 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 \
  771. and c.state_id=0;";
  772. std::string Error;
  773. YADB::CDBResultSet DBRes;
  774. sDBConnPool.Query(sql,DBRes,Error);
  775. if(!Error.empty())
  776. log_error("load_his_card_postion_vehicle列表 Error,%s",Error.c_str());
  777. uint64_t nCount = DBRes.GetRecordCount( Error );
  778. if (nCount > 0)
  779. {
  780. log_info( "load_his_card_postion_vehicle. The record count=%ld\n", nCount );
  781. while ( DBRes.GetNextRecod(Error) )
  782. {
  783. std::string card_id = "";
  784. DBRes.GetField( "card_id",card_id, Error );
  785. uint32_t id = tool_other::id64_to_id(card_id);
  786. int type = tool_other::id64_to_type(card_id);
  787. auto temp_ptr = card_list::instance()->get(card_list::to_id64(type, id));
  788. if(!temp_ptr || !temp_ptr->is_vehicle())
  789. {
  790. log_error("全局卡列表中找不到卡,卡id=%d,卡type=%d", id, type);
  791. continue;
  792. }
  793. auto card_ptr = static_cast<car*>(temp_ptr.get());
  794. double x = 0;
  795. DBRes.GetField( "x",x, Error );
  796. double y = 0;
  797. DBRes.GetField( "y",y, Error );
  798. double z = 0;
  799. DBRes.GetField( "z",z, Error );
  800. int map_id = 0;
  801. DBRes.GetField( "map_id",map_id, Error );
  802. int area_id = 0;
  803. DBRes.GetField( "area_id",area_id, Error );
  804. int state = 0;
  805. DBRes.GetField( "state",state, Error );
  806. double speed = 0;
  807. DBRes.GetField( "speed",speed, Error );
  808. std::string enter_time = "";
  809. DBRes.GetField( "enter_time",enter_time, Error );
  810. std::string start_time = "";
  811. DBRes.GetField( "start_time",start_time, Error );
  812. std::string end_time = "";
  813. DBRes.GetField( "end_time",end_time, Error );
  814. int landmark_id = 0;
  815. DBRes.GetField( "landmark_id",landmark_id, Error );
  816. int direction_mapper_id = 0;
  817. DBRes.GetField( "direction_mapper_id",direction_mapper_id, Error );
  818. double landmark_dist = 0;
  819. DBRes.GetField( "landmark_dist",landmark_dist, Error );
  820. card_ptr->x = x;
  821. card_ptr->y = y;
  822. card_ptr->z = z;
  823. auto area = area_list::instance()->get(area_id);
  824. if(area == nullptr)
  825. {
  826. log_error("load_vehicle...area_list 找不到区域:区域id=%d", area_id);
  827. continue;
  828. }
  829. area->m_vehicle_count++;
  830. point pt = *card_ptr;
  831. card_ptr->m_area_tool->m_area_hover = std::make_shared<area_hover>( area, pt,speed);
  832. auto area_hover_ptr = card_ptr->get_area_hover();
  833. auto e_t = tool_time::to_time_ex(enter_time);
  834. area_hover_ptr->m_enter_time = std::chrono::system_clock::to_time_t(e_t);
  835. //int map_id = 0;
  836. //int state = 0;
  837. card_ptr->m_speed = speed;
  838. if(end_time.empty())
  839. {
  840. auto mine_tool_ptr = card_ptr->get_mine_tool();
  841. mine_tool_ptr->m_attendance_start_time = tool_time::to_time_ex(start_time);
  842. mine_tool_ptr->m_stat_attendance = AS_ATTENDANCE;
  843. }
  844. area_hover_ptr->landmark_id = landmark_id;
  845. area_hover_ptr->landmark_dir = direction_mapper_id;
  846. area_hover_ptr->landmark_dis = landmark_dist;
  847. card_ptr->m_time = tool_time::now_to_ms();
  848. }
  849. }
  850. }
  851. void card_list::load_his_card_postion_staff()
  852. {
  853. const char *sql = "select l.card_id, l.cur_time, l.x, l.y, l.z, l.map_id, la.area_id, l.state, \
  854. case when l.cur_time >= date_sub(now(), interval 2 minute) then l.speed else 0 end as speed, \
  855. l.mileage, la.enter_time, att.start_time, \
  856. att.end_time, \
  857. l.landmark_id, l.direction_mapper_id, l.landmark_dist \
  858. from rt_location l, rt_location_area la, rt_att_staff att, dat_card c, dat_staff_extend s \
  859. 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\
  860. and c.state_id=0;";
  861. std::string Error;
  862. YADB::CDBResultSet DBRes;
  863. sDBConnPool.Query(sql,DBRes,Error);
  864. if(!Error.empty())
  865. log_error("load_his_card_postion_vehicle列表 Error,%s",Error.c_str());
  866. uint64_t nCount = DBRes.GetRecordCount( Error );
  867. if (nCount > 0)
  868. {
  869. log_info( "load_his_card_postion_vehicle. The record count=%ld\n", nCount );
  870. while ( DBRes.GetNextRecod(Error) )
  871. {
  872. std::string end_time = "";
  873. DBRes.GetField( "end_time",end_time, Error );
  874. if(!end_time.empty()) // 已升井,不再读入
  875. {
  876. continue;
  877. }
  878. std::string card_id = "";
  879. DBRes.GetField( "card_id",card_id, Error );
  880. uint32_t id = tool_other::id64_to_id(card_id);
  881. int type = tool_other::id64_to_type(card_id);
  882. auto temp_ptr = card_list::instance()->get(card_list::to_id64(type, id));
  883. if(!temp_ptr || !temp_ptr->is_person())
  884. {
  885. log_error("全局卡列表中找不到卡,卡id=%d,卡type=%d", id, type);
  886. continue;
  887. }
  888. auto card_ptr = static_cast<car*>(temp_ptr.get());
  889. double x = 0;
  890. DBRes.GetField( "x",x, Error );
  891. double y = 0;
  892. DBRes.GetField( "y",y, Error );
  893. double z = 0;
  894. DBRes.GetField( "z",z, Error );
  895. int map_id = 0;
  896. DBRes.GetField( "map_id",map_id, Error );
  897. int area_id = 0;
  898. DBRes.GetField( "area_id",area_id, Error );
  899. int state = 0;
  900. DBRes.GetField( "state",state, Error );
  901. double speed = 0;
  902. DBRes.GetField( "speed",speed, Error );
  903. std::string enter_time = "";
  904. DBRes.GetField( "enter_time",enter_time, Error );
  905. std::string start_time = "";
  906. DBRes.GetField( "start_time",start_time, Error );
  907. int landmark_id = 0;
  908. DBRes.GetField( "landmark_id",landmark_id, Error );
  909. int direction_mapper_id = 0;
  910. DBRes.GetField( "direction_mapper_id",direction_mapper_id, Error );
  911. double landmark_dist = 0;
  912. DBRes.GetField( "landmark_dist",landmark_dist, Error );
  913. card_ptr->x = x;
  914. card_ptr->y = y;
  915. card_ptr->z = z;
  916. auto area = area_list::instance()->get(area_id);
  917. if(area == nullptr)
  918. {
  919. log_error("area_list 找不到区域:区域id=%d", area_id);
  920. continue;
  921. }
  922. area->m_person_count++;
  923. point pt = *card_ptr;
  924. card_ptr->m_area_tool->m_area_hover = std::make_shared<area_hover>(area,pt,speed);
  925. auto area_hover_ptr = card_ptr->get_area_hover();
  926. auto e_t = tool_time::to_time_ex(enter_time);
  927. area_hover_ptr->m_enter_time = std::chrono::system_clock::to_time_t(e_t);
  928. log_info("load_staff...%d,areaid:%d,mapid:%d",id,area->id(),area->mapid());
  929. //int map_id = 0;
  930. //int state = 0;
  931. card_ptr->m_speed = speed;
  932. if(end_time.empty())
  933. {
  934. auto mine_tool_ptr = card_ptr->get_mine_tool();
  935. mine_tool_ptr->m_attendance_start_time = tool_time::to_time_ex(start_time);
  936. mine_tool_ptr->m_stat_attendance = AS_ATTENDANCE;
  937. }
  938. area_hover_ptr->landmark_id = landmark_id;
  939. area_hover_ptr->landmark_dir = direction_mapper_id;
  940. area_hover_ptr->landmark_dis = landmark_dist;
  941. card_ptr->m_time = tool_time::now_to_ms();
  942. }
  943. }
  944. }
  945. void card_list::on_message(zloop<task*> *loop,const message_locinfo&loc,bool is_history)
  946. {
  947. //std::shared_ptr<card_location_base>c=get(loc.m_card_id);
  948. uint64_t cardid = getId(loc.m_card_id,loc.m_card_type);
  949. const auto c=get(cardid);
  950. if(c==nullptr)
  951. {
  952. log_warn("数据库中未定义该卡的信息,card_id=%d", loc.m_card_id);
  953. return;
  954. }
  955. log_info("card message:site=%d,ant=%d,card=%d,tof=%lld,rav=%02X,acc=%02X,rssi=%d,stamp=%llu",
  956. 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);
  957. c->on_message(loop,loc,is_history);
  958. }
  959. struct local_visit:visitor<std::shared_ptr<card_location_base>>
  960. {
  961. bool visit(std::shared_ptr<card_location_base> c)
  962. {
  963. c->on_timer();
  964. return true;
  965. }
  966. };
  967. void card_list::onTimer()
  968. {
  969. local_visit lv;
  970. while(!m_bflag)
  971. {
  972. card_list::instance()->accept(lv);
  973. std::this_thread::sleep_for(std::chrono::seconds(1));
  974. }
  975. }
  976. //-----------------card_location_base..
  977. 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)
  978. :card(id,dis,t,deptid,level_id,cid)
  979. {
  980. select_tool_manage::instance()->create_tool(type,m_sel_tool,m_smo_tool);
  981. }
  982. void card_location_base::do_status(STATUS_CARD st)
  983. {
  984. module_mgr::do_status(st, m_id, m_type);
  985. }
  986. void card_location_base::on_location(const std::vector<point>&vp,const std::vector<loc_message> &lm )
  987. {
  988. //ct timestamp;
  989. //m_ct = lm[0].m_card_ct;
  990. //m_time = lm[0].m_loc_time;
  991. loc_point pt = m_sel_tool->select_solution(vp,lm);
  992. pt.y=-pt.y;
  993. if(pt.m_useless)
  994. {
  995. x = pt.x;
  996. y = pt.y;
  997. Msg m;
  998. m.type=m_type;m.x=(int)x;m.y=(int)y;m.cmd=CMD_HANDLE;m.cardid=m_type<<32|m_id;
  999. //cardMgr::instance()->tryPut(m);
  1000. double acc = lm[0].m_acc;
  1001. 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);
  1002. do_business(pt,acc);
  1003. }
  1004. }
  1005. void card_location_base::on_message(zloop<task*> * loop,const message_locinfo&loc,bool is_history)
  1006. {
  1007. m_ct = loc.m_card_ct;
  1008. m_time = loc.m_time_stamp;
  1009. m_message_handle->on_message(loop,loc,is_history);
  1010. }
  1011. //前端推送位置函数
  1012. void card_location_base::upt_card_pos(YA::_CARD_POS_ &cp,const point &pt)
  1013. {
  1014. cp.x = pt.x;
  1015. cp.y = pt.y;
  1016. cp.z = pt.z;
  1017. cp.Type=m_type;
  1018. cp.ID = m_id;
  1019. cp.speed = abs(ceil(m_speed));
  1020. cp.running_stat = m_stat;
  1021. cp.dept_id = m_deptid;
  1022. cp.display=m_display;
  1023. cp.rec_time=m_time;
  1024. cp.level_id = m_level_id;
  1025. swsTimerThrd.upt_card_pos(cp);
  1026. }
  1027. void card_location_base::del_card_pos()
  1028. {
  1029. YA::_CARD_POS_ cp;
  1030. cp.ID = m_id;
  1031. cp.Type=m_type;
  1032. swsTimerThrd.del_card_pos(cp);
  1033. }
  1034. int card_location_base::get_stat()
  1035. {
  1036. //盲区>呼救>呼叫>超时>超速>正常
  1037. uint64_t now = time(0)*1000;
  1038. if(now-m_time>CARD_LOST_TIME_OUT)
  1039. {
  1040. return STATUS_LOST;
  1041. }
  1042. else if(auto ev_ptr = event_list::instance()->get_event_card(m_id, m_type, ET_CARD_HELP))
  1043. {
  1044. return (ES_DEAL_HELP == ev_ptr->m_status) ? STATUS_HELP_DEALED : STATUS_HELP;
  1045. }
  1046. else if(CALL_NONE != get_mine_tool()->m_status_call)
  1047. {
  1048. return STATUS_CALL;
  1049. }
  1050. else if(event_list::instance()->get_event_card(m_id, m_type,
  1051. is_person()? ET_CARD_AREA_OVER_TIME_PERSON: ET_CARD_AREA_OVER_TIME_VEHICLE))
  1052. {
  1053. return STATUS_AREA_OVER_TIME;
  1054. }
  1055. else if(event_list::instance()->get_event_card(m_id, m_type, ET_CARD_OVER_SPEED))
  1056. {
  1057. return STATUS_OVER_SPEED;
  1058. }
  1059. return STATUS_NORMAL;
  1060. }
  1061. void card_location_base::clear()
  1062. {
  1063. // uint16_t m_display; //1显示0不显示,往前端推送
  1064. m_speed=0; //速度
  1065. m_is_attendance=0; //井上井下状态 0初始状态 1 井上 2 井下
  1066. m_stat=0; //运动静止状态
  1067. //m_ct; //ct
  1068. m_time=0; //时间戳
  1069. }
  1070. void card_location_base::put_three_rates(card_pos & cp)
  1071. {
  1072. cp.rec_time=m_time;cp.type=m_type;cp.id=m_id;
  1073. cp.identifier_id=m_cid;cp.running_stat=m_stat;cp.final_v=m_speed;
  1074. log_info("three_rates:type:%d,id:%d,cid:%d",cp.type,cp.id,cp.identifier_id);
  1075. three_rates::get_instance()->put(cp);
  1076. }
  1077. bool card_location_base::is_person() const
  1078. {
  1079. return tool_other::is_person(m_type);
  1080. }
  1081. bool card_location_base::is_vehicle() const
  1082. {
  1083. return tool_other::is_vehicle(m_type);
  1084. }
  1085. card_location_base::~card_location_base()
  1086. {
  1087. }
  1088. template<> std::shared_ptr<card_list>
  1089. single_base<card_list, uint64_t, std::shared_ptr<card_location_base>>::m_instance=std::make_shared<card_list>();