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

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

?? lcdmemc.c

?? s3c44b0+ucgui+初始化的一個版本
?? C
?? 第 1 頁 / 共 4 頁
字號:
  case 7:                                         \
    p+=2;                                         \
    *p = (*p&~(7<<0))|(c);                        \
    break;                                        \
  }                                               \
}

#elif (LCD_BITSPERPIXEL == 6)

void SetPixelPhys222(int x, int y, LCD_PIXELINDEX c) {
  U8 LCD_VRAMTYPE* p0 = OFF2PTR_0(XY2OFF(x,y));
  U8 LCD_VRAMTYPE* p1 = OFF2PTR_1(XY2OFF(x,y));
  U8 c0 = ((c & 0x20) >> 3) + ((c & 0x08) >> 2) + ((c & 0x02) >> 1);
  U8 c1 = ((c & 0x10) >> 2) + ((c & 0x04) >> 1) +  (c & 0x01);
  switch (x&7) {
  case 0:
    *p0 = (*p0&~(7<<5))|(c0<<5);
    *p1 = (*p1&~(7<<5))|(c1<<5);
    break;
  case 1:
    *p0 = (*p0&~(7<<2))|(c0<<2);
    *p1 = (*p1&~(7<<2))|(c1<<2);
    break;
  case 2:
    *p0   = (*p0&~(3))|(c0>>1);
    *p1   = (*p1&~(3))|(c1>>1);
    p0++;
    p1++;
    *p0 = (*p0 &~(1<<7))|(c0<<7);
    *p1 = (*p1 &~(1<<7))|(c1<<7);
    break;
  case 3:
    p0++;
    p1++;
    *p0 = (*p0&~(7<<4))|(c0<<4);
    *p1 = (*p1&~(7<<4))|(c1<<4);
    break;
  case 4:
    p0++;
    p1++;
    *p0 = (*p0&~(7<<1))|(c0<<1);
    *p1 = (*p1&~(7<<1))|(c1<<1);
    break;
  case 5:
    p0++;
    p1++;
    *p0   = (*p0&~(1))|(c0>>2);
    *p1   = (*p1&~(1))|(c1>>2);
    p0++;
    p1++;
    *p0 = (*p0 &~(3<<6))|(c0<<6);
    *p1 = (*p1 &~(3<<6))|(c1<<6);
    break;
  case 6:
    p0+=2;
    p1+=2;
    *p0 = (*p0&~(7<<3))|(c0<<3);
    *p1 = (*p1&~(7<<3))|(c1<<3);
    break;
  case 7:
    p0+=2;
    p1+=2;
    *p0 = (*p0&~(7<<0))|(c0);
    *p1 = (*p1&~(7<<0))|(c1);
    break;
  }
}

#define SETPIXELPHYS(x,y,c) SetPixelPhys222(x,y,c) 

#endif

static void SetPixelPhys(int x, int y, LCD_PIXELINDEX c) {
  SETPIXELPHYS(x,y,c);
}


/*
        *********************************************************
        *                                                       *
        *       Next pixel routines, optimized for 3bpp
        *                                                       *
        *********************************************************
*/

#if      (LCD_OPTIMIZE)             \
      && (!LCD_MIRROR_X)            \
      && (!LCD_MIRROR_Y)            \
      && (!LCD_SWAP_XY)             \
      && (!LCD_SUPPORT_COMTRANS)    \
      && (!LCD_SUPPORT_SEGTRANS)    \
      && (LCD_BITSPERPIXEL == 3)

static int CurPosX;
static U8 LCD_VRAMTYPE* pCurPos;

static void SetPosXY(int x, int y) {
  CurPosX = x;
  pCurPos = OFF2PTR(XY2OFF(x,y));
  switch (x&7) {
  case 3:
  case 4:
  case 5:
    pCurPos++; break;
  case 6:
  case 7:
    pCurPos+=2;
  }
}

static void SetNextPixel(LCD_PIXELINDEX c) {
  switch (CurPosX&7) {
  case 0: *pCurPos = (*pCurPos&~(7<<5))|(c<<5); break;
  case 1: *pCurPos = (*pCurPos&~(7<<2))|(c<<2); break;
  case 2: *pCurPos = (*pCurPos&~(3))|(c>>1);
           pCurPos++;
          *pCurPos = (*pCurPos &~(1<<7))|(c<<7);
           break;
  case 3: *pCurPos = (*pCurPos&~(7<<4))|(c<<4); break;
  case 4: *pCurPos = (*pCurPos&~(7<<1))|(c<<1); break;
  case 5: *pCurPos = (*pCurPos&~(1))|(c>>2);
           pCurPos++;
          *pCurPos = (*pCurPos &~(3<<6))|(c<<6);
           break;
  case 6: *pCurPos = (*pCurPos&~(7<<3))|(c<<3); break;
  case 7: *pCurPos = (*pCurPos&~(7<<0))|(c);
           pCurPos++;
           break;
  }
  CurPosX++;
}

