NAME
UAV::Pilot::ARDrone::Video
SYNOPSIS
my $cv = AnyEvent->condvar;
my $handler = ...; # An object that does UAV::Pilot::Driver::ARDrone::VideoHandler
my $ardrone = ...; # An instance of UAV::Pilot::Driver::ARDrone
my $video = UAV::Pilot::Driver::ARDrone::Video->new({
handlers => [ $handler ],
condvar => $cv,
driver => $ardrone,
});
$video->init_event_loop;
$cv->recv;
DESCRIPTION
Processes the Parrot AR.Drone v2 video stream, which is an h264 stream with some additional header data.
Note that this will not work with the AR.Drone v1.
METHODS
new
new({
handlers => [ $handler ],
condvar => $cv,
driver => $ardrone,
})
Constructor. The handlers
param is an array of objects that do the role UAV::Pilot::Driver::ARDrone::VideoHandler
. Param condvar
is an AnyEvent::CondVar. Param driver
is an instance of UAV::Pilot::Driver::ARDrone
.
init_event_loop
Starts the AnyEvent loop for processing video packets.
emergency_restart
The AR.Drone will close the connection when emergency mode is toggled. Calling this will close the stream on our end and reintitlize.
You shouldn't have to call this directly. Pass this object to your UAV::Pilot::Control::ARDrone
instance and it will do it for you.
add_handler
add_handler( $handler );
Adds a UAV::Pilot::Video::H264Handler
object to the list of handlers.