#include #include #include "card_message_handle.h" #include "card_person.h" #include "card_car.h" #include "config_file.h" #include "select_tool.h" #include "module_service/module_mgr.h" #include "websocket/wsClientMgr.h" #include "websocket/wsTimerThread.h" #include "three_rates.h" #include "his_location.h" #include "event.h" #include "module_service/module_call.h" #include "mine.h" #include "common_tool.h" #include "ant.h" #include "area.h" #include "loc_point.h" #include "loc_message.h" extern config_file config; card_location_base::card_location_base(const std::string&type,uint32_t id,uint16_t dis,int16_t t,int32_t deptid,int32_t level_id,uint32_t cid) :card(id,dis,t,deptid,level_id,cid) ,m_display_old(dis) { select_tool_manage::instance()->create_tool(type,m_sel_tool,m_smo_tool); m_his_location_card.reset(new location_card(m_id,m_type,cid)); } void card_location_base::do_status(int st) { time_t now=time(0); bool help_flag=false; if((m_help_bit & 1) && (st & STATUS_HELP)) { // 1111111111 // ^ m_help_last_time=now; } else if((m_help_bit & 1) && (st & STATUS_HELP)==0) { // 11111111100000 // ^ m_help_bit<<=1; } else if((m_help_bit & 1)==0 && (st & STATUS_HELP)) { // 00000000011111 // ^ if((m_help_bit&0x3)==2) { log_warn("handle_m_help,card_id:%d\n",m_id); help_flag=true; } m_help_last_time=now; m_help_bit<<=1; m_help_bit|=1; } else { // 11111111100000 // ^ if(now-m_help_last_time>60) { m_help_bit=0; } } if(!help_flag) { st = st & (0xFFFFFFFF ^ STATUS_HELP); } if((STATUS_POWER_LOWER_SERIOUS & st) != 0) { m_pwr_stat=STATUS_POWER_LOWER_SERIOUS; } else { m_pwr_stat=0; } module_mgr::do_status((STATUS_CARD)st, m_id, m_type); } void card_location_base::make_his_location(uint64_t t,const point & pt,bool bclose /*= false*/) { int area_id=0,map_id=0,site_id=0; if(auto site_ptr=get_area_tool()->m_site) { area_id=site_ptr->m_area_id; map_id=site_ptr->m_map_id; site_id=site_ptr->m_id; } m_his_location_card->push(t,pt,area_id,map_id,site_id,bclose); } void card_location_base::on_location(const std::vector&vp,const std::vector &lm ) { loc_point pt = m_sel_tool->select_solution(vp,lm); pt.y=-pt.y; auto site_ptr=get_area_tool()->m_site; int sid=0; if(site_ptr)sid=site_ptr->m_id; if(pt.m_useless) { x = tool_other::round(pt.x,3); y = tool_other::round(pt.y,3); double acc = lm[0].m_acc; m_acc = lm[0].m_acc; log_info("useful:type:%d,card_id:%d,site:%d,ct:%d,timestamp:%llu, loc_point,x:%f,y:%f acc:%.2f",m_type,m_id,sid,m_ct,m_time,x,y,acc); do_business(lm.front().m_sit, pt, acc); } else { log_warn("坐标不可用:site_id:%d,type:%d,card_id:%d,ct:%d,x:%f,y:%f",sid,m_type,m_id,m_ct,pt.x,pt.y); } } void card_location_base::on_message(zloop * loop,const message_locinfo&loc,bool is_history) { m_ct = loc.m_card_ct; m_time = loc.m_time_stamp; auto site_ptr = sit_list::instance()->get(loc.m_site_id); if(!site_ptr) { log_warn("接收到分站%d的数据,CARD=%d, CT=%d,但是分站未定义",loc.m_site_id,m_id,loc.m_card_ct); return; } auto area_tool=get_area_tool(); area_tool->set_site(site_ptr); if(site_ptr->is_up_site()) { log_info("%d被井上分站[%d]收到",m_id,site_ptr->id()); area_tool->on_point(shared_from_this(),point(1,1)); this->site_hover(loc.m_site_id); } else { if(site_ptr->is_path_empty()) { log_warn("接收到分站%d的数据,CT=%d,但是分站路径为空",site_ptr->id(),loc.m_card_ct); } m_message_handle->on_message(loop,loc,is_history); } } struct ld_1318 { ld_1318(double a,double b,double c) :x(a) ,y(b) ,speed(c) {} double x; double y; double speed; }; //前端推送位置函数. void card_location_base::upt_card_pos(YA::_CARD_POS_&cp, point &pt) { // YA::_CARD_POS_ cp; point _p; if(pt.empty()) { _p=*this;pt=_p; } else _p=pt; //cp.z = pt.z; cp.Type=m_type; cp.ID = m_id; // if(m_type==4 && m_id==1318) // { // static std::list list_1318; // if(list_1318.size()>=60) // { // double tx=0,ty=0,ts=0; // std::for_each(list_1318.begin(),list_1318.end(),[&tx,&ty,&ts](const ld_1318& ld){ // tx+=ld.x;ty=ld.y;ts+=ld.speed; // }); // size_t n=list_1318.size(); // tx/=n;ts/=n; // _p.set(tx,ty,0); // cp.speed = ts; // list_1318.pop_front(); // log_info("get_speed:%d (%f,%f), %f",m_id,tx,ty,ts); // } // else // _p=*this; // double speed = abs((int)(m_speed*10000)/10000.); // list_1318.emplace_back(x,y,speed); // } // else cp.speed = abs(ceil(m_speed)); cp.x = tool_other::round(_p.x,3); cp.y = tool_other::round(_p.y,3); cp.running_stat = m_stat; cp.dept_id = m_deptid; cp.display=m_display; cp.rec_time=m_time; cp.level_id = m_level_id; cp.stat=m_pwr_stat; swsTimerThrd.upt_card_pos(cp); } void card_location_base::del_card_pos() { YA::_CARD_POS_ cp; cp.ID = m_id; cp.Type=m_type; swsTimerThrd.del_card_pos(cp); } int card_location_base::get_stat() { //盲区>呼救>呼叫>超时>超速>正常 uint64_t now = time(0)*1000; uint64_t tlost=now>m_time?now-m_time:m_time-now; log_info("card_lost:%03d%010d,[%lu-%lu]tlost:%lu---%s",m_type,m_id,now,m_time,tlost,tlost>CARD_LOST_TIME_OUT?"True":"False"); if(tlost>CARD_LOST_TIME_OUT) { return STATUS_LOST; } else if(auto ev_ptr = event_list::instance()->get_event_card(m_id, m_type, ET_CARD_HELP)) { return (ES_DEAL_HELP == ev_ptr->m_status) ? STATUS_HELP_DEALED : STATUS_HELP; } else if(CALL_NONE != get_mine_tool()->m_status_call) { return STATUS_CALL; } else if(is_person()) { if(event_list::instance()->get_event_card(m_id, m_type,ET_CARD_AREA_OVER_TIME_PERSON)|| event_list::instance()->get_event_card(m_id, m_type,ET_CARD_OVER_TIME_PERSON)) return STATUS_AREA_OVER_TIME; } else if(event_list::instance()->get_event_card(m_id, m_type, ET_CARD_OVER_SPEED)) { return STATUS_OVER_SPEED; } return STATUS_NORMAL; } void card_location_base::clear() { // uint16_t m_display; //1显示0不显示,往前端推送 m_speed=0; //速度 m_stat=0; //运动静止状态 //m_ct; //ct m_time=0; //时间戳 } void card_location_base::put_three_rates(card_pos & cp) { if(!three_rates_flag)return; cp.rec_time=m_time;cp.type=m_type;cp.id=m_id; cp.identifier_id=m_cid;cp.running_stat=m_stat;cp.final_v=m_speed; cp.dpt_id = m_deptid; std::shared_ptr _areatool = get_area_tool(); if(nullptr != _areatool && nullptr != _areatool->m_site) { cp.reader_x = _areatool->m_site->x; cp.reader_y = _areatool->m_site->y; cp.reader_id = _areatool->m_site->m_id; } log_info("three_rates:type:%d,id:%d,cid:%d",cp.type,cp.id,cp.identifier_id); three_rates::get_instance()->put(cp); } bool card_location_base::is_person() const { return tool_other::is_person(m_type); } bool card_location_base::is_vehicle() const { return tool_other::is_vehicle(m_type); } void card_location_base::set_base_data(uint32_t cid,uint16_t type,uint32_t deptid,int32_t level_id) { m_cid=cid;m_type=type;m_deptid=deptid;m_level_id=level_id; m_his_location_card->set_cid(cid); } card_location_base::~card_location_base() { } std::shared_ptr card_location_base::make_person(const std::string&type,uint32_t cardid,uint16_t needdisplay,int16_t t, int32_t deptid,int32_t level_id,uint32_t cid,int wl,const std::string &sname,const std::string & dname,int worktype_id) { return std::make_shared(type,cardid,needdisplay,t, deptid,level_id,cid,wl,sname,dname,worktype_id); } std::shared_ptr card_location_base::make_car(const std::string&type,uint32_t cardid,uint16_t needdisplay,int16_t t, int32_t deptid, int32_t categoryid, int type_id,int32_t level_id,uint32_t cid) { return std::make_shared(type,cardid,needdisplay,t, deptid, categoryid, type_id,level_id,cid); }