[![Build Status](https://travis-ci.org/sanko/RPi-UnicornHatHD.svg?branch=master)](https://travis-ci.org/sanko/RPi-UnicornHatHD) [![MetaCPAN Release](https://badge.fury.io/pl/RPi-UnicornHatHD.svg)](https://metacpan.org/release/RPi-UnicornHatHD) # NAME RPi::UnicornHatHD - Use Pimoroni's Awesome Unicorn HAT HD in Perl # SYNOPSIS ```perl use RPi::UnicornHatHD; my $display = RPi::UnicornHatHD->new(); while (1) { # Mini rave! $display->set_all(sprintf '#%06X', int rand(hex 'FFFFFF')); for (0 .. 100, reverse 0 .. 100) { $display->brightness($_ / 100); $display->show(); } } ``` # DESCRIPTION Pimoroni's Unicorn HAT HD crams 256 RGB LEDs, in a 16x16 matrix, onto a single HAT for your Raspberry Pi. Use it for scrolling news or stock quotes. Mount it somewhere as a mood light. Build a binary clock. Uh. I don't know, you'll think of something. # METHODS Use these to make pretty pictures. ## `new()` ``` $display = RPi::UnicornHatHD->new(); ``` Creates a new object representing your Unicorn Hat HD. Obviously. ## `brightness($b)` ``` $display->brightness(.25); # For tinkering at 1a ``` Set the display brightness between `0.0` and `1.0`. The default is `0.5`. ## `clear()` ``` $display->clear; ``` Clears the display matrix. This does not clear the display; it simply resets the 'canvas' for you. ## `get_pixel($x, $y)` ```perl my ($r, $g, $b) = $display->get_pixel(10, 15); ``` Returns the color this pixel will display. ## `off()` ``` $display->off; ``` Clears the display matrix and immediately updates the Unicorn Hat HD. This turns off all the pixels. ## `rotation($r)` ``` $display->rotation(180); ``` Set the display rotation in degrees. Actual rotation will be snapped to the nearest 90 degrees. ## `set_all($r, $g, $b)` ``` $display->set_all(0xFF, 0, 0); $display->set_all('#FF0000'); ``` Turns the entire display a single color. Either... ``` $r = Amount of red from 0 to 255 $g = Amount of green from 0 to 255 $b = Amount of blue from 0 to 255 ``` ...or... ``` $h = Hex triplet from #000000 to #FFFFFF ``` ## `set_pixel($x, $y, $r, $g, $b)` ```perl for my $x (1..10) { $display->set_pixel($x, 10, 1, 1, 1); } $display->set_pixel(0, 0, '#FFF000'); ``` Set a single pixel to RGB color. ``` $x = Horizontal position from 0 to 15 $y = Vertical position from 0 to 15 ``` ...and either... ``` $r = Amount of red from 0 to 255 $g = Amount of green from 0 to 255 $b = Amount of blue from 0 to 255 ``` ...or... ``` $h = Hex triplet from #000000 to #FFFFFF ``` ## `show()` ``` $display->show; ``` Outputs the contents of the matrix buffer to your Unicorn HAT HD. # SEE ALSO - Buy one: [http://shop.pimoroni.com/products/unicorn-hat-hd](http://shop.pimoroni.com/products/unicorn-hat-hd) - GPIO Pinout: [http://pinout.xyz/pinout/unicorn\_hat\_hd](http://pinout.xyz/pinout/unicorn_hat_hd) - Github: [https://github.com/sanko/RPi-UnicornHatHD](https://github.com/sanko/RPi-UnicornHatHD) # LICENSE Copyright (C) Sanko Robinson. This library is free software; you can redistribute it and/or modify it under the terms of the Artistic License 2. # AUTHOR Sanko Robinson <sanko@cpan.org>