laser_task_command.h 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. //laser_task_command,是雷达任务指令的相关功能
  2. //功能:用作应用层向laser模块传输任务,的指令消息
  3. //用法:应用层直接调用laser的接口函数,并将Laser_task类作为参数传递
  4. //CLaser类则按照Laser_task的功能码和指定的参数,执行相应的功能
  5. //并将结果填充到Laser_task,返回给应用层
  6. #ifndef __LASER_TASK_COMMAND__HH__
  7. #define __LASER_TASK_COMMAND__HH__
  8. #include "Point2D.h"
  9. #include "Point3D.h"
  10. #include "../error_code/error_code.h"
  11. #include <vector>
  12. #include "../task/task_command_manager.h"
  13. //雷达模块的任务指令,从Task_Base继承,
  14. //补充了雷达专属的数据输入和输出
  15. class Laser_task:public Task_Base
  16. {
  17. public:
  18. //构造函数
  19. Laser_task();
  20. //析构函数
  21. ~Laser_task();
  22. //初始化任务单,必须初始化之后才可以使用,(必选参数)
  23. //input:task_type 任务类型
  24. // input:task_statu任务状态
  25. // output:p_task_point3d_cloud_vector三维点云容器指针
  26. //注:task_points_number默认为0,如果为0,则使用laser默认的点云的采集数量
  27. Error_manager task_init(Task_type task_type,
  28. Task_statu task_statu,
  29. std::vector<CPoint3D> * p_task_point3d_cloud_vector);
  30. //初始化任务单,必须初始化之后才可以使用,(可选参数)
  31. // input:task_type 任务类型
  32. // input:task_statu任务状态
  33. // input:task_statu_information状态说明
  34. // input:task_points_number点云的采集数量
  35. // output:p_task_point3d_cloud_vector三维点云容器指针
  36. //注:task_points_number默认为0,如果为0,则使用laser默认的点云的采集数量
  37. Error_manager task_init(Task_type task_type,
  38. Task_statu task_statu,
  39. std::string & task_statu_information,
  40. int task_points_number,
  41. std::vector<CPoint3D> * p_task_point3d_cloud_vector);
  42. //获取 点云的采集数量
  43. int get_task_points_number();
  44. //获取 三维点云容器
  45. std::vector<CPoint3D> * get_task_point3d_cloud_vector();
  46. //获取 错误码
  47. Error_manager get_task_error_manager();
  48. //设置 任务状态
  49. void set_task_statu(Task_statu task_statu);
  50. //设置 任务状态说明
  51. void set_task_statu_information(std::string & task_statu_information);
  52. //设置 点云的采集数量
  53. void set_task_points_number(int task_points_number);
  54. //设置 三维点云容器
  55. void set_task_point3d_cloud_vector(std::vector<CPoint3D> * p_task_point3d_cloud_vector);
  56. //设置 错误码
  57. void set_task_error_manager(Error_manager & error_manager);
  58. protected:
  59. //点云的采集数量,任务输入
  60. int m_task_points_number;
  61. //采集结果,三维点云容器,任务输出
  62. //这里只是指针,实际内存由应用层管理,初始化时必须保证内存有效。
  63. std::vector<CPoint3D> * pm_task_point3d_cloud_vector;
  64. //错误码,任务故障信息,任务输出
  65. Error_manager m_task_error_manager;
  66. };
  67. #endif //__LASER_TASK_COMMAND__HH__