card_base.h 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. #ifndef _CARD_BASE_HPP_
  2. #define _CARD_BASE_HPP_
  3. #include <vector>
  4. #include <memory>
  5. #include <atomic>
  6. #include "point.h"
  7. #include "common.h"
  8. #define CARD_LOST_TIME_OUT (60*1000)
  9. struct task;
  10. template<typename T> struct zloop;
  11. struct select_tool;
  12. struct smooth_tool;
  13. struct monkey_person;
  14. struct card_message_handle;
  15. struct card_location_base;
  16. struct message_locinfo;
  17. struct loc_message;
  18. struct mine_tool;
  19. struct location_card;
  20. struct card_pos;
  21. struct area_hover;
  22. struct site_area_hover;
  23. struct site;
  24. struct area_tool;
  25. struct message_tdoa_locinfo;
  26. struct message_pdoa_locinfo;
  27. namespace YA{struct _CARD_POS_;}
  28. struct card:point
  29. {
  30. card(uint32_t id,uint16_t dis,uint64_t type,int32_t deptid,int32_t level_id,uint32_t cid)
  31. :m_type(type)
  32. ,m_time(0)
  33. ,m_id(id)
  34. ,m_cid(cid)
  35. ,m_deptid(deptid)
  36. ,m_level_id(level_id)
  37. ,m_stat(0)
  38. ,m_biz_stat(0)
  39. ,m_pwr_stat(0)
  40. ,m_display(dis)
  41. ,m_ct(0)
  42. ,m_freq_id(0)
  43. ,m_freq(0.0)
  44. ,m_acc(0)
  45. ,m_speed(0)
  46. {}
  47. uint64_t type_(){return m_type;}
  48. uint64_t time_(){return m_time;}
  49. uint64_t m_type; //类型
  50. uint64_t m_time; //时间戳 ms
  51. uint32_t m_id; //卡号
  52. uint32_t m_cid; //标识id 人staff_id 车 vehicle_id
  53. int32_t m_deptid; //部门编号
  54. int32_t m_level_id; //职务级别
  55. int m_stat; //运动静止状态
  56. int m_biz_stat;
  57. int m_pwr_stat; //电量状态
  58. uint16_t m_display; //1显示0不显示,往前端推送
  59. uint16_t m_ct; //ct
  60. uint8_t m_freq_id; // 频率索引
  61. double m_freq; // 频率值
  62. ///人卡(加速度状态),其值就是0和1,掘进机和采煤机,其值就是0~255,车辆,其值就需要乘以0.01,用于表示加速度值
  63. double m_acc;
  64. double m_speed; //速度
  65. };
  66. struct card_location_base:card,std::enable_shared_from_this<card_location_base>
  67. {
  68. uint64_t m_timeval=0;
  69. uint16_t m_display_old{0}; //1显示0不显示,往前端推送
  70. void update_display(){m_display_old=m_display;}
  71. bool eq_display(){return m_display_old==m_display;}
  72. std::uint8_t m_event[CARD_EVENT_COUNT_MAX]{0};
  73. std::unique_ptr<select_tool> m_sel_tool;
  74. std::unique_ptr<smooth_tool> m_smo_tool;
  75. std::unique_ptr<card_message_handle> m_message_handle;
  76. std::unique_ptr<location_card> m_his_location_card;
  77. std::atomic<int> m_upmine_flag{0};
  78. time_t m_help_last_time=0;
  79. int m_help_bit=0;
  80. card_location_base()=default;
  81. card_location_base(const std::string&type,uint32_t id,uint16_t dis,int16_t t,int32_t,int32_t,uint32_t );
  82. void inc_upmine_flag(int flag){m_upmine_flag=flag;}
  83. int upmine_flag(){return m_upmine_flag.load();}
  84. virtual void do_business(const std::shared_ptr<site>&site,const point &pt,double acc)=0;
  85. virtual void on_timer()=0;
  86. virtual std::shared_ptr<mine_tool> get_mine_tool()=0;
  87. virtual void clear();
  88. virtual void reset(std::shared_ptr<monkey_person> mp){}
  89. virtual int get_vehicle_type_id(){return 0;}
  90. virtual void set_area_info(int mapid,double scale,int areaid,uint64_t t,int type)=0;
  91. virtual int get_area(){return -1;}
  92. virtual std::shared_ptr<area_tool> get_area_tool()=0;
  93. virtual int get_vehicle_category_id(){return -1;}
  94. virtual int get_workline(){return -1;}
  95. virtual void get_card(bool f)=0;
  96. virtual void site_hover(int sid){}
  97. virtual void handle_message(uint16_t ct,uint8_t& value){}
  98. void make_his_location(uint64_t t,const point & pt,bool bclose = false);
  99. void on_message(zloop<task*>* loop, message_locinfo&loc, bool is_history);
  100. void on_message(zloop<task*>* loop, message_tdoa_locinfo& loc, bool is_history);
  101. void on_message(zloop<task*>* loop, message_pdoa_locinfo& loc, bool is_history);
  102. void on_location(const std::vector<point>&vp,const std::vector<loc_message> &lm );
  103. void do_status(int st);
  104. void upt_card_pos(YA::_CARD_POS_&cp, point &pt);
  105. void del_card_pos();
  106. int get_stat();
  107. void put_three_rates(card_pos &);
  108. void set_event_flag(EVENT_TYPE et,std::uint8_t f=1){m_event[et]=f;}
  109. bool get_event_flag(EVENT_TYPE et){return m_event[et];}
  110. bool is_person() const;
  111. bool is_vehicle() const;
  112. void set_base_data(uint32_t cid,uint16_t type,uint32_t deptid,int32_t level_id);
  113. virtual ~card_location_base();
  114. static std::shared_ptr<card_location_base> make_person(const std::string&type,uint32_t cardid,uint16_t needdisplay,int16_t t,
  115. int32_t deptid,int32_t level_id,uint32_t cid,int wl,const std::string & sname,const std::string & dname,int worktype_id);
  116. static std::shared_ptr<card_location_base> make_car(const std::string&type,uint32_t cardid,uint16_t needdisplay,int16_t t,
  117. int32_t deptid, int32_t categoryid, int type_id,int32_t level_id,uint32_t cid);
  118. void set_freq_id(const uint8_t& val)
  119. {
  120. m_freq_id = val;
  121. }
  122. };
  123. #endif