Compare commits

..

2 Commits

Author SHA1 Message Date
594f0fe49e Hiep update 2025-12-30 10:23:19 +07:00
b1aaa1a946 HiepLM update 2025-12-30 09:07:01 +07:00
3 changed files with 47 additions and 17 deletions

View File

@@ -5,6 +5,10 @@ set(CMAKE_CXX_STANDARD 17)
add_library(data_convert INTERFACE)
target_link_libraries(data_convert INTERFACE
robot_geometry_msgs
)
target_include_directories(data_convert
INTERFACE
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>

View File

@@ -1,10 +1,10 @@
#ifndef COSTMAP_2D_DATA_CONVERT_H
#define COSTMAP_2D_DATA_CONVERT_H
#include <geometry_msgs/TransformStamped.h>
#include <geometry_msgs/Quaternion.h>
#include <geometry_msgs/Pose.h>
#include <geometry_msgs/PoseStamped.h>
#include <robot_geometry_msgs/TransformStamped.h>
#include <robot_geometry_msgs/Quaternion.h>
#include <robot_geometry_msgs/Pose.h>
#include <robot_geometry_msgs/PoseStamped.h>
#include <tf3/utils.h>
#include <tf3/compat.h>
#include <robot/time.h>
@@ -12,16 +12,16 @@
namespace data_convert
{
inline double getYaw(const geometry_msgs::Quaternion& q)
inline double getYaw(const robot_geometry_msgs::Quaternion& q)
{
double siny_cosp = 2.0 * (q.w * q.z + q.x * q.y);
double cosy_cosp = 1.0 - 2.0 * (q.y * q.y + q.z * q.z);
return std::atan2(siny_cosp, cosy_cosp);
}
inline geometry_msgs::Quaternion getQuaternion(const double& yaw)
inline robot_geometry_msgs::Quaternion getQuaternion(const double& yaw)
{
geometry_msgs::Quaternion q;
robot_geometry_msgs::Quaternion q;
q.x = 0.0;
q.y = 0.0;
q.z = std::sin(yaw / 2.0);
@@ -45,15 +45,15 @@ namespace data_convert
return time_tmp;
}
inline tf3::Quaternion convertQuaternion(const geometry_msgs::Quaternion& q)
inline tf3::Quaternion convertQuaternion(const robot_geometry_msgs::Quaternion& q)
{
tf3::Quaternion out(q.x,q.y,q.z,q.w);
return out;
}
inline geometry_msgs::Quaternion convertQuaternion(const tf3::Quaternion& q)
inline robot_geometry_msgs::Quaternion convertQuaternion(const tf3::Quaternion& q)
{
geometry_msgs::Quaternion out;
robot_geometry_msgs::Quaternion out;
out.x = q.x();
out.y = q.y();
out.z = q.z();
@@ -61,12 +61,12 @@ namespace data_convert
return out;
}
inline geometry_msgs::Quaternion createQuaternionMsgFromYaw(const double& yaw)
inline robot_geometry_msgs::Quaternion createQuaternionMsgFromYaw(const double& yaw)
{
tf3::Quaternion q;
q.setRPY(0.0, 0.0, yaw);
geometry_msgs::Quaternion q_msg;
robot_geometry_msgs::Quaternion q_msg;
q_msg.x = q.x();
q_msg.y = q.y();
q_msg.z = q.z();
@@ -75,7 +75,7 @@ namespace data_convert
return q_msg;
}
inline tf3::Transform convertTotf3Transform(const geometry_msgs::Transform& msg)
inline tf3::Transform convertTotf3Transform(const robot_geometry_msgs::Transform& msg)
{
tf3::Quaternion q(
msg.rotation.x,
@@ -134,7 +134,7 @@ namespace data_convert
return out;
}
inline tf3::Transform convertTotf3Transform(const geometry_msgs::TransformStamped& msg)
inline tf3::Transform convertTotf3Transform(const robot_geometry_msgs::TransformStamped& msg)
{
tf3::Transform out;
@@ -155,7 +155,7 @@ namespace data_convert
return out;
}
inline tf3::TransformStampedMsg convertToTransformStampedMsg(const geometry_msgs::TransformStamped& msg)
inline tf3::TransformStampedMsg convertToTransformStampedMsg(const robot_geometry_msgs::TransformStamped& msg)
{
tf3::TransformStampedMsg out;
out.header.seq = msg.header.seq;
@@ -172,9 +172,9 @@ namespace data_convert
return out;
}
inline geometry_msgs::TransformStamped convertToTransformStamped(const tf3::TransformStampedMsg& msg)
inline robot_geometry_msgs::TransformStamped convertToTransformStamped(const tf3::TransformStampedMsg& msg)
{
geometry_msgs::TransformStamped out;
robot_geometry_msgs::TransformStamped out;
out.header.seq = msg.header.seq;
out.header.stamp = convertTime(msg.header.stamp);
out.header.frame_id = msg.header.frame_id;

26
package.xml Normal file
View File

@@ -0,0 +1,26 @@
<package>
<name>data_convert</name>
<version>0.7.10</version>
<description>
data_convert is the second generation of the transform library, which lets
the user keep track of multiple coordinate frames over time. data_convert
maintains the relationship between coordinate frames in a tree
structure buffered in time, and lets the user transform points,
vectors, etc between any two coordinate frames at any desired
point in time.
</description>
<author>Tully Foote</author>
<author>Eitan Marder-Eppstein</author>
<author>Wim Meeussen</author>
<maintainer email="tfoote@osrfoundation.org">Tully Foote</maintainer>
<license>BSD</license>
<url type="website">http://www.ros.org/wiki/data_convert</url>
<buildtool_depend version_gte="0.5.68">catkin</buildtool_depend>
<build_depend>libconsole-bridge-dev</build_depend>
<run_depend>libconsole-bridge-dev</run_depend>
</package>