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

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

?? libmng_pixels.c

?? 一款最完整的工業組態軟源代碼
?? C
?? 第 1 頁 / 共 5 頁
字號:
       (BC) = (mng_uint16)((S * (mng_uint32)(BT) +                               \
                            T * (mng_uint32)(BB) + (mng_uint32)32767) >> 16); }

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

/* note a good optimizing compiler will optimize this */
#define DIV255B8(x) (mng_uint8)(((x) + 127) / 255)
#define DIV255B16(x) (mng_uint16)(((x) + 32767) / 65535)

/* ************************************************************************** */
/* *                                                                        * */
/* * Progressive display check - checks to see if progressive display is    * */
/* * in order & indicates so                                                * */
/* *                                                                        * */
/* * The routine is called after a call to one of the display_xxx routines  * */
/* * if appropriate                                                         * */
/* *                                                                        * */
/* * The refresh is warrented in the read_chunk routine (mng_read.c)        * */
/* * and only during read&display processing, since there's not much point  * */
/* * doing it from memory!                                                  * */
/* *                                                                        * */
/* ************************************************************************** */

mng_retcode mng_display_progressive_check (mng_datap pData)
{
  if ((pData->bDoProgressive) &&       /* need progressive display? */
      ((pData->eImagetype != mng_it_mng) || (pData->iDataheight > 300)) &&
      (pData->iDestb - pData->iDestt > 50) && (!pData->pCurraniobj))
  {
    mng_int32 iC = pData->iRow + pData->iDestt - pData->iSourcet;

    if (iC % 20 == 0)                  /* every 20th line */
      pData->bNeedrefresh = MNG_TRUE;

  }

  return MNG_NOERROR;
}

/* ************************************************************************** */
/* *                                                                        * */
/* * Display routines - convert rowdata (which is already color-corrected)  * */
/* * to the output canvas, respecting the opacity information               * */
/* *                                                                        * */
/* ************************************************************************** */

MNG_LOCAL void check_update_region (mng_datap pData)
{                                      /* determine actual canvas row */
  mng_int32 iRow = pData->iRow + pData->iDestt - pData->iSourcet;
                                       /* check for change in update-region */
  if ((pData->iDestl < (mng_int32)pData->iUpdateleft) || (pData->iUpdateright == 0))
    pData->iUpdateleft   = pData->iDestl;

  if (pData->iDestr > (mng_int32)pData->iUpdateright)
    pData->iUpdateright  = pData->iDestr;

  if ((iRow < (mng_int32)pData->iUpdatetop) || (pData->iUpdatebottom == 0))
    pData->iUpdatetop    = iRow;

  if (iRow+1 > (mng_int32)pData->iUpdatebottom)
    pData->iUpdatebottom = iRow+1;

  return;
}

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

