rospy节点一边接收topic,一边将topic数据可视化

2023-11-11 21:20

本文主要是介绍rospy节点一边接收topic,一边将topic数据可视化,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

如果想要matplotlib动态更新画图,只能将matplotlib放在主线程中,如果放进子线程,就会报这个错

ValueError: set_wakeup_fd only works in main thread

但是如果要订阅ros的topic,主线程会被阻塞,matplotlib无法动态更新。

因此,通过将matplotlib嵌入tkinter中,实现一边订阅topic,一边动态更新画图

import math
import rospy
import message_filters
import tkinter as tk
from matplotlib.figure import Figure
from matplotlib.backends.backend_tkagg import FigureCanvasTkAgg
from my_pkg.msg import MyArrayMessageclass ROS_Tkinter_App:def __init__(self, master):self.master = mastermaster.title("ROS Tkinter App")# Matplotlib setup for scatter plotself.figure = Figure(figsize=(10, 8), dpi=100)self.scatter_plot = self.figure.add_subplot(111)self.scatter_plot.set_title('Scatter Plot')self.canvas = FigureCanvasTkAgg(self.figure, master=master)self.canvas.get_tk_widget().pack()# ROS Initializationrospy.init_node('ros_tkinter_app', anonymous=True)# Define subscribers for the two topicssub_topic1 = message_filters.Subscriber("/global_path", MyArrayMessage)sub_topic2 = message_filters.Subscriber("/vehicle_position", MyArrayMessage)# Synchronize the subscribers using ApproximateTimeSynchronizerts = message_filters.ApproximateTimeSynchronizer([sub_topic1, sub_topic2], queue_size=10, slop=0.1)ts.registerCallback(self.callback)# Bind the update_plot_size function to the <Configure> event# master.bind("<Configure>", self.update_plot_size)def callback(self, data1, data2):# This method will be called when a new message is received on the /ros_topicrospy.loginfo("ROS Topic Data")# 这里处理topic内的数据# Update scatter plot with new dataself.update_scatter_plot(Target_Angle, Center_y, Center_x, waypoints_y, waypoints_x)  # Assuming the data is a float, update accordinglydef update_scatter_plot(self, angle_radians, Center_x, Center_y, waypoints_x, waypoints_y):# Update the scatter plot with new dataself.scatter_plot.clear()self.scatter_plot.set_title('Scatter Plot')self.scatter_plot.scatter(Center_x, Center_y, color='red', marker='o', label='Center Point')self.scatter_plot.plot([Center_x, end_x], [Center_y, end_y], color='blue', linestyle='--', label='Line Segment')self.scatter_plot.scatter(waypoints_x, waypoints_y, color='green', marker='o', label='Waypoint')# 设置x轴和y轴的显示范围self.scatter_plot.set_xlim(-100, 100)  # 设置x轴的范围self.scatter_plot.set_ylim(-100, 100)  # 设置y轴的范围# 设置 x 轴和 y 轴的相同比例尺self.scatter_plot.set_aspect('equal')# 设置坐标轴标签self.scatter_plot.set_xlabel('CARLA Y Axis')self.scatter_plot.set_ylabel('CARLA X Axis')self.canvas.draw()def update_plot_size(self, event):# Update the plot size based on the new window sizenew_width = event.width / self.canvas.figure.get_dpi()new_height = event.height / self.canvas.figure.get_dpi()self.figure.set_size_inches(new_width, new_height)self.canvas.draw()def main():root = tk.Tk()app = ROS_Tkinter_App(root)root.mainloop()if __name__ == '__main__':main()

这篇关于rospy节点一边接收topic,一边将topic数据可视化的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/392885

相关文章

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

使用SpringBoot整合Sharding Sphere实现数据脱敏的示例

《使用SpringBoot整合ShardingSphere实现数据脱敏的示例》ApacheShardingSphere数据脱敏模块,通过SQL拦截与改写实现敏感信息加密存储,解决手动处理繁琐及系统改... 目录痛点一:痛点二:脱敏配置Quick Start——Spring 显示配置:1.引入依赖2.创建脱敏

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

Python数据分析与可视化的全面指南(从数据清洗到图表呈现)

《Python数据分析与可视化的全面指南(从数据清洗到图表呈现)》Python是数据分析与可视化领域中最受欢迎的编程语言之一,凭借其丰富的库和工具,Python能够帮助我们快速处理、分析数据并生成高质... 目录一、数据采集与初步探索二、数据清洗的七种武器1. 缺失值处理策略2. 异常值检测与修正3. 数据

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=

C#代码实现解析WTGPS和BD数据

《C#代码实现解析WTGPS和BD数据》在现代的导航与定位应用中,准确解析GPS和北斗(BD)等卫星定位数据至关重要,本文将使用C#语言实现解析WTGPS和BD数据,需要的可以了解下... 目录一、代码结构概览1. 核心解析方法2. 位置信息解析3. 经纬度转换方法4. 日期和时间戳解析5. 辅助方法二、L

使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)

《使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)》字体设计和矢量图形处理是编程中一个有趣且实用的领域,通过Python的matplotlib库,我们可以轻松将字体轮廓... 目录背景知识字体轮廓的表示实现步骤1. 安装依赖库2. 准备数据3. 解析路径指令4. 绘制图形关键

解决mysql插入数据锁等待超时报错:Lock wait timeout exceeded;try restarting transaction

《解决mysql插入数据锁等待超时报错:Lockwaittimeoutexceeded;tryrestartingtransaction》:本文主要介绍解决mysql插入数据锁等待超时报... 目录报错信息解决办法1、数据库中执行如下sql2、再到 INNODB_TRX 事务表中查看总结报错信息Lock

使用C#删除Excel表格中的重复行数据的代码详解

《使用C#删除Excel表格中的重复行数据的代码详解》重复行是指在Excel表格中完全相同的多行数据,删除这些重复行至关重要,因为它们不仅会干扰数据分析,还可能导致错误的决策和结论,所以本文给大家介绍... 目录简介使用工具C# 删除Excel工作表中的重复行语法工作原理实现代码C# 删除指定Excel单元