From Code to Community: Sponsoring The Perl and Raku Conference 2025 Learn more

NAME

Device::USB::MissileLauncher::RocketBaby - interface to toy missile launchers from Dream Cheeky

SYNOPSIS

my $ml = Device::USB::MissileLauncher::RocketBaby->new;
while (<>) {
/j/ && $ml->do("down");
/k/ && $ml->do("up");
/h/ && $ml->do("left");
/l/ && $ml->do("right");
/f/ && $ml->do("fire");
/s/ && $ml->do("stop");
}

DESCRIPTION

This provides a basic interface to the toy USB missile launchers produced by Dream Cheeky. The device name of USB protocol is "Rocket Baby Rocket Baby".

METHODS

new ()

Creates an instance.

do ( STRING )

send command string to the launcher. commands are following:

left
right
up
down
fire
stop
cando ( STRING )

returns whether the command is executable.

NOTE

cando("fire") returns false at only moment of launching. You can launch rockets one by one like this:

use Time::Hires qw( sleep );
sub fire1
{
my $ml = shift;
if ($ml->cando("fire")) {
$ml->do('fire');
eval {
local $SIG{ALRM} = sub { die "alarm" };
alarm 5;
while ($ml->cando("fire")) {
sleep 0.15;
}
sleep 0.5;
alarm 0;
}
$ml->do("stop");
}
}

You might have to adjust sleep figures.

SEE ALSO

Device::USB::MissileLauncher

http://www.dreamcheeky.com/product/missile-launcher.php

AUTHOR

Abe Masahiro, <pen@thcomp.org>

COPYRIGHT AND LICENSE

Copyright (C) 2007 by Abe Masahiro

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8.8 or, at your option, any later version of Perl 5 you may have available.