#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 "cardMgr.h" extern config_file config; const static int three_rates_flag=config.get("service.three_rates_flag",0); 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) { select_tool_manage::instance()->create_tool(type,m_sel_tool,m_smo_tool); } 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); } module_mgr::do_status((STATUS_CARD)st, m_id, m_type); } 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; if(pt.m_useless) { x = tool_other::round(pt.x,3); y = tool_other::round(pt.y,3); Msg m; m.type=m_type;m.x=(int)x;m.y=(int)y;m.cmd=CMD_HANDLE;m.cardid=m_type<<32|m_id; cardMgr::instance()->tryPut(m); double acc = lm[0].m_acc; m_acc = lm[0].m_acc; log_info("useful:type:%d,card_id:%d,ct:%d,timestamp:%llu, loc_point,x:%f,y:%f acc:%.2f",m_type,m_id,m_ct,m_time,x,y,acc); do_business(lm.front().m_sit, pt, acc); } else { int sid=0; auto site_ptr=get_area_tool()->m_site; if(site_ptr) { sid=site_ptr->m_id; } 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); } } //前端推送位置函数. 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.x = tool_other::round(_p.x,3); cp.y = tool_other::round(_p.y,3); //cp.z = pt.z; cp.Type=m_type; cp.ID = m_id; cp.speed = abs(ceil(m_speed)); 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; 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); } 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); }