/*
        *********************************************************
        *                                                       *
        *       Next pixel routines, optimized for 6bpp
        *                                                       *
        *********************************************************
*/

#elif    (LCD_OPTIMIZE)             \
      && (!LCD_MIRROR_X)            \
      && (!LCD_MIRROR_Y)            \
      && (!LCD_SWAP_XY)             \
      && (!LCD_SUPPORT_COMTRANS)    \
      && (!LCD_SUPPORT_SEGTRANS)    \
      && (LCD_BITSPERPIXEL == 6)

static int CurPosX;
static U8 LCD_VRAMTYPE* pCurPos_0;
static U8 LCD_VRAMTYPE* pCurPos_1;

static void SetPosXY(int x, int y) {
  CurPosX = x;
  pCurPos_0 = OFF2PTR_0(XY2OFF(x,y));
  pCurPos_1 = OFF2PTR_1(XY2OFF(x,y));
  switch (x&7) {
  case 3:
  case 4:
  case 5:
    pCurPos_0++;
    pCurPos_1++;
    break;
  case 6:
  case 7:
    pCurPos_0+=2;
    pCurPos_1+=2;
  }
}

static void SetNextPixel(LCD_PIXELINDEX c) {
  U8 c0 = ((c & 0x20) >> 3) + ((c & 0x08) >> 2) + ((c & 0x02) >> 1);
  U8 c1 = ((c & 0x10) >> 2) + ((c & 0x04) >> 1) +  (c & 0x01);
  switch (CurPosX&7) {
  case 0: 
    *pCurPos_0 = (*pCurPos_0&~(7<<5))|(c0<<5); 
    *pCurPos_1 = (*pCurPos_1&~(7<<5))|(c1<<5); 
    break;
  case 1: 
    *pCurPos_0 = (*pCurPos_0&~(7<<2))|(c0<<2); 
    *pCurPos_1 = (*pCurPos_1&~(7<<2))|(c1<<2); 
    break;
  case 2: 
    *pCurPos_0 = (*pCurPos_0&~(3))|(c0>>1);
    *pCurPos_1 = (*pCurPos_1&~(3))|(c1>>1);
    pCurPos_0++;
    pCurPos_1++;
    *pCurPos_0 = (*pCurPos_0 &~(1<<7))|(c0<<7);
    *pCurPos_1 = (*pCurPos_1 &~(1<<7))|(c1<<7);
    break;
  case 3: 
    *pCurPos_0 = (*pCurPos_0&~(7<<4))|(c0<<4); 
    *pCurPos_1 = (*pCurPos_1&~(7<<4))|(c1<<4); 
    break;
  case 4: 
    *pCurPos_0 = (*pCurPos_0&~(7<<1))|(c0<<1); 
    *pCurPos_1 = (*pCurPos_1&~(7<<1))|(c1<<1); 
    break;
  case 5: 
    *pCurPos_0 = (*pCurPos_0&~(1))|(c0>>2);
    *pCurPos_1 = (*pCurPos_1&~(1))|(c1>>2);
    pCurPos_0++;
    pCurPos_1++;
    *pCurPos_0 = (*pCurPos_0 &~(3<<6))|(c0<<6);
    *pCurPos_1 = (*pCurPos_1 &~(3<<6))|(c1<<6);
    break;
  case 6: 
    *pCurPos_0 = (*pCurPos_0&~(7<<3))|(c0<<3); 
    *pCurPos_1 = (*pCurPos_1&~(7<<3))|(c1<<3); 
    break;
  case 7: 
    *pCurPos_0 = (*pCurPos_0&~(7<<0))|(c0);
    *pCurPos_1 = (*pCurPos_1&~(7<<0))|(c1);
    pCurPos_0++;
    pCurPos_1++;
    break;
  }
  CurPosX++;
}

#endif

#if (LCD_BITSPERPIXEL == 3)

