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

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

?? visualpng.c

?? Borland C++BuilderT 6 Developer s Guide
?? C
?? 第 1 頁 / 共 2 頁
字號:

   // Calculate new X position, then adjust for workarea
   xNew = rParent.left + ((wParent - wChild) /2);
   if (xNew < rWorkArea.left) {
      xNew = rWorkArea.left;
   } else if ((xNew+wChild) > rWorkArea.right) {
      xNew = rWorkArea.right - wChild;
   }

   // Calculate new Y position, then adjust for workarea
   yNew = rParent.top  + ((hParent - hChild) /2);
   if (yNew < rWorkArea.top) {
      yNew = rWorkArea.top;
   } else if ((yNew+hChild) > rWorkArea.bottom) {
      yNew = rWorkArea.bottom - hChild;
   }

   // Set it, and return
   return SetWindowPos (hwndChild, NULL, xNew, yNew, 0, 0, SWP_NOSIZE |
          SWP_NOZORDER);
}

//----------------
//  BuildPngList
//----------------

BOOL BuildPngList (PTSTR pstrPathName, TCHAR **ppFileList, int *pFileCount,
     int *pFileIndex)
{
    static TCHAR              szImgPathName [MAX_PATH];
    static TCHAR              szImgFileName [MAX_PATH];
    static TCHAR              szImgFindName [MAX_PATH];

    WIN32_FIND_DATA           finddata;
    HANDLE                    hFind;

    static TCHAR              szTmp [MAX_PATH];
    BOOL                      bOk;
    int                       i, ii;
    int                       j, jj;

    // free previous file-list

    if (*ppFileList != NULL)
    {
        free (*ppFileList);
        *ppFileList = NULL;
    }

    // extract foldername, filename and search-name

    strcpy (szImgPathName, pstrPathName);
    strcpy (szImgFileName, strrchr (pstrPathName, '\\') + 1);

    strcpy (szImgFindName, szImgPathName);
    *(strrchr (szImgFindName, '\\') + 1) = '\0';
    strcat (szImgFindName, "*.png");

    // first cycle: count number of files in directory for memory allocation

    *pFileCount = 0;

    hFind = FindFirstFile(szImgFindName, &finddata);
    bOk = (hFind != (HANDLE) -1);

    while (bOk)
    {
        *pFileCount += 1;
        bOk = FindNextFile(hFind, &finddata);
    }
    FindClose(hFind);

    // allocation memory for file-list

    *ppFileList = (TCHAR *) malloc (*pFileCount * MAX_PATH);

    // second cycle: read directory and store filenames in file-list

    hFind = FindFirstFile(szImgFindName, &finddata);
    bOk = (hFind != (HANDLE) -1);

    i = 0;
    ii = 0;
    while (bOk)
    {
        strcpy (*ppFileList + ii, szImgPathName);
        strcpy (strrchr(*ppFileList + ii, '\\') + 1, finddata.cFileName);

        if (strcmp(pstrPathName, *ppFileList + ii) == 0)
            *pFileIndex = i;

        ii += MAX_PATH;
        i++;

        bOk = FindNextFile(hFind, &finddata);
    }
    FindClose(hFind);

    // finally we must sort the file-list

    for (i = 0; i < *pFileCount - 1; i++)
    {
        ii = i * MAX_PATH;
        for (j = i+1; j < *pFileCount; j++)
        {
            jj = j * MAX_PATH;
            if (strcmp (*ppFileList + ii, *ppFileList + jj) > 0)
            {
                strcpy (szTmp, *ppFileList + jj);
                strcpy (*ppFileList + jj, *ppFileList + ii);
                strcpy (*ppFileList + ii, szTmp);

                // check if this was the current image that we moved

                if (*pFileIndex == i)
                    *pFileIndex = j;
                else
                    if (*pFileIndex == j)
                        *pFileIndex = i;
            }
        }
    }

    return TRUE;
}

//----------------
//  SearchPngList
//----------------

