LCDP565.c
上传用户:zbk8730
上传日期:2017-08-10
资源大小:12168k
文件大小:2k
源码类别:

uCOS

开发平台:

C/C++

  1. /*
  2. *********************************************************************************************************
  3. *                                                uC/GUI
  4. *                        Universal graphic software for embedded applications
  5. *
  6. *                       (c) Copyright 2002, Micrium Inc., Weston, FL
  7. *                       (c) Copyright 2002, SEGGER Microcontroller Systeme GmbH
  8. *
  9. *              礐/GUI is protected by international copyright laws. Knowledge of the
  10. *              source code may not be used to write a similar product. This file may
  11. *              only be used in accordance with a license and should not be redistributed
  12. *              in any way. We appreciate your understanding and fairness.
  13. *
  14. ----------------------------------------------------------------------
  15. File        : LCD565.C
  16. Purpose     : Color conversion routines for emWin GSC
  17. ---------------------------END-OF-HEADER------------------------------
  18. */
  19. #include <stddef.h>           /* needed for definition of NULL */
  20. #include "LCD_Protected.h"    /* inter modul definitions */
  21. /*********************************************************************
  22. *
  23. *       LCD_FIXEDPALETTE == 565
  24. *
  25. *         2^16 = 65536 colors
  26. *
  27. **********************************************************************
  28. */
  29. int LCD_Color2Index_565(LCD_COLOR Color) {
  30.   int r,g,b;
  31.   b = (Color>> (0+3))  &0x1f;
  32.   g = (Color>> (8+2)) &0x3f;
  33.   r = (Color>>(16+3)) &0x1f;
  34.   return b+(g<<5)+(r<<11);
  35. }
  36. LCD_COLOR LCD_Index2Color_565(int Index) {
  37.   unsigned int r,g,b;
  38.   /* Seperate the color masks */
  39.   b = Index & 0x1f;
  40.   g = (Index>>5) & 0x3f;
  41.   r = ((unsigned)Index >> 11) & 0x1f;
  42.   /* Convert the color masks */
  43.   b = r * 255 / 31;
  44.   g = g * 255 / 63;
  45.   r = b * 255 / 31;
  46.   return b + (g<<8) + (((U32)r)<<16);
  47. }