unsigned int GetPixel(int x, int y) {
  U8 LCD_VRAMTYPE* p = OFF2PTR(XY2OFF(x,y));
  switch(x&7) {
    case 0: return (*p>>5);
    case 1: return (*p>>2)&7;
    case 2: return ((*p&(3   )) <<1)|(*(p+1)>>7);
    case 3: return (*(p+1)>>4) &7;
    case 4: return (*(p+1)>>1) &7;
    case 5: return ((*(p+1)&(1)) <<2)|(*(p+2)>>6);
    case 6: return (*(p+2)&(7<<3)) >>3;
  }
  return (*(p+2)&(7<<0)) >>0;
}

unsigned int LCD_L0_GetPixelIndex(int x, int y) {
  return GETPIXEL(x, y);
}

#elif (LCD_BITSPERPIXEL == 6)

unsigned int GetPixel(int x, int y) {
  U8 LCD_VRAMTYPE* p0 = OFF2PTR_0(XY2OFF(x,y));
  U8 LCD_VRAMTYPE* p1 = OFF2PTR_1(XY2OFF(x,y));
  U8 c0, c1;
  switch(x&7) {
    case 0: 
      c0 = (*p0>>5);
      c1 = (*p1>>5);
      break;
    case 1: 
      c0 = (*p0>>2)&7;
      c1 = (*p1>>2)&7;
      break;
    case 2: 
      c0 = ((*p0&3)<<1)|(*(p0+1)>>7);
      c1 = ((*p1&3)<<1)|(*(p1+1)>>7);
      break;
    case 3: 
      c0 = (*(p0+1)>>4) &7;
      c1 = (*(p1+1)>>4) &7;
      break;
    case 4: 
      c0 = (*(p0+1)>>1) &7;
      c1 = (*(p1+1)>>1) &7;
      break;
    case 5: 
      c0 = ((*(p0+1)&(1)) <<2)|(*(p0+2)>>6);
      c1 = ((*(p1+1)&(1)) <<2)|(*(p1+2)>>6);
      break;
    case 6: 
      c0 = (*(p0+2)&(7<<3)) >>3;
      c1 = (*(p1+2)&(7<<3)) >>3;
      break;
    case 7: 
      c0 = (*(p0+2)&(7<<0)) >>0;
      c1 = (*(p1+2)&(7<<0)) >>0;
      break;
  }
  return ((c0 & 0x04) << 3) + ((c0 & 0x02) << 2) + ((c0 & 0x01) << 1)
       + ((c1 & 0x04) << 2) + ((c1 & 0x02) << 1) +  (c1 & 0x01);
}

unsigned int LCD_L0_GetPixelIndex(int x, int y) {
  return GETPIXEL(x, y);
}

#endif


static void XorPixel   (int x, int y) {
  LCD_PIXELINDEX Index = GetPixel(x,y);
  Index = LCD_NUM_COLORS-1-Index;
  SetPixelPhys(x,y,Index);
}

void LCD_L0_XorPixel   (int x, int y) {
  XORPIXEL(x,y);
}

void LCD_L0_SetPixelIndex   (int x, int y, int ColorIndex) {
  SETPIXELFAST(x,y,ColorIndex);
}



/*
        *********************************************************
        *                                                       *
        *          LCD_DrawHLine optimized                      *
        *                                                       *
        *          Normal display, 3 Bpp                        *
        *                                                       *
        *********************************************************
*/

#if      (LCD_OPTIMIZE)             \
      && (!LCD_MIRROR_X)            \
      && (!LCD_MIRROR_Y)            \
      && (!LCD_SWAP_XY)             \
      && (!LCD_SUPPORT_COMTRANS)    \
      && (!LCD_SUPPORT_SEGTRANS)    \
      && (LCD_BITSPERPIXEL == 3)

static U8 MaskLeft[8][3] = {
  { 0xff, 0xff, 0xff},
  { 0x1f, 0xff, 0xff},
  { 0x03, 0xff, 0xff},
  { 0x00, 0x7f, 0xff},
  { 0x00, 0x0f, 0xff},
  { 0x00, 0x01, 0xff},
  { 0x00, 0x00, 0x3f},
  { 0x00, 0x00, 0x07}/*!!!0x0e*/
};

static U8 MaskRight[8][3] = {
  { 0xe0, 0x00, 0x00},
  { 0xfc, 0x00, 0x00},
  { 0xff, 0x80, 0x00},
  { 0xff, 0xf0, 0x00},
  { 0xff, 0xfe, 0x00},
  { 0xff, 0xff, 0xc0},
  { 0xff, 0xff, 0xf8},
  { 0xff, 0xff, 0xff}
};

static U8* GetMaskRight(int x) { return &MaskRight[(x&7)][0]; }
static U8* GetMaskLeft (int x) { return &MaskLeft[(x&7)][0]; }