BOOL SearchPngList (
        TCHAR *pFileList, int FileCount, int *pFileIndex,
        PTSTR pstrPrevName, PTSTR pstrNextName)
{
    if (FileCount > 0)
    {
        // get previous entry
        
        if (pstrPrevName != NULL)
        {
            if (*pFileIndex > 0)
                *pFileIndex -= 1;
            else
                *pFileIndex = FileCount - 1;
            
            strcpy (pstrPrevName, pFileList + (*pFileIndex * MAX_PATH));
        }
        
        // get next entry
        
        if (pstrNextName != NULL)
        {
            if (*pFileIndex < FileCount - 1)
                *pFileIndex += 1;
            else
                *pFileIndex = 0;
            
            strcpy (pstrNextName, pFileList + (*pFileIndex * MAX_PATH));
        }
        
        return TRUE;
    }
    else
    {
        return FALSE;
    }
}

//-----------------
//  LoadImageFile
//-----------------

BOOL LoadImageFile (HWND hwnd, PTSTR pstrPathName,
                png_byte **ppbImage, int *pxImgSize, int *pyImgSize,
                int *piChannels, png_color *pBkgColor)
{
    static TCHAR szTmp [MAX_PATH];

    // if there's an existing PNG, free the memory

    if (*ppbImage)
    {
        free (*ppbImage);
        *ppbImage = NULL;
    }

    // Load the entire PNG into memory

    SetCursor (LoadCursor (NULL, IDC_WAIT));
    ShowCursor (TRUE);

    PngLoadImage (pstrPathName, ppbImage, pxImgSize, pyImgSize, piChannels,
                  pBkgColor);

    ShowCursor (FALSE);
    SetCursor (LoadCursor (NULL, IDC_ARROW));

    if (*ppbImage != NULL)
    {
        sprintf (szTmp, "VisualPng - %s", strrchr(pstrPathName, '\\') + 1);
        SetWindowText (hwnd, szTmp);
    }
    else
    {
        MessageBox (hwnd, TEXT ("Error in loading the PNG image"),
            szProgName, MB_ICONEXCLAMATION | MB_OK);
        return FALSE;
    }

    return TRUE;
}

//----------------
//  DisplayImage
//----------------

BOOL DisplayImage (HWND hwnd, BYTE **ppDib,
        BYTE **ppDiData, int cxWinSize, int cyWinSize,
        BYTE *pbImage, int cxImgSize, int cyImgSize, int cImgChannels,
        BOOL bStretched)
{
    BYTE                       *pDib = *ppDib;
    BYTE                       *pDiData = *ppDiData;
    // BITMAPFILEHEADER        *pbmfh;
    BITMAPINFOHEADER           *pbmih;
    WORD                        wDIRowBytes;
    png_color                   bkgBlack = {0, 0, 0};
    png_color                   bkgGray  = {127, 127, 127};
    png_color                   bkgWhite = {255, 255, 255};

    // allocate memory for the Device Independant bitmap

    wDIRowBytes = (WORD) ((3 * cxWinSize + 3L) >> 2) << 2;

    if (pDib)
    {
        free (pDib);
        pDib = NULL;
    }

    if (!(pDib = (BYTE *) malloc (sizeof(BITMAPINFOHEADER) +
        wDIRowBytes * cyWinSize)))
    {
        MessageBox (hwnd, TEXT ("Error in displaying the PNG image"),
            szProgName, MB_ICONEXCLAMATION | MB_OK);
        *ppDib = pDib = NULL;
        return FALSE;
    }
    *ppDib = pDib;
    memset (pDib, 0, sizeof(BITMAPINFOHEADER));

    // initialize the dib-structure

    pbmih = (BITMAPINFOHEADER *) pDib;
    pbmih->biSize = sizeof(BITMAPINFOHEADER);
    pbmih->biWidth = cxWinSize;
    pbmih->biHeight = -((long) cyWinSize);
    pbmih->biPlanes = 1;
    pbmih->biBitCount = 24;
    pbmih->biCompression = 0;
    pDiData = pDib + sizeof(BITMAPINFOHEADER);
    *ppDiData = pDiData;

    // first fill bitmap with gray and image border

    InitBitmap (pDiData, cxWinSize, cyWinSize);

    // then fill bitmap with image

    if (pbImage)
    {
        FillBitmap (
            pDiData, cxWinSize, cyWinSize,
            pbImage, cxImgSize, cyImgSize, cImgChannels,
            bStretched);
    }

    return TRUE;
}

