card.cpp 39 KB

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