void LCD_L0_DrawHLine  (int x0, int y,  int x1) {
  if (x0>x1) return;  /* Check if nothing to draw */
  if (GUI_Context.DrawMode & LCD_DRAWMODE_XOR) {
    while (x0 <= x1) {
      XORPIXEL(x0, y);
      x0++;
    }
  } else {
    int i;
    U8 LCD_VRAMTYPE* p = OFF2PTR(XY2OFF(x0,y));
    U8* pMask = GetMaskLeft(x0);
    U8 aData[3];
    U8 aDataMasked[3];
    aData[0] = (COLOR<<5)|(COLOR<<2)|(COLOR>>1);            /* hhhgggff */
    aData[1] = (COLOR<<7)|(COLOR<<4)|(COLOR<<1)|(COLOR>>2); /* feeedddc */
    aData[2] = (COLOR<<6)|(COLOR<<3)|(COLOR);               /* ccbbbaaa */
    for (i=0; i<3; i++, pMask++) {
      aDataMasked[i] = (*(p+i) &~*pMask) | (aData[i] &*pMask);
    }
    if ((x0&~7) == (x1&~7)) {    /* Do we have to clip left and right side ? */
      U8* pMask = GetMaskRight(x1);
#if 0
      for (i=0; i<3; i++, pMask++) {
        *(p+i) = (*(p+i) &~*pMask) | (aDataMasked[i]&*pMask);
      }
#else
      *(p+0) = (*(p+0) &~*(pMask+0)) | (aDataMasked[0]&*(pMask+0));
      *(p+1) = (*(p+1) &~*(pMask+1)) | (aDataMasked[1]&*(pMask+1));
      *(p+2) = (*(p+2) &~*(pMask+2)) | (aDataMasked[2]&*(pMask+2));
#endif
      return;
    }
    *p = aDataMasked[0];
    *(p+1) = aDataMasked[1];
    *(p+2) = aDataMasked[2];
    p+=3;
    x0 = (x0&~7)+8;
/* Draw optimized portion */
    {
      int Len = (x1-x0+1)>>3;
      if (Len >0) {
        x0 += Len<<3;
        do {
          *p     = aData[0];
          *(p+1) = aData[1];
          *(p+2) = aData[2];
          p+=3;
        } while (--Len);
      }
    }
    /* Draw right portion */
    if ((x1&7)!=7) {
      U8* pMask = GetMaskRight(x1);
      for (i=0; i<3; i++, pMask++) {
        *(p+i) = (*(p+i) &~*pMask) | (aData[i]&*pMask);
      }
    }
    
  }
}

