152 lines
4.6 KiB
C++
152 lines
4.6 KiB
C++
#pragma once
|
|
#include <ros/ros.h>
|
|
#include <sensor_msgs/NavSatFix.h>
|
|
#include "mavros_msgs/GlobalPositionTarget.h"
|
|
#include "mavros_msgs/CommandCode.h"
|
|
#include "mavros_msgs/CommandInt.h"
|
|
#include "mavros_msgs/CommandLong.h"
|
|
#include "mavros_msgs/CommandBool.h"
|
|
#include "mavros_msgs/ExtendedState.h"
|
|
#include "mavros_msgs/SetMode.h"
|
|
#include "mavros_msgs/State.h"
|
|
#include "mavros_msgs/BatteryStatus.h"
|
|
#include "mavros_msgs/Mavlink.h"
|
|
#include "sensor_msgs/NavSatStatus.h"
|
|
#include <sensor_msgs/LaserScan.h>
|
|
#include <rosbuzz/neigh_pos.h>
|
|
#include <sstream>
|
|
#include <buzz/buzzasm.h>
|
|
#include "buzz_utility.h"
|
|
#include "uav_utility.h"
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <math.h>
|
|
#include <signal.h>
|
|
#include <ostream>
|
|
#include <map>
|
|
#include "buzzuav_closures.h"
|
|
|
|
#define UPDATER_MESSAGE_CONSTANT 987654321
|
|
#define XBEE_MESSAGE_CONSTANT 586782343
|
|
#define XBEE_STOP_TRANSMISSION 4355356352
|
|
|
|
using namespace std;
|
|
|
|
namespace rosbzz_node{
|
|
|
|
class roscontroller{
|
|
|
|
public:
|
|
roscontroller(ros::NodeHandle n_c);
|
|
~roscontroller();
|
|
//void RosControllerInit();
|
|
void RosControllerRun();
|
|
|
|
private:
|
|
|
|
double cur_pos[3];
|
|
uint64_t payload;
|
|
std::map< int, buzz_utility::Pos_struct> neighbours_pos_map;
|
|
std::map< int, buzz_utility::Pos_struct> raw_neighbours_pos_map;
|
|
//std::map< int, buzz_utility::Pos_struct> pub_neigh_pos;
|
|
int timer_step=0;
|
|
int robot_id=0;
|
|
//int oldcmdID=0;
|
|
int rc_cmd;
|
|
int barrier;
|
|
std::string bzzfile_name, fcclient_name, rcservice_name,bcfname,dbgfname,out_payload,in_payload,stand_by; //, rcclient;
|
|
bool rcclient;
|
|
bool multi_msg;
|
|
ros::ServiceClient mav_client;
|
|
ros::Publisher payload_pub;
|
|
ros::Publisher neigh_pos_pub;
|
|
ros::ServiceServer service;
|
|
ros::Subscriber current_position_sub;
|
|
ros::Subscriber battery_sub;
|
|
ros::Subscriber payload_sub;
|
|
ros::Subscriber flight_status_sub;
|
|
ros::Subscriber obstacle_sub;
|
|
/*Commands for flight controller*/
|
|
//mavros_msgs::CommandInt cmd_srv;
|
|
mavros_msgs::CommandLong cmd_srv;
|
|
|
|
std::vector<std::string> m_sMySubscriptions;
|
|
std::map<std::string, std::string> m_smTopic_infos;
|
|
|
|
mavros_msgs::CommandBool m_cmdBool;
|
|
ros::ServiceClient arm_client;
|
|
|
|
mavros_msgs::SetMode m_cmdSetMode;
|
|
ros::ServiceClient mode_client;
|
|
|
|
void Initialize_pub_sub(ros::NodeHandle n_c);
|
|
|
|
/*Obtain data from ros parameter server*/
|
|
void Rosparameters_get(ros::NodeHandle n_c);
|
|
|
|
/*compiles buzz script from the specified .bzz file*/
|
|
void Compile_bzz();
|
|
|
|
/*Prepare messages and publish*/
|
|
void prepare_msg_and_publish();
|
|
|
|
|
|
/*Refresh neighbours Position for every ten step*/
|
|
void maintain_pos(int tim_step);
|
|
|
|
/*Puts neighbours position inside neigbours_pos_map*/
|
|
void neighbours_pos_put(int id, buzz_utility::Pos_struct pos_arr );
|
|
|
|
/*Puts raw neighbours position in lat.,long.,alt. inside raw_neigbours_pos_map*/
|
|
void raw_neighbours_pos_put(int id, buzz_utility::Pos_struct pos_arr );
|
|
|
|
/*Set the current position of the robot callback*/
|
|
void set_cur_pos(double latitude,
|
|
double longitude,
|
|
double altitude);
|
|
/*convert from cartesian to spherical coordinate system callback */
|
|
void cvt_spherical_coordinates(double neighbours_pos_payload [], double out[]);
|
|
|
|
/*convert from spherical to cartesian coordinate system callback */
|
|
void cvt_cartesian_coordinates(double neighbours_pos_payload [], double out[]);
|
|
|
|
/*convert from spherical to cartesian coordinate system callback */
|
|
void cvt_rangebearing_coordinates(double neighbours_pos_payload [], double out[], double pos[]);
|
|
|
|
/*convert from spherical to cartesian coordinate system callback */
|
|
void cvt_rangebearingGB_coordinates(double neighbours_pos_payload [], double out[], double pos[]);
|
|
|
|
/*convert from spherical to cartesian coordinate system callback */
|
|
void cvt_rangebearing2D_coordinates(double neighbours_pos_payload [], double out[], double pos[]);
|
|
|
|
/*battery status callback*/
|
|
void battery(const mavros_msgs::BatteryStatus::ConstPtr& msg);
|
|
|
|
/*flight extended status callback*/
|
|
void flight_extended_status_update(const mavros_msgs::ExtendedState::ConstPtr& msg);
|
|
|
|
/*flight status callback*/
|
|
void flight_status_update(const mavros_msgs::State::ConstPtr& msg);
|
|
|
|
/*current position callback*/
|
|
void current_pos(const sensor_msgs::NavSatFix::ConstPtr& msg);
|
|
|
|
/*payload callback callback*/
|
|
void payload_obt(const mavros_msgs::Mavlink::ConstPtr& msg);
|
|
|
|
/* RC commands service */
|
|
bool rc_callback(mavros_msgs::CommandLong::Request &req, mavros_msgs::CommandLong::Response &res);
|
|
|
|
void obstacle_dist(const sensor_msgs::LaserScan::ConstPtr& msg);
|
|
|
|
void GetSubscriptionParameters(ros::NodeHandle node_handle);
|
|
|
|
void Arm();
|
|
|
|
void SetMode();
|
|
|
|
void Subscribe(ros::NodeHandle n_c);
|
|
};
|
|
|
|
}
|