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. m_site_area.reset(new site_area_hover);
  197. m_area_tool.reset(new area_tool);
  198. m_mine_tool.reset(new mine_tool);
  199. card_location_base::clear();
  200. }
  201. virtual void site_hover(int sid)
  202. {
  203. if(m_time<=0)
  204. {
  205. return;
  206. }
  207. m_site_area->on_point(m_id,sid,nullptr, m_type);
  208. }
  209. virtual std::shared_ptr<area_hover> get_area_hover()
  210. {
  211. return m_area_tool->m_area_hover;
  212. }
  213. virtual std::shared_ptr<mine_tool> get_mine_tool()
  214. {
  215. return m_mine_tool;
  216. }
  217. virtual std::shared_ptr<site_area_hover> get_site_area()
  218. {
  219. return m_site_area;
  220. }
  221. virtual void do_business(const point &pt,double acc)
  222. {
  223. m_area_tool->on_point(m_id,pt,m_speed,m_type);
  224. m_site_area->on_point(m_id,0,this, m_type);
  225. handle_three_rates(pt);
  226. }
  227. void reset(std::shared_ptr<monkey_person> mp)
  228. {
  229. m_monkeyPerson = mp;
  230. }
  231. ~person(){}
  232. private:
  233. void handle_three_rates(const point & pt)
  234. {
  235. card_pos cp;
  236. cp.work_line=m_workLine;
  237. cp.biz_stat = get_stat();
  238. cp.x=pt.x;cp.y=pt.y;cp.z=pt.z;
  239. const auto lm = m_area_tool->getLandmark();
  240. cp.enter_time = std::get<0>(lm)*1000;
  241. cp.area_id = std::get<3>(lm);
  242. put_three_rates(cp);
  243. }
  244. void on_timer()
  245. {
  246. if(!m_mine_tool->is_attendance())
  247. return;
  248. YA::_CARD_POS_ cp;
  249. uint64_t _time=0;
  250. point pt = getSmoothPoint(_time);
  251. const auto lm = m_area_tool->getLandmark();
  252. cp.enter_area_time = std::get<0>(lm)*1000;
  253. cp.rec_time = std::get<1>(lm);
  254. int32_t map_id = std::get<2>(lm);
  255. int32_t area_id = std::get<3>(lm);
  256. cp.map_id=map_id;cp.area_id=area_id;
  257. cp.landmark_id = std::get<4>(lm);
  258. cp.lm_direction = std::get<5>(lm);
  259. cp.landmark_dis=std::get<6>(lm);
  260. cp.biz_stat = get_stat();
  261. cp.down_time = m_mine_tool->get_down_time();
  262. cp.work_time = m_mine_tool->get_work_time();
  263. cp.is_on_duty= m_mine_tool->is_on_duty();
  264. log_info("on_timer here ...%d,%lld,%.2f,%.2f,%d,%d",m_id,_time,pt.x,pt.y,area_id,map_id);
  265. m_his_location_card->push(_time,pt,area_id,map_id);
  266. upt_card_pos(cp,pt);
  267. }
  268. point getSmoothPoint(uint64_t& t)
  269. {
  270. point pt;
  271. loc_point lp = m_smo_tool->smooth_strategy();
  272. m_speed = lp.m_speed;
  273. m_stat = lp.m_stat;
  274. pt.x = lp.x;
  275. pt.y = -lp.y;
  276. t=lp.m_time;
  277. if(auto p = m_monkeyPerson.lock() )
  278. {
  279. if(p->is_on_bus())
  280. {
  281. m_stat = 7;
  282. pt = p->getPoint(t);
  283. log_info("getpoint_oncar:%d,%lld",m_id,t);
  284. }
  285. }
  286. return pt;
  287. }
  288. };
  289. struct car:card_location_base,card_area
  290. {
  291. int m_vehicle_category_id=0;
  292. int m_vehicle_type_id=0;
  293. double m_acc =0;
  294. car(std::string type,uint32_t cardid,uint16_t needdisplay,int16_t t,int32_t deptid,
  295. int32_t categoryid, int type_id,int32_t level_id,uint32_t cid)
  296. :card_location_base(type,cardid,needdisplay,t,deptid,level_id,cid)
  297. ,m_vehicle_category_id(categoryid)
  298. ,m_vehicle_type_id(type_id)
  299. {
  300. m_message_handle.reset(new card_message_handle(this));
  301. m_his_location_card.reset(new location_vehicle(m_id,m_type));
  302. }
  303. virtual void site_hover(int sid)
  304. {
  305. if(m_time<=0)
  306. {
  307. return;
  308. }
  309. m_site_area->on_point(m_id,sid,0, m_type);
  310. }
  311. virtual std::shared_ptr<area_hover> get_area_hover()
  312. {
  313. return m_area_tool->m_area_hover;
  314. }
  315. virtual std::shared_ptr<mine_tool> get_mine_tool()
  316. {
  317. return m_mine_tool;
  318. }
  319. virtual std::shared_ptr<site_area_hover> get_site_area()
  320. {
  321. return m_site_area;
  322. }
  323. virtual void do_business(const point &pt,double acc)
  324. {
  325. m_acc=acc;
  326. m_area_tool->on_point(m_id,pt,m_speed,m_type);
  327. m_site_area->on_point(m_id,0,this, m_type);
  328. m_mine_tool->on_point(m_id, m_type, m_vehicle_category_id);
  329. handle_three_rates(pt);
  330. }
  331. int get_vehicle_type_id()
  332. {
  333. return m_vehicle_type_id;
  334. }
  335. ~car(){}
  336. private:
  337. void handle_three_rates(const point &pt)
  338. {
  339. card_pos cp;
  340. cp.biz_stat = get_stat();
  341. cp.x=pt.x;cp.y=pt.y;cp.z=pt.z;
  342. const auto lm = m_area_tool->getLandmark();
  343. cp.enter_time = std::get<0>(lm)*1000;
  344. cp.area_id = std::get<3>(lm);
  345. cp.map_id = std::get<2>(lm);
  346. cp.vibration=m_acc;
  347. put_three_rates(cp);
  348. }
  349. void on_timer()
  350. {
  351. make_package();
  352. }
  353. int statbiz(int32_t special_id)
  354. {
  355. int status = get_stat();
  356. if(status == STATUS_LOST)
  357. {
  358. if(!m_area_tool->special_area())
  359. {
  360. special_id = special_area_list::instance()->get_special_id(m_id,*this,m_vehicle_category_id);
  361. log_info("enter_special_area:%.2f,%2.f,id:%d,special_area_id:%d",x,y,m_id,special_id);
  362. if(special_id != -1)
  363. m_area_tool->change_area(m_id,m_speed,m_type,special_id);//自动拖车
  364. }
  365. }
  366. return status;
  367. }
  368. void make_package()
  369. {
  370. int32_t special_id=-1;
  371. YA::_CARD_POS_ cp;
  372. loc_point pt = getSmoothPoint();
  373. const auto lm = m_area_tool->getLandmark();
  374. cp.enter_area_time = std::get<0>(lm);
  375. cp.rec_time = std::get<1>(lm);
  376. uint32_t map_id = std::get<2>(lm);
  377. uint32_t area_id = std::get<3>(lm);
  378. cp.map_id =map_id;cp.area_id=area_id;
  379. cp.landmark_id = std::get<4>(lm);
  380. cp.lm_direction = std::get<5>(lm);
  381. cp.landmark_dis=std::get<6>(lm);
  382. int32_t biz_stat=statbiz(special_id);
  383. cp.biz_stat=biz_stat;
  384. cp.down_time = m_mine_tool->get_down_time();
  385. cp.work_time = m_mine_tool->get_work_time();
  386. //for now
  387. cp.is_on_duty=m_mine_tool->is_on_duty();
  388. upt_card_pos(cp,pt);
  389. m_his_location_card->push(pt.m_time,pt,area_id,map_id);
  390. if(biz_stat==STATUS_LOST && special_id != -1 && m_display==1)
  391. {
  392. cp.area_id = special_id;
  393. swsClientMgr.SendSpecialAreaProcess(cp);
  394. }
  395. }
  396. loc_point getSmoothPoint()
  397. {
  398. loc_point lp = m_smo_tool->smooth_strategy();
  399. m_speed = lp.m_speed;
  400. m_stat = lp.m_stat;
  401. lp.y = -lp.y;
  402. return lp;
  403. }
  404. };
  405. loc_tool_main one_ct_message_handle::m_loc_tool;
  406. uint64_t card_list::getId(uint32_t cardid,uint64_t type)
  407. {
  408. return type<<32|cardid;
  409. }
  410. void card_list::init_staffer(int32_t id)
  411. {
  412. std::string strategy = config.get("person.strategy","person1");
  413. std::string sql = "SELECT staff_id, s.card_id, c.card_type_id, s.dept_id, s.group_id, s.occupation_id, \
  414. ol.occupation_level_id,s.worktype_id,s.need_display,s.work_line\
  415. FROM dat_staff_extend s \
  416. LEFT JOIN dat_card c ON s.card_id = c.card_id \
  417. LEFT JOIN dat_occupation o ON s.occupation_id = o.occupation_id \
  418. LEFT JOIN dat_occupation_level ol ON ol.occupation_level_id = o.occupation_level_id \
  419. WHERE c.card_type_id = 1 AND s.duty_id = 0 AND c.state_id = 0";
  420. int type = CT_PERSON;
  421. std::string card_id_str = card_list::to_id64_str(type, static_cast<uint32_t>(id));
  422. if(-1 == id)
  423. {
  424. sql.append(";");
  425. }
  426. else
  427. {
  428. sql.append(" AND s.card_id = '");
  429. sql.append(card_id_str);
  430. sql.append("';");
  431. std_debug("基础数据 增加或修改人卡 sql=%s", sql.c_str());
  432. log_info("基础数据 增加或修改人卡 sql=%s", sql.c_str());
  433. }
  434. std::string Error;
  435. YADB::CDBResultSet DBRes;
  436. sDBConnPool.Query(sql.c_str(),DBRes,Error);
  437. int nCount = DBRes.GetRecordCount( Error );
  438. if (nCount < 1)
  439. {
  440. log_error("增加或修改失败,数据库中找不到: card_id=%s", card_id_str.c_str());
  441. return ;
  442. }
  443. std::unordered_map<uint64_t,std::shared_ptr<card_location_base>> map;
  444. while ( DBRes.GetNextRecod(Error) )
  445. {
  446. unsigned int staff_id = 0;
  447. DBRes.GetField( "staff_id",staff_id, Error );
  448. std::string card_id;
  449. DBRes.GetField( "card_id",card_id, Error );
  450. uint32_t vsid = atoi(card_id.substr(3).c_str());
  451. unsigned int card_type_id = 0;
  452. DBRes.GetField( "card_type_id",card_type_id, Error );
  453. int dept_id = 0;
  454. DBRes.GetField( "dept_id",dept_id, Error );
  455. int group_id = 0;
  456. DBRes.GetField( "group_id",group_id, Error );
  457. int occupation_id = 0;
  458. DBRes.GetField( "occupation_id",occupation_id, Error );
  459. int occupation_level_id = 0;
  460. DBRes.GetField( "occupation_level_id",occupation_level_id, Error );
  461. int need_display = 0;
  462. DBRes.GetField( "need_display",need_display, Error );
  463. int work_line = 0;
  464. DBRes.GetField( "work_line",work_line, Error );
  465. //for now;
  466. //staff_id = vsid;
  467. if(-1 == id)
  468. {
  469. std::shared_ptr<card_location_base> clb =
  470. std::make_shared<person>(strategy,vsid,need_display,card_type_id,dept_id,occupation_level_id,staff_id,work_line);
  471. uint64_t cardid = getId(vsid,type);
  472. log_info("cardId:%llu,id:%d dept_id:%d,need_display:%d,card:%s:work_line:%d,staff_id:%d,type:%d",
  473. cardid,vsid,dept_id,need_display,card_id.c_str(),work_line,staff_id,card_type_id);
  474. map.insert({cardid,clb});
  475. }
  476. else
  477. {
  478. auto card_id64 = card_list::to_id64(type, static_cast<uint32_t>(id));
  479. auto card_ptr = card_list::instance()->get(card_id64);
  480. if(card_ptr)
  481. {
  482. person* tmp_ptr= static_cast<person*>(card_ptr.get());
  483. tmp_ptr->m_display = static_cast<uint16_t>(need_display);
  484. tmp_ptr->m_deptid = dept_id;
  485. //group_id
  486. //occ_id
  487. tmp_ptr->m_level_id = occupation_level_id;
  488. //worktype_id
  489. }
  490. else
  491. {
  492. auto clb = std::make_shared<person>(strategy,vsid,need_display,card_type_id,dept_id,occupation_level_id,staff_id,work_line);
  493. card_list::instance()->add(card_id64, clb);
  494. }
  495. log_info("基础数据 增加或修改人卡成功:卡id:%d,卡type:%d dept_id:%d,need_display:%d,occupation_level_id:%d",
  496. id,type,dept_id,need_display,occupation_level_id);
  497. std_debug("基础数据 增加或修改人卡成功:卡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. }
  500. }
  501. if(-1 == id)
  502. {
  503. log_info( "init_staffer. The record count=%d\n", nCount );
  504. card_list::instance()->add(map);
  505. }
  506. }
  507. void card_list::init_vehicle(int32_t id)
  508. {
  509. std::string strategy = config.get("car.strategy","car1");
  510. std::string sql = "SELECT ve.vehicle_id, ve.card_id, c.card_type_id, \
  511. ve.dept_id, ve.group_id, v.vehicle_type_id, vt.vehicle_level_id, \
  512. vt.is_railroad AS vt_is_railroad,ve.need_display ,ve.power_alarm,\
  513. vt.vehicle_category_id,v.bigger_car_flag,vc.over_speed \
  514. FROM dat_vehicle_extend ve \
  515. LEFT JOIN dat_vehicle v ON ve.vehicle_id = v.vehicle_id \
  516. LEFT JOIN dat_card c ON ve.card_id = c.card_id \
  517. LEFT JOIN dat_dept d ON ve.dept_id = d.dept_id \
  518. LEFT JOIN dat_group g ON ve.group_id = g.group_id \
  519. LEFT JOIN dat_vehicle_type vt ON v.vehicle_type_id = vt.vehicle_type_id \
  520. LEFT JOIN dat_vehicle_category vc ON vc.vehicle_category_id = vt.vehicle_category_id \
  521. WHERE c.card_type_id = 2 AND c.state_id = 0";
  522. int type = CT_VEHICLE;
  523. std::string card_id_str = card_list::to_id64_str(type, static_cast<uint32_t>(id));
  524. if(-1 == id)
  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 == id)
  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,type);
  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(type, static_cast<uint32_t>(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:%d,卡type:%d dept_id:%d,need_display:%d,categoryid:%d",
  604. vsid,type,dept_id,need_display,vehicle_category_id);
  605. std_debug("基础数据 增加或修改车卡成功:卡id:%d,卡type:%d dept_id:%d,need_display:%d,categoryid:%d",
  606. vsid,type,dept_id,need_display,vehicle_category_id);
  607. }
  608. }
  609. if(-1 == id)
  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. card_location_base::~card_location_base()
  1078. {
  1079. }
  1080. template<> std::shared_ptr<card_list>
  1081. single_base<card_list, uint64_t, std::shared_ptr<card_location_base>>::m_instance=std::make_shared<card_list>();