/*
        *********************************************************
        *                                                       *

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美性三三影院| 国产精品丝袜一区| 久久精品欧美日韩精品| 一区二区日韩电影| 韩国成人精品a∨在线观看| 一本大道久久a久久综合婷婷 | 免费观看久久久4p| 97久久超碰精品国产| 久久综合九色综合欧美亚洲| 午夜精品久久久久久久| 99久久伊人精品| 精品美女在线播放| 日韩av电影天堂| 欧美图片一区二区三区| 综合激情成人伊人| 丁香天五香天堂综合| 欧美岛国在线观看| 日本视频免费一区| 4438成人网| 三级一区在线视频先锋 | 337p日本欧洲亚洲大胆精品| 午夜电影久久久| 欧美三日本三级三级在线播放| 国产精品视频在线看| 国产成人99久久亚洲综合精品| 日韩欧美中文字幕精品| 日韩精品免费专区| 欧美二区在线观看| 偷窥国产亚洲免费视频| 欧美日韩高清一区二区| 亚洲一区二区三区小说| 欧洲精品一区二区| 亚洲电影一区二区三区| 欧美日韩免费在线视频| 亚洲va欧美va天堂v国产综合| 日本精品裸体写真集在线观看 | 久久美女高清视频| 韩国中文字幕2020精品| 久久在线观看免费| 国产精品123区| 国产精品电影院| 91九色02白丝porn| 亚洲高清免费视频| 欧美一区二区日韩一区二区| 免费精品视频在线| 国产午夜精品美女毛片视频| 国产91精品精华液一区二区三区| 中文字幕第一页久久| 99r国产精品| 亚洲一区在线观看免费观看电影高清| 91福利视频在线| 天天综合日日夜夜精品| 精品国产自在久精品国产| 国产精品18久久久久久久网站| 久久免费看少妇高潮| 9色porny自拍视频一区二区| 一级特黄大欧美久久久| 91精品国产乱码久久蜜臀| 蓝色福利精品导航| 国产精品家庭影院| 欧美区视频在线观看| 国产尤物一区二区| 国产精品福利电影一区二区三区四区| 欧美亚洲一区二区三区四区| 美女视频一区二区三区| 欧美国产日韩亚洲一区| 欧洲日韩一区二区三区| 麻豆精品视频在线观看视频| 国产精品久久久久久久久晋中 | 国产精品中文有码| 中文字幕在线不卡视频| 欧美视频在线播放| 国产精品羞羞答答xxdd| 亚洲国产视频一区二区| 久久久久久综合| 欧美日精品一区视频| 久久精品亚洲一区二区三区浴池| 国产精品白丝jk黑袜喷水| 日本韩国精品在线| 精品国产91洋老外米糕| 亚洲蜜臀av乱码久久精品蜜桃| 久久成人免费网| 欧美日韩亚洲另类| 亚洲高清久久久| 91在线视频18| 国产精品丝袜一区| 免费久久精品视频| 首页欧美精品中文字幕| 日本高清不卡视频| 国产成人精品影院| 蜜臀国产一区二区三区在线播放| 亚洲激情图片小说视频| 久久久精品黄色| 日韩一区二区三区av| 欧美午夜影院一区| 成人av影院在线| 国产精品456露脸| 精品一区二区三区蜜桃| 亚洲成人tv网| 亚洲综合色成人| 亚洲女厕所小便bbb| 国产精品视频一区二区三区不卡| 精品动漫一区二区三区在线观看| 欧美精品一二三四| 欧美图区在线视频| 欧美色区777第一页| 色久综合一二码| 99久久久免费精品国产一区二区| 国产精品夜夜爽| 国产精选一区二区三区| 久久av资源网| 国产一区二区视频在线播放| 六月丁香婷婷久久| 久久99国产精品免费网站| 美女视频黄 久久| 激情亚洲综合在线| 99久久国产免费看| 91黄色激情网站| 欧美三级电影网| 欧美男女性生活在线直播观看| 欧美日韩一区二区三区不卡| 欧美日韩一区二区电影| 4438亚洲最大| 精品国产1区二区| 26uuu另类欧美| 成人免费在线播放视频| 亚洲人成亚洲人成在线观看图片| 亚洲女同女同女同女同女同69| 一区二区三区在线免费播放| 亚洲一区中文在线| 日韩av一区二区在线影视| 精品亚洲成a人| 成人黄色av电影| 在线免费观看日韩欧美| 日韩一区二区麻豆国产| 久久综合色之久久综合| 国产精品国产三级国产| 亚洲综合激情网| 美腿丝袜亚洲色图| 粉嫩av一区二区三区粉嫩| 91麻豆高清视频| 91精品国产日韩91久久久久久| 精品欧美一区二区三区精品久久| 国产午夜精品久久久久久久 | 色哟哟在线观看一区二区三区| 欧美三级三级三级爽爽爽| 91精品国产综合久久福利软件 | 国产精品91一区二区| 欧美经典一区二区三区| 国产精品福利一区| 视频在线在亚洲| 丰满亚洲少妇av| 7777精品伊人久久久大香线蕉经典版下载| 欧美一级二级在线观看| 国产精品进线69影院| 日本欧美韩国一区三区| 成人国产亚洲欧美成人综合网 | 日本欧美一区二区三区| 成人午夜av电影| 在线播放国产精品二区一二区四区| 久久久蜜桃精品| 日日摸夜夜添夜夜添国产精品| 国产精品一区二区三区乱码| 欧美精品在线视频| 欧美国产日韩在线观看| 日本欧美一区二区在线观看| 91日韩在线专区| 久久久久久免费| 视频一区二区三区中文字幕| www.亚洲色图| 精品日韩一区二区三区| 午夜欧美2019年伦理| 91亚洲精品一区二区乱码| 久久久久久久精| 捆绑变态av一区二区三区| 欧美在线看片a免费观看| 中文字幕在线不卡| 国产乱码精品一区二区三区av | 国产精品88av| 日韩一区二区三区视频在线| 亚洲第一久久影院| 在线观看不卡视频| 中文字幕综合网| av电影在线观看一区| 国产三级一区二区| 国产精品资源在线| 2014亚洲片线观看视频免费| 久久精品国产澳门| 91精品在线免费观看| 亚洲成人高清在线| 欧美日韩一区二区在线观看视频 | 国产精品网曝门| 大白屁股一区二区视频| 国产丝袜欧美中文另类| 狠狠色综合日日| 精品国产欧美一区二区| 精品一区二区在线观看| 欧美α欧美αv大片| 久久99热国产| 久久久久久久久久久电影|