//--------------
//  InitBitmap
//--------------

BOOL InitBitmap (BYTE *pDiData, int cxWinSize, int cyWinSize)
{
    BYTE *dst;
    int x, y, col;

    // initialize the background with gray

    dst = pDiData;
    for (y = 0; y < cyWinSize; y++)
    {
        col = 0;
        for (x = 0; x < cxWinSize; x++)
        {
            // fill with GRAY
            *dst++ = 127;
            *dst++ = 127;
            *dst++ = 127;
            col += 3;
        }
        // rows start on 4 byte boundaries
        while ((col % 4) != 0)
        {
            dst++;
            col++;
        }
    }

    return TRUE;
}

//--------------
//  FillBitmap
//--------------

BOOL FillBitmap (
        BYTE *pDiData, int cxWinSize, int cyWinSize,
        BYTE *pbImage, int cxImgSize, int cyImgSize, int cImgChannels,
        BOOL bStretched)
{
    BYTE *pStretchedImage;
    BYTE *pImg;
    BYTE *src, *dst;
    BYTE r, g, b, a;
    const int cDIChannels = 3;
    WORD wImgRowBytes;
    WORD wDIRowBytes;
    int cxNewSize, cyNewSize;
    int cxImgPos, cyImgPos;
    int xImg, yImg;
    int xWin, yWin;
    int xOld, yOld;
    int xNew, yNew;

    if (bStretched)
    {
        cxNewSize = cxWinSize - 2 * MARGIN;
        cyNewSize = cyWinSize - 2 * MARGIN;

        // stretch the image to it's window determined size

        // the following two are the same, but the first has side-effects
        // because of rounding
//      if ((cyNewSize / cxNewSize) > (cyImgSize / cxImgSize))
        if ((cyNewSize * cxImgSize) > (cyImgSize * cxNewSize))
        {
            cyNewSize = cxNewSize * cyImgSize / cxImgSize;
            cxImgPos = MARGIN;
            cyImgPos = (cyWinSize - cyNewSize) / 2;
        }
        else
        {
            cxNewSize = cyNewSize * cxImgSize / cyImgSize;
            cyImgPos = MARGIN;
            cxImgPos = (cxWinSize - cxNewSize) / 2;
        }

        pStretchedImage = malloc (cImgChannels * cxNewSize * cyNewSize);
        pImg = pStretchedImage;

        for (yNew = 0; yNew < cyNewSize; yNew++)
        {
            yOld = yNew * cyImgSize / cyNewSize;
            for (xNew = 0; xNew < cxNewSize; xNew++)
            {
                xOld = xNew * cxImgSize / cxNewSize;

                r = *(pbImage + cImgChannels * ((yOld * cxImgSize) + xOld) + 0);
                g = *(pbImage + cImgChannels * ((yOld * cxImgSize) + xOld) + 1);
                b = *(pbImage + cImgChannels * ((yOld * cxImgSize) + xOld) + 2);
                *pImg++ = r;
                *pImg++ = g;
                *pImg++ = b;
                if (cImgChannels == 4)
                {
                    a = *(pbImage + cImgChannels * ((yOld * cxImgSize) + xOld)
                        + 3);
                    *pImg++ = a;
                }
            }
        }

        // calculate row-bytes

        wImgRowBytes = cImgChannels * cxNewSize;
        wDIRowBytes = (WORD) ((cDIChannels * cxWinSize + 3L) >> 2) << 2;

        // copy image to screen

        for (yImg = 0, yWin = cyImgPos; yImg < cyNewSize; yImg++, yWin++)
        {
            if (yWin >= cyWinSize - cyImgPos)
                break;
            src = pStretchedImage + yImg * wImgRowBytes;
            dst = pDiData + yWin * wDIRowBytes + cxImgPos * cDIChannels;

            for (xImg = 0, xWin = cxImgPos; xImg < cxNewSize; xImg++, xWin++)
            {
                if (xWin >= cxWinSize - cxImgPos)
                    break;
                r = *src++;
                g = *src++;
                b = *src++;
                *dst++ = b; /* note the reverse order */
                *dst++ = g;
                *dst++ = r;
                if (cImgChannels == 4)
                {
                    a = *src++;
                }
            }
        }

        // free memory

        if (pStretchedImage != NULL)
        {
            free (pStretchedImage);
            pStretchedImage = NULL;
        }

    }

    // process the image not-stretched

    else
    {
        // calculate the central position

        cxImgPos = (cxWinSize - cxImgSize) / 2;
        cyImgPos = (cyWinSize - cyImgSize) / 2;

        // check for image larger than window

        if (cxImgPos < MARGIN)
            cxImgPos = MARGIN;
        if (cyImgPos < MARGIN)
            cyImgPos = MARGIN;

        // calculate both row-bytes

        wImgRowBytes = cImgChannels * cxImgSize;
        wDIRowBytes = (WORD) ((cDIChannels * cxWinSize + 3L) >> 2) << 2;

        // copy image to screen

        for (yImg = 0, yWin = cyImgPos; yImg < cyImgSize; yImg++, yWin++)
        {
            if (yWin >= cyWinSize - MARGIN)
                break;
            src = pbImage + yImg * wImgRowBytes;
            dst = pDiData + yWin * wDIRowBytes + cxImgPos * cDIChannels;

            for (xImg = 0, xWin = cxImgPos; xImg < cxImgSize; xImg++, xWin++)
            {
                if (xWin >= cxWinSize - MARGIN)
                    break;
                r = *src++;
                g = *src++;
                b = *src++;
                *dst++ = b; /* note the reverse order */
                *dst++ = g;
                *dst++ = r;
                if (cImgChannels == 4)
                {
                    a = *src++;
                }
            }
        }
    }

    return TRUE;
}

