/perl-Device-BlinkyTape

Perl module to control the BlinkyTape device

Primary LanguagePerl

NAME
    Device::BlinkyTape - Control a BlinkyTape led strip

SYNOPSIS
        use Device::BlinkyTape::WS2811; # BlinkyTape uses WS2811
        my $bb = Device::BlinkyTape::WS2811->new(dev => '/dev/tty.usbmodem');
        # Set all led pixels on full white
        $bb->all_on();
        # Set all led pixels off
        $bb->all_off();

        # Send a white pixel (RGB 255/255/255).
        # Pixels are sent one by one from left to right.
        $bb->send_pixel(255,255,255);
        $bb->send_pixel(5,5,5);
        # Show all sent pixels and reset send_pixel to the first pixel.
        $bb->show();

  dev
    The device where your usb ledstrip is at. Defaults to /dev/tty.usbmodem.

  port
    Instead of giving the device you can create the instance of this module
    by directly giving it a Device:SerialPort object. By default the
    Device::SerialPort object is created from the device given in the 'dev'
    parameter.

  gamma
    Specify the gamma correction. Defaults to [1,1,1]

  led_count
    Specify the led count, counting from 1. The default is 60.

  simulate
    Specify if the module should simulate a BlinkyTape onscreen instead of
    using one in the usb port. Defaults to 0 (false). If this is true then
    the port and dev parameters have no effect.

  sleeptime
    Sending data too fast freezes the BlinkyTape. Sleeping for 30
    microseconds between each byte makes sure the atmega processor of the
    BlinkyTape can keep up with the incoming data.

  all_on
    Turns all leds on.

  all_off
    Turns all leds off.

  send_pixel(r,g,b)
    Send the RGB value for the next pixel. Values 0-254 are sent as is,
    value 255 is converted to 254.

  show
    Shows the sent pixels and resets the send_pixel to the first led pixel
    of the strip. This is done by sending a single 255 value byte to the led
    strip.

ABOUT BLINKYTAPE
    Blinkytape is a controllable led strip available at
    http://blinkiverse.com/blinkytape/

USING THE MODULE ON OS X WITHOUT OWNING A BLINKYTAPE
    This module comes with a BlinkyTape simulator. Install X11 server to use
    the simulator: http://xquartz.macosforge.org/landing/

BUGS
    The device is not yet available so the module has been implemented by
    inspecting partly undocumented and unfinished code in other languages.
    Feel free to file any bug reports in Github, patches welcome.

REFERENCE READING
    Communicating with the Arduino in Perl
    http://playground.arduino.cc/interfacing/PERL

    Perl communication to Arduino over serial USB
    http://www.windmeadow.com/node/38

AUTHOR
    Oskari Okko Ojala <okko@cpan.org>

    Based on exampls/Blinkyboard.py in Blinkiverse's BlinkyTape repository
    at https://github.com/blinkiverse/BlinkyTape/ by Max Henstell
    (mhenstell) and Marty McGuire (martymcguire).

COPYRIGHT AND LICENSE
    Copyright (C) Oskari Okko Ojala 2013

    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 you may have available.