#ifndef MNG_SKIPCANVAS_RGB8
mng_retcode mng_display_rgb8 (mng_datap pData)
{
  mng_uint8p pScanline;
  mng_uint8p pDataline;
  mng_int32  iX;
#ifndef MNG_NO_16BIT_SUPPORT
  mng_uint16 iA16;
#ifndef MNG_OPTIMIZE_FOOTPRINT_COMPOSE
  mng_uint16 iFGr16, iFGg16, iFGb16;
  mng_uint16 iBGr16, iBGg16, iBGb16;
#else
  mng_uint16 iFGg16;
  mng_uint16 iBGg16;
#endif
#endif
  mng_uint8  iA8;

#ifdef MNG_SUPPORT_TRACE
  MNG_TRACE (pData, MNG_FN_DISPLAY_RGB8, MNG_LC_START)
#endif
                                       /* viewable row ? */
  if ((pData->iRow >= pData->iSourcet) && (pData->iRow < pData->iSourceb))
  {                                    /* address destination row */
    pScanline = (mng_uint8p)pData->fGetcanvasline (((mng_handle)pData),
                                                   pData->iRow + pData->iDestt -
                                                   pData->iSourcet);
                                       /* adjust destination row starting-point */
    pScanline = pScanline + (pData->iCol * 3) + (pData->iDestl * 3);
    pDataline = pData->pRGBArow;       /* address source row */

#ifndef MNG_NO_16BIT_SUPPORT
    if (pData->bIsRGBA16)              /* adjust source row starting-point */
      pDataline = pDataline + ((pData->iSourcel / pData->iColinc) << 3);
    else
#endif
      pDataline = pDataline + ((pData->iSourcel / pData->iColinc) << 2);

    if (pData->bIsOpaque)              /* forget about transparency ? */
    {
#ifndef MNG_NO_16BIT_SUPPORT
      if (pData->bIsRGBA16)            /* 16-bit input row ? */
      {
        for (iX = pData->iSourcel + pData->iCol; iX < pData->iSourcer; iX += pData->iColinc)
        {                              /* scale down by dropping the LSB */
          *pScanline     = *pDataline;
          *(pScanline+1) = *(pDataline+2);
          *(pScanline+2) = *(pDataline+4);

          pScanline += (pData->iColinc * 3);
          pDataline += 8;
        }
      }
      else
#endif
      {
        for (iX = pData->iSourcel + pData->iCol; iX < pData->iSourcer; iX += pData->iColinc)
        {                              /* copy the values */
          *pScanline     = *pDataline;
          *(pScanline+1) = *(pDataline+1);
          *(pScanline+2) = *(pDataline+2);

          pScanline += (pData->iColinc * 3);
          pDataline += 4;
        }
      }
    }
    else
    {
#ifndef MNG_NO_16BIT_SUPPORT
      if (pData->bIsRGBA16)            /* 16-bit input row ? */
      {
        for (iX = pData->iSourcel + pData->iCol; iX < pData->iSourcer; iX += pData->iColinc)
        {
          iA16 = mng_get_uint16 (pDataline+6);

          if (iA16)                    /* any opacity at all ? */
          {
            if (iA16 == 0xFFFF)        /* fully opaque ? */
            {                          /* scale down by dropping the LSB */
              *pScanline     = *pDataline;
              *(pScanline+1) = *(pDataline+2);
              *(pScanline+2) = *(pDataline+4);
            }
            else
            {                          /* get the proper values */
#ifdef MNG_OPTIMIZE_FOOTPRINT_COMPOSE
            int i;
            for (i=2; i >= 0; i--)
            {
              iFGg16 = mng_get_uint16 (pDataline+i+i);
                                       /* scale background up */
              iBGg16 = (mng_uint16)(*(pScanline+i));
              iBGg16 = (mng_uint16)((mng_uint32)iBGg16 << 8) | iBGg16;
                                       /* now compose */
              MNG_COMPOSE16(iFGg16, iFGg16, iA16, iBGg16)
                                       /* and return the composed values */
              *(pScanline+i) = (mng_uint8)(iFGg16 >> 8);
            }
#else
              iFGr16 = mng_get_uint16 (pDataline  );
              iFGg16 = mng_get_uint16 (pDataline+2);
              iFGb16 = mng_get_uint16 (pDataline+4);
                                       /* scale background up */
              iBGr16 = (mng_uint16)(*pScanline    );
              iBGg16 = (mng_uint16)(*(pScanline+1));
              iBGb16 = (mng_uint16)(*(pScanline+2));
              iBGr16 = (mng_uint16)((mng_uint32)iBGr16 << 8) | iBGr16;
              iBGg16 = (mng_uint16)((mng_uint32)iBGg16 << 8) | iBGg16;
              iBGb16 = (mng_uint16)((mng_uint32)iBGb16 << 8) | iBGb16;
                                       /* now compose */
              MNG_COMPOSE16(iFGr16, iFGr16, iA16, iBGr16)
              MNG_COMPOSE16(iFGg16, iFGg16, iA16, iBGg16)
              MNG_COMPOSE16(iFGb16, iFGb16, iA16, iBGb16)
                                       /* and return the composed values */
              *pScanline     = (mng_uint8)(iFGr16 >> 8);
              *(pScanline+1) = (mng_uint8)(iFGg16 >> 8);
              *(pScanline+2) = (mng_uint8)(iFGb16 >> 8);
#endif
            }
          }

          pScanline += (pData->iColinc * 3);
          pDataline += 8;
        }
      }
      else
#endif
      {
        for (iX = pData->iSourcel + pData->iCol; iX < pData->iSourcer; iX += pData->iColinc)
        {
          iA8 = *(pDataline+3);        /* get alpha value */

          if (iA8)                     /* any opacity at all ? */
          {
            if (iA8 == 0xFF)           /* fully opaque ? */
            {                          /* then simply copy the values */
              *pScanline     = *pDataline;
              *(pScanline+1) = *(pDataline+1);
              *(pScanline+2) = *(pDataline+2);
            }
            else
            {                          /* do alpha composing */
#ifdef MNG_OPTIMIZE_FOOTPRINT_COMPOSE
              int i;
              for (i=2; i >= 0; i--)
              {
              MNG_COMPOSE8 (*(pScanline+i), *(pDataline+i), iA8, *(pScanline+i))
              }
#else
              MNG_COMPOSE8 (*pScanline,     *pDataline,     iA8, *pScanline    )
              MNG_COMPOSE8 (*(pScanline+1), *(pDataline+1), iA8, *(pScanline+1))
              MNG_COMPOSE8 (*(pScanline+2), *(pDataline+2), iA8, *(pScanline+2))
#endif
            }
          }

          pScanline += (pData->iColinc * 3);
          pDataline += 4;
        }
      }
    }
  }

  check_update_region (pData);

#ifdef MNG_SUPPORT_TRACE
  MNG_TRACE (pData, MNG_FN_DISPLAY_RGB8, MNG_LC_END)
#endif

  return MNG_NOERROR;
}
#endif /* MNG_SKIPCANVAS_RGB8 */

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

