亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? lcdl0mag.c

?? ucgui在ARM44B0目標板上的移植代碼支持16級灰度
?? C
字號:
/*********************************************************************
*                SEGGER MICROCONTROLLER SYSTEME GmbH                 *
*        Solutions for real time microcontroller applications        *
**********************************************************************
*                                                                    *
*        (c) 2002         SEGGER Microcontroller Systeme GmbH        *
*                                                                    *
*        Internet: www.segger.com    Support:  support@segger.com    *
*                                                                    *
**********************************************************************

**** emWin/GSC Grafical user interface for embedded applications ****
emWin is protected by international copyright laws. Knowledge of the
source code may not be used to write a similar product. This file may
only be used in accordance with a license and should not be re-
distributed in any way. We appreciate your understanding and fairness.
----------------------------------------------------------------------
File        : LCD.c
Purpose     : Link between GUI and LCD_L0
              Performs most of the clipping.
---------------------------END-OF-HEADER------------------------------
*/

#include <stddef.h>             /* needed for definition of NULL */
#include "GUI_Private.h"
#include "GUIDebug.h"
#include "LCD_Private.H"      /* private modul definitions & config */



#if LCD_XMAG > 2
  #error Not yet supported
#endif


#if LCD_XMAG == 2

static const U8 abData12[16] = {
  0x0, 0x3, 0xc, 0xf, 0x30, 0x33, 0x3c, 0x3f, 0xC0, 0xC3, 0xCc, 0xcf, 0xf0, 0xf3, 0xfc, 0xff
};

static const U8 abData22[16] = {
  0x0,   0x5, 0x5*2, 0x5*3,
  0x50*1+0x0, 0x50*1+0x5, 0x50*1+0x5*2, 0x50*1+0x5*3,
  0x50*2+0x0, 0x50*2+0x5, 0x50*2+0x5*2, 0x50*2+0x5*3,
  0x50*3+0x0, 0x50*3+0x5, 0x50*3+0x5*2, 0x50*3+0x5*3
};

static const U8 abData32[16] = {
  0x0, 0x11, 0x22, 0x33,
  0x44, 0x55, 0x66, 0x77,
  0x88, 0x99, 0xaa, 0xbb,
  0xcc, 0xdd, 0xee, 0xff
};

static void DrawBitline(int x0, int y0, int xsize, int BPP, const U8*pData, int Diff, const LCD_PIXELINDEX* pTrans) {
  union {
    U8  ab[100];     /* Byte Buffer */
    U16 au16[50];    /* Word Buffer */
  } Buffer;
  int i;
  int NumPixels;
  int NumPixelsMax = sizeof(Buffer.ab)*8/BPP/LCD_XMAG;
  while (xsize >0) {
    int iOff =0;
    NumPixels = (xsize < NumPixelsMax) ? xsize : NumPixelsMax;
    switch (BPP) {
    case 1:
      for (i=0; i<NumPixels; i+=8) {
        /* load the byte */
        U16 Data;
        if (Diff) {
          Data = ((*pData) << 8) | (*(pData+1));
          Data >>= 8-Diff;
          Data &= 0xff;
        } else {
          Data = *pData;
        }
        pData++;
        Buffer.ab[iOff++] = abData12[Data>>4]; 
        Buffer.ab[iOff++] = abData12[Data&15]; 
      }
      break;
    case 2:
      for (i=0; i<NumPixels; i+=4) {
        /* load the byte */
        U16 Data;
        if (Diff) {
          Data = ((*pData) << 8) | (*(pData+1));
          Data >>= 8-(Diff<<1);
          Data &= 0xff;
        } else {
          Data = *pData;
        }
        pData++;
        Buffer.ab[iOff++] = abData22[Data>>4]; 
        Buffer.ab[iOff++] = abData22[Data&15]; 
      }
      break;
    case 4:
      for (i=0; i<NumPixels; i+=2) {
        /* load the byte */
        U16 Data;
        if (Diff) {
          Data = ((*pData) << 8) | (*(pData+1));
          Data >>= 8-(Diff<<2);
          Data &= 0xff;
        } else {
          Data = *pData;
        }
        pData++;
        Buffer.ab[iOff++] = abData32[Data>>4]; 
        Buffer.ab[iOff++] = abData32[Data&15]; 
      }
      break;
    case 8:
      for (i=0; i<NumPixels; i++) {
        #if LCD_XMAG > 2
          memset (&Buffer.ab[i*LCD_XMAG], *(pData+i), LCD_XMAG);
        #else
          Buffer.ab[i*LCD_XMAG] = Buffer.ab[i*LCD_XMAG+1] = *pData++; 
        #endif
      }
      break;
    case 16:
      for (i=0; i<NumPixels; i++) {
        #if LCD_XMAG > 2
          memset (&Buffer.ab[i*LCD_XMAG], *(pData+i), LCD_XMAG);
        #else
          Buffer.au16[i*LCD_XMAG] = Buffer.au16[i*LCD_XMAG+1] = *(U16*)pData;
          pData += 2; /* Move to next word */
        #endif
      }
      break;
    }
    LCD_L0_DrawBitmap(x0 + Diff * LCD_XMAG, y0, NumPixels * LCD_XMAG, LCD_YMAG, BPP, 0, Buffer.ab, 0, pTrans);
    x0 += NumPixels*LCD_XMAG;
    xsize -= NumPixels;
  }
}




