[Documentation] [TitleIndex] [WordIndex

Only released in EOL distros:  

Package Summary

A ROS Node to Stream Image Topics Via a MJPEG Server

Package Summary

A ROS Node to Stream Image Topics Via a MJPEG Server

Package Summary

A ROS Node to Stream Image Topics Via a MJPEG Server

This package is EOL, and has been replaced by web_video_server.


A natural means of interacting with and checking upon the progress of the robot is through video. MJPEGs, or motion JPEGs, are a file format in which each frame of a video stream is separately compressed as a JPEG image. The mjpeg_server is a streaming server that subscribes to requested image topics in ROS and publishes those topics as MJPEG streams via HTTP. While rosbridge is capable of streaming video, as it is just another message type from ROS, the web browser is optimized to efficiently download images in binary format. Thus for increased performance benefits this additional communication channel is used. In order to deal with a user’s specific requirements the video streams can be provided at a desired quality and size to accommodate different connection speeds and interface designs. mjpeg_server is developed as part of the Robot Web Tools effort.

MJPEG Stream


To install the mjpeg_server package, you can choose to either install from source, or from the Ubuntu package:


To install from source, execute the following:

  •    1 cd /path/to/your/catkin/workspace/src
       2 git clone https://github.com/RobotWebTools/mjpeg_server.git -b groovy-devel
       3 cd ../
       4 catkin_make install

Ubuntu Package

To install the Ubuntu package, execute the following:

  • sudo apt-get install ros-groovy-mjpeg-server

Running the Node

In a new terminal, run the mjpeg_server:

By default the server serves streams on port 8080. If this port is already used by another process you will see an appropriate error message.

Optionally, you can set a different port on the command line when launching mjpeg_server:

Accessing the Stream in a Web Browser

The stream can be viewed by any current browser. If the server runs on the local machine you can access the stream using the following URL:

Here, /IMAGE_TOPIC is a ROS topic generated by the image_transport module, e.g. /wide_stereo/left/image_color in case you are using a PR2.

Single image snapshots

Instead of displaying a stream of images, it is also possible to display a single image snapshot. The URL for snapshots is:

Display parameters

The image stream can be configured by several parameters. The parameters are added to the URL according to the URI scheme:

Currently the following parameters are available:

The following example shows a resized version of an image stream:


Please send bug reports to the GitHub Issue Tracker. Feel free to contact us at any point with questions and comments.

2020-03-28 12:52