Package symbol

mavros package from mavros repo

libmavconn mavros mavros_extras mavros_msgs

ROS Distro
humble

Package Summary

Tags uav mav mavlink plugin apm px4
Version 2.12.0
License GPLv3
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Description MAVLink to ROS gateway with proxy for Ground Control Station
Checkout URI https://github.com/mavlink/mavros.git
VCS Type git
VCS Version ros2
Last Updated 2025-10-18
Dev Status DEVELOPED
Released RELEASED
Tags uav ros mavlink ros-node mavros mavros-msgs mav plugin apm px4
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

MAVROS -- MAVLink extendable communication node for ROS with proxy for Ground Control Station.

Additional Links

Maintainers

  • Vladimir Ermakov

Authors

  • Vladimir Ermakov

MAVROS

MAVLink extendable communication node for ROS2.

ROS API documentation moved to [wiki.ros.org][wiki].

Features

  • Communication with autopilot via serial port, UDP or TCP (e.g. [PX4 Pro][px4] or [ArduPilot][apm])
  • Internal proxy for Ground Control Station (serial, UDP, TCP)
  • Plugin system for ROS-MAVLink translation
  • Parameter manipulation tool
  • Waypoint manipulation tool
  • PX4Flow support (by [mavros_extras][mrext])
  • OFFBOARD mode support
  • Geographic coordinates conversions.

Limitations

Only for Linux.

This package are dependent on [ros-*-mavlink][mlwiki] build from [mavlink-gbp-release][mlgbp]. It exists in ROS package index and usually updates each month.

Connection URL

Connection defined by URL, you can use any supported type for FCU and GCS.

Supported schemas:

  • Serial: /path/to/serial/device[:baudrate]
  • Serial: serial:///path/to/serial/device[:baudrate][?ids=sysid,compid]
  • Serial with hardware flow control: serial-hwfc:///path/to/serial/device[:baudrate][?ids=sysid,compid]
  • UDP: udp://[bind_host][:port]@[remote_host[:port]][/?ids=sysid,compid]
  • UDP broadcast until GCS discovery: udp-b://[bind_host][:port]@[:port][/?ids=sysid,compid]
  • UDP broadcast (permanent): udp-pb://[bind_host][:port]@[:port][/?ids=sysid,compid]
  • TCP client: tcp://[server_host][:port][/?ids=sysid,compid]
  • TCP server: tcp-l://[bind_host][:port][/?ids=sysid,compid]

Note:

  • Ids from URL overrides value given by system_id & component_id parameters.
  • bind_host - default 0.0.0.0 - i.e. IP4 ANY
  • UDP default ports: 14555 @ 14550
  • UDP remote address updated every time with incoming packet on bind port.
  • TCP default port: 5760

Coordinate frames

MAVROS does translate Aerospace NED frames, used in FCUs to ROS ENU frames and vice-versa. For translate airframe related data we simply apply rotation 180° about ROLL (X) axis. For local we apply 180° about ROLL (X) and 90° about YAW (Z) axes. Please read documents from issue #473 for additional information.

All the conversions are handled in src/lib/ftf_frame_conversions.cpp and src/lib/ftf_quaternion_utils.cpp and tested in test/test_frame_conversions.cpp and test/test_quaternion_utils.cpp respectively.