//-----------------
//  end of source
//-----------------

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
狠狠色狠狠色综合| 欧美日本一区二区在线观看| 91久久奴性调教| 欧美一区二区三区视频在线 | 图片区小说区国产精品视频| 国产永久精品大片wwwapp| 99精品国产视频| 亚洲精品一区二区三区在线观看| 亚洲综合免费观看高清在线观看| 国产呦精品一区二区三区网站| 欧美又粗又大又爽| 国产精品水嫩水嫩| 国内精品视频666| 在线播放91灌醉迷j高跟美女| 国产精品免费aⅴ片在线观看| 精品亚洲aⅴ乱码一区二区三区| 欧美性大战久久| 亚洲日本一区二区| 成人免费福利片| 国产日韩欧美精品一区| 老司机免费视频一区二区| 在线日韩国产精品| 亚洲精品高清在线| 色国产综合视频| 亚洲三级在线观看| 波多野洁衣一区| 国产精品久久久久久久裸模| 成人免费视频一区| 久久网站最新地址| 国产一区二区三区久久悠悠色av| 日韩午夜小视频| 久久er99精品| 久久这里只有精品6| 久久精品国产亚洲高清剧情介绍 | 亚洲免费av高清| 成人国产精品免费网站| 国产精品私人自拍| 成人h动漫精品一区二区| 中文字幕第一区综合| 成人av电影在线| 亚洲免费观看在线视频| 99久久久国产精品免费蜜臀| 中文字幕中文字幕中文字幕亚洲无线| 国产成人精品网址| 国产精品沙发午睡系列990531| 色欧美日韩亚洲| 亚洲色图欧美激情| 91高清视频免费看| 日本成人在线视频网站| 精品久久久久久久久久久久久久久| 精品一区二区三区在线播放视频| 精品国产一区二区三区四区四| 国产一区二区成人久久免费影院 | 亚洲男人电影天堂| 欧美视频在线一区| 日本在线不卡视频| 久久色成人在线| 99精品视频在线观看免费| 亚洲三级小视频| 欧美高清dvd| 国产一区二区三区四区五区美女| 国产欧美日韩在线观看| 色综合久久综合中文综合网| 亚洲午夜精品久久久久久久久| 欧美电影免费观看高清完整版在线观看| 久久99久国产精品黄毛片色诱| 国产精品激情偷乱一区二区∴| 欧美性大战久久久久久久蜜臀| 激情小说亚洲一区| 成人免费视频在线观看| 777xxx欧美| 成人免费视频一区二区| 视频一区中文字幕| 国产精品进线69影院| 91精品国产综合久久婷婷香蕉| 顶级嫩模精品视频在线看| 一区二区三区欧美视频| 精品国产伦一区二区三区观看方式| www.日韩精品| 久久激五月天综合精品| 亚洲欧美精品午睡沙发| 26uuu欧美日本| 欧美三级中文字幕在线观看| 国产精品99久久久久久宅男| 亚洲成人动漫在线观看| 国产精品每日更新在线播放网址| 在线综合亚洲欧美在线视频| 9i在线看片成人免费| 久久精品国产精品青草| 亚洲午夜一区二区| 亚洲视频在线一区| 国产日韩在线不卡| 日韩一区二区在线观看视频播放| 日本高清不卡视频| av资源网一区| 福利一区二区在线| 国内精品国产三级国产a久久| 天天综合网 天天综合色| 亚洲精品写真福利| 中文字幕一区二区三区在线播放| 久久久久久久久久看片| 欧美成人性福生活免费看| 91精品国产综合久久久久久久| 色成人在线视频| 成人a区在线观看| 处破女av一区二区| 国产激情一区二区三区四区| 久久精工是国产品牌吗| 日韩国产精品91| 视频一区免费在线观看| 亚洲成人免费电影| 国产精品乡下勾搭老头1| 蜜桃av一区二区三区电影| 亚洲bdsm女犯bdsm网站| 性欧美疯狂xxxxbbbb| 亚洲电影激情视频网站| 亚洲成av人综合在线观看| 亚洲国产精品一区二区www | 91在线丨porny丨国产| 国产精品一级黄| 国产精品123区| 国产91精品在线观看| 国产69精品久久久久毛片| caoporen国产精品视频| 91小视频在线观看| 色菇凉天天综合网| 欧美日韩国产经典色站一区二区三区 | 精品日韩在线一区| 精品日产卡一卡二卡麻豆| 精品国产3级a| 国产午夜精品一区二区三区视频| 欧美精品一区二区三区高清aⅴ| 精品国内片67194| 国产欧美一区二区精品性色 | 欧美日韩精品一区视频| 欧美丝袜丝nylons| 日韩欧美一级特黄在线播放| 国产亚洲精久久久久久| 亚洲欧洲日产国码二区| 亚洲v精品v日韩v欧美v专区 | 精品欧美一区二区在线观看| 国产欧美精品一区二区色综合朱莉| 国产精品白丝在线| 五月天精品一区二区三区| 国内精品伊人久久久久影院对白| 成人污污视频在线观看| 日本久久电影网| 日韩视频一区二区| 国产精品情趣视频| 三级一区在线视频先锋| 国产精品亚洲视频| 欧美日韩国产一级| 欧美极品美女视频| 午夜成人在线视频| 不卡一区二区中文字幕| 欧美日韩在线综合| 久久综合狠狠综合| 亚洲图片欧美综合| 国产激情精品久久久第一区二区| 色婷婷精品久久二区二区蜜臀av| 日韩限制级电影在线观看| 中文字幕在线不卡一区二区三区| 全国精品久久少妇| 91丨porny丨最新| 欧美精品一区二区蜜臀亚洲| 亚洲一线二线三线视频| 国产激情视频一区二区三区欧美 | 午夜成人免费电影| 国产白丝网站精品污在线入口| 欧美日韩国产美| 亚洲免费视频中文字幕| 国产精品综合在线视频| 91精品国产手机| 亚洲最新在线观看| 国产精品乡下勾搭老头1| 日韩精品一区二区三区swag | 欧美国产激情二区三区| 日本中文字幕一区二区视频| 91麻豆免费看片| 欧美激情一区二区在线| 日本成人在线电影网| 91国产免费观看| 亚洲免费在线观看视频| 国产成人av福利| 久久久久久久久久久久久久久99| 日韩成人一级大片| 欧美日韩视频专区在线播放| 亚洲女人小视频在线观看| 国产成人免费视| 久久九九全国免费| 国产在线不卡一区| 久久综合色鬼综合色| 奇米一区二区三区| 日韩一级片在线播放| 三级欧美在线一区| 欧美一级黄色片| 久久99精品久久久久久动态图 | 91极品美女在线| 日韩伦理免费电影| 91蝌蚪porny|