1
0

card.cpp 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281
  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/CDBSingletonDefine.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. // TODO : 停止进程
  968. void card_list::onStopRun()
  969. {
  970. card_list::instance()->m_bflag = true;
  971. card_list::instance()->m_pThread->join();
  972. }
  973. void card_list::onTimer()
  974. {
  975. local_visit lv;
  976. while(!m_bflag)
  977. {
  978. card_list::instance()->accept(lv);
  979. std::this_thread::sleep_for(std::chrono::seconds(1));
  980. }
  981. }
  982. //-----------------card_location_base..
  983. 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)
  984. :card(id,dis,t,deptid,level_id,cid)
  985. {
  986. select_tool_manage::instance()->create_tool(type,m_sel_tool,m_smo_tool);
  987. }
  988. void card_location_base::do_status(STATUS_CARD st)
  989. {
  990. module_mgr::do_status(st, m_id, m_type);
  991. }
  992. void card_location_base::on_location(const std::vector<point>&vp,const std::vector<loc_message> &lm )
  993. {
  994. //ct timestamp;
  995. //m_ct = lm[0].m_card_ct;
  996. //m_time = lm[0].m_loc_time;
  997. loc_point pt = m_sel_tool->select_solution(vp,lm);
  998. pt.y=-pt.y;
  999. if(pt.m_useless)
  1000. {
  1001. x = pt.x;
  1002. y = pt.y;
  1003. //Msg m;
  1004. //m.type=m_type;m.x=(int)x;m.y=(int)y;m.cmd=CMD_HANDLE;m.cardid=m_type<<32|m_id;
  1005. //cardMgr::instance()->tryPut(m);
  1006. double acc = lm[0].m_acc;
  1007. 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);
  1008. do_business(pt,acc);
  1009. }
  1010. }
  1011. void card_location_base::on_message(zloop<task*> * loop,const message_locinfo&loc,bool is_history)
  1012. {
  1013. m_ct = loc.m_card_ct;
  1014. m_time = loc.m_time_stamp;
  1015. m_message_handle->on_message(loop,loc,is_history);
  1016. }
  1017. //前端推送位置函数
  1018. void card_location_base::upt_card_pos(YA::_CARD_POS_ &cp,const point &pt)
  1019. {
  1020. cp.x = pt.x;
  1021. cp.y = pt.y;
  1022. cp.z = pt.z;
  1023. cp.Type=m_type;
  1024. cp.ID = m_id;
  1025. cp.speed = abs(ceil(m_speed));
  1026. cp.running_stat = m_stat;
  1027. cp.dept_id = m_deptid;
  1028. cp.display=m_display;
  1029. cp.rec_time=m_time;
  1030. cp.level_id = m_level_id;
  1031. swsTimerThrd.upt_card_pos(cp);
  1032. }
  1033. void card_location_base::del_card_pos()
  1034. {
  1035. YA::_CARD_POS_ cp;
  1036. cp.ID = m_id;
  1037. cp.Type=m_type;
  1038. swsTimerThrd.del_card_pos(cp);
  1039. }
  1040. int card_location_base::get_stat()
  1041. {
  1042. //盲区>呼救>呼叫>超时>超速>正常
  1043. uint64_t now = time(0)*1000;
  1044. if(now-m_time>CARD_LOST_TIME_OUT)
  1045. {
  1046. return STATUS_LOST;
  1047. }
  1048. else if(auto ev_ptr = event_list::instance()->get_event_card(m_id, m_type, ET_CARD_HELP))
  1049. {
  1050. return (ES_DEAL_HELP == ev_ptr->m_status) ? STATUS_HELP_DEALED : STATUS_HELP;
  1051. }
  1052. else if(CALL_NONE != get_mine_tool()->m_status_call)
  1053. {
  1054. return STATUS_CALL;
  1055. }
  1056. else if(event_list::instance()->get_event_card(m_id, m_type,
  1057. is_person()? ET_CARD_AREA_OVER_TIME_PERSON: ET_CARD_AREA_OVER_TIME_VEHICLE))
  1058. {
  1059. return STATUS_AREA_OVER_TIME;
  1060. }
  1061. else if(event_list::instance()->get_event_card(m_id, m_type, ET_CARD_OVER_SPEED))
  1062. {
  1063. return STATUS_OVER_SPEED;
  1064. }
  1065. return STATUS_NORMAL;
  1066. }
  1067. void card_location_base::clear()
  1068. {
  1069. // uint16_t m_display; //1显示0不显示,往前端推送
  1070. m_speed=0; //速度
  1071. m_is_attendance=0; //井上井下状态 0初始状态 1 井上 2 井下
  1072. m_stat=0; //运动静止状态
  1073. //m_ct; //ct
  1074. m_time=0; //时间戳
  1075. }
  1076. void card_location_base::put_three_rates(card_pos & cp)
  1077. {
  1078. cp.rec_time=m_time;cp.type=m_type;cp.id=m_id;
  1079. cp.identifier_id=m_cid;cp.running_stat=m_stat;cp.final_v=m_speed;
  1080. log_info("three_rates:type:%d,id:%d,cid:%d",cp.type,cp.id,cp.identifier_id);
  1081. three_rates::get_instance()->put(cp);
  1082. }
  1083. bool card_location_base::is_person() const
  1084. {
  1085. return tool_other::is_person(m_type);
  1086. }
  1087. bool card_location_base::is_vehicle() const
  1088. {
  1089. return tool_other::is_vehicle(m_type);
  1090. }
  1091. card_location_base::~card_location_base()
  1092. {
  1093. }
  1094. template<> std::shared_ptr<card_list>
  1095. single_base<card_list, uint64_t, std::shared_ptr<card_location_base>>::m_instance=std::make_shared<card_list>();