void LCD_L0_MAG_DrawBitmap   (int x0, int y0, int xsize, int ysize,
                       int BPP, int BytesPerLine,
                       const U8* pData, int Diff,
                       const LCD_PIXELINDEX* pTrans)
{
  int iLine;
  y0 *= LCD_YMAG;
  x0 *= LCD_XMAG;
  for (iLine = 0; iLine < ysize; iLine++) {
    #if LCD_XMAG == 1
      LCD_L0_DrawBitmap(x0, y0, xsize, LCD_YMAG, BPP, 0, pData, Diff, pTrans);
    #else
      DrawBitline(x0, y0, xsize, BPP, pData, Diff, pTrans);
    #endif
    y0+= LCD_YMAG;
    pData += BytesPerLine;
  }
}




void         LCD_L0_MAG_DrawHLine    (int x0, int y0,  int x1) {
  x0 *= LCD_XMAG;
  x1 = x1*(LCD_XMAG) + LCD_XMAG-1;
  y0 *= LCD_YMAG;
  LCD_L0_FillRect(x0, y0, x1, y0 + LCD_YMAG-1);
}

void         LCD_L0_MAG_DrawVLine    (int x0 , int y0,  int y1) {
  y0 *= LCD_YMAG;
  y1 = y1*(LCD_YMAG) + LCD_YMAG-1;
  x0 *= LCD_XMAG;
  LCD_L0_FillRect(x0, y0, x0 + LCD_XMAG-1, y1);
}

void         LCD_L0_MAG_FillRect     (int x0, int y0, int x1, int y1) {
  y0 *= LCD_YMAG;
  y1 = y1*(LCD_YMAG) + LCD_YMAG-1;
  x0 *= LCD_XMAG;
  x1 = x1*(LCD_XMAG) + LCD_XMAG-1;
  LCD_L0_FillRect(x0, y0, x1, y1);
}

unsigned int LCD_L0_MAG_GetPixelIndex(int x, int y) {
  return LCD_L0_GetPixelIndex(x* LCD_XMAG, y* LCD_YMAG);
}

void         LCD_L0_MAG_SetPixelIndex(int x, int y, int ColorIndex) {
  int ix, iy;
  y *= LCD_YMAG;
  x *= LCD_XMAG;
  for (iy=0; iy< LCD_YMAG; iy++) {
    for (ix=0; ix< LCD_XMAG; ix++) {
      LCD_L0_SetPixelIndex(x+ix, y+iy, ColorIndex);
    }
  }
}

void         LCD_L0_MAG_XorPixel     (int x, int y) {
  int ix, iy;
  y *= LCD_YMAG;
  x *= LCD_XMAG;
  for (iy=0; iy< LCD_YMAG; iy++) {
    for (ix=0; ix< LCD_XMAG; ix++) {
      LCD_L0_XorPixel(x+ix, y+iy);
    }
  }
}

#else

void LCDL0Mag(void) { } /* avoid empty object files */

#endif