#ifndef MNG_SKIPCANVAS_RGBA8
mng_retcode mng_display_rgba8 (mng_datap pData)
{
  mng_uint8p pScanline;
  mng_uint8p pDataline;
  mng_int32  iX;
  mng_uint8  iFGa8, iBGa8, iCa8;
#ifndef MNG_NO_16BIT_SUPPORT
  mng_uint16 iFGa16, iBGa16, iCa16;
#ifndef MNG_OPTIMIZE_FOOTPRINT_COMPOSE
  mng_uint16 iFGr16, iFGg16, iFGb16;
#else
  mng_uint16 iFGg16;
#endif
  mng_uint16 iBGr16, iBGg16, iBGb16;
  mng_uint16 iCr16, iCg16, iCb16;
#endif
  mng_uint8  iCr8, iCg8, iCb8;

#ifdef MNG_SUPPORT_TRACE
  MNG_TRACE (pData, MNG_FN_DISPLAY_RGBA8, MNG_LC_START)
#endif
                                       /* viewable row ? */
  if ((pData->iRow >= pData->iSourcet) && (pData->iRow < pData->iSourceb))
  {                                    /* address destination row */
    pScanline = (mng_uint8p)pData->fGetcanvasline (((mng_handle)pData),
                                                   pData->iRow + pData->iDestt -
                                                   pData->iSourcet);
                                       /* adjust destination row starting-point */
    pScanline = pScanline + (pData->iCol << 2) + (pData->iDestl << 2);
    pDataline = pData->pRGBArow;       /* address source row */

#ifndef MNG_NO_16BIT_SUPPORT
    if (pData->bIsRGBA16)              /* adjust source row starting-point */
      pDataline = pDataline + ((pData->iSourcel / pData->iColinc) << 3);
    else
#endif
      pDataline = pDataline + ((pData->iSourcel / pData->iColinc) << 2);

    if (pData->bIsOpaque)              /* forget about transparency ? */
    {
#ifndef MNG_NO_16BIT_SUPPORT
      if (pData->bIsRGBA16)            /* 16-bit input row ? */
      {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久电影网站中文字幕| 亚洲精品欧美专区| 韩国视频一区二区| 精品久久久久久综合日本欧美| 日韩国产精品91| 日韩片之四级片| 激情欧美日韩一区二区| 国产性色一区二区| jizzjizzjizz欧美| 一区二区三区国产精华| 91精品国产麻豆| 国产一区二区在线免费观看| 国产日韩高清在线| 91蜜桃免费观看视频| 久久综合九色欧美综合狠狠| 成人午夜激情视频| 亚洲综合色区另类av| 日韩欧美国产系列| 粉嫩嫩av羞羞动漫久久久| 亚洲欧美日韩中文字幕一区二区三区| 在线精品亚洲一区二区不卡| 日韩福利视频导航| 欧美国产欧美综合| 欧美少妇bbb| 激情另类小说区图片区视频区| 国产调教视频一区| 欧洲亚洲精品在线| 激情久久五月天| 亚洲精品久久7777| 精品国产污网站| 色94色欧美sute亚洲线路二| 麻豆精品蜜桃视频网站| 国产精品久久久爽爽爽麻豆色哟哟| 欧美日韩国产综合一区二区三区| 国产精品一级二级三级| 一区二区三区四区在线播放| 久久久噜噜噜久久人人看| 欧美在线|欧美| 国产伦精一区二区三区| 亚洲第一会所有码转帖| 欧美激情一区二区三区四区| 欧美一区午夜精品| 色哟哟在线观看一区二区三区| 日本一不卡视频| 一区二区三区高清不卡| 国产亚洲精品7777| 日韩欧美激情在线| 欧美丰满嫩嫩电影| 91免费看片在线观看| 国产高清在线观看免费不卡| 爽好久久久欧美精品| 亚洲天堂福利av| 国产精品色一区二区三区| 日韩欧美一区在线观看| 欧美日免费三级在线| 97精品国产露脸对白| 国产成人精品午夜视频免费| 免费在线观看精品| 一区二区三区日韩在线观看| 中文字幕欧美日韩一区| 成人国产精品免费| 国产精品99久久久久久久vr | 激情深爱一区二区| 一区二区三区中文在线观看| 精品美女一区二区| 色综合天天综合网国产成人综合天 | 国产成人av电影在线观看| 一区二区成人在线| 久久久综合精品| 日韩西西人体444www| 在线免费观看成人短视频| 丁香激情综合五月| 麻豆91在线观看| 午夜精品久久久久久不卡8050| 精品国产免费视频| 久久综合资源网| 欧美男生操女生| 日韩亚洲欧美中文三级| 欧美三级三级三级| 欧美日韩精品久久久| 色婷婷精品久久二区二区蜜臂av| 成人免费av资源| 国产精品一区三区| 国产v综合v亚洲欧| 国产精品99久久久久久久女警 | 2020日本不卡一区二区视频| 91精品国产综合久久久久| 6080日韩午夜伦伦午夜伦| 色视频欧美一区二区三区| 在线视频综合导航| 在线免费精品视频| 欧美日韩日日骚| 欧美性高清videossexo| 91精品国产91久久久久久最新毛片 | 调教+趴+乳夹+国产+精品| 日本免费新一区视频| 蜜芽一区二区三区| 国产精品一区二区三区99| 国产黄人亚洲片| 在线观看91视频| 欧美日本国产视频| 欧美日韩一区二区欧美激情| 欧美日韩久久一区二区| 日韩欧美不卡在线观看视频| 精品国产sm最大网站免费看| 最新日韩av在线| 亚洲大片在线观看| 久久se精品一区二区| 国产成人亚洲综合a∨婷婷| 99精品视频中文字幕| 91国模大尺度私拍在线视频 | 欧美日韩高清在线播放| 在线亚洲免费视频| 日韩视频不卡中文| 欧美日韩精品欧美日韩精品一| 精品毛片乱码1区2区3区| 欧美日韩一区二区三区高清| 日韩欧美中文字幕一区| 51久久夜色精品国产麻豆| 国产网站一区二区| 中文字幕在线播放不卡一区| 免费观看30秒视频久久| 蜜臀99久久精品久久久久久软件| 成人av在线网站| 色综合久久久久综合| 日韩一区国产二区欧美三区| 欧美大白屁股肥臀xxxxxx| 亚洲桃色在线一区| 视频一区中文字幕| 不卡电影一区二区三区| 日本乱人伦aⅴ精品| 久久影院视频免费| 亚洲欧洲日韩在线| 韩国精品久久久| 99在线精品免费| 久久久久综合网| 久久亚洲精华国产精华液| 亚洲成人av资源| va亚洲va日韩不卡在线观看| 91精品国产色综合久久久蜜香臀| 亚洲婷婷在线视频| 激情久久五月天| 日韩三级高清在线| 亚洲综合一区二区精品导航| 国产激情视频一区二区三区欧美 | 成人黄色一级视频| 欧美一级黄色大片| 亚洲欧美视频在线观看视频| 免费观看在线色综合| 欧美性受xxxx黑人xyx| 久久久久久影视| 精品一区二区在线免费观看| 色婷婷国产精品久久包臀| 亚洲国产精品高清| 蜜桃视频在线观看一区| 欧美性欧美巨大黑白大战| 欧美高清在线一区| 亚洲综合999| 国产在线视频一区二区三区| 欧美精品色综合| 亚洲国产毛片aaaaa无费看| 99精品一区二区| 亚洲人成在线观看一区二区| 国产又黄又大久久| 久久久久久一二三区| 久久国产精品无码网站| 欧美岛国在线观看| 日韩黄色一级片| 欧美mv和日韩mv国产网站| 日一区二区三区| 欧美一区二区三区免费| 亚洲精品一卡二卡| 欧美专区亚洲专区| 亚洲二区在线观看| 99久久国产综合精品女不卡| 日韩一级片网址| 久久97超碰色| 欧美不卡在线视频| 日本视频一区二区三区| 精品99一区二区| 老司机精品视频线观看86| 2024国产精品视频| 三级欧美韩日大片在线看| 久久亚洲影视婷婷| 成人午夜碰碰视频| 亚洲色图色小说| 69久久99精品久久久久婷婷| 日本色综合中文字幕| 日韩三级视频中文字幕| 午夜伦理一区二区| 欧美探花视频资源| 天涯成人国产亚洲精品一区av| 欧美日韩免费一区二区三区视频| 日本不卡一区二区| 欧美日韩一区二区欧美激情| 精品亚洲国产成人av制服丝袜 | 91一区二区三区在线观看| 久久免费视频色| 北条麻妃一区二区三区| 樱花影视一区二区|