Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependencies: BLE_API mbed-dev-bin nRF51822
Fork of microbit-dal by
MicroBitDisplay.h
00001 /* 00002 The MIT License (MIT) 00003 00004 Copyright (c) 2016 British Broadcasting Corporation. 00005 This software is provided by Lancaster University by arrangement with the BBC. 00006 00007 Permission is hereby granted, free of charge, to any person obtaining a 00008 copy of this software and associated documentation files (the "Software"), 00009 to deal in the Software without restriction, including without limitation 00010 the rights to use, copy, modify, merge, publish, distribute, sublicense, 00011 and/or sell copies of the Software, and to permit persons to whom the 00012 Software is furnished to do so, subject to the following conditions: 00013 00014 The above copyright notice and this permission notice shall be included in 00015 all copies or substantial portions of the Software. 00016 00017 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 00018 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 00019 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 00020 THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 00021 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 00022 FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER 00023 DEALINGS IN THE SOFTWARE. 00024 */ 00025 00026 #ifndef MICROBIT_DISPLAY_H 00027 #define MICROBIT_DISPLAY_H 00028 00029 #include "mbed.h" 00030 #include "MicroBitConfig.h" 00031 #include "ManagedString.h" 00032 #include "MicroBitComponent.h" 00033 #include "MicroBitImage.h" 00034 #include "MicroBitFont.h" 00035 #include "MicroBitMatrixMaps.h" 00036 #include "MicroBitLightSensor.h" 00037 00038 /** 00039 * Event codes raised by MicroBitDisplay 00040 */ 00041 #define MICROBIT_DISPLAY_EVT_ANIMATION_COMPLETE 1 00042 #define MICROBIT_DISPLAY_EVT_LIGHT_SENSE 2 00043 00044 // 00045 // Internal constants 00046 // 00047 #define MICROBIT_DISPLAY_DEFAULT_AUTOCLEAR 1 00048 #define MICROBIT_DISPLAY_SPACING 1 00049 #define MICROBIT_DISPLAY_GREYSCALE_BIT_DEPTH 8 00050 #define MICROBIT_DISPLAY_ANIMATE_DEFAULT_POS -255 00051 00052 enum AnimationMode { 00053 ANIMATION_MODE_NONE, 00054 ANIMATION_MODE_STOPPED, 00055 ANIMATION_MODE_SCROLL_TEXT, 00056 ANIMATION_MODE_PRINT_TEXT, 00057 ANIMATION_MODE_SCROLL_IMAGE, 00058 ANIMATION_MODE_ANIMATE_IMAGE, 00059 ANIMATION_MODE_ANIMATE_IMAGE_WITH_CLEAR, 00060 ANIMATION_MODE_PRINT_CHARACTER 00061 }; 00062 00063 enum DisplayMode { 00064 DISPLAY_MODE_BLACK_AND_WHITE, 00065 DISPLAY_MODE_GREYSCALE, 00066 DISPLAY_MODE_BLACK_AND_WHITE_LIGHT_SENSE 00067 }; 00068 00069 enum DisplayRotation { 00070 MICROBIT_DISPLAY_ROTATION_0, 00071 MICROBIT_DISPLAY_ROTATION_90, 00072 MICROBIT_DISPLAY_ROTATION_180, 00073 MICROBIT_DISPLAY_ROTATION_270 00074 }; 00075 00076 /** 00077 * Class definition for MicroBitDisplay. 00078 * 00079 * A MicroBitDisplay represents the LED matrix array on the micro:bit. 00080 */ 00081 class MicroBitDisplay : public MicroBitComponent 00082 { 00083 uint8_t width; 00084 uint8_t height; 00085 uint8_t brightness; 00086 uint8_t strobeRow; 00087 uint8_t rotation; 00088 uint8_t mode; 00089 uint8_t greyscaleBitMsk; 00090 uint8_t timingCount; 00091 uint32_t col_mask; 00092 00093 Timeout renderTimer; 00094 PortOut *LEDMatrix; 00095 00096 // 00097 // State used by all animation routines. 00098 // 00099 00100 // The animation mode that's currently running (if any) 00101 volatile AnimationMode animationMode; 00102 00103 // The time in milliseconds between each frame update. 00104 uint16_t animationDelay; 00105 00106 // The time in milliseconds since the frame update. 00107 uint16_t animationTick; 00108 00109 // Stop playback of any animations 00110 void stopAnimation(int delay); 00111 00112 // 00113 // State for scrollString() method. 00114 // This is a surprisingly intricate method. 00115 // 00116 // The text being displayed. 00117 ManagedString scrollingText; 00118 00119 // The index of the character currently being displayed. 00120 uint16_t scrollingChar; 00121 00122 // The number of pixels the current character has been shifted on the display. 00123 uint8_t scrollingPosition; 00124 00125 // 00126 // State for printString() method. 00127 // 00128 // The text being displayed. NULL if no message is scheduled for playback. 00129 // We *could* get some reuse in here with the scroll* variables above, 00130 // but best to keep it clean in case kids try concurrent operation (they will!), 00131 // given the small RAM overhead needed to maintain orthogonality. 00132 ManagedString printingText; 00133 00134 // The index of the character currently being displayed. 00135 uint16_t printingChar; 00136 00137 // 00138 // State for scrollImage() method. 00139 // 00140 // The image being displayed. 00141 MicroBitImage scrollingImage; 00142 00143 // The number of pixels the image has been shifted on the display. 00144 int16_t scrollingImagePosition; 00145 00146 // The number of pixels the image is shifted on the display in each quantum. 00147 int8_t scrollingImageStride; 00148 00149 // A pointer to an instance of light sensor, if in use 00150 MicroBitLightSensor* lightSensor; 00151 00152 // Flag to indicate if image has been rendered to screen yet (or not) 00153 bool scrollingImageRendered; 00154 00155 const MatrixMap &matrixMap; 00156 00157 // Internal methods to handle animation. 00158 00159 /** 00160 * Periodic callback, that we use to perform any animations we have running. 00161 */ 00162 void animationUpdate(); 00163 00164 /** 00165 * Called by the display in an interval determined by the brightness of the display, to give an impression 00166 * of brightness. 00167 */ 00168 void renderFinish(); 00169 00170 /** 00171 * Translates a bit mask to a bit mask suitable for the nrf PORT0 and PORT1. 00172 * Brightness has two levels on, or off. 00173 */ 00174 void render(); 00175 00176 /** 00177 * Renders the current image, and drops the fourth frame to allow for 00178 * sensors that require the display to operate. 00179 */ 00180 void renderWithLightSense(); 00181 00182 /** 00183 * Translates a bit mask into a timer interrupt that gives the appearence of greyscale. 00184 */ 00185 void renderGreyscale(); 00186 00187 /** 00188 * Internal scrollText update method. 00189 * Shift the screen image by one pixel to the left. If necessary, paste in the next char. 00190 */ 00191 void updateScrollText(); 00192 00193 /** 00194 * Internal printText update method. 00195 * Paste the next character in the string. 00196 */ 00197 void updatePrintText(); 00198 00199 /** 00200 * Internal scrollImage update method. 00201 * Paste the stored bitmap at the appropriate point. 00202 */ 00203 void updateScrollImage(); 00204 00205 /** 00206 * Internal animateImage update method. 00207 * Paste the stored bitmap at the appropriate point and stop on the last frame. 00208 */ 00209 void updateAnimateImage(); 00210 00211 /** 00212 * Broadcasts an event onto the defult EventModel indicating that the 00213 * current animation has completed. 00214 */ 00215 void sendAnimationCompleteEvent(); 00216 00217 /** 00218 * Blocks the current fiber until the display is available (i.e. does not effect is being displayed). 00219 * Animations are queued until their time to display. 00220 */ 00221 void waitForFreeDisplay(); 00222 00223 /** 00224 * Blocks the current fiber until the current animation has finished. 00225 * If the scheduler is not running, this call will essentially perform a spinning wait. 00226 */ 00227 void fiberWait(); 00228 00229 /** 00230 * Enables or disables the display entirely, and releases the pins for other uses. 00231 * 00232 * @param enableDisplay true to enabled the display, or false to disable it. 00233 */ 00234 void setEnable(bool enableDisplay); 00235 00236 public: 00237 // The mutable bitmap buffer being rendered to the LED matrix. 00238 MicroBitImage image; 00239 00240 /** 00241 * Constructor. 00242 * 00243 * Create a software representation the micro:bit's 5x5 LED matrix. 00244 * The display is initially blank. 00245 * 00246 * @param id The id the display should use when sending events on the MessageBus. Defaults to MICROBIT_ID_DISPLAY. 00247 * 00248 * @param map The mapping information that relates pin inputs/outputs to physical screen coordinates. 00249 * Defaults to microbitMatrixMap, defined in MicroBitMatrixMaps.h. 00250 * 00251 * @code 00252 * MicroBitDisplay display; 00253 * @endcode 00254 */ 00255 MicroBitDisplay(uint16_t id = MICROBIT_ID_DISPLAY, const MatrixMap &map = microbitMatrixMap); 00256 00257 /** 00258 * Stops any currently running animation, and any that are waiting to be displayed. 00259 */ 00260 void stopAnimation(); 00261 00262 /** 00263 * Frame update method, invoked periodically to strobe the display. 00264 */ 00265 virtual void systemTick(); 00266 00267 /** 00268 * Prints the given character to the display, if it is not in use. 00269 * 00270 * @param c The character to display. 00271 * 00272 * @param delay Optional parameter - the time for which to show the character. Zero displays the character forever, 00273 * or until the Displays next use. 00274 * 00275 * @return MICROBIT_OK, MICROBIT_BUSY is the screen is in use, or MICROBIT_INVALID_PARAMETER. 00276 * 00277 * @code 00278 * display.printAsync('p'); 00279 * display.printAsync('p',100); 00280 * @endcode 00281 */ 00282 int printCharAsync(char c, int delay = 0); 00283 00284 /** 00285 * Prints the given ManagedString to the display, one character at a time. 00286 * Returns immediately, and executes the animation asynchronously. 00287 * 00288 * @param s The string to display. 00289 * 00290 * @param delay The time to delay between characters, in milliseconds. Must be > 0. 00291 * Defaults to: MICROBIT_DEFAULT_PRINT_SPEED. 00292 * 00293 * @return MICROBIT_OK, or MICROBIT_INVALID_PARAMETER. 00294 * 00295 * @code 00296 * display.printAsync("abc123",400); 00297 * @endcode 00298 */ 00299 int printAsync(ManagedString s, int delay = MICROBIT_DEFAULT_PRINT_SPEED); 00300 00301 /** 00302 * Prints the given image to the display, if the display is not in use. 00303 * Returns immediately, and executes the animation asynchronously. 00304 * 00305 * @param i The image to display. 00306 * 00307 * @param x The horizontal position on the screen to display the image. Defaults to 0. 00308 * 00309 * @param y The vertical position on the screen to display the image. Defaults to 0. 00310 * 00311 * @param alpha Treats the brightness level '0' as transparent. Defaults to 0. 00312 * 00313 * @param delay The time to delay between characters, in milliseconds. Defaults to 0. 00314 * 00315 * @code 00316 * MicrobitImage i("1,1,1,1,1\n1,1,1,1,1\n"); 00317 * display.print(i,400); 00318 * @endcode 00319 */ 00320 int printAsync(MicroBitImage i, int x = 0, int y = 0, int alpha = 0, int delay = 0); 00321 00322 /** 00323 * Prints the given character to the display. 00324 * 00325 * @param c The character to display. 00326 * 00327 * @param delay Optional parameter - the time for which to show the character. Zero displays the character forever, 00328 * or until the Displays next use. 00329 * 00330 * @return MICROBIT_OK, MICROBIT_CANCELLED or MICROBIT_INVALID_PARAMETER. 00331 * 00332 * @code 00333 * display.printAsync('p'); 00334 * display.printAsync('p',100); 00335 * @endcode 00336 */ 00337 int printChar(char c, int delay = 0); 00338 00339 /** 00340 * Prints the given string to the display, one character at a time. 00341 * 00342 * Blocks the calling thread until all the text has been displayed. 00343 * 00344 * @param s The string to display. 00345 * 00346 * @param delay The time to delay between characters, in milliseconds. Defaults 00347 * to: MICROBIT_DEFAULT_PRINT_SPEED. 00348 * 00349 * @return MICROBIT_OK, MICROBIT_CANCELLED or MICROBIT_INVALID_PARAMETER. 00350 * 00351 * @code 00352 * display.print("abc123",400); 00353 * @endcode 00354 */ 00355 int print(ManagedString s, int delay = MICROBIT_DEFAULT_PRINT_SPEED); 00356 00357 /** 00358 * Prints the given image to the display. 00359 * Blocks the calling thread until all the image has been displayed. 00360 * 00361 * @param i The image to display. 00362 * 00363 * @param x The horizontal position on the screen to display the image. Defaults to 0. 00364 * 00365 * @param y The vertical position on the screen to display the image. Defaults to 0. 00366 * 00367 * @param alpha Treats the brightness level '0' as transparent. Defaults to 0. 00368 * 00369 * @param delay The time to display the image for, or zero to show the image forever. Defaults to 0. 00370 * 00371 * @return MICROBIT_OK, MICROBIT_BUSY if the display is already in use, or MICROBIT_INVALID_PARAMETER. 00372 * 00373 * @code 00374 * MicrobitImage i("1,1,1,1,1\n1,1,1,1,1\n"); 00375 * display.print(i,400); 00376 * @endcode 00377 */ 00378 int print(MicroBitImage i, int x = 0, int y = 0, int alpha = 0, int delay = 0); 00379 00380 /** 00381 * Scrolls the given string to the display, from right to left. 00382 * Returns immediately, and executes the animation asynchronously. 00383 * 00384 * @param s The string to display. 00385 * 00386 * @param delay The time to delay between characters, in milliseconds. Defaults 00387 * to: MICROBIT_DEFAULT_SCROLL_SPEED. 00388 * 00389 * @return MICROBIT_OK, MICROBIT_BUSY if the display is already in use, or MICROBIT_INVALID_PARAMETER. 00390 * 00391 * @code 00392 * display.scrollAsync("abc123",100); 00393 * @endcode 00394 */ 00395 int scrollAsync(ManagedString s, int delay = MICROBIT_DEFAULT_SCROLL_SPEED); 00396 00397 /** 00398 * Scrolls the given image across the display, from right to left. 00399 * Returns immediately, and executes the animation asynchronously. 00400 * 00401 * @param image The image to display. 00402 * 00403 * @param delay The time between updates, in milliseconds. Defaults 00404 * to: MICROBIT_DEFAULT_SCROLL_SPEED. 00405 * 00406 * @param stride The number of pixels to shift by in each update. Defaults to MICROBIT_DEFAULT_SCROLL_STRIDE. 00407 * 00408 * @return MICROBIT_OK, MICROBIT_BUSY if the display is already in use, or MICROBIT_INVALID_PARAMETER. 00409 * 00410 * @code 00411 * MicrobitImage i("1,1,1,1,1\n1,1,1,1,1\n"); 00412 * display.scrollAsync(i,100,1); 00413 * @endcode 00414 */ 00415 int scrollAsync(MicroBitImage image, int delay = MICROBIT_DEFAULT_SCROLL_SPEED, int stride = MICROBIT_DEFAULT_SCROLL_STRIDE); 00416 00417 /** 00418 * Scrolls the given string across the display, from right to left. 00419 * Blocks the calling thread until all text has been displayed. 00420 * 00421 * @param s The string to display. 00422 * 00423 * @param delay The time to delay between characters, in milliseconds. Defaults 00424 * to: MICROBIT_DEFAULT_SCROLL_SPEED. 00425 * 00426 * @return MICROBIT_OK, MICROBIT_CANCELLED or MICROBIT_INVALID_PARAMETER. 00427 * 00428 * @code 00429 * display.scroll("abc123",100); 00430 * @endcode 00431 */ 00432 int scroll(ManagedString s, int delay = MICROBIT_DEFAULT_SCROLL_SPEED); 00433 00434 /** 00435 * Scrolls the given image across the display, from right to left. 00436 * Blocks the calling thread until all the text has been displayed. 00437 * 00438 * @param image The image to display. 00439 * 00440 * @param delay The time between updates, in milliseconds. Defaults 00441 * to: MICROBIT_DEFAULT_SCROLL_SPEED. 00442 * 00443 * @param stride The number of pixels to shift by in each update. Defaults to MICROBIT_DEFAULT_SCROLL_STRIDE. 00444 * 00445 * @return MICROBIT_OK, MICROBIT_CANCELLED or MICROBIT_INVALID_PARAMETER. 00446 * 00447 * @code 00448 * MicrobitImage i("1,1,1,1,1\n1,1,1,1,1\n"); 00449 * display.scroll(i,100,1); 00450 * @endcode 00451 */ 00452 int scroll(MicroBitImage image, int delay = MICROBIT_DEFAULT_SCROLL_SPEED, int stride = MICROBIT_DEFAULT_SCROLL_STRIDE); 00453 00454 /** 00455 * "Animates" the current image across the display with a given stride, finishing on the last frame of the animation. 00456 * Returns immediately. 00457 * 00458 * @param image The image to display. 00459 * 00460 * @param delay The time to delay between each update of the display, in milliseconds. 00461 * 00462 * @param stride The number of pixels to shift by in each update. 00463 * 00464 * @param startingPosition the starting position on the display for the animation 00465 * to begin at. Defaults to MICROBIT_DISPLAY_ANIMATE_DEFAULT_POS. 00466 * 00467 * @param autoClear defines whether or not the display is automatically cleared once the animation is complete. By default, the display is cleared. Set this parameter to zero to disable the autoClear operation. 00468 * 00469 * @return MICROBIT_OK, MICROBIT_BUSY if the screen is in use, or MICROBIT_INVALID_PARAMETER. 00470 * 00471 * @code 00472 * const int heart_w = 10; 00473 * const int heart_h = 5; 00474 * const uint8_t heart[] = { 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, }; 00475 * 00476 * MicroBitImage i(heart_w,heart_h,heart); 00477 * display.animateAsync(i,100,5); 00478 * @endcode 00479 */ 00480 int animateAsync(MicroBitImage image, int delay, int stride, int startingPosition = MICROBIT_DISPLAY_ANIMATE_DEFAULT_POS, int autoClear = MICROBIT_DISPLAY_DEFAULT_AUTOCLEAR); 00481 00482 /** 00483 * "Animates" the current image across the display with a given stride, finishing on the last frame of the animation. 00484 * Blocks the calling thread until the animation is complete. 00485 * 00486 * 00487 * @param delay The time to delay between each update of the display, in milliseconds. 00488 * 00489 * @param stride The number of pixels to shift by in each update. 00490 * 00491 * @param startingPosition the starting position on the display for the animation 00492 * to begin at. Defaults to MICROBIT_DISPLAY_ANIMATE_DEFAULT_POS. 00493 * 00494 * @param autoClear defines whether or not the display is automatically cleared once the animation is complete. By default, the display is cleared. Set this parameter to zero to disable the autoClear operation. 00495 * 00496 * @return MICROBIT_OK, MICROBIT_CANCELLED or MICROBIT_INVALID_PARAMETER. 00497 * 00498 * @code 00499 * const int heart_w = 10; 00500 * const int heart_h = 5; 00501 * const uint8_t heart[] = { 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1, 0, 1, 1, 1, 0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, }; 00502 * 00503 * MicroBitImage i(heart_w,heart_h,heart); 00504 * display.animate(i,100,5); 00505 * @endcode 00506 */ 00507 int animate(MicroBitImage image, int delay, int stride, int startingPosition = MICROBIT_DISPLAY_ANIMATE_DEFAULT_POS, int autoClear = MICROBIT_DISPLAY_DEFAULT_AUTOCLEAR); 00508 00509 /** 00510 * Configures the brightness of the display. 00511 * 00512 * @param b The brightness to set the brightness to, in the range 0 - 255. 00513 * 00514 * @return MICROBIT_OK, or MICROBIT_INVALID_PARAMETER 00515 * 00516 * @code 00517 * display.setBrightness(255); //max brightness 00518 * @endcode 00519 */ 00520 int setBrightness(int b); 00521 00522 /** 00523 * Configures the mode of the display. 00524 * 00525 * @param mode The mode to swap the display into. One of: DISPLAY_MODE_GREYSCALE, 00526 * DISPLAY_MODE_BLACK_AND_WHITE, DISPLAY_MODE_BLACK_AND_WHITE_LIGHT_SENSE 00527 * 00528 * @code 00529 * display.setDisplayMode(DISPLAY_MODE_GREYSCALE); //per pixel brightness 00530 * @endcode 00531 */ 00532 void setDisplayMode(DisplayMode mode); 00533 00534 /** 00535 * Retrieves the mode of the display. 00536 * 00537 * @return the current mode of the display 00538 */ 00539 int getDisplayMode(); 00540 00541 /** 00542 * Fetches the current brightness of this display. 00543 * 00544 * @return the brightness of this display, in the range 0..255. 00545 * 00546 * @code 00547 * display.getBrightness(); //the current brightness 00548 * @endcode 00549 */ 00550 int getBrightness(); 00551 00552 /** 00553 * Rotates the display to the given position. 00554 * 00555 * Axis aligned values only. 00556 * 00557 * @code 00558 * display.rotateTo(MICROBIT_DISPLAY_ROTATION_180); //rotates 180 degrees from original orientation 00559 * @endcode 00560 */ 00561 void rotateTo(DisplayRotation position); 00562 00563 /** 00564 * Enables the display, should only be called if the display is disabled. 00565 * 00566 * @code 00567 * display.enable(); //Enables the display mechanics 00568 * @endcode 00569 * 00570 * @note Only enables the display if the display is currently disabled. 00571 */ 00572 void enable(); 00573 00574 /** 00575 * Disables the display, which releases control of the GPIO pins used by the display, 00576 * which are exposed on the edge connector. 00577 * 00578 * @code 00579 * display.disable(); //disables the display 00580 * @endcode 00581 * 00582 * @note Only disables the display if the display is currently enabled. 00583 */ 00584 void disable(); 00585 00586 /** 00587 * Clears the display of any remaining pixels. 00588 * 00589 * `display.image.clear()` can also be used! 00590 * 00591 * @code 00592 * display.clear(); //clears the display 00593 * @endcode 00594 */ 00595 void clear(); 00596 00597 /** 00598 * Updates the font that will be used for display operations. 00599 * 00600 * @param font the new font that will be used to render characters. 00601 * 00602 * @note DEPRECATED! Please use MicroBitFont::setSystemFont() instead. 00603 */ 00604 void setFont(MicroBitFont font); 00605 00606 /** 00607 * Retrieves the font object used for rendering characters on the display. 00608 * 00609 * @note DEPRECATED! Please use MicroBitFont::getSystemFont() instead. 00610 */ 00611 MicroBitFont getFont(); 00612 00613 /** 00614 * Captures the bitmap currently being rendered on the display. 00615 * 00616 * @return a MicroBitImage containing the captured data. 00617 */ 00618 MicroBitImage screenShot(); 00619 00620 /** 00621 * Gives a representative figure of the light level in the current environment 00622 * where are micro:bit is situated. 00623 * 00624 * Internally, it constructs an instance of a MicroBitLightSensor if not already configured 00625 * and sets the display mode to DISPLAY_MODE_BLACK_AND_WHITE_LIGHT_SENSE. 00626 * 00627 * This also changes the tickPeriod to MICROBIT_LIGHT_SENSOR_TICK_SPEED so 00628 * that the display does not suffer from artifacts. 00629 * 00630 * @return an indicative light level in the range 0 - 255. 00631 * 00632 * @note this will return 0 on the first call to this method, a light reading 00633 * will be available after the display has activated the light sensor for the 00634 * first time. 00635 */ 00636 int readLightLevel(); 00637 00638 /** 00639 * Destructor for MicroBitDisplay, where we deregister this instance from the array of system components. 00640 */ 00641 ~MicroBitDisplay(); 00642 }; 00643 00644 #endif
Generated on Tue Jul 12 2022 21:36:42 by
