40 #include <QMouseEvent> 44 #include <opencv2/core/core.hpp> 46 #include <geometry_msgs/Point32.h> 47 #include <geometry_msgs/PolygonStamped.h> 60 DrawPolygonPlugin::DrawPolygonPlugin() :
61 config_widget_(new QWidget()),
64 is_mouse_down_(false),
65 max_ms_(Q_INT64_C(500)),
70 ui_.color->setColor(Qt::green);
73 p.setColor(QPalette::Background, Qt::white);
76 QPalette p3(
ui_.status->palette());
77 p3.setColor(QPalette::Text, Qt::red);
78 ui_.status->setPalette(p3);
80 QObject::connect(
ui_.selectframe, SIGNAL(clicked()),
this,
82 QObject::connect(
ui_.frame, SIGNAL(editingFinished()),
this,
84 QObject::connect(
ui_.publish, SIGNAL(clicked()),
this,
86 QObject::connect(
ui_.clear, SIGNAL(clicked()),
this,
103 ui_.frame->setText(QString::fromStdString(frame));
127 geometry_msgs::PolygonStamped polygon;
129 polygon.header.frame_id =
ui_.frame->text().toStdString();
133 geometry_msgs::Point32 point;
134 point.x = vertex.x();
135 point.y = vertex.y();
137 polygon.polygon.points.push_back(point);
182 switch (event->type())
184 case QEvent::MouseButtonPress:
186 case QEvent::MouseButtonRelease:
188 case QEvent::MouseMove:
198 int closest_point = 0;
199 double closest_distance = std::numeric_limits<double>::max();
201 QPointF point =
event->localPos();
203 std::string frame =
ui_.frame->text().toStdString();
206 for (
size_t i = 0; i <
vertices_.size(); i++)
209 vertex = transform * vertex;
213 double distance = QLineF(transformed, point).length();
215 if (distance < closest_distance)
217 closest_distance = distance;
218 closest_point =
static_cast<int>(i);
223 if (event->button() == Qt::LeftButton)
225 if (closest_distance < 15)
238 else if (event->button() == Qt::RightButton)
240 if (closest_distance < 15)
253 std::string frame =
ui_.frame->text().toStdString();
256 QPointF point =
event->localPos();
261 tf::Vector3 position(transformed.x(), transformed.y(), 0.0);
262 position = transform * position;
281 QPointF point =
event->localPos();
285 ROS_INFO(
"mouse point at %f, %f -> %f, %f", point.x(), point.y(), transformed.x(), transformed.y());
288 tf::Vector3 position(transformed.x(), transformed.y(), 0.0);
292 position = transform * position;
295 ROS_INFO(
"Adding vertex at %lf, %lf %s", position.x(), position.y(), frame.c_str());
308 QPointF point =
event->localPos();
310 std::string frame =
ui_.frame->text().toStdString();
314 tf::Vector3 position(transformed.x(), transformed.y(), 0.0);
315 position = transform * position;
328 std::string frame =
ui_.frame->text().toStdString();
335 for (
size_t i = 0; i <
vertices_.size(); i++)
341 const QColor color =
ui_.color->color();
342 glColor4d(color.redF(), color.greenF(), color.blueF(), 1.0);
343 glBegin(GL_LINE_STRIP);
347 glVertex2d(vertex.x(), vertex.y());
354 glColor4d(color.redF(), color.greenF(), color.blueF(), 0.25);
356 if (transformed_vertices_.size() > 2)
358 glVertex2d(transformed_vertices_.front().x(), transformed_vertices_.front().y());
359 glVertex2d(transformed_vertices_.back().x(), transformed_vertices_.back().y());
368 for (
const auto& vertex: transformed_vertices_)
370 glVertex2d(vertex.x(), vertex.y());
384 ui_.frame->setText(source_frame_.c_str());
387 if (node[
"polygon_topic"])
389 std::string polygon_topic;
390 node[
"polygon_topic"] >> polygon_topic;
391 ui_.topic->setText(polygon_topic.c_str());
396 node[
"color"] >> color;
397 ui_.color->setColor(QColor(color.c_str()));
403 std::string frame =
ui_.frame->text().toStdString();
404 emitter << YAML::Key <<
"frame" << YAML::Value << frame;
406 std::string polygon_topic =
ui_.topic->text().toStdString();
407 emitter << YAML::Key <<
"polygon_topic" << YAML::Value << polygon_topic;
409 std::string color =
ui_.color->color().name().toStdString();
410 emitter << YAML::Key <<
"color" << YAML::Value << color;
ros::Publisher polygon_pub_
void SaveConfig(YAML::Emitter &emitter, const std::string &path)
QPointF MapGlCoordToFixedFrame(const QPointF &point)
std::string polygon_topic_
swri_transform_util::TransformManager tf_manager_
void publish(const boost::shared_ptr< M > &message) const
void transform(Route &route, const swri_transform_util::Transform &transform, const std::string &target_frame)
bool handleMousePress(QMouseEvent *)
bool handleMouseRelease(QMouseEvent *)
void PrintWarning(const std::string &message)
std::vector< tf::Vector3 > transformed_vertices_
void LoadConfig(const YAML::Node &node, const std::string &path)
static void PrintWarningHelper(QLabel *status_label, const std::string &message, double throttle=0.0)
bool Initialize(QGLWidget *canvas)
static void PrintErrorHelper(QLabel *status_label, const std::string &message, double throttle=0.0)
void PrintInfo(const std::string &message)
TFSIMD_FORCE_INLINE tfScalar distance(const Vector3 &v) const
std::string target_frame_
Ui::draw_polygon_config ui_
static void PrintInfoHelper(QLabel *status_label, const std::string &message, double throttle=0.0)
std::string source_frame_
void PrintError(const std::string &message)
QWidget * GetConfigWidget(QWidget *parent)
QPointF FixedFrameToMapGlCoord(const QPointF &point)
Publisher advertise(const std::string &topic, uint32_t queue_size, bool latch=false)
std::vector< tf::Vector3 > vertices_
boost::shared_ptr< tf::TransformListener > tf_
virtual ~DrawPolygonPlugin()
bool eventFilter(QObject *object, QEvent *event)
#define PLUGINLIB_EXPORT_CLASS(class_type, base_class_type)
void Draw(double x, double y, double scale)
bool handleMouseMove(QMouseEvent *)
mapviz::MapCanvas * map_canvas_