Related issues: [#49 (outdated)][iss49], [#216 (outdated)][iss216], [#317 (outdated)][iss317], [#319 (outdated)][iss319], [#321 (outdated)][iss321], [#473][iss473]. Documents: [Frame Conversions][iss473rfc], [Mavlink coordinate frames][iss473table].

MAVROS also allows conversion of geodetic and geocentric coordinates through [GeographicLib][geolib] given that:

  • geographic_msgs and NatSatFix.msg require the LLA fields to be filled in WGS-84 datum, meaning that the altitude should be the height above the WGS-84 ellipsoid. For that, a conversion from the height above the geoid (AMSL, considering the egm96 geoid model) to height above the WGS-84 ellipsoid, and vice-versa, is available and used in several plugins;
  • According to ROS REP 105, the earth frame should be propagated in ECEF (Earth-Centered, Earth-Fixed) local coordinates. For that, the functionalities of GeographicLib are used in order to allow conversion from geodetic coordinates to geocentric coordinates;
  • The translation from GPS coordinates to local geocentric coordinates require the definition of a local origin on the map frame, in ECEF, and calculate the offset to it in ENU. All the conversions are supported by GeographicLib classes and methods and implemented in the global_position plugin.

Composite nodes

See also: https://docs.ros.org/en/foxy/Tutorials/Composition.html

mavros::router::Router

This is router node required to support connections to FCU(s), GCS(es) and UAS nodes. The Router allows you to add/remove endpoints on the fly without node restart.

mavros::uas::UAS

This node is a plugin container which manages all protocol plugins. Each plugin is a subnode to this.

Programs

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package mavros

2.12.0 (2025-09-14)

  • launch: fix python format lint
  • cmake: explicit link diagnostic_msgs Fix #2062
  • mission: switch to latched state qos from custom ones
  • include: add common qos profile for latched state topics
  • uncrustify to kilted
  • DDS equivalent of latched topic for gp_origin topic
  • code style fix
  • Contributors: ArielSulton, Bruno Celaries, Vladimir Ermakov

2.11.0 (2025-09-10)

  • launch: load all plugins in uas1

  • test: add second UAS into the same container

  • router: fix copy-paste error in endpoint loading

  • router: fix mavros_node fault introduced by #2053 Fix #2055

  • breaking: support mavlink 2025.9.9 move of AUTOPILOT_VERSION to standard

  • uas: fix old tf2 headers include

  • cmake: disable uncrustify for humble

  • cmake: update for kilted+, possibly break humble

  • regenerate all and uncrustify

  • tools: move scripts to use with uv

  • Update RouterTest for Router parameters post-constructor.

    • Added startup_delay_timer->cancel() to RouterTest::create_node()

    - Created RouterTest::create_node_no_endpoints() for the two unit tests which call Router::set_parameters() to set endpoints.

    - Converterd Router parameter declaration from an inline functional to a standalone function which can be called from RouterTest::Create_node_no_endpoints(), and from the timer in the constructor

  • uncrustify as noted by CI jobs

  • Remove extraneous blank line

  • unrustify code style fixes

  • Put add_on_set_parameters_callback in time-delayed function. Resolves bad_weak_ptr issue when starting router as composable node

  • Update ArduPlane mode 14 from LAND to AVOID_ADSB.

  • Contributors: Aaron Marburg, FAC94, Vladimir Ermakov

2.10.1 (2025-06-06)

  • fix: display topic on service timeout error
  • Fix incorrect macro usage RCLCPP_SMART_PTR_DEFINITIONS eventually is expanding to: #define __RCLCPP_MAKE_UNIQUE_DEFINITION(...) template<typename ... Args> static std::unique_ptr<__VA_ARGS_> make_unique(Args && ... args) { return std::unique_ptr<__VA_ARGS_>(new __VA_ARGS_(std::forward<Args>(args) ...)); } which is incorrect for abstract classes like Endpoint or Plugin RCLCPP_SMART_PTR_DEFINITIONS_NOT_COPYABLE is used instead excluding make_unique functionality
  • Contributors: Emmanuel Ferdman, Mykhailo Kuznietsov

2.10.0 (2025-05-05)

  • extras: fix odid build

  • extras: re-generate all cog scripts

  • mavros: fix indentation

  • Merge branch 'master' into ros2

    * master: 1.20.1 update changelog 1.20.0 update changelog update mavlink dep branch Add missing std_srvs dependency add param to odom plugin add frame_id parameter Fix compile error when compiling with gcc 13

  • 1.20.1

  • update changelog

  • fix spelling error

File truncated at 100 lines see the full file

Launch files

  • launch/apm.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • namespace [default: mavros]
  • launch/multi_uas.launch
      • id [default: 0]
      • fcu_url [default: udp://:14540@127.0.0.1:14580]
      • id [default: 1]
      • fcu_url [default: udp://:14541@127.0.0.1:14581]
  • launch/node.launch
      • fcu_url
      • gcs_url
      • tgt_system
      • tgt_component
      • pluginlists_yaml
      • config_yaml
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • namespace [default: mavros]
  • launch/px4.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • namespace [default: mavros]

Messages

No message files found.

Services

No service files found

Plugins

Recent questions tagged mavros at Robotics Stack Exchange

Package symbol

mavros package from mavros repo

libmavconn mavros mavros_extras mavros_msgs

ROS Distro
jazzy

Package Summary

Tags uav mav mavlink plugin apm px4
Version 2.12.0
License GPLv3
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Description MAVLink to ROS gateway with proxy for Ground Control Station
Checkout URI https://github.com/mavlink/mavros.git
VCS Type git
VCS Version ros2
Last Updated 2025-10-18
Dev Status DEVELOPED
Released RELEASED
Tags uav ros mavlink ros-node mavros mavros-msgs mav plugin apm px4
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

MAVROS -- MAVLink extendable communication node for ROS with proxy for Ground Control Station.

Additional Links

Maintainers

  • Vladimir Ermakov

Authors

  • Vladimir Ermakov

MAVROS

MAVLink extendable communication node for ROS2.

ROS API documentation moved to [wiki.ros.org][wiki].

Features

  • Communication with autopilot via serial port, UDP or TCP (e.g. [PX4 Pro][px4] or [ArduPilot][apm])
  • Internal proxy for Ground Control Station (serial, UDP, TCP)
  • Plugin system for ROS-MAVLink translation
  • Parameter manipulation tool
  • Waypoint manipulation tool
  • PX4Flow support (by [mavros_extras][mrext])
  • OFFBOARD mode support
  • Geographic coordinates conversions.

Limitations

Only for Linux.

This package are dependent on [ros-*-mavlink][mlwiki] build from [mavlink-gbp-release][mlgbp]. It exists in ROS package index and usually updates each month.

Connection URL

Connection defined by URL, you can use any supported type for FCU and GCS.

Supported schemas:

  • Serial: /path/to/serial/device[:baudrate]
  • Serial: serial:///path/to/serial/device[:baudrate][?ids=sysid,compid]
  • Serial with hardware flow control: serial-hwfc:///path/to/serial/device[:baudrate][?ids=sysid,compid]
  • UDP: udp://[bind_host][:port]@[remote_host[:port]][/?ids=sysid,compid]
  • UDP broadcast until GCS discovery: udp-b://[bind_host][:port]@[:port][/?ids=sysid,compid]
  • UDP broadcast (permanent): udp-pb://[bind_host][:port]@[:port][/?ids=sysid,compid]
  • TCP client: tcp://[server_host][:port][/?ids=sysid,compid]
  • TCP server: tcp-l://[bind_host][:port][/?ids=sysid,compid]

Note:

  • Ids from URL overrides value given by system_id & component_id parameters.
  • bind_host - default 0.0.0.0 - i.e. IP4 ANY
  • UDP default ports: 14555 @ 14550
  • UDP remote address updated every time with incoming packet on bind port.
  • TCP default port: 5760

Coordinate frames

MAVROS does translate Aerospace NED frames, used in FCUs to ROS ENU frames and vice-versa. For translate airframe related data we simply apply rotation 180° about ROLL (X) axis. For local we apply 180° about ROLL (X) and 90° about YAW (Z) axes. Please read documents from issue #473 for additional information.

All the conversions are handled in src/lib/ftf_frame_conversions.cpp and src/lib/ftf_quaternion_utils.cpp and tested in test/test_frame_conversions.cpp and test/test_quaternion_utils.cpp respectively.

Related issues: [#49 (outdated)][iss49], [#216 (outdated)][iss216], [#317 (outdated)][iss317], [#319 (outdated)][iss319], [#321 (outdated)][iss321], [#473][iss473]. Documents: [Frame Conversions][iss473rfc], [Mavlink coordinate frames][iss473table].

MAVROS also allows conversion of geodetic and geocentric coordinates through [GeographicLib][geolib] given that:

  • geographic_msgs and NatSatFix.msg require the LLA fields to be filled in WGS-84 datum, meaning that the altitude should be the height above the WGS-84 ellipsoid. For that, a conversion from the height above the geoid (AMSL, considering the egm96 geoid model) to height above the WGS-84 ellipsoid, and vice-versa, is available and used in several plugins;
  • According to ROS REP 105, the earth frame should be propagated in ECEF (Earth-Centered, Earth-Fixed) local coordinates. For that, the functionalities of GeographicLib are used in order to allow conversion from geodetic coordinates to geocentric coordinates;
  • The translation from GPS coordinates to local geocentric coordinates require the definition of a local origin on the map frame, in ECEF, and calculate the offset to it in ENU. All the conversions are supported by GeographicLib classes and methods and implemented in the global_position plugin.

Composite nodes

See also: https://docs.ros.org/en/foxy/Tutorials/Composition.html

mavros::router::Router

This is router node required to support connections to FCU(s), GCS(es) and UAS nodes. The Router allows you to add/remove endpoints on the fly without node restart.

mavros::uas::UAS

This node is a plugin container which manages all protocol plugins. Each plugin is a subnode to this.

Programs

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package mavros

2.12.0 (2025-09-14)

  • launch: fix python format lint
  • cmake: explicit link diagnostic_msgs Fix #2062
  • mission: switch to latched state qos from custom ones
  • include: add common qos profile for latched state topics
  • uncrustify to kilted
  • DDS equivalent of latched topic for gp_origin topic
  • code style fix
  • Contributors: ArielSulton, Bruno Celaries, Vladimir Ermakov

2.11.0 (2025-09-10)

  • launch: load all plugins in uas1

  • test: add second UAS into the same container

  • router: fix copy-paste error in endpoint loading

  • router: fix mavros_node fault introduced by #2053 Fix #2055

  • breaking: support mavlink 2025.9.9 move of AUTOPILOT_VERSION to standard

  • uas: fix old tf2 headers include

  • cmake: disable uncrustify for humble

  • cmake: update for kilted+, possibly break humble

  • regenerate all and uncrustify

  • tools: move scripts to use with uv

  • Update RouterTest for Router parameters post-constructor.

    • Added startup_delay_timer->cancel() to RouterTest::create_node()

    - Created RouterTest::create_node_no_endpoints() for the two unit tests which call Router::set_parameters() to set endpoints.

    - Converterd Router parameter declaration from an inline functional to a standalone function which can be called from RouterTest::Create_node_no_endpoints(), and from the timer in the constructor

  • uncrustify as noted by CI jobs

  • Remove extraneous blank line

  • unrustify code style fixes

  • Put add_on_set_parameters_callback in time-delayed function. Resolves bad_weak_ptr issue when starting router as composable node

  • Update ArduPlane mode 14 from LAND to AVOID_ADSB.

  • Contributors: Aaron Marburg, FAC94, Vladimir Ermakov

2.10.1 (2025-06-06)

  • fix: display topic on service timeout error
  • Fix incorrect macro usage RCLCPP_SMART_PTR_DEFINITIONS eventually is expanding to: #define __RCLCPP_MAKE_UNIQUE_DEFINITION(...) template<typename ... Args> static std::unique_ptr<__VA_ARGS_> make_unique(Args && ... args) { return std::unique_ptr<__VA_ARGS_>(new __VA_ARGS_(std::forward<Args>(args) ...)); } which is incorrect for abstract classes like Endpoint or Plugin RCLCPP_SMART_PTR_DEFINITIONS_NOT_COPYABLE is used instead excluding make_unique functionality
  • Contributors: Emmanuel Ferdman, Mykhailo Kuznietsov

2.10.0 (2025-05-05)

  • extras: fix odid build

  • extras: re-generate all cog scripts

  • mavros: fix indentation

  • Merge branch 'master' into ros2

    * master: 1.20.1 update changelog 1.20.0 update changelog update mavlink dep branch Add missing std_srvs dependency add param to odom plugin add frame_id parameter Fix compile error when compiling with gcc 13

  • 1.20.1

  • update changelog

  • fix spelling error

File truncated at 100 lines see the full file

Launch files

  • launch/apm.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • namespace [default: mavros]
  • launch/multi_uas.launch
      • id [default: 0]
      • fcu_url [default: udp://:14540@127.0.0.1:14580]
      • id [default: 1]
      • fcu_url [default: udp://:14541@127.0.0.1:14581]
  • launch/node.launch
      • fcu_url
      • gcs_url
      • tgt_system
      • tgt_component
      • pluginlists_yaml
      • config_yaml
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • namespace [default: mavros]
  • launch/px4.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • namespace [default: mavros]

Messages

No message files found.

Services

No service files found

Plugins

Recent questions tagged mavros at Robotics Stack Exchange

Package symbol

mavros package from mavros repo

libmavconn mavros mavros_extras mavros_msgs

ROS Distro
kilted

Package Summary

Tags uav mav mavlink plugin apm px4
Version 2.12.0
License GPLv3
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Description MAVLink to ROS gateway with proxy for Ground Control Station
Checkout URI https://github.com/mavlink/mavros.git
VCS Type git
VCS Version ros2
Last Updated 2025-10-18
Dev Status DEVELOPED
Released RELEASED
Tags uav ros mavlink ros-node mavros mavros-msgs mav plugin apm px4
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

MAVROS -- MAVLink extendable communication node for ROS with proxy for Ground Control Station.

Additional Links

Maintainers

  • Vladimir Ermakov

Authors

  • Vladimir Ermakov

MAVROS

MAVLink extendable communication node for ROS2.

ROS API documentation moved to [wiki.ros.org][wiki].

Features

  • Communication with autopilot via serial port, UDP or TCP (e.g. [PX4 Pro][px4] or [ArduPilot][apm])
  • Internal proxy for Ground Control Station (serial, UDP, TCP)
  • Plugin system for ROS-MAVLink translation
  • Parameter manipulation tool
  • Waypoint manipulation tool
  • PX4Flow support (by [mavros_extras][mrext])
  • OFFBOARD mode support
  • Geographic coordinates conversions.

Limitations

Only for Linux.

This package are dependent on [ros-*-mavlink][mlwiki] build from [mavlink-gbp-release][mlgbp]. It exists in ROS package index and usually updates each month.

Connection URL

Connection defined by URL, you can use any supported type for FCU and GCS.

Supported schemas:

  • Serial: /path/to/serial/device[:baudrate]
  • Serial: serial:///path/to/serial/device[:baudrate][?ids=sysid,compid]
  • Serial with hardware flow control: serial-hwfc:///path/to/serial/device[:baudrate][?ids=sysid,compid]
  • UDP: udp://[bind_host][:port]@[remote_host[:port]][/?ids=sysid,compid]
  • UDP broadcast until GCS discovery: udp-b://[bind_host][:port]@[:port][/?ids=sysid,compid]
  • UDP broadcast (permanent): udp-pb://[bind_host][:port]@[:port][/?ids=sysid,compid]
  • TCP client: tcp://[server_host][:port][/?ids=sysid,compid]
  • TCP server: tcp-l://[bind_host][:port][/?ids=sysid,compid]

Note:

  • Ids from URL overrides value given by system_id & component_id parameters.
  • bind_host - default 0.0.0.0 - i.e. IP4 ANY
  • UDP default ports: 14555 @ 14550
  • UDP remote address updated every time with incoming packet on bind port.
  • TCP default port: 5760

Coordinate frames

MAVROS does translate Aerospace NED frames, used in FCUs to ROS ENU frames and vice-versa. For translate airframe related data we simply apply rotation 180° about ROLL (X) axis. For local we apply 180° about ROLL (X) and 90° about YAW (Z) axes. Please read documents from issue #473 for additional information.

All the conversions are handled in src/lib/ftf_frame_conversions.cpp and src/lib/ftf_quaternion_utils.cpp and tested in test/test_frame_conversions.cpp and test/test_quaternion_utils.cpp respectively.

Related issues: [#49 (outdated)][iss49], [#216 (outdated)][iss216], [#317 (outdated)][iss317], [#319 (outdated)][iss319], [#321 (outdated)][iss321], [#473][iss473]. Documents: [Frame Conversions][iss473rfc], [Mavlink coordinate frames][iss473table].

MAVROS also allows conversion of geodetic and geocentric coordinates through [GeographicLib][geolib] given that:

  • geographic_msgs and NatSatFix.msg require the LLA fields to be filled in WGS-84 datum, meaning that the altitude should be the height above the WGS-84 ellipsoid. For that, a conversion from the height above the geoid (AMSL, considering the egm96 geoid model) to height above the WGS-84 ellipsoid, and vice-versa, is available and used in several plugins;
  • According to ROS REP 105, the earth frame should be propagated in ECEF (Earth-Centered, Earth-Fixed) local coordinates. For that, the functionalities of GeographicLib are used in order to allow conversion from geodetic coordinates to geocentric coordinates;
  • The translation from GPS coordinates to local geocentric coordinates require the definition of a local origin on the map frame, in ECEF, and calculate the offset to it in ENU. All the conversions are supported by GeographicLib classes and methods and implemented in the global_position plugin.

Composite nodes

See also: https://docs.ros.org/en/foxy/Tutorials/Composition.html

mavros::router::Router

This is router node required to support connections to FCU(s), GCS(es) and UAS nodes. The Router allows you to add/remove endpoints on the fly without node restart.

mavros::uas::UAS

This node is a plugin container which manages all protocol plugins. Each plugin is a subnode to this.

Programs

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package mavros

2.12.0 (2025-09-14)

  • launch: fix python format lint
  • cmake: explicit link diagnostic_msgs Fix #2062
  • mission: switch to latched state qos from custom ones
  • include: add common qos profile for latched state topics
  • uncrustify to kilted
  • DDS equivalent of latched topic for gp_origin topic
  • code style fix
  • Contributors: ArielSulton, Bruno Celaries, Vladimir Ermakov

2.11.0 (2025-09-10)

  • launch: load all plugins in uas1

  • test: add second UAS into the same container

  • router: fix copy-paste error in endpoint loading

  • router: fix mavros_node fault introduced by #2053 Fix #2055

  • breaking: support mavlink 2025.9.9 move of AUTOPILOT_VERSION to standard

  • uas: fix old tf2 headers include

  • cmake: disable uncrustify for humble

  • cmake: update for kilted+, possibly break humble

  • regenerate all and uncrustify

  • tools: move scripts to use with uv

  • Update RouterTest for Router parameters post-constructor.

    • Added startup_delay_timer->cancel() to RouterTest::create_node()

    - Created RouterTest::create_node_no_endpoints() for the two unit tests which call Router::set_parameters() to set endpoints.

    - Converterd Router parameter declaration from an inline functional to a standalone function which can be called from RouterTest::Create_node_no_endpoints(), and from the timer in the constructor

  • uncrustify as noted by CI jobs

  • Remove extraneous blank line

  • unrustify code style fixes

  • Put add_on_set_parameters_callback in time-delayed function. Resolves bad_weak_ptr issue when starting router as composable node

  • Update ArduPlane mode 14 from LAND to AVOID_ADSB.

  • Contributors: Aaron Marburg, FAC94, Vladimir Ermakov

2.10.1 (2025-06-06)

  • fix: display topic on service timeout error
  • Fix incorrect macro usage RCLCPP_SMART_PTR_DEFINITIONS eventually is expanding to: #define __RCLCPP_MAKE_UNIQUE_DEFINITION(...) template<typename ... Args> static std::unique_ptr<__VA_ARGS_> make_unique(Args && ... args) { return std::unique_ptr<__VA_ARGS_>(new __VA_ARGS_(std::forward<Args>(args) ...)); } which is incorrect for abstract classes like Endpoint or Plugin RCLCPP_SMART_PTR_DEFINITIONS_NOT_COPYABLE is used instead excluding make_unique functionality
  • Contributors: Emmanuel Ferdman, Mykhailo Kuznietsov

2.10.0 (2025-05-05)

  • extras: fix odid build

  • extras: re-generate all cog scripts

  • mavros: fix indentation

  • Merge branch 'master' into ros2

    * master: 1.20.1 update changelog 1.20.0 update changelog update mavlink dep branch Add missing std_srvs dependency add param to odom plugin add frame_id parameter Fix compile error when compiling with gcc 13

  • 1.20.1

  • update changelog

  • fix spelling error

File truncated at 100 lines see the full file

Launch files

  • launch/apm.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • namespace [default: mavros]
  • launch/multi_uas.launch
      • id [default: 0]
      • fcu_url [default: udp://:14540@127.0.0.1:14580]
      • id [default: 1]
      • fcu_url [default: udp://:14541@127.0.0.1:14581]
  • launch/node.launch
      • fcu_url
      • gcs_url
      • tgt_system
      • tgt_component
      • pluginlists_yaml
      • config_yaml
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • namespace [default: mavros]
  • launch/px4.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • namespace [default: mavros]

Messages

No message files found.

Services

No service files found

Plugins

Recent questions tagged mavros at Robotics Stack Exchange

Package symbol

mavros package from mavros repo

libmavconn mavros mavros_extras mavros_msgs

ROS Distro
rolling

Package Summary

Tags uav mav mavlink plugin apm px4
Version 2.12.0
License GPLv3
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Description MAVLink to ROS gateway with proxy for Ground Control Station
Checkout URI https://github.com/mavlink/mavros.git
VCS Type git
VCS Version ros2
Last Updated 2025-10-18
Dev Status DEVELOPED
Released RELEASED
Tags uav ros mavlink ros-node mavros mavros-msgs mav plugin apm px4
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

MAVROS -- MAVLink extendable communication node for ROS with proxy for Ground Control Station.

Additional Links

Maintainers

  • Vladimir Ermakov

Authors

  • Vladimir Ermakov

MAVROS

MAVLink extendable communication node for ROS2.

ROS API documentation moved to [wiki.ros.org][wiki].

Features

  • Communication with autopilot via serial port, UDP or TCP (e.g. [PX4 Pro][px4] or [ArduPilot][apm])
  • Internal proxy for Ground Control Station (serial, UDP, TCP)
  • Plugin system for ROS-MAVLink translation
  • Parameter manipulation tool
  • Waypoint manipulation tool
  • PX4Flow support (by [mavros_extras][mrext])
  • OFFBOARD mode support
  • Geographic coordinates conversions.

Limitations

Only for Linux.

This package are dependent on [ros-*-mavlink][mlwiki] build from [mavlink-gbp-release][mlgbp]. It exists in ROS package index and usually updates each month.

Connection URL

Connection defined by URL, you can use any supported type for FCU and GCS.

Supported schemas:

  • Serial: /path/to/serial/device[:baudrate]
  • Serial: serial:///path/to/serial/device[:baudrate][?ids=sysid,compid]
  • Serial with hardware flow control: serial-hwfc:///path/to/serial/device[:baudrate][?ids=sysid,compid]
  • UDP: udp://[bind_host][:port]@[remote_host[:port]][/?ids=sysid,compid]
  • UDP broadcast until GCS discovery: udp-b://[bind_host][:port]@[:port][/?ids=sysid,compid]
  • UDP broadcast (permanent): udp-pb://[bind_host][:port]@[:port][/?ids=sysid,compid]
  • TCP client: tcp://[server_host][:port][/?ids=sysid,compid]
  • TCP server: tcp-l://[bind_host][:port][/?ids=sysid,compid]

Note:

  • Ids from URL overrides value given by system_id & component_id parameters.
  • bind_host - default 0.0.0.0 - i.e. IP4 ANY
  • UDP default ports: 14555 @ 14550
  • UDP remote address updated every time with incoming packet on bind port.
  • TCP default port: 5760

Coordinate frames

MAVROS does translate Aerospace NED frames, used in FCUs to ROS ENU frames and vice-versa. For translate airframe related data we simply apply rotation 180° about ROLL (X) axis. For local we apply 180° about ROLL (X) and 90° about YAW (Z) axes. Please read documents from issue #473 for additional information.

All the conversions are handled in src/lib/ftf_frame_conversions.cpp and src/lib/ftf_quaternion_utils.cpp and tested in test/test_frame_conversions.cpp and test/test_quaternion_utils.cpp respectively.

Related issues: [#49 (outdated)][iss49], [#216 (outdated)][iss216], [#317 (outdated)][iss317], [#319 (outdated)][iss319], [#321 (outdated)][iss321], [#473][iss473]. Documents: [Frame Conversions][iss473rfc], [Mavlink coordinate frames][iss473table].

MAVROS also allows conversion of geodetic and geocentric coordinates through [GeographicLib][geolib] given that:

  • geographic_msgs and NatSatFix.msg require the LLA fields to be filled in WGS-84 datum, meaning that the altitude should be the height above the WGS-84 ellipsoid. For that, a conversion from the height above the geoid (AMSL, considering the egm96 geoid model) to height above the WGS-84 ellipsoid, and vice-versa, is available and used in several plugins;
  • According to ROS REP 105, the earth frame should be propagated in ECEF (Earth-Centered, Earth-Fixed) local coordinates. For that, the functionalities of GeographicLib are used in order to allow conversion from geodetic coordinates to geocentric coordinates;
  • The translation from GPS coordinates to local geocentric coordinates require the definition of a local origin on the map frame, in ECEF, and calculate the offset to it in ENU. All the conversions are supported by GeographicLib classes and methods and implemented in the global_position plugin.

Composite nodes

See also: https://docs.ros.org/en/foxy/Tutorials/Composition.html

mavros::router::Router

This is router node required to support connections to FCU(s), GCS(es) and UAS nodes. The Router allows you to add/remove endpoints on the fly without node restart.

mavros::uas::UAS

This node is a plugin container which manages all protocol plugins. Each plugin is a subnode to this.

Programs

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package mavros

2.12.0 (2025-09-14)

  • launch: fix python format lint
  • cmake: explicit link diagnostic_msgs Fix #2062
  • mission: switch to latched state qos from custom ones
  • include: add common qos profile for latched state topics
  • uncrustify to kilted
  • DDS equivalent of latched topic for gp_origin topic
  • code style fix
  • Contributors: ArielSulton, Bruno Celaries, Vladimir Ermakov

2.11.0 (2025-09-10)

  • launch: load all plugins in uas1

  • test: add second UAS into the same container

  • router: fix copy-paste error in endpoint loading

  • router: fix mavros_node fault introduced by #2053 Fix #2055

  • breaking: support mavlink 2025.9.9 move of AUTOPILOT_VERSION to standard

  • uas: fix old tf2 headers include

  • cmake: disable uncrustify for humble

  • cmake: update for kilted+, possibly break humble

  • regenerate all and uncrustify

  • tools: move scripts to use with uv

  • Update RouterTest for Router parameters post-constructor.

    • Added startup_delay_timer->cancel() to RouterTest::create_node()

    - Created RouterTest::create_node_no_endpoints() for the two unit tests which call Router::set_parameters() to set endpoints.

    - Converterd Router parameter declaration from an inline functional to a standalone function which can be called from RouterTest::Create_node_no_endpoints(), and from the timer in the constructor

  • uncrustify as noted by CI jobs

  • Remove extraneous blank line

  • unrustify code style fixes

  • Put add_on_set_parameters_callback in time-delayed function. Resolves bad_weak_ptr issue when starting router as composable node

  • Update ArduPlane mode 14 from LAND to AVOID_ADSB.

  • Contributors: Aaron Marburg, FAC94, Vladimir Ermakov

2.10.1 (2025-06-06)

  • fix: display topic on service timeout error
  • Fix incorrect macro usage RCLCPP_SMART_PTR_DEFINITIONS eventually is expanding to: #define __RCLCPP_MAKE_UNIQUE_DEFINITION(...) template<typename ... Args> static std::unique_ptr<__VA_ARGS_> make_unique(Args && ... args) { return std::unique_ptr<__VA_ARGS_>(new __VA_ARGS_(std::forward<Args>(args) ...)); } which is incorrect for abstract classes like Endpoint or Plugin RCLCPP_SMART_PTR_DEFINITIONS_NOT_COPYABLE is used instead excluding make_unique functionality
  • Contributors: Emmanuel Ferdman, Mykhailo Kuznietsov

2.10.0 (2025-05-05)

  • extras: fix odid build

  • extras: re-generate all cog scripts

  • mavros: fix indentation

  • Merge branch 'master' into ros2

    * master: 1.20.1 update changelog 1.20.0 update changelog update mavlink dep branch Add missing std_srvs dependency add param to odom plugin add frame_id parameter Fix compile error when compiling with gcc 13

  • 1.20.1

  • update changelog

  • fix spelling error

File truncated at 100 lines see the full file

Launch files

  • launch/apm.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • namespace [default: mavros]
  • launch/multi_uas.launch
      • id [default: 0]
      • fcu_url [default: udp://:14540@127.0.0.1:14580]
      • id [default: 1]
      • fcu_url [default: udp://:14541@127.0.0.1:14581]
  • launch/node.launch
      • fcu_url
      • gcs_url
      • tgt_system
      • tgt_component
      • pluginlists_yaml
      • config_yaml
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • namespace [default: mavros]
  • launch/px4.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • namespace [default: mavros]

Messages

No message files found.

Services

No service files found

Plugins

Recent questions tagged mavros at Robotics Stack Exchange

Package Summary

Tags uav mav mavlink plugin apm px4
Version 1.5.1
License GPLv3
Build type CATKIN
Use RECOMMENDED

Repository Summary

Description A ROS Workspace for the interception of a ball projectile via a simulated drone
Checkout URI https://github.com/arijitnoobstar/uavprojectilecatcher.git
VCS Type git
VCS Version master
Last Updated 2021-05-16
Dev Status UNKNOWN
Released UNRELEASED
Tags uav mav mavlink plugin apm px4
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

MAVROS -- MAVLink extendable communication node for ROS with proxy for Ground Control Station.

Additional Links

Maintainers

  • Vladimir Ermakov

Authors

  • Vladimir Ermakov

MAVROS

MAVLink extendable communication node for ROS with proxy for Ground Control Station (e.g. [QGroundControl][qgc]).

ROS API documentation moved to [wiki.ros.org][wiki].

Features

  • Communication with autopilot via serial port, UDP or TCP (e.g. [PX4 Pro][px4] or [ArduPilot][apm])
  • Internal proxy for Ground Control Station (serial, UDP, TCP)
  • Plugin system for ROS-MAVLink translation
  • Parameter manipulation tool
  • Waypoint manipulation tool
  • PX4Flow support (by [mavros_extras][mrext])
  • OFFBOARD mode support
  • Geographic coordinates conversions.

Limitations

Only for Linux. Depends on [Boost library][boost], GCC 4.8+ (C++11 support). Catkin build system required.

This package are dependent on [ros-*-mavlink][mlwiki] build from [mavlink-gbp-release][mlgbp]. It exists in ROS package index and usually updates each month.

Connection URL

Connection defined by URL, you can use any supported type for FCU and GCS.

Supported schemas:

  • Serial: /path/to/serial/device[:baudrate]
  • Serial: serial:///path/to/serial/device[:baudrate][?ids=sysid,compid]
  • Serial with hardware flow control: serial-hwfc:///path/to/serial/device[:baudrate][?ids=sysid,compid]
  • UDP: udp://[bind_host][:port]@[remote_host[:port]][/?ids=sysid,compid]
  • UDP broadcast until GCS discovery: udp-b://[bind_host][:port]@[:port][/?ids=sysid,compid]
  • UDP broadcast (permanent): udp-pb://[bind_host][:port]@[:port][/?ids=sysid,compid]
  • TCP client: tcp://[server_host][:port][/?ids=sysid,compid]
  • TCP server: tcp-l://[bind_host][:port][/?ids=sysid,compid]

Note:

  • Ids from URL overrides value given by system_id & component_id parameters.
  • bind_host - default 0.0.0.0 - i.e. IP4 ANY
  • UDP default ports: 14555 @ 14550
  • UDP remote address updated every time with incoming packet on bind port.
  • TCP default port: 5760

Coordinate frames

MAVROS does translate Aerospace NED frames, used in FCUs to ROS ENU frames and vice-versa. For translate airframe related data we simply apply rotation 180° about ROLL (X) axis. For local we apply 180° about ROLL (X) and 90° about YAW (Z) axes. Please read documents from issue #473 for additional information.

All the conversions are handled in src/lib/ftf_frame_conversions.cpp and src/lib/ftf_quaternion_utils.cpp and tested in test/test_frame_conversions.cpp and test/test_quaternion_utils.cpp respectively.

Related issues: [#49 (outdated)][iss49], [#216 (outdated)][iss216], [#317 (outdated)][iss317], [#319 (outdated)][iss319], [#321 (outdated)][iss321], [#473][iss473]. Documents: [Frame Conversions][iss473rfc], [Mavlink coordinate frames][iss473table].

MAVROS also allows conversion of geodetic and geocentric coordinates through [GeographicLib][geolib] given that:

  • geographic_msgs and NatSatFix.msg require the LLA fields to be filled in WGS-84 datum, meaning that the altitude should be the height above the WGS-84 ellipsoid. For that, a conversion from the height above the geoid (AMSL, considering the egm96 geoid model) to height above the WGS-84 ellipsoid, and vice-versa, is available and used in several plugins;
  • According to ROS REP 105, the earth frame should be propagated in ECEF (Earth-Centered, Earth-Fixed) local coordinates. For that, the functionalities of GeographicLib are used in order to allow conversion from geodetic coordinates to geocentric coordinates;
  • The translation from GPS coordinates to local geocentric coordinates require the definition of a local origin on the map frame, in ECEF, and calculate the offset to it in ENU. All the conversions are supported by GeographicLib classes and methods and implemented in the global_position plugin.

Programs

mavros_node – main communication node

Main node. Allow disable GCS proxy by setting empty URL.

Run example (autopilot connected via USB at 921600 baud, GCS running on the host with IP 172.16.254.1):

rosrun mavros mavros_node _fcu_url:=/dev/ttyACM0:921600 _gcs_url:=udp://@172.16.254.1

gcs_bridge – additional proxy

Allows you to add a channel for GCS. For example if you need to connect one GCS for HIL and the second on the tablet.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package mavros

1.5.1 (2021-01-04)

  • Fix tests for renaming of ECEF cases Introduced in 6234af29
  • Initialise message structures Uninitialised Mavlink 2 extension fields were sent if the fields were not later set. Initialising the fields to zero is the default value for extension fields and appears to the receiver as though sender is unaware of Mavlink 2. Instances were found with regex below, more may exist: mavlink::[\^:]+::msg::[\^:={]+ ?[\^:={]*;
  • Contributors: Rob Clarke

1.5.0 (2020-11-11)

  • mavros/sys_status: Fill flight_custom_version field
  • mavros: Add override specifiers
  • mavros: Move ECEF tf enums to separate enum class This avoids a bunch of unhandled switch cases, and should improve type safety a bit.
  • Contributors: Morten Fyhn Amundsen

1.4.0 (2020-09-11)

  • mavros: use mavlink::minimal:: after incompatible changes in mavlink package Incompatible change: https://github.com/mavlink/mavlink/pull/1463 Fix: #1483, https://github.com/mavlink/mavlink/issues/1474
  • fixes based on vooon's review
  • fix issue what we couldn't set real parameters to 0.0 in mavros
  • Add error message
  • Fixed compilation error: publish std_msgs::String, not std::string for gcs_ip
  • Dispatch GCS IP address
  • Contributors: Artem Batalov, Marcelino, Morten Fyhn Amundsen, Vladimir Ermakov, Øystein Skotheim

1.3.0 (2020-08-08)

  • fake_gps.cpp: implement speed accuracy
  • fake_gps.cpp: Add mocap_withcovariance configuration parameter
  • fake_gps.cpp: add initial support for GPS_INPUT MAVLink message
  • apm.launch: Avoid warning: Warning: You are using <arg> inside an <include> tag with the default=XY attribute - which is superfluous. Use value=XY instead for less confusion. Attribute name: respawn_mavros
  • Added support for MavProxy parameter file format
  • Ignore read-only parameters and statistics parameters in push operations
  • fix indentation
  • transform based on coordinate_frame
  • wind plugin: fix ArduPilot wind transformation
  • Contributors: Ben Wolsieffer, Dr.-Ing. Amilcar do Carmo Lucas, Yuan, Yuan Xu

1.2.0 (2020-05-22)

  • has_capability only works for enums
  • Uncrustify
  • Reworked Waypoint plugin to use capabilities_cb Additionally added helper functions has_capability and has_capabilities so that people can use either ints or enums to check if the UAS has a capability. This might make accepting capabilities as a parameter moot though.
  • Added alias for capabilities enum to UAS
  • Added alias for capabilities enum to UAS
  • Added a capabilities change cb queue Plugins can now write functions that they add to the capabilities_cb_vec. These functions will be called only when there is a change to the capabilities themselves not whenever the known status of the fcu_capabilities change. These functions should have a parameter of type mavlink::common::MAV_PROTOCOL_CAPABILITY which is essentially just a uint64_t however being more opinionated is helpful when looking for what the canonical enum names are in the mavlink project header files.
  • Uncrustify
  • Fixed Removed Uncrustify Option I'm not sure why this didn't break when I ran uncrustify previously but it seems that the align_number_left option was removed a while ago with this merge request but I may be mistaken https://github.com/uncrustify/uncrustify/pull/1393 I replaced it which align_number_right=true since it seems to be the inverse of align_number_left=true.
  • Removed deprecated MAV_FRAME values
  • Removed use of variant in favor of templates Since ROS messages are now the storage type in the node, providing to and from conversion functions is sufficient and can be better expressed with function templates.
  • Encode factor returns double
  • Changed encoding factor cog code
  • Uncrustify changes
  • Added new parameter to config.yamls
  • Updated waypoint plugin to support MISSION_ITEM_INT These changes add a new parameter use_mission_item_int, which allows users to prefer the old behavior. These changes also verify that the flight controller supports _INT messages since APM only sends REQUEST_ITEM messages even though it accepts _INT items back. This commit is functional and tested with the APM stack only. PX4 sitl jmavsim threw: WP: upload failed: Command is not supported. FCU: IGN MISSION_ITEM: Busy

File truncated at 100 lines see the full file

Launch files

  • launch/apm.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
  • launch/apm2.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
  • launch/mavlink_bridge.launch
      • ns [default: iris]
      • mavlink_bridge_url [default: udp://127.0.0.1:14553@127.0.0.1:14560]
  • launch/node.launch
      • fcu_url
      • gcs_url
      • tgt_system
      • tgt_component
      • pluginlists_yaml
      • config_yaml
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
  • launch/px4.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • respawn_mavros [default: $(arg respawn_mavros)]

Messages

Services

No service files found

Plugins

Recent questions tagged mavros at Robotics Stack Exchange

Package symbol

mavros package from mavros repo

libmavconn mavros mavros_extras mavros_msgs

ROS Distro
galactic

Package Summary

Tags uav mav mavlink plugin apm px4
Version 2.12.0
License GPLv3
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Description MAVLink to ROS gateway with proxy for Ground Control Station
Checkout URI https://github.com/mavlink/mavros.git
VCS Type git
VCS Version ros2
Last Updated 2025-10-18
Dev Status DEVELOPED
Released RELEASED
Tags uav ros mavlink ros-node mavros mavros-msgs mav plugin apm px4
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

MAVROS -- MAVLink extendable communication node for ROS with proxy for Ground Control Station.

Additional Links

Maintainers

  • Vladimir Ermakov

Authors

  • Vladimir Ermakov

MAVROS

MAVLink extendable communication node for ROS2.

ROS API documentation moved to [wiki.ros.org][wiki].

Features

  • Communication with autopilot via serial port, UDP or TCP (e.g. [PX4 Pro][px4] or [ArduPilot][apm])
  • Internal proxy for Ground Control Station (serial, UDP, TCP)
  • Plugin system for ROS-MAVLink translation
  • Parameter manipulation tool
  • Waypoint manipulation tool
  • PX4Flow support (by [mavros_extras][mrext])
  • OFFBOARD mode support
  • Geographic coordinates conversions.

Limitations

Only for Linux.

This package are dependent on [ros-*-mavlink][mlwiki] build from [mavlink-gbp-release][mlgbp]. It exists in ROS package index and usually updates each month.

Connection URL

Connection defined by URL, you can use any supported type for FCU and GCS.

Supported schemas:

  • Serial: /path/to/serial/device[:baudrate]
  • Serial: serial:///path/to/serial/device[:baudrate][?ids=sysid,compid]
  • Serial with hardware flow control: serial-hwfc:///path/to/serial/device[:baudrate][?ids=sysid,compid]
  • UDP: udp://[bind_host][:port]@[remote_host[:port]][/?ids=sysid,compid]
  • UDP broadcast until GCS discovery: udp-b://[bind_host][:port]@[:port][/?ids=sysid,compid]
  • UDP broadcast (permanent): udp-pb://[bind_host][:port]@[:port][/?ids=sysid,compid]
  • TCP client: tcp://[server_host][:port][/?ids=sysid,compid]
  • TCP server: tcp-l://[bind_host][:port][/?ids=sysid,compid]

Note:

  • Ids from URL overrides value given by system_id & component_id parameters.
  • bind_host - default 0.0.0.0 - i.e. IP4 ANY
  • UDP default ports: 14555 @ 14550
  • UDP remote address updated every time with incoming packet on bind port.
  • TCP default port: 5760

Coordinate frames

MAVROS does translate Aerospace NED frames, used in FCUs to ROS ENU frames and vice-versa. For translate airframe related data we simply apply rotation 180° about ROLL (X) axis. For local we apply 180° about ROLL (X) and 90° about YAW (Z) axes. Please read documents from issue #473 for additional information.

All the conversions are handled in src/lib/ftf_frame_conversions.cpp and src/lib/ftf_quaternion_utils.cpp and tested in test/test_frame_conversions.cpp and test/test_quaternion_utils.cpp respectively.

Related issues: [#49 (outdated)][iss49], [#216 (outdated)][iss216], [#317 (outdated)][iss317], [#319 (outdated)][iss319], [#321 (outdated)][iss321], [#473][iss473]. Documents: [Frame Conversions][iss473rfc], [Mavlink coordinate frames][iss473table].

MAVROS also allows conversion of geodetic and geocentric coordinates through [GeographicLib][geolib] given that:

  • geographic_msgs and NatSatFix.msg require the LLA fields to be filled in WGS-84 datum, meaning that the altitude should be the height above the WGS-84 ellipsoid. For that, a conversion from the height above the geoid (AMSL, considering the egm96 geoid model) to height above the WGS-84 ellipsoid, and vice-versa, is available and used in several plugins;
  • According to ROS REP 105, the earth frame should be propagated in ECEF (Earth-Centered, Earth-Fixed) local coordinates. For that, the functionalities of GeographicLib are used in order to allow conversion from geodetic coordinates to geocentric coordinates;
  • The translation from GPS coordinates to local geocentric coordinates require the definition of a local origin on the map frame, in ECEF, and calculate the offset to it in ENU. All the conversions are supported by GeographicLib classes and methods and implemented in the global_position plugin.

Composite nodes

See also: https://docs.ros.org/en/foxy/Tutorials/Composition.html

mavros::router::Router

This is router node required to support connections to FCU(s), GCS(es) and UAS nodes. The Router allows you to add/remove endpoints on the fly without node restart.

mavros::uas::UAS

This node is a plugin container which manages all protocol plugins. Each plugin is a subnode to this.

Programs

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package mavros

2.12.0 (2025-09-14)

  • launch: fix python format lint
  • cmake: explicit link diagnostic_msgs Fix #2062
  • mission: switch to latched state qos from custom ones
  • include: add common qos profile for latched state topics
  • uncrustify to kilted
  • DDS equivalent of latched topic for gp_origin topic
  • code style fix
  • Contributors: ArielSulton, Bruno Celaries, Vladimir Ermakov

2.11.0 (2025-09-10)

  • launch: load all plugins in uas1

  • test: add second UAS into the same container

  • router: fix copy-paste error in endpoint loading

  • router: fix mavros_node fault introduced by #2053 Fix #2055

  • breaking: support mavlink 2025.9.9 move of AUTOPILOT_VERSION to standard

  • uas: fix old tf2 headers include

  • cmake: disable uncrustify for humble

  • cmake: update for kilted+, possibly break humble

  • regenerate all and uncrustify

  • tools: move scripts to use with uv

  • Update RouterTest for Router parameters post-constructor.

    • Added startup_delay_timer->cancel() to RouterTest::create_node()

    - Created RouterTest::create_node_no_endpoints() for the two unit tests which call Router::set_parameters() to set endpoints.

    - Converterd Router parameter declaration from an inline functional to a standalone function which can be called from RouterTest::Create_node_no_endpoints(), and from the timer in the constructor

  • uncrustify as noted by CI jobs

  • Remove extraneous blank line

  • unrustify code style fixes

  • Put add_on_set_parameters_callback in time-delayed function. Resolves bad_weak_ptr issue when starting router as composable node

  • Update ArduPlane mode 14 from LAND to AVOID_ADSB.

  • Contributors: Aaron Marburg, FAC94, Vladimir Ermakov

2.10.1 (2025-06-06)

  • fix: display topic on service timeout error
  • Fix incorrect macro usage RCLCPP_SMART_PTR_DEFINITIONS eventually is expanding to: #define __RCLCPP_MAKE_UNIQUE_DEFINITION(...) template<typename ... Args> static std::unique_ptr<__VA_ARGS_> make_unique(Args && ... args) { return std::unique_ptr<__VA_ARGS_>(new __VA_ARGS_(std::forward<Args>(args) ...)); } which is incorrect for abstract classes like Endpoint or Plugin RCLCPP_SMART_PTR_DEFINITIONS_NOT_COPYABLE is used instead excluding make_unique functionality
  • Contributors: Emmanuel Ferdman, Mykhailo Kuznietsov

2.10.0 (2025-05-05)

  • extras: fix odid build

  • extras: re-generate all cog scripts

  • mavros: fix indentation

  • Merge branch 'master' into ros2

    * master: 1.20.1 update changelog 1.20.0 update changelog update mavlink dep branch Add missing std_srvs dependency add param to odom plugin add frame_id parameter Fix compile error when compiling with gcc 13

  • 1.20.1

  • update changelog

  • fix spelling error

File truncated at 100 lines see the full file

Launch files

  • launch/apm.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • namespace [default: mavros]
  • launch/multi_uas.launch
      • id [default: 0]
      • fcu_url [default: udp://:14540@127.0.0.1:14580]
      • id [default: 1]
      • fcu_url [default: udp://:14541@127.0.0.1:14581]
  • launch/node.launch
      • fcu_url
      • gcs_url
      • tgt_system
      • tgt_component
      • pluginlists_yaml
      • config_yaml
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • namespace [default: mavros]
  • launch/px4.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • namespace [default: mavros]

Messages

No message files found.

Services

No service files found

Plugins

Recent questions tagged mavros at Robotics Stack Exchange

Package symbol

mavros package from mavros repo

libmavconn mavros mavros_extras mavros_msgs

ROS Distro
iron

Package Summary

Tags uav mav mavlink plugin apm px4
Version 2.12.0
License GPLv3
Build type AMENT_CMAKE
Use RECOMMENDED

Repository Summary

Description MAVLink to ROS gateway with proxy for Ground Control Station
Checkout URI https://github.com/mavlink/mavros.git
VCS Type git
VCS Version ros2
Last Updated 2025-10-18
Dev Status DEVELOPED
Released RELEASED
Tags uav ros mavlink ros-node mavros mavros-msgs mav plugin apm px4
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

MAVROS -- MAVLink extendable communication node for ROS with proxy for Ground Control Station.

Additional Links

Maintainers

  • Vladimir Ermakov

Authors

  • Vladimir Ermakov

MAVROS

MAVLink extendable communication node for ROS2.

ROS API documentation moved to [wiki.ros.org][wiki].

Features

  • Communication with autopilot via serial port, UDP or TCP (e.g. [PX4 Pro][px4] or [ArduPilot][apm])
  • Internal proxy for Ground Control Station (serial, UDP, TCP)
  • Plugin system for ROS-MAVLink translation
  • Parameter manipulation tool
  • Waypoint manipulation tool
  • PX4Flow support (by [mavros_extras][mrext])
  • OFFBOARD mode support
  • Geographic coordinates conversions.

Limitations

Only for Linux.

This package are dependent on [ros-*-mavlink][mlwiki] build from [mavlink-gbp-release][mlgbp]. It exists in ROS package index and usually updates each month.

Connection URL

Connection defined by URL, you can use any supported type for FCU and GCS.

Supported schemas:

  • Serial: /path/to/serial/device[:baudrate]
  • Serial: serial:///path/to/serial/device[:baudrate][?ids=sysid,compid]
  • Serial with hardware flow control: serial-hwfc:///path/to/serial/device[:baudrate][?ids=sysid,compid]
  • UDP: udp://[bind_host][:port]@[remote_host[:port]][/?ids=sysid,compid]
  • UDP broadcast until GCS discovery: udp-b://[bind_host][:port]@[:port][/?ids=sysid,compid]
  • UDP broadcast (permanent): udp-pb://[bind_host][:port]@[:port][/?ids=sysid,compid]
  • TCP client: tcp://[server_host][:port][/?ids=sysid,compid]
  • TCP server: tcp-l://[bind_host][:port][/?ids=sysid,compid]

Note:

  • Ids from URL overrides value given by system_id & component_id parameters.
  • bind_host - default 0.0.0.0 - i.e. IP4 ANY
  • UDP default ports: 14555 @ 14550
  • UDP remote address updated every time with incoming packet on bind port.
  • TCP default port: 5760

Coordinate frames

MAVROS does translate Aerospace NED frames, used in FCUs to ROS ENU frames and vice-versa. For translate airframe related data we simply apply rotation 180° about ROLL (X) axis. For local we apply 180° about ROLL (X) and 90° about YAW (Z) axes. Please read documents from issue #473 for additional information.

All the conversions are handled in src/lib/ftf_frame_conversions.cpp and src/lib/ftf_quaternion_utils.cpp and tested in test/test_frame_conversions.cpp and test/test_quaternion_utils.cpp respectively.

Related issues: [#49 (outdated)][iss49], [#216 (outdated)][iss216], [#317 (outdated)][iss317], [#319 (outdated)][iss319], [#321 (outdated)][iss321], [#473][iss473]. Documents: [Frame Conversions][iss473rfc], [Mavlink coordinate frames][iss473table].

MAVROS also allows conversion of geodetic and geocentric coordinates through [GeographicLib][geolib] given that:

  • geographic_msgs and NatSatFix.msg require the LLA fields to be filled in WGS-84 datum, meaning that the altitude should be the height above the WGS-84 ellipsoid. For that, a conversion from the height above the geoid (AMSL, considering the egm96 geoid model) to height above the WGS-84 ellipsoid, and vice-versa, is available and used in several plugins;
  • According to ROS REP 105, the earth frame should be propagated in ECEF (Earth-Centered, Earth-Fixed) local coordinates. For that, the functionalities of GeographicLib are used in order to allow conversion from geodetic coordinates to geocentric coordinates;
  • The translation from GPS coordinates to local geocentric coordinates require the definition of a local origin on the map frame, in ECEF, and calculate the offset to it in ENU. All the conversions are supported by GeographicLib classes and methods and implemented in the global_position plugin.

Composite nodes

See also: https://docs.ros.org/en/foxy/Tutorials/Composition.html

mavros::router::Router

This is router node required to support connections to FCU(s), GCS(es) and UAS nodes. The Router allows you to add/remove endpoints on the fly without node restart.

mavros::uas::UAS

This node is a plugin container which manages all protocol plugins. Each plugin is a subnode to this.

Programs

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package mavros

2.12.0 (2025-09-14)

  • launch: fix python format lint
  • cmake: explicit link diagnostic_msgs Fix #2062
  • mission: switch to latched state qos from custom ones
  • include: add common qos profile for latched state topics
  • uncrustify to kilted
  • DDS equivalent of latched topic for gp_origin topic
  • code style fix
  • Contributors: ArielSulton, Bruno Celaries, Vladimir Ermakov

2.11.0 (2025-09-10)

  • launch: load all plugins in uas1

  • test: add second UAS into the same container

  • router: fix copy-paste error in endpoint loading

  • router: fix mavros_node fault introduced by #2053 Fix #2055

  • breaking: support mavlink 2025.9.9 move of AUTOPILOT_VERSION to standard

  • uas: fix old tf2 headers include

  • cmake: disable uncrustify for humble

  • cmake: update for kilted+, possibly break humble

  • regenerate all and uncrustify

  • tools: move scripts to use with uv

  • Update RouterTest for Router parameters post-constructor.

    • Added startup_delay_timer->cancel() to RouterTest::create_node()

    - Created RouterTest::create_node_no_endpoints() for the two unit tests which call Router::set_parameters() to set endpoints.

    - Converterd Router parameter declaration from an inline functional to a standalone function which can be called from RouterTest::Create_node_no_endpoints(), and from the timer in the constructor

  • uncrustify as noted by CI jobs

  • Remove extraneous blank line

  • unrustify code style fixes

  • Put add_on_set_parameters_callback in time-delayed function. Resolves bad_weak_ptr issue when starting router as composable node

  • Update ArduPlane mode 14 from LAND to AVOID_ADSB.

  • Contributors: Aaron Marburg, FAC94, Vladimir Ermakov

2.10.1 (2025-06-06)

  • fix: display topic on service timeout error
  • Fix incorrect macro usage RCLCPP_SMART_PTR_DEFINITIONS eventually is expanding to: #define __RCLCPP_MAKE_UNIQUE_DEFINITION(...) template<typename ... Args> static std::unique_ptr<__VA_ARGS_> make_unique(Args && ... args) { return std::unique_ptr<__VA_ARGS_>(new __VA_ARGS_(std::forward<Args>(args) ...)); } which is incorrect for abstract classes like Endpoint or Plugin RCLCPP_SMART_PTR_DEFINITIONS_NOT_COPYABLE is used instead excluding make_unique functionality
  • Contributors: Emmanuel Ferdman, Mykhailo Kuznietsov

2.10.0 (2025-05-05)

  • extras: fix odid build

  • extras: re-generate all cog scripts

  • mavros: fix indentation

  • Merge branch 'master' into ros2

    * master: 1.20.1 update changelog 1.20.0 update changelog update mavlink dep branch Add missing std_srvs dependency add param to odom plugin add frame_id parameter Fix compile error when compiling with gcc 13

  • 1.20.1

  • update changelog

  • fix spelling error

File truncated at 100 lines see the full file

Launch files

  • launch/apm.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • namespace [default: mavros]
  • launch/multi_uas.launch
      • id [default: 0]
      • fcu_url [default: udp://:14540@127.0.0.1:14580]
      • id [default: 1]
      • fcu_url [default: udp://:14541@127.0.0.1:14581]
  • launch/node.launch
      • fcu_url
      • gcs_url
      • tgt_system
      • tgt_component
      • pluginlists_yaml
      • config_yaml
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • namespace [default: mavros]
  • launch/px4.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • namespace [default: mavros]

Messages

No message files found.

Services

No service files found

Plugins

Recent questions tagged mavros at Robotics Stack Exchange

Package symbol

mavros package from mavros repo

libmavconn mavros mavros_extras mavros_msgs test_mavros

ROS Distro
melodic

Package Summary

Tags uav mav mavlink plugin apm px4
Version 1.21.0
License GPLv3
Build type CATKIN
Use RECOMMENDED

Repository Summary

Description MAVLink to ROS gateway with proxy for Ground Control Station
Checkout URI https://github.com/mavlink/mavros.git
VCS Type git
VCS Version master
Last Updated 2025-09-08
Dev Status DEVELOPED
Released RELEASED
Tags uav ros mavlink ros-node mavros mavros-msgs mav plugin apm px4
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

MAVROS -- MAVLink extendable communication node for ROS with proxy for Ground Control Station.

Additional Links

Maintainers

  • Vladimir Ermakov

Authors

  • Vladimir Ermakov

MAVROS

MAVLink extendable communication node for ROS with proxy for Ground Control Station (e.g. [QGroundControl][qgc]).

ROS API documentation moved to [wiki.ros.org][wiki].

Features

  • Communication with autopilot via serial port, UDP or TCP (e.g. [PX4 Pro][px4] or [ArduPilot][apm])
  • Internal proxy for Ground Control Station (serial, UDP, TCP)
  • Plugin system for ROS-MAVLink translation
  • Parameter manipulation tool
  • Waypoint manipulation tool
  • PX4Flow support (by [mavros_extras][mrext])
  • OFFBOARD mode support
  • Geographic coordinates conversions.

Limitations

Only for Linux. Depends on [Boost library][boost], GCC 4.8+ (C++11 support). Catkin build system required.

This package are dependent on [ros-*-mavlink][mlwiki] build from [mavlink-gbp-release][mlgbp]. It exists in ROS package index and usually updates each month.

Connection URL

Connection defined by URL, you can use any supported type for FCU and GCS.

Supported schemas:

  • Serial: /path/to/serial/device[:baudrate]
  • Serial: serial:///path/to/serial/device[:baudrate][?ids=sysid,compid]
  • Serial with hardware flow control: serial-hwfc:///path/to/serial/device[:baudrate][?ids=sysid,compid]
  • UDP: udp://[bind_host][:port]@[remote_host[:port]][/?ids=sysid,compid]
  • UDP broadcast until GCS discovery: udp-b://[bind_host][:port]@[:port][/?ids=sysid,compid]
  • UDP broadcast (permanent): udp-pb://[bind_host][:port]@[:port][/?ids=sysid,compid]
  • TCP client: tcp://[server_host][:port][/?ids=sysid,compid]
  • TCP server: tcp-l://[bind_host][:port][/?ids=sysid,compid]

Note:

  • Ids from URL overrides value given by system_id & component_id parameters.
  • bind_host - default 0.0.0.0 - i.e. IP4 ANY
  • UDP default ports: 14555 @ 14550
  • UDP remote address updated every time with incoming packet on bind port.
  • TCP default port: 5760

Coordinate frames

MAVROS does translate Aerospace NED frames, used in FCUs to ROS ENU frames and vice-versa. For translate airframe related data we simply apply rotation 180° about ROLL (X) axis. For local we apply 180° about ROLL (X) and 90° about YAW (Z) axes. Please read documents from issue #473 for additional information.

All the conversions are handled in src/lib/ftf_frame_conversions.cpp and src/lib/ftf_quaternion_utils.cpp and tested in test/test_frame_conversions.cpp and test/test_quaternion_utils.cpp respectively.

Related issues: [#49 (outdated)][iss49], [#216 (outdated)][iss216], [#317 (outdated)][iss317], [#319 (outdated)][iss319], [#321 (outdated)][iss321], [#473][iss473]. Documents: [Frame Conversions][iss473rfc], [Mavlink coordinate frames][iss473table].

MAVROS also allows conversion of geodetic and geocentric coordinates through [GeographicLib][geolib] given that:

  • geographic_msgs and NatSatFix.msg require the LLA fields to be filled in WGS-84 datum, meaning that the altitude should be the height above the WGS-84 ellipsoid. For that, a conversion from the height above the geoid (AMSL, considering the egm96 geoid model) to height above the WGS-84 ellipsoid, and vice-versa, is available and used in several plugins;
  • According to ROS REP 105, the earth frame should be propagated in ECEF (Earth-Centered, Earth-Fixed) local coordinates. For that, the functionalities of GeographicLib are used in order to allow conversion from geodetic coordinates to geocentric coordinates;
  • The translation from GPS coordinates to local geocentric coordinates require the definition of a local origin on the map frame, in ECEF, and calculate the offset to it in ENU. All the conversions are supported by GeographicLib classes and methods and implemented in the global_position plugin.

Programs

mavros_node – main communication node

Main node. Allow disable GCS proxy by setting empty URL.

Run example (autopilot connected via USB at 921600 baud, GCS running on the host with IP 172.16.254.1):

rosrun mavros mavros_node _fcu_url:=/dev/ttyACM0:921600 _gcs_url:=udp://@172.16.254.1

gcs_bridge – additional proxy

Allows you to add a channel for GCS. For example if you need to connect one GCS for HIL and the second on the tablet.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package mavros

1.21.0 (2025-09-08)

  • regenerate all
  • tools: move scripts to use with uv add uncrustify helper
  • Update mode 14 from LAND to AVOID_ADSB.
  • Contributors: FAC94, Vladimir Ermakov

1.20.1 (2025-05-05)

1.20.0 (2024-10-10)

  • add param to odom plugin
  • add frame_id parameter
  • Contributors: EnderMandS

1.19.0 (2024-06-06)

1.18.0 (2024-03-03)

  • sys_status.cpp: improve timeout code
  • sys_status.cpp: Add a SYS_STATUS message publisher
  • Contributors: Dr.-Ing. Amilcar do Carmo Lucas

1.17.0 (2023-09-09)

  • cog: regenerate all

  • Bugfix/update map origin with home position (#1892)

    • Update map origin with home position
    • Uncrustify

    * Revert "Uncrustify" This reverts commit f1387c79c7670cc241986586436e3da43842e877.

    * Change to relative topic ---------Co-authored-by: Natalia Molina <<molina-munoz@wingcopter.com>>

  • Merge pull request #1865 from scoutdi/warnings Fix / suppress some build warnings

  • mavros: Remove extra ';'

  • Suppress warnings from included headers

  • Contributors: Morten Fyhn Amundsen, Vladimir Ermakov, natmol

1.16.0 (2023-05-05)

  • Merge pull request #1829 from snwu1996/latched_gp_origin_pub Made it such that the gp_origin topic publisher is latched.
  • made it such that the gp_origin topic published latched.
  • Merge pull request #1817 from lucasw/pluginlib_hpp use hpp instead of deprecated .h pluginlib headers
  • use hpp instead of deprecated .h pluginlib headers
  • Contributors: Lucas Walter, Shu-Nong Wu, Vladimir Ermakov

1.15.0 (2022-12-30)

  • Merge pull request #1806 from scoutdi/fix-some-warnings mavros: Fix some warnings
  • mavros: Fix some warnings
  • Contributors: Morten Fyhn Amundsen, Vladimir Ermakov

1.14.0 (2022-09-24)

  • scripts: waypoint and param files are text, not binary Fix #1784
  • Merge pull request #1780 from snktshrma/master guided_target: accept position-target-global-int messages
  • plugins: add guided_target to accept offboard position targets Update guided_target.cpp Update guided_target.cpp Update mavros_plugins.xml Update CMakeLists.txt Added offboard_position.cpp Update apm_config.yaml Update offboard_position.cpp Update offboard_position.cpp Rename offboard_position.cpp to guided_target.cpp Update CMakeLists.txt Update mavros_plugins.xml Update apm_config.yaml Update guided_target.cpp
  • Merge pull request #1775 from acxz/find-geographiclib use already installed FindGeographicLib.cmake
  • add cmake module path for geographiclib on debian based systems

File truncated at 100 lines see the full file

Launch files

  • launch/apm.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
  • launch/apm2.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
  • launch/mavlink_bridge.launch
      • ns [default: iris]
      • mavlink_bridge_url [default: udp://127.0.0.1:14553@127.0.0.1:14560]
  • launch/node.launch
      • fcu_url
      • gcs_url
      • tgt_system
      • tgt_component
      • pluginlists_yaml
      • config_yaml
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
  • launch/px4.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • respawn_mavros [default: $(arg respawn_mavros)]

Messages

No message files found.

Services

No service files found

Plugins

Recent questions tagged mavros at Robotics Stack Exchange

Package symbol

mavros package from mavros repo

libmavconn mavros mavros_extras mavros_msgs test_mavros

ROS Distro
noetic

Package Summary

Tags uav mav mavlink plugin apm px4
Version 1.21.0
License GPLv3
Build type CATKIN
Use RECOMMENDED

Repository Summary

Description MAVLink to ROS gateway with proxy for Ground Control Station
Checkout URI https://github.com/mavlink/mavros.git
VCS Type git
VCS Version master
Last Updated 2025-09-08
Dev Status DEVELOPED
Released RELEASED
Tags uav ros mavlink ros-node mavros mavros-msgs mav plugin apm px4
Contributing Help Wanted (-)
Good First Issues (-)
Pull Requests to Review (-)

Package Description

MAVROS -- MAVLink extendable communication node for ROS with proxy for Ground Control Station.

Additional Links

Maintainers

  • Vladimir Ermakov

Authors

  • Vladimir Ermakov

MAVROS

MAVLink extendable communication node for ROS with proxy for Ground Control Station (e.g. [QGroundControl][qgc]).

ROS API documentation moved to [wiki.ros.org][wiki].

Features

  • Communication with autopilot via serial port, UDP or TCP (e.g. [PX4 Pro][px4] or [ArduPilot][apm])
  • Internal proxy for Ground Control Station (serial, UDP, TCP)
  • Plugin system for ROS-MAVLink translation
  • Parameter manipulation tool
  • Waypoint manipulation tool
  • PX4Flow support (by [mavros_extras][mrext])
  • OFFBOARD mode support
  • Geographic coordinates conversions.

Limitations

Only for Linux. Depends on [Boost library][boost], GCC 4.8+ (C++11 support). Catkin build system required.

This package are dependent on [ros-*-mavlink][mlwiki] build from [mavlink-gbp-release][mlgbp]. It exists in ROS package index and usually updates each month.

Connection URL

Connection defined by URL, you can use any supported type for FCU and GCS.

Supported schemas:

  • Serial: /path/to/serial/device[:baudrate]
  • Serial: serial:///path/to/serial/device[:baudrate][?ids=sysid,compid]
  • Serial with hardware flow control: serial-hwfc:///path/to/serial/device[:baudrate][?ids=sysid,compid]
  • UDP: udp://[bind_host][:port]@[remote_host[:port]][/?ids=sysid,compid]
  • UDP broadcast until GCS discovery: udp-b://[bind_host][:port]@[:port][/?ids=sysid,compid]
  • UDP broadcast (permanent): udp-pb://[bind_host][:port]@[:port][/?ids=sysid,compid]
  • TCP client: tcp://[server_host][:port][/?ids=sysid,compid]
  • TCP server: tcp-l://[bind_host][:port][/?ids=sysid,compid]

Note:

  • Ids from URL overrides value given by system_id & component_id parameters.
  • bind_host - default 0.0.0.0 - i.e. IP4 ANY
  • UDP default ports: 14555 @ 14550
  • UDP remote address updated every time with incoming packet on bind port.
  • TCP default port: 5760

Coordinate frames

MAVROS does translate Aerospace NED frames, used in FCUs to ROS ENU frames and vice-versa. For translate airframe related data we simply apply rotation 180° about ROLL (X) axis. For local we apply 180° about ROLL (X) and 90° about YAW (Z) axes. Please read documents from issue #473 for additional information.

All the conversions are handled in src/lib/ftf_frame_conversions.cpp and src/lib/ftf_quaternion_utils.cpp and tested in test/test_frame_conversions.cpp and test/test_quaternion_utils.cpp respectively.

Related issues: [#49 (outdated)][iss49], [#216 (outdated)][iss216], [#317 (outdated)][iss317], [#319 (outdated)][iss319], [#321 (outdated)][iss321], [#473][iss473]. Documents: [Frame Conversions][iss473rfc], [Mavlink coordinate frames][iss473table].

MAVROS also allows conversion of geodetic and geocentric coordinates through [GeographicLib][geolib] given that:

  • geographic_msgs and NatSatFix.msg require the LLA fields to be filled in WGS-84 datum, meaning that the altitude should be the height above the WGS-84 ellipsoid. For that, a conversion from the height above the geoid (AMSL, considering the egm96 geoid model) to height above the WGS-84 ellipsoid, and vice-versa, is available and used in several plugins;
  • According to ROS REP 105, the earth frame should be propagated in ECEF (Earth-Centered, Earth-Fixed) local coordinates. For that, the functionalities of GeographicLib are used in order to allow conversion from geodetic coordinates to geocentric coordinates;
  • The translation from GPS coordinates to local geocentric coordinates require the definition of a local origin on the map frame, in ECEF, and calculate the offset to it in ENU. All the conversions are supported by GeographicLib classes and methods and implemented in the global_position plugin.

Programs

mavros_node – main communication node

Main node. Allow disable GCS proxy by setting empty URL.

Run example (autopilot connected via USB at 921600 baud, GCS running on the host with IP 172.16.254.1):

rosrun mavros mavros_node _fcu_url:=/dev/ttyACM0:921600 _gcs_url:=udp://@172.16.254.1

gcs_bridge – additional proxy

Allows you to add a channel for GCS. For example if you need to connect one GCS for HIL and the second on the tablet.

File truncated at 100 lines see the full file

CHANGELOG

Changelog for package mavros

1.21.0 (2025-09-08)

  • regenerate all
  • tools: move scripts to use with uv add uncrustify helper
  • Update mode 14 from LAND to AVOID_ADSB.
  • Contributors: FAC94, Vladimir Ermakov

1.20.1 (2025-05-05)

1.20.0 (2024-10-10)

  • add param to odom plugin
  • add frame_id parameter
  • Contributors: EnderMandS

1.19.0 (2024-06-06)

1.18.0 (2024-03-03)

  • sys_status.cpp: improve timeout code
  • sys_status.cpp: Add a SYS_STATUS message publisher
  • Contributors: Dr.-Ing. Amilcar do Carmo Lucas

1.17.0 (2023-09-09)

  • cog: regenerate all

  • Bugfix/update map origin with home position (#1892)

    • Update map origin with home position
    • Uncrustify

    * Revert "Uncrustify" This reverts commit f1387c79c7670cc241986586436e3da43842e877.

    * Change to relative topic ---------Co-authored-by: Natalia Molina <<molina-munoz@wingcopter.com>>

  • Merge pull request #1865 from scoutdi/warnings Fix / suppress some build warnings

  • mavros: Remove extra ';'

  • Suppress warnings from included headers

  • Contributors: Morten Fyhn Amundsen, Vladimir Ermakov, natmol

1.16.0 (2023-05-05)

  • Merge pull request #1829 from snwu1996/latched_gp_origin_pub Made it such that the gp_origin topic publisher is latched.
  • made it such that the gp_origin topic published latched.
  • Merge pull request #1817 from lucasw/pluginlib_hpp use hpp instead of deprecated .h pluginlib headers
  • use hpp instead of deprecated .h pluginlib headers
  • Contributors: Lucas Walter, Shu-Nong Wu, Vladimir Ermakov

1.15.0 (2022-12-30)

  • Merge pull request #1806 from scoutdi/fix-some-warnings mavros: Fix some warnings
  • mavros: Fix some warnings
  • Contributors: Morten Fyhn Amundsen, Vladimir Ermakov

1.14.0 (2022-09-24)

  • scripts: waypoint and param files are text, not binary Fix #1784
  • Merge pull request #1780 from snktshrma/master guided_target: accept position-target-global-int messages
  • plugins: add guided_target to accept offboard position targets Update guided_target.cpp Update guided_target.cpp Update mavros_plugins.xml Update CMakeLists.txt Added offboard_position.cpp Update apm_config.yaml Update offboard_position.cpp Update offboard_position.cpp Rename offboard_position.cpp to guided_target.cpp Update CMakeLists.txt Update mavros_plugins.xml Update apm_config.yaml Update guided_target.cpp
  • Merge pull request #1775 from acxz/find-geographiclib use already installed FindGeographicLib.cmake
  • add cmake module path for geographiclib on debian based systems

File truncated at 100 lines see the full file

Launch files

  • launch/apm.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
  • launch/apm2.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
  • launch/mavlink_bridge.launch
      • ns [default: iris]
      • mavlink_bridge_url [default: udp://127.0.0.1:14553@127.0.0.1:14560]
  • launch/node.launch
      • fcu_url
      • gcs_url
      • tgt_system
      • tgt_component
      • pluginlists_yaml
      • config_yaml
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
  • launch/px4.launch
      • fcu_url [default: /dev/ttyACM0:57600]
      • gcs_url [default: ]
      • tgt_system [default: 1]
      • tgt_component [default: 1]
      • log_output [default: screen]
      • fcu_protocol [default: v2.0]
      • respawn_mavros [default: false]
      • respawn_mavros [default: $(arg respawn_mavros)]

Messages

No message files found.

Services

No service files found

Plugins

Recent questions tagged mavros at Robotics Stack Exchange