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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? bitmap-lite.c

?? miniucgui1.30版本的源碼
?? C
字號(hào):
/*** $Id: bitmap-lite.c,v 1.17 2003/09/04 03:09:52 weiym Exp $**** Bitmap operations of GDI for MiniGUI-Lite.**** Copyright (C) 2003 Feynman Software** Copyright (C) 2000 ~ 2002 Wei Yongming.**** Current maintainer: Wei Yongming.**** Create date: 2000/06/12, derived from original gdi.c*//*** This program is free software; you can redistribute it and/or modify** it under the terms of the GNU General Public License as published by** the Free Software Foundation; either version 2 of the License, or** (at your option) any later version.**** This program is distributed in the hope that it will be useful,** but WITHOUT ANY WARRANTY; without even the implied warranty of** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the** GNU General Public License for more details.**** You should have received a copy of the GNU General Public License** along with this program; if not, write to the Free Software** Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA*//*** TODO:*/ #include <stdio.h>#include <stdlib.h>#include <string.h>#include "common.h"#include "minigui.h"#include "gdi.h"#include "window.h"#include "cliprect.h"#include "gal.h"#include "internals.h"#include "ctrlclass.h"#include "dc.h"#include "cursor.h"extern BOOL dc_GenerateECRgn(PDC pdc, BOOL fForce);/****************************** Bitmap Support *******************************/void GUIAPI FillBox (HDC hdc, int x, int y, int w, int h){    PCLIPRECT pClipRect;    PDC pdc;    RECT rcOutput;    pdc = dc_HDC2PDC(hdc);    if (dc_IsGeneralHDC(hdc)) {        if (!dc_GenerateECRgn (pdc, FALSE)) {            return;        }    }    // Transfer logical to device to screen here.    w += x; h += y;    coor_LP2SP(pdc, &x, &y);    coor_LP2SP(pdc, &w, &h);    rcOutput.left = x;    rcOutput.top  = y;    rcOutput.right = w;    rcOutput.bottom = h;    NormalizeRect (&rcOutput);    w = RECTW (rcOutput); h = RECTH (rcOutput);    IntersectRect (&rcOutput, &rcOutput, &pdc->ecrgn.rcBound);    if( !dc_IsMemHDC(hdc) ) ShowCursorForGDI(FALSE, &rcOutput);        // set graphics context.    GAL_SetGC (pdc->gc);    GAL_SetFgColor (pdc->gc, pdc->brushcolor);    pClipRect = pdc->ecrgn.head;    while(pClipRect)    {        if (DoesIntersect (&rcOutput, &pClipRect->rc)) {            GAL_SetClipping(pdc->gc, pClipRect->rc.left, pClipRect->rc.top,                    pClipRect->rc.right - 1, pClipRect->rc.bottom - 1);                    GAL_FillBox (pdc->gc, x, y, w, h, pdc->brushcolor);        }        pClipRect = pClipRect->next;    }    if( !dc_IsMemHDC(hdc) ) ShowCursorForGDI(TRUE, &rcOutput);}BOOL GUIAPI FillBoxWithBitmap (HDC hdc, int x, int y, int w, int h,                               const BITMAP* pBitmap){    PCLIPRECT pClipRect;    PDC pdc;    void* scaledBitmap;    int sw = pBitmap->bmWidth, sh = pBitmap->bmHeight;    RECT rcOutput;     if (pBitmap->bmWidth <= 0 || pBitmap->bmHeight <= 0 || pBitmap->bmBits == NULL)        return FALSE;    if (w <= 0 || h <= 0) {        w = sw;        h = sh;    }    pdc = dc_HDC2PDC(hdc);    if (dc_IsGeneralHDC(hdc)) {        if (!dc_GenerateECRgn (pdc, FALSE)) {            return TRUE;        }    }    // Transfer logical to device to screen here.    w += x; h += y;    coor_LP2SP(pdc, &x, &y);    coor_LP2SP(pdc, &w, &h);    rcOutput.left = x;    rcOutput.top = y;    rcOutput.right = w;    rcOutput.bottom = h;    NormalizeRect (&rcOutput);    w = RECTW (rcOutput); h = RECTH (rcOutput);    IntersectRect (&rcOutput, &rcOutput, &pdc->ecrgn.rcBound);    if( !dc_IsMemHDC(hdc) ) ShowCursorForGDI(FALSE, &rcOutput);    if(w == sw && h == sh)        scaledBitmap = pBitmap->bmBits;    else    {        if ((scaledBitmap = malloc (GAL_BoxSize (pdc->gc, w, h))) == NULL)            goto free_ret;        GAL_ScaleBox (pdc->gc, sw, sh, pBitmap->bmBits, w, h, scaledBitmap);    }    // set graphics context.    GAL_SetGC (pdc->gc);    pClipRect = pdc->ecrgn.head;    while (pClipRect)    {        if (DoesIntersect (&rcOutput, &pClipRect->rc)) {            GAL_SetClipping(pdc->gc, pClipRect->rc.left, pClipRect->rc.top,                    pClipRect->rc.right - 1, pClipRect->rc.bottom - 1);            if (pBitmap->bmType != BMP_TYPE_COLORKEY)                GAL_PutBox (pdc->gc, x, y, w, h, scaledBitmap);            else                GAL_PutBoxMask (pdc->gc, x, y, w, h, scaledBitmap, pBitmap->bmColorKey);        }        pClipRect = pClipRect->next;    }free_ret:    if( !dc_IsMemHDC(hdc) ) ShowCursorForGDI(TRUE, &rcOutput);    if (w != sw || h != sh) {        free (scaledBitmap);    }    return TRUE;}static void bmpGetBoxPart (int bpp, int w, int h, void* part,                            int ow, int oh, void* full, int xo, int yo){    int i;    int offset;    int lineoffset;    int linebytes;    lineoffset = ow * bpp;    linebytes = w * bpp;    offset = (ow * yo + xo) * bpp;        for (i=0; i<h; i++) {        memcpy (part, full + offset, linebytes);        part += linebytes;        offset += lineoffset;    }}BOOL GUIAPI FillBoxWithBitmapPart (HDC hdc, int x, int y, int w, int h,                int bw, int bh, const BITMAP* pBitmap, int xo, int yo){    PCLIPRECT pClipRect;    PDC pdc;    void* scaledBitmap = NULL;    void* partBitmap = NULL;    int sw = pBitmap->bmWidth, sh = pBitmap->bmHeight;    RECT rcOutput;    int bpp;    if (pBitmap->bmWidth <= 0 || pBitmap->bmHeight <= 0 || pBitmap->bmBits == NULL)        return FALSE;    pdc = dc_HDC2PDC(hdc);    bpp = GAL_BytesPerPixel (pdc->gc);    if (dc_IsGeneralHDC(hdc)) {        if (!dc_GenerateECRgn (pdc, FALSE)) {            return TRUE;        }    }    // Transfer logical to device to screen here.    w += x; h += y;    coor_LP2SP(pdc, &x, &y);    coor_LP2SP(pdc, &w, &h);    rcOutput.left = x;    rcOutput.top = y;    rcOutput.right = w;    rcOutput.bottom = h;    NormalizeRect (&rcOutput);    w = RECTW (rcOutput); h = RECTH (rcOutput);    IntersectRect (&rcOutput, &rcOutput, &pdc->ecrgn.rcBound);    if( !dc_IsMemHDC(hdc) ) ShowCursorForGDI(FALSE, &rcOutput);    // set graphics context.    GAL_SetGC(pdc->gc);    if (bw <= 0 || bh <= 0) {        scaledBitmap = pBitmap->bmBits;        bw = sw;        bh = sh;    }    else if (bw == sw && bh == sh)        scaledBitmap = pBitmap->bmBits;    else {        if ((scaledBitmap = malloc (GAL_BoxSize(pdc->gc, w, h))) == NULL)            goto free_ret;        GAL_ScaleBox (pdc->gc, sw, sh, pBitmap->bmBits, bw, bh, scaledBitmap);    }    // extract part box    if ((partBitmap = malloc (GAL_BoxSize(pdc->gc, w, h))) == NULL)        goto free_ret;    bmpGetBoxPart (bpp, w, h, partBitmap, bw, bh, scaledBitmap, xo, yo);    pClipRect = pdc->ecrgn.head;    while(pClipRect)    {        if (DoesIntersect (&rcOutput, &pClipRect->rc)) {            GAL_SetClipping(pdc->gc, pClipRect->rc.left, pClipRect->rc.top,                    pClipRect->rc.right - 1, pClipRect->rc.bottom - 1);            if (pBitmap->bmType != BMP_TYPE_COLORKEY)                GAL_PutBox (pdc->gc, x, y, w, h, partBitmap);            else                GAL_PutBoxMask (pdc->gc, x, y, w, h, partBitmap, pBitmap->bmColorKey);        }        pClipRect = pClipRect->next;    }free_ret:    if( !dc_IsMemHDC(hdc) ) ShowCursorForGDI(TRUE, &rcOutput);    if (bw != sw || bh != sh)        free (scaledBitmap);    free (partBitmap);    return TRUE;}void GUIAPI PutSavedBoxOnDC (HDC hdc, int x, int y, int w, int h, void* vbuf){    PCLIPRECT pClipRect;    PDC pdc;    RECT rcOutput;    pdc = dc_HDC2PDC(hdc);    if (dc_IsGeneralHDC(hdc)) {        if (!dc_GenerateECRgn (pdc, FALSE)) {            return;        }    }    // Transfer logical to device to screen here.    w += x; h += y;    coor_LP2SP(pdc, &x, &y);    coor_LP2SP(pdc, &w, &h);    rcOutput.left = x;    rcOutput.top = y;    rcOutput.right = w;    rcOutput.bottom = h;    NormalizeRect (&rcOutput);    w = RECTW (rcOutput); h = RECTH (rcOutput);    IntersectRect (&rcOutput, &rcOutput, &pdc->ecrgn.rcBound);    if( !dc_IsMemHDC(hdc) ) ShowCursorForGDI(FALSE, &rcOutput);    GAL_SetGC (pdc->gc);    pClipRect = pdc->ecrgn.head;    while(pClipRect)    {        if (DoesIntersect (&rcOutput, &pClipRect->rc)) {            GAL_SetClipping(pdc->gc, pClipRect->rc.left, pClipRect->rc.top,                    pClipRect->rc.right - 1, pClipRect->rc.bottom - 1);            GAL_PutBox (pdc->gc, x, y, w, h, vbuf);        }        pClipRect = pClipRect->next;    }    if( !dc_IsMemHDC(hdc) ) ShowCursorForGDI(TRUE, &rcOutput);}void ScreenCopy (int sx, int sy, HDC hdc, int dx, int dy){    PCLIPRECT pClipRect;    PDC pdc;    int offx, offy;    int boxLeft, boxTop, boxWidth, boxHeight;    RECT* prc;    pdc = dc_HDC2PDC(hdc);    if (dc_IsGeneralHDC(hdc)) {        if (!dc_GenerateECRgn (pdc, FALSE)) {            return;        }    }    else        return;    coor_LP2SP(pdc, &dx, &dy);    offx = sx - dx;    offy = sy - dy;    ShowCursorForGDI(FALSE, &g_rcScr);    GAL_SetGC (PHYSICALGC);    GAL_DisableClipping (pdc->gc);    pClipRect = pdc->ecrgn.head;    while (pClipRect)    {        prc = &pClipRect->rc;        boxLeft   = prc->left   + offx;        boxTop    = prc->top    + offy;        boxWidth  = prc->right  - prc->left;        boxHeight = prc->bottom - prc->top;        GAL_CopyBox (pdc->gc, boxLeft, boxTop, boxWidth, boxHeight, prc->left, prc->top);        pClipRect = pClipRect->next;    }    ShowCursorForGDI(TRUE, &g_rcScr);}void GUIAPI BitBlt(HDC hsdc, int sx, int sy, int sw, int sh,                   HDC hddc, int dx, int dy, DWORD dwRop){    PCLIPRECT pClipRect;    PDC psdc, pddc;    RECT rcOutput;    psdc = dc_HDC2PDC(hsdc);    pddc = dc_HDC2PDC(hddc);    if (dc_IsGeneralHDC(hddc)) {        if (!dc_GenerateECRgn (pddc, FALSE)) {            return;        }    }    if (sw <= 0 || sh <= 0) {        sw = RECTW (psdc->DevRC);        sh = RECTH (psdc->DevRC);    }    // Transfer logical to device to screen here.    sw += sx; sh += sy;    coor_LP2SP(psdc, &sx, &sy);    coor_LP2SP(psdc, &sw, &sh);    (sw > sx) ? (sw -= sx) : (sw = sx - sw);    (sh > sy) ? (sh -= sy) : (sh = sy - sh);    coor_LP2SP(pddc, &dx, &dy);    rcOutput.left = dx;    rcOutput.top  = dy;    rcOutput.right = dx + sw;    rcOutput.bottom = dy + sh;    NormalizeRect(&rcOutput);        ShowCursorForGDI(FALSE, &g_rcScr);    // set graphics context.    GAL_SetGC (pddc->gc);    pClipRect = pddc->ecrgn.head;    while(pClipRect)    {        if (DoesIntersect (&rcOutput, &pClipRect->rc)) {            GAL_SetClipping(pddc->gc, pClipRect->rc.left, pClipRect->rc.top,                    pClipRect->rc.right - 1, pClipRect->rc.bottom - 1);            GAL_CrossBlit (psdc->gc, sx, sy, sw, sh, pddc->gc, dx, dy);        }        pClipRect = pClipRect->next;    }    ShowCursorForGDI(TRUE, &g_rcScr);}void GUIAPI StretchBlt (HDC hsdc, int sx, int sy, int sw, int sh,                       HDC hddc, int dx, int dy, int dw, int dh, DWORD dwRop){    PCLIPRECT pClipRect;    PDC psdc, pddc;    void* srcBitmap = NULL;     void* scaledBitmap = NULL;    RECT rcOutput;    psdc = dc_HDC2PDC(hsdc);    pddc = dc_HDC2PDC(hddc);    if (dc_IsGeneralHDC(hddc)) {        if (!dc_GenerateECRgn (pddc, FALSE)) {            return;        }    }    // Transfer logical to device to screen here.    sw += sx; sh += sy;    coor_LP2SP(psdc, &sx, &sy);    coor_LP2SP(psdc, &sw, &sh);    (sw > sx) ? (sw -= sx) : (sw = sx - sw);    (sh > sy) ? (sh -= sy) : (sh = sy - sh);    dw += dx; dh += dy;    coor_LP2SP(pddc, &dx, &dy);    coor_LP2SP(pddc, &dw, &dh);    rcOutput.left = dx;    rcOutput.top = dy;    rcOutput.right = dw;    rcOutput.bottom = dh;    NormalizeRect (&rcOutput);    dw -= dx; dh -= dy;    if (!dc_IsMemHDC(hddc)) ShowCursorForGDI(FALSE, &g_rcScr);    GAL_SetGC (psdc->gc);    if ((srcBitmap = malloc (GAL_BoxSize (psdc->gc, sw, sh))) == NULL ||         (scaledBitmap = malloc (GAL_BoxSize (pddc->gc, dw, dh))) == NULL)        goto free_ret;    GAL_GetBox (psdc->gc, sx, sy, sw, sh, srcBitmap);    GAL_ScaleBox (psdc->gc, sw, sh, srcBitmap, dw, dh, scaledBitmap);    GAL_SetGC (pddc->gc);    pClipRect = pddc->ecrgn.head;    while(pClipRect)    {        if (DoesIntersect (&rcOutput, &pClipRect->rc)) {            GAL_SetClipping (pddc->gc, pClipRect->rc.left, pClipRect->rc.top,                    pClipRect->rc.right - 1, pClipRect->rc.bottom - 1);            GAL_PutBox (pddc->gc, dx, dy, dw, dh, scaledBitmap);        }        pClipRect = pClipRect->next;    }free_ret:    if (!dc_IsMemHDC(hddc)) ShowCursorForGDI (TRUE, &g_rcScr);    free (srcBitmap);    free (scaledBitmap);}#include "bitmap-comm.c"

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区在线观看网站| 91在线视频免费观看| 亚洲妇女屁股眼交7| 亚洲色图丝袜美腿| 国产精品视频线看| 中文av一区特黄| 中文字幕av一区二区三区高| 欧美国产精品一区| 中文字幕亚洲一区二区va在线| 国产精品毛片高清在线完整版 | 日韩精品专区在线影院重磅| 91精品国产综合久久久久| 91精品国产综合久久小美女| 91精品国产91久久久久久一区二区| 欧美年轻男男videosbes| 欧美日本精品一区二区三区| 日韩区在线观看| 2023国产精华国产精品| 国产欧美一区二区精品秋霞影院| 久久精品人人做人人爽97| 国产日韩在线不卡| 国产精品第四页| 一区二区三区在线观看网站| 亚洲成人资源网| 蜜臀av性久久久久蜜臀aⅴ流畅| 韩国v欧美v日本v亚洲v| 成人三级在线视频| 91网站在线播放| 在线免费观看成人短视频| 欧美久久一区二区| 欧美tk—视频vk| 中文文精品字幕一区二区| 亚洲精品国产视频| 奇米精品一区二区三区在线观看| 精品一区二区三区蜜桃| 成人av片在线观看| 欧美午夜电影网| 精品免费日韩av| 综合久久一区二区三区| 亚洲va韩国va欧美va| 精久久久久久久久久久| 91在线云播放| 日韩午夜av电影| 国产精品你懂的在线欣赏| 亚洲va韩国va欧美va| 国产精品自拍一区| 欧美色图12p| 国产亚洲精久久久久久| 亚洲一区二区精品久久av| 国精产品一区一区三区mba视频 | 精品中文字幕一区二区小辣椒| 国产精品一区二区x88av| 欧美在线高清视频| 亚洲精品一线二线三线| 一区二区三区高清在线| 精品亚洲porn| 欧美三级资源在线| 欧美韩日一区二区三区四区| 日韩不卡一区二区三区 | 久久精品夜夜夜夜久久| 亚洲一区二区精品视频| 懂色一区二区三区免费观看| 欧美精品在线视频| 亚洲日本一区二区| 极品少妇xxxx精品少妇偷拍| 欧洲国产伦久久久久久久| 国产欧美精品国产国产专区| 日本欧美在线观看| 在线免费观看日韩欧美| 国产精品嫩草99a| 精品影院一区二区久久久| 欧美色男人天堂| 亚洲色图欧美激情| 国产高清久久久| 欧美v日韩v国产v| 五月综合激情日本mⅴ| 91蜜桃婷婷狠狠久久综合9色| 精品日韩一区二区三区免费视频| 亚洲成人在线观看视频| 一本久久精品一区二区| 精品国产1区二区| 强制捆绑调教一区二区| 欧美日韩在线一区二区| 亚洲美腿欧美偷拍| 成人av网站在线| 亚洲国产高清在线观看视频| 国内外成人在线视频| 欧美一区二区三区四区久久| 亚洲一区二区三区四区不卡| 色综合天天综合网天天看片| 国产精品水嫩水嫩| 国产福利一区在线| 久久在线观看免费| 黑人精品欧美一区二区蜜桃| 91精品国产免费| 性感美女久久精品| 欧美日韩精品是欧美日韩精品| 中文字幕综合网| 99久久国产综合精品色伊 | 黄色小说综合网站| 欧美成人一区二区三区片免费| 天天亚洲美女在线视频| 欧美精品日日鲁夜夜添| 香蕉久久夜色精品国产使用方法| 在线影院国内精品| 亚洲国产精品久久不卡毛片 | 精品国产免费一区二区三区香蕉| 日韩电影一区二区三区| 8x福利精品第一导航| 日本网站在线观看一区二区三区| 欧美一区二区三区免费观看视频| 日本三级亚洲精品| 精品国产乱码久久久久久免费| 韩国三级在线一区| 国产日韩欧美不卡| av资源站一区| 亚洲午夜私人影院| 久久久久久夜精品精品免费| 精品影视av免费| 国产午夜久久久久| www.欧美精品一二区| 亚洲在线一区二区三区| 精品视频一区三区九区| 奇米777欧美一区二区| 欧美va天堂va视频va在线| 国产成人综合网站| 亚洲色大成网站www久久九九| 欧美色中文字幕| 丝瓜av网站精品一区二区| 欧美不卡一区二区三区四区| 国产在线视视频有精品| 国产精品久久国产精麻豆99网站 | 国产亚洲女人久久久久毛片| www.爱久久.com| 亚洲尤物视频在线| 精品国产乱码久久久久久牛牛| 成人av电影免费观看| 亚洲一区二区三区在线| 欧美成人a视频| 成人午夜大片免费观看| 亚洲一级二级在线| 久久日韩粉嫩一区二区三区| 99精品欧美一区二区蜜桃免费 | 国产一区二区三区久久悠悠色av| 中文字幕欧美激情| 欧美中文字幕一区二区三区| 久久99精品国产91久久来源| 自拍视频在线观看一区二区| 制服丝袜日韩国产| 成人性生交大合| 亚洲成av人片在线观看| 国产亚洲人成网站| 欧美日韩免费一区二区三区视频| 激情偷乱视频一区二区三区| 亚洲激情综合网| 久久免费视频色| 欧美日韩在线一区二区| 国产成人一级电影| 首页亚洲欧美制服丝腿| 欧美激情一区二区三区| 欧美一区二区三区四区久久| 91视频免费观看| 国内精品伊人久久久久av一坑 | 成人免费毛片高清视频| 日韩精品亚洲一区| 亚洲免费视频中文字幕| 精品美女在线播放| 欧美日韩午夜影院| 豆国产96在线|亚洲| 老司机午夜精品99久久| 亚洲午夜精品17c| 国产精品视频免费| 精品国产一区二区三区久久影院| 欧美亚洲动漫制服丝袜| 国产成人综合视频| 奇米色一区二区三区四区| 亚洲综合色视频| 亚洲欧洲成人自拍| 久久婷婷色综合| 91精品国产手机| 色哟哟日韩精品| 成人午夜免费电影| 九一久久久久久| 天天色 色综合| 亚洲午夜在线观看视频在线| 亚洲视频一二区| 日本一区二区免费在线| 亚洲精品一线二线三线无人区| 5858s免费视频成人| 欧美日韩免费一区二区三区 | 日本高清不卡视频| 国产成+人+日韩+欧美+亚洲| 免费成人在线网站| 日本大胆欧美人术艺术动态 | 欧美喷水一区二区| 欧美伊人久久大香线蕉综合69 | 久久久久久影视| 精品国一区二区三区| 日韩欧美一区在线观看| 69久久夜色精品国产69蝌蚪网|