A class library for "mbeduino" + "4x4x4 LED Cube shield" demo. \\ There are two demo programs for this library available. Please find those at...\\ (1) Very simplified demo sample code : \\ http://mbed.org/users/okano/programs/LED_Cube444_mbeduino-very_simple_demo/\\ (2) More complex (fancy) demo : \\ http://mbed.org/users/okano/programs/LED_Cube444_mbeduino_demo/\\ Another application code is available for hardware test...\\ http://mbed.org/users/okano/programs/mbeduino_LED_Cube444_test/\\ About the hardware :\\ http://mbed.org/users/okini3939/notebook/mbeduino/ \\ http://www.galileo-7.com/?pid=20015630 \\ - * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *\\ "mbeduino" + "4x4x4 LED Cube shield"のデモ用に作成したクラスライブラリです.\\ このクラスライブラリには2つのデモ・プログラム(サンプル・コード)が用意されています.\\ (1) 単純化したデモ・サンプル\\ http://mbed.org/users/okano/programs/LED_Cube444_mbeduino-very_simple_demo/\\ (2) 点灯バリエーションを盛り込んだデモ\\ http://mbed.org/users/okano/programs/LED_Cube444_mbeduino_demo/\\ またこれとは別に,ハードウェアのテスト用のコードを公開してあります\\ http://mbed.org/users/okano/programs/mbeduino_LED_Cube444_test/\\ ハードウェアについては以下のリンクを参照下さい\\ http://mbed.org/users/okini3939/notebook/mbeduino/ \\ http://www.galileo-7.com/?pid=20015630 \\
Diff: LED_Cube444.h
- Revision:
- 1:86d2cad72832
- Parent:
- 0:6c57a47e2079
--- a/LED_Cube444.h Thu Oct 14 14:26:21 2010 +0000 +++ b/LED_Cube444.h Wed Dec 08 02:03:02 2010 +0000 @@ -1,15 +1,21 @@ -/** mbeduino demo code (with 4x4x4 LED Cube shield) +/** LED Cube 4x4x4 control library * - * This is a simple demo code of mbeduino + 4x4x4 LED Cube shield + * @class LED_Cube444 + * @author Tedd OKANO + * @version 0.51(08-Dec-2010) + * + * This is a library for a demo code of mbeduino + 4x4x4 LED Cube shield * * mbeduino = http://mbed.org/users/okini3939/notebook/mbeduino/ (Japanese) * 4x4x4 LED Cube shield = http://www.galileo-7.com/?pid=20015630 (Japanese) * * Released under the MIT License: http://mbed.org/license/mit * - * revision 0.5 14-Oct-2010 1st release + * revision 0.5 14-Oct-2010 1st release + * revision 0.51 08-Dec-2010 Document reformatted */ + #ifndef _LED_Cube #define _LED_Cube @@ -30,20 +36,133 @@ #define DISPLAY_REFRESH_RETE 0.002 -/** LED_Cube444 +/** LED_Cube444 control class + * + * Example: + * @code + * #include "mbed.h" + * #include "LED_Cube444.h" + * + * LED_Cube444 cube; + * + * int main() { + * + * cube.set_bits( 0, 0xA5A5 ); + * cube.set_bits( 1, 0x5A5A ); + * cube.set_bits( 2, 0xA5A5 ); + * cube.set_bits( 3, 0x5A5A ); + * wait( 0.5 ); * - * + * cube.set_bits( 0, 0x5A5A ); + * cube.set_bits( 1, 0xA5A5 ); + * cube.set_bits( 2, 0x5A5A ); + * cube.set_bits( 3, 0xA5A5 ); + * wait( 0.5 ); + * + * cube.clear(); + * + * int v = 1; + * + * while ( 1 ) { + * + * for ( int x = 0; x < 4; x++ ) { + * for ( int y = 0; y < 4; y++ ) { + * for ( int z = 0; z < 4; z++ ) { + * cube.set_bit( x, y, z, v ); + * wait( 0.01 ); + * } + * } + * } + * + * v = !v; + * } + * } + * @endcode */ + class LED_Cube444 { public: + + /** Class constructor for LED_Cube444 + * + * This will create the instance and start periodical routine to display class internal buffer content to LED cube + */ + LED_Cube444(); + + /** Set bits into cube + * + * The 16 bit word array will be copied into class internal buffer. + * It will be displayed at next update timing by periodical routine + * + * @param v[4] whole cube bits can be represented in this array. each U16 data represents the bits on each planes. + */ + void set_bits( U16 v[4] ); + + /** Set bits into cube + * + * The 16 bit word will be copied into specified layer of class internal buffer. + * It will be displayed at next update timing by periodical routine + * + * @param v Bit pattern for a layer. Overwrites the buffer contents + */ + void set_bits( int layer, U16 v ); + + /** Set bit into cube + * + * Set a specified bit in the buffer. + * It will be displayed at next update timing by periodical routine + * + * @param x Coodinate: x + * @param y Coodinate: y + * @param z Coodinate: z + * @param v Value for the bit (0 or 1) + */ + void set_bit( int x, int y, int z, U16 v ); + + /** Clear + * + * Turn-OFF all LEDs + */ + void clear( void ); + + /** All on + * + * Turn-ON all LEDs + */ + void all_on( void ); + + /** Set bits into cube + * + * The 16 bit word will be copied into all layers of class internal buffer. + * It will be displayed at next update timing by periodical routine + * + * @param v Bit pattern for layers. Overwrites the buffer contents + */ + void set_all_words( int v ); + + /** Setting for synchronous display update + * + * If the "synchronous display" option is set (default) the display + * (main) buffer will be updated each timing if just before layer 0 update. + * This machanism has been made to avoid flicker when main routine update + * buffer so frequently. + * To implement this mechanism, this class has 2 buffers. + * One is called main buffer and another is temporary buffer. + * All API calls that makes modifications of the buffer content will affect to the temp buffer. + * The display will be done with main buffer contents. So the timing of update can be controled by buffer copying. + * If the "synchronous display" option is cleard, the temporary buffer will be used for display (not tested). + * + * @param v TRUE for set, FALSE for clear + */ + void set_synchronous_draw( int v ); private: @@ -55,8 +174,31 @@ U16 temp_buffer[ CUBE_SIZE ]; int syncronous; + /** Displaying + * + * This function will be called by Ticker which set by this class' constructor. + * It displays just one layer by single call. + */ + void display( void ); + + /** Data for serial register + * + * Drives the pins to send serial data to serial register on the shield + * + * @param v Bit pattern for a layer. + */ + void set_serialregister( U16 v ); + + /** Array copy function + * + * Just copies the array. Loop is unrolled because it;s not big array. + * + * @param src Pointer to source array. + * @param trg Pointer to target array. + */ + void buffer_copy( U16 *src, U16 *trg ); };