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

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

?? bitmap.c

?? 這是針對 Linux (i386)平臺的 minigui 3.6.2 開發包(MiniGUI-Processes 運行模式)。
?? C
字號:
/*** $Id: bitmap.c,v 1.43 2005/01/04 07:11:16 limei Exp $**** Bitmap operations of GDI.**** 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*/#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"#include "gdidecl.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;    if (w == 0 || h == 0)        return;#ifndef _LITE_VERSION    //FIXME    pdc = dc_HDC2PDC(hdc);#endif    LOCK_ECRGN(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);    LOCK_GDI();    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);    UNLOCK_GDI();    UNLOCK_ECRGN();}BOOL GUIAPI FillBoxWithBitmap (HDC hdc, int x, int y, int w, int h,                               const BITMAP* pBitmap){    PCLIPRECT pClipRect;    PDC pdc;    void* scaledBitmap;    int sw, sh;    RECT rcOutput;    if (!pBitmap || pBitmap->bmWidth <= 0 || pBitmap->bmHeight <= 0 || pBitmap->bmBits == NULL)        return FALSE;    sw = pBitmap->bmWidth;    sh = pBitmap->bmHeight;    if (w <= 0 || h <= 0) {        w = sw;        h = sh;    }#ifndef _LITE_VERSION    //FIXME    pdc = dc_HDC2PDC(hdc);#endif    LOCK_ECRGN(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);    LOCK_GDI();    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);    UNLOCK_GDI();    UNLOCK_ECRGN();    if (w != sw || h != sh) {        free (scaledBitmap);    }    return TRUE;}static void bmpGetBoxPart (int bpp, int w, int h, unsigned char* part,                            int ow, int oh, unsigned char* 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;#ifndef _LITE_VERSION    //FIXME    pdc = dc_HDC2PDC(hdc);#endif    LOCK_ECRGN(return TRUE);    bpp = GAL_BytesPerPixel (pdc->gc);    // 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);    LOCK_GDI();    IntersectRect (&rcOutput, &rcOutput, &pdc->ecrgn.rcBound);    if( !dc_IsMemHDC(hdc) ) ShowCursorForGDI(FALSE, &rcOutput);    // set graphics context.    GAL_SetGC(pdc->gc);    if (bw <= 0) bw = sw;    if (bh <= 0) bh = sh;    if (bw == sw && bh == sh)        scaledBitmap = pBitmap->bmBits;    else {        if ((scaledBitmap = malloc (GAL_BoxSize (pdc->gc, bw, bh))) == 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);    UNLOCK_GDI();    UNLOCK_ECRGN();    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;#ifndef _LITE_VERSION    //FIXME    pdc = dc_HDC2PDC(hdc);#endif    LOCK_ECRGN(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);    LOCK_GDI();    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);    UNLOCK_GDI();    UNLOCK_ECRGN();}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;#ifndef _LITE_VERSION    //FIXME    pdc = dc_HDC2PDC(hdc);#endif    LOCK_ECRGN(return)    else return;    coor_LP2SP(pdc, &dx, &dy);    offx = sx - dx;    offy = sy - dy;    LOCK_GDI();    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);    UNLOCK_GDI();    UNLOCK_ECRGN();}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);    LOCK_ECRGN_EX(pddc, hddc, return);    if (sw <= 0) sw = RECTW (psdc->DevRC);    if (sh <= 0) sh = RECTH (psdc->DevRC);    // Transfer device to screen here.    coor_DP2SP(psdc, &sx, &sy);    coor_DP2SP(pddc, &dx, &dy);    rcOutput.left = dx;    rcOutput.top  = dy;    rcOutput.right = dx + sw;    rcOutput.bottom = dy + sh;        LOCK_GDI();    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);    UNLOCK_GDI();    UNLOCK_ECRGN_EX(pddc, hddc);}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);    LOCK_ECRGN_EX(pddc, hddc, return);    if (sw <= 0) sw = RECTW (psdc->DevRC);    if (sh <= 0) sh = RECTH (psdc->DevRC);    if (dw <= 0) dw = RECTW (pddc->DevRC);    if (dh <= 0) dh = RECTH (pddc->DevRC);    // Transfer device to screen here.    coor_DP2SP(psdc, &sx, &sy);    coor_DP2SP(pddc, &dx, &dy);    rcOutput.left = dx;    rcOutput.top = dy;    rcOutput.right = dx + dw;    rcOutput.bottom = dy + dh;    LOCK_GDI();    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);    UNLOCK_GDI();    UNLOCK_ECRGN_EX(pddc, hddc);    free (srcBitmap);    free (scaledBitmap);}#include "bitmap-comm.c"

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品国产乱码久久久久久闺蜜 | 欧美aaaaaa午夜精品| 中文字幕乱码亚洲精品一区| 久久综合资源网| 久久蜜臀精品av| 久久久精品国产99久久精品芒果| 久久先锋资源网| 国产欧美日韩麻豆91| 国产精品网站在线| 亚洲精品视频在线观看网站| 一区二区三区在线视频免费| 亚洲一区二区视频在线| 青娱乐精品视频在线| 精品一区二区三区久久| 国产成人综合在线观看| 91免费精品国自产拍在线不卡| 97精品国产露脸对白| 色天天综合久久久久综合片| 色婷婷综合久色| 欧美日韩国产在线观看| 欧美成人一区二区三区在线观看| 精品国免费一区二区三区| 在线观看免费一区| 91浏览器在线视频| 日韩一区二区三区视频| 欧美国产日韩在线观看| 亚洲一区精品在线| 玖玖九九国产精品| 日本一二三不卡| 亚洲图片欧美色图| 国产精品一区在线| 欧美一a一片一级一片| 日韩精品中文字幕一区二区三区| 国产视频一区在线观看| 亚洲成人一区二区| 成人一区二区三区在线观看| 欧美日韩免费不卡视频一区二区三区 | 麻豆成人综合网| 91在线一区二区三区| 日韩欧美一级片| 亚洲人成在线播放网站岛国| 精品午夜久久福利影院| 色噜噜狠狠一区二区三区果冻| 日韩欧美亚洲另类制服综合在线| 国产片一区二区三区| 午夜欧美在线一二页| 成人av在线资源网站| 日韩一区二区影院| 亚洲一区二区精品视频| 不卡一卡二卡三乱码免费网站 | 国产精华液一区二区三区| 欧美日韩在线免费视频| 国产日产欧产精品推荐色| 免费成人在线观看| 欧美三级日韩三级| 中文字幕制服丝袜成人av| 男男视频亚洲欧美| 欧美日韩一卡二卡| 一区二区三区在线观看欧美| 成人一区二区三区视频 | 91国产成人在线| 亚洲桃色在线一区| 波多野结衣在线一区| 久久久精品免费观看| 国产剧情av麻豆香蕉精品| 欧美一区二区福利视频| 午夜欧美一区二区三区在线播放 | 麻豆精品视频在线| 91精品国产一区二区三区香蕉| 一区二区三区不卡视频| 高清视频一区二区| 久久久影视传媒| 国产一区 二区 三区一级| 欧美mv日韩mv亚洲| 韩国av一区二区三区四区| 精品三级在线观看| 国内不卡的二区三区中文字幕| 欧美va亚洲va| 国产成人免费视频网站| 日本一区二区视频在线观看| 成人综合日日夜夜| 亚洲婷婷在线视频| 欧美亚洲免费在线一区| 偷拍一区二区三区四区| 日韩免费电影网站| 国产麻豆精品视频| 国产精品久久午夜夜伦鲁鲁| 91网站最新网址| 亚洲国产日产av| 日韩欧美亚洲国产另类| 国产成人av电影免费在线观看| 国产精品视频观看| 在线精品国精品国产尤物884a| 天堂午夜影视日韩欧美一区二区| 欧美一区二区三区性视频| 国内精品视频一区二区三区八戒| 国产欧美一区二区精品秋霞影院| 99re亚洲国产精品| 天天影视涩香欲综合网 | 99国产精品久久久久久久久久久| 亚洲欧洲性图库| 欧美群妇大交群中文字幕| 精品一区二区三区在线观看 | 欧美日韩一区小说| 免费成人你懂的| 中文字幕日本乱码精品影院| 欧美人与z0zoxxxx视频| 国产成人av自拍| 天天综合天天综合色| 中文字幕欧美区| 在线综合亚洲欧美在线视频| 成人激情午夜影院| 日本vs亚洲vs韩国一区三区| 国产精品狼人久久影院观看方式| 在线综合+亚洲+欧美中文字幕| 99综合影院在线| 麻豆精品蜜桃视频网站| 亚洲精品一二三区| 国产日韩欧美精品一区| 欧美特级限制片免费在线观看| 国产伦理精品不卡| 视频一区二区三区入口| 亚洲人精品午夜| 久久精品在线免费观看| 91精品国产欧美一区二区18| 99精品视频一区二区三区| 韩国欧美国产一区| 免费久久99精品国产| 亚洲乱码中文字幕| 国产精品日韩成人| 久久先锋影音av| 91精品国产高清一区二区三区 | 91精品国产一区二区三区蜜臀| 一本在线高清不卡dvd| 国产成人高清在线| 国产成人日日夜夜| 国产精品 欧美精品| 国产一区二区在线观看免费| 蜜桃精品在线观看| 五月婷婷综合激情| 亚洲妇熟xx妇色黄| 亚洲激情成人在线| 亚洲日本青草视频在线怡红院 | 久久免费的精品国产v∧| 日韩精品一区国产麻豆| 91超碰这里只有精品国产| 91国模大尺度私拍在线视频| 91蝌蚪porny| 91小宝寻花一区二区三区| 99久久久久久| 日本道在线观看一区二区| 日本高清免费不卡视频| 欧美日韩一区二区三区四区| 91免费版pro下载短视频| 99久久精品免费看| 色哟哟一区二区| 在线精品亚洲一区二区不卡| 欧美日韩精品专区| 制服丝袜激情欧洲亚洲| 精品免费日韩av| 久久男人中文字幕资源站| 国产精品乱码人人做人人爱| 中文字幕一区二区三区色视频| 亚洲欧洲韩国日本视频 | 7777女厕盗摄久久久| 91精品国产欧美一区二区| 精品国产髙清在线看国产毛片| 日韩一区二区三区精品视频| 久久亚洲免费视频| 最新国产精品久久精品| 一区二区三区免费观看| 日韩高清在线电影| 国产在线视频一区二区三区| 不卡视频免费播放| 欧美在线视频你懂得| 欧美精品tushy高清| 精品久久久久久久久久久久包黑料| 精品国产一区二区三区不卡 | 91黄色免费版| 欧美一级精品大片| 亚洲国产精品成人综合| 亚洲综合成人在线视频| 久久激情综合网| 91日韩在线专区| 日韩一级免费观看| 最新不卡av在线| 天天爽夜夜爽夜夜爽精品视频| 国内精品久久久久影院薰衣草| 色综合久久综合网欧美综合网 | 中文字幕视频一区| 免费成人在线视频观看| 91免费看片在线观看| 日韩欧美不卡在线观看视频| 中文字幕制服丝袜成人av| 秋霞电影网一区二区| 色婷婷国产精品| 国产区在线观看成人精品| 香蕉久久夜色精品国产使用方法 | 欧美日韩精品专区| 中文成人综合网|