Camera Network is a camera sensor project developped with ROS (Robotic Operating System) to communicate easily with multiple camera device on the network.
For now, Camera Network is compatible with gphoto and the picamera module.
You can communicate with the network directly with ROS, or with the WebGUI (if the master-server is launched with the right webserver url)
The system is mainly used for still pictures. The ROS interface is made of two abstraction layers : Camera's driver and Camera controller.
#Camera Driver
This layer interact directly with the camera, it is used by camera controller so it need to implement right services to make it compatible with the system. The two actual drivers are : gphoto and picamera.A mobile prototype is implemented (only capture feature). USB could be supported in the futur.
The services are :
- capture_camera : service that take picture and store it in default place
- preview_capture : Method that send preview to mjpeg stream
- capture_video : service that take video and store it in default place
- load_camera : service that upload default's picture place to user's place it place the file and rename it with a standard
- get_camera : service that return camera's data (iso, aperture, shutterspeed, format)
- set_camera : service that set camera's data (iso, aperture, shutterspeed, format)
- calibrate_picture : methode that automatically calibrate camera's parameters
This layer is normally not launched directly by the user. Camera controller's launcher will do it
#Camera Controller
This layer interact with the Camera drivers. It can handle network task and individual task. The user should never call camera driver services (ROS give no protection although) but always call Camera Controller. The webGUI is entirely communicating with Camera Controller, so it dont care what kind of camera each device are using. The button with (beta) mean that it interact with the device, using it wrongly could lead to errors
To launch the controller you need to make a ROS launchfile with these steps (use the one in this repo as templates):
- Your computer must have the env variable CAMERA_NAME to set a unique namespace
- The launch file must set a parameter in /IP wich is the interface's IP adress
- It must load a yaml file (check template timelaps_nikon.yaml)
- It must load a camera driver (gphoto or picam), camera controller, and image_streamer.
- You can load pigpio if you want to use the button interface
Here is the services,actions and subscribe the camera Controller offer: Subscriber:
- network_capture_chatter : Publish on this topic to make all device take a picture
- network_capture_video_chatter : Publish on this topic to make all device take a video
Services:
- preview_camera : take a picture and stream it to mjpeg to view (the picture is deleted afterward)
- shutdown_device : can shutdown or reboot the device
- calibrate_device : call Camera's Driver service to calibrate and update datas
- save_config : Save HDR configurations to default param file
- capture_video : if supported, will capture a video given a delay in seconds
Action:
- timelaps : Take picture with parameters : quantity, delay between each pictures and if HDR or normal pictures
#Camera Master
Camera Master is an interface to control the whole network at once with extra network features: Actions:
- network_timelaps: Implement the same action as Camera Controller but from the network point of view. Instead of calling devices individually, it publish on topic
Its Launchfile call mjpeg_server for streaming and rosbridge_websocket for javascript bridge. This node have master as namespace.
#Special pigpio is a special feature for raspberry pi only. It enable the use of three buttons with its gpio interface to call ROS services. It can be added in camera controller launch file. The three buttons must be interfaced on:
- pin 4: take picture with device
- pin 22: take network picture
- pin 23: set predefined timelaps
The pins are software debounced, and react on falling edge, no need of super user access to call them, see INSTALL.
#Parameter Server
- /IP : this namespace contain a dictionnarie of device name with there IP adress as value
- /"DeviceName" : every device have its own namespace
- file : yaml file for timelaps
- camerasetting : camera's information
- iso
- aperture
- shutterspeed
- imageformat
- captureSequence : dictionnary of camerasetting to take hdr pictures
None of these are dynamic parameter