?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区三区四区五区美女 | 色婷婷av一区二区三区gif| 色婷婷狠狠综合| 国产丝袜欧美中文另类| 亚洲成人av在线电影| 成人一道本在线| 欧美大片顶级少妇| 午夜精品久久久久久久久久| av一二三不卡影片| 久久久久久久电影| 美女一区二区三区| 欧美日韩国产一二三| 中文欧美字幕免费| 韩国精品一区二区| 欧美一区二区三区免费在线看| 亚洲最大色网站| 97se亚洲国产综合自在线| 久久久亚洲午夜电影| 秋霞电影一区二区| 欧亚一区二区三区| 一区二区三区中文字幕精品精品| www.欧美精品一二区| 国产免费观看久久| 国产成人免费视频 | 色av成人天堂桃色av| 国产精品久久久久久久久免费樱桃 | 亚洲精品成a人| 91污片在线观看| 亚洲精选视频在线| 91久久精品国产91性色tv | 免费观看久久久4p| 日韩视频免费观看高清完整版 | 亚洲人快播电影网| 91在线观看高清| 洋洋成人永久网站入口| 欧美日韩在线亚洲一区蜜芽| 亚洲国产精品一区二区久久恐怖片| 在线视频观看一区| 亚洲午夜免费视频| 日韩一区二区在线播放| 久久99久久久久| 久久综合成人精品亚洲另类欧美 | 婷婷国产v国产偷v亚洲高清| 欧美三级在线播放| 久久99精品国产麻豆婷婷洗澡| 精品国精品自拍自在线| 国产剧情一区二区三区| 欧美极品aⅴ影院| 91美女蜜桃在线| 亚洲电影中文字幕在线观看| 日韩一级在线观看| 国产98色在线|日韩| 日韩伦理电影网| 91麻豆精品国产| 国产酒店精品激情| 亚洲欧美二区三区| 69堂成人精品免费视频| 狠狠色丁香婷婷综合| 国产精品乱码妇女bbbb| 欧美亚洲国产bt| 精品一区中文字幕| 最新热久久免费视频| 91精品国产色综合久久久蜜香臀| 国产主播一区二区| 一片黄亚洲嫩模| 久久网这里都是精品| 色婷婷综合在线| 国产一区二区在线电影| 亚洲免费在线播放| 久久色中文字幕| 91精彩视频在线观看| 国产原创一区二区| 亚洲国产精品综合小说图片区| 日韩欧美中文字幕制服| 91美女在线视频| 久久er99热精品一区二区| 一区二区视频在线看| 久久综合九色综合欧美98| 91美女福利视频| 国产精品18久久久久久久网站| 亚洲国产精品欧美一二99| 国产精品毛片a∨一区二区三区| 制服视频三区第一页精品| 99视频一区二区| 国产在线视频一区二区三区| 亚洲第一av色| 亚洲日本欧美天堂| 中文字幕精品在线不卡| 精品久久久久久综合日本欧美| 欧美制服丝袜第一页| 99久久精品情趣| 91天堂素人约啪| 精品一区二区久久久| 日韩在线观看一区二区| 亚洲影院理伦片| 亚洲欧洲另类国产综合| 久久精品一区二区三区不卡牛牛| 日韩欧美国产电影| 91精品国产一区二区| 欧美日韩在线观看一区二区| 一本久道中文字幕精品亚洲嫩| 成人激情免费网站| 国产麻豆精品视频| 狠狠色丁香久久婷婷综合丁香| 秋霞午夜av一区二区三区| 五月激情综合色| 日韩极品在线观看| 亚洲高清视频在线| 亚洲成av人片| 日韩不卡一区二区三区| 亚洲444eee在线观看| 亚洲一区在线观看视频| 亚洲最新视频在线观看| 亚洲香肠在线观看| 亚洲成人免费看| 视频一区二区中文字幕| 天天爽夜夜爽夜夜爽精品视频| 午夜视频一区在线观看| 蜜桃视频一区二区| 伦理电影国产精品| 麻豆精品国产91久久久久久| 久久99精品一区二区三区三区| 国产综合久久久久久鬼色 | 琪琪久久久久日韩精品| 麻豆一区二区三| 国产美女视频一区| 成人免费毛片a| 91精品办公室少妇高潮对白| 欧美日韩国产123区| 欧美成人精品高清在线播放 | 国产盗摄女厕一区二区三区| 国产91色综合久久免费分享| 99久久亚洲一区二区三区青草| 91美女片黄在线观看| 欧美日韩一区二区三区四区| 日韩欧美高清在线| 欧美激情一区二区三区四区| 亚洲精品成人a在线观看| 日日骚欧美日韩| 国产高清在线精品| 色国产综合视频| 欧美电视剧在线观看完整版| 欧美国产激情二区三区| 亚洲美女一区二区三区| 蜜桃精品视频在线| 99精品国产91久久久久久| 欧美人xxxx| 日韩一区在线免费观看| 日本人妖一区二区| www.欧美亚洲| 欧美一级电影网站| 成人欧美一区二区三区白人| 日韩精品国产欧美| 91在线一区二区| 欧美一区二区三区爱爱| 国产精品久久久久7777按摩| 日韩激情视频在线观看| www.亚洲国产| 日韩一区二区三区视频| 亚洲欧美偷拍另类a∨色屁股| 麻豆精品视频在线| 色婷婷综合久久久久中文 | 亚洲一区二区三区中文字幕| 国模大尺度一区二区三区| 欧美色图天堂网| 国产精品久久99| 成人夜色视频网站在线观看| 欧美午夜影院一区| 中文字幕一区不卡| 国产精品一二一区| 日韩视频免费观看高清在线视频| 亚洲乱码国产乱码精品精小说 | 亚洲欧美日本韩国| 国产91在线观看| 2023国产一二三区日本精品2022| 亚洲一区免费视频| 91丨国产丨九色丨pron| 国产欧美视频在线观看| 国内精品国产成人国产三级粉色 | 国产河南妇女毛片精品久久久| 欧美日韩三级视频| 一卡二卡欧美日韩| 91黄色免费版| 亚洲免费观看高清| 91麻豆成人久久精品二区三区| 国产亚洲精品超碰| 国产成人av电影在线观看| 精品美女在线播放| 老司机午夜精品| 制服丝袜av成人在线看| 天天综合色天天综合| 欧美亚洲丝袜传媒另类| 亚洲美女免费视频| 色综合久久99| 亚洲小少妇裸体bbw| 欧美日韩精品系列| 午夜久久久久久| 欧美一区二区精美| 老司机免费视频一区二区三区| 日韩午夜激情av|