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

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

?? images.c

?? 用于移動設備上的java虛擬機源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* * @(#)images.c	1.53 02/11/07 @(#) * * Copyright (c) 1999-2002 Sun Microsystems, Inc.  All rights reserved. * PROPRIETARY/CONFIDENTIAL * Use is subject to license terms. */#include <stdio.h>#define NeedFunctionPrototypes 1#include <kni.h>#include <defaultLCDUI.h>#include <nativeGUI.h>#include <imageDecode.h>#include <midpMalloc.h>#include <midpServices.h>#include <images.h>typedef struct _mbs {    Pixmap        pixmap;    XImage        image;    unsigned char *imageMask; /* this serves as a bit mask and as an alpha			       * channel array depending on what kind of			       * information is in the image. these two			       * properties are mutually exclusive so this                               * is ok                               */    jint           width;    jint           height;    jint           mutable;    jbyte          prop;} myBitmapStruct;typedef struct _imgDst {    imageDstData   super;    myBitmapStruct *bitmap;    jint            cmap[256];    unsigned char  tmap[256];    jint            dataSize;    jboolean       mutable;    jboolean       hasColormap;    jboolean       hasTransMap;} _imageDstData, *_imageDstPtr;/* REMIND: this is 3:3:2.  Consider 6x6x6 + 16 grays instead. */#define GETRGBPIXEL(r, g, b) \    rgbTable[((r & 0xe0) >> 0) | ((g & 0xe0) >> 3) | ((b & 0xc0) >> 6)].pixel/*  * getPixelParts scales 16 bit xcolor componets for red, green, blue * to 8 bit values.  Thus the red/green/blue values returned in * xcolor correspond to 8 bit rgb values of the color displayed. */static voidgetPixelParts(long pixel, XColor *xcolor){    XColor *table;    int i;    switch (numColors) {        case 2:         case 4:        case 16:            table = grayTable;            break;        default:            table = rgbTable;            break;    }    for (i = 0; i < numColors; i++) {        if (pixel == table[i].pixel) {            switch (numColors) {                case 2:                    xcolor->red   = grayTable[i].red >> 7;                    xcolor->green = xcolor->red;                    xcolor->blue  = xcolor->red;                    return;                case 4:                    xcolor->red   = grayTable[i].red >> 6;                    xcolor->green = xcolor->red;                    xcolor->blue  = xcolor->red;                    return;                case 16:                    xcolor->red   = grayTable[i].red >> 4;                    xcolor->green = xcolor->red;                    xcolor->blue  = xcolor->red;                    return;                default:                    xcolor->red   = (rgbTable[i].red   >> 8) & 0xe0;                    xcolor->green = (rgbTable[i].green >> 8) & 0xe0;                    xcolor->blue  = (rgbTable[i].blue  >> 8) & 0xc0;                    return;            }        }    }    xcolor->red = xcolor->green = xcolor->blue = 0;}static intgetPixelValue(int r, int g, int b){    switch (numColors) {        case  2: return grayTable[r >> 7].pixel;        case  4: return grayTable[r >> 6].pixel;        case 16: return grayTable[r >> 4].pixel;        default: return GETRGBPIXEL(r, g, b);    }}static intgetColorPixel(int rgb, int gray, int isGray){    int r = (rgb >> 16) & 0xff;    int g = (rgb >> 8)  & 0xff;    int b = (rgb >> 0)  & 0xff;    return GETRGBPIXEL(r, g, b);}static intgetGrayPixel(int rgb, int gray, int isGray){    switch (numColors) {    case  2: return grayTable[gray >> 7].pixel;    case  4: return grayTable[gray >> 6].pixel;    case 16: return grayTable[gray >> 4].pixel;    default:        fprintf(stderr, "Unsupported number of gray levels -- %d\n",                numColors);    }    return 0;}#define NTSC(r, g, b) ((r*78 + g*150 + b*29) >> 8)intLCDUIgetPixel(int rgb, int gray, int isGray) {    return numColors < 256 ? getGrayPixel(rgb, gray, isGray) :                              getColorPixel(rgb, gray, isGray);}intLCDUIgetDisplayColor(int color) {    int r = (color >> 16) & 0xff;    int g = (color >> 8)  & 0xff;    int b = (color >> 0)  & 0xff;    int pix;    pix = getPixelValue(r, g, b);    /* the returned values are X's Xcolor.pixel       stored as BGR */    b = (pix >> 16) & 0xff;    g = (pix >> 8)  & 0xff;    r = (pix >> 0)  & 0xff;     pix = ((r << 16) | (g << 8) | b)          & 0xFFFFFF;    return (pix);}/*  * fill rgbBuffer with pixels in 0xAARRGGBB format  * assume that (*rgbBuffer) can move, as it is on the java heap * * implements this function: *   rgbData[offset + (a - x) + (b - y) * scanlength] = P(a, b) *       for *   x <= a < x + width *   y <= b < y + height */void LCDUIgetRGB(int** rgbBuffer, int offset, int scanLength,	    int x, int y, int width, int height, void *img){    int curX;    int curY;    int curOffset = offset; /* current offset in output array */    int maskOffset;    unsigned char alpha;    /*     * unsigned char red;     * unsigned char green;     * unsigned char blue;      */    int argb;    int _argb;    char alphaFlag = 0;    /* zero if we don't need to process 			      alpha channel values */    XColor color;    Pixmap *pmap;    XImage *image;        myBitmapStruct *p = (myBitmapStruct *)img;    pmap = &p->pixmap;    image = &p->image;    if (img == NULL) return;    if (p->prop == HAS_ALPHA && p->imageMask != NULL)	alphaFlag = 1;    if (p->mutable) {        int w = p->width, h = p->height;        image = XGetImage(display, *pmap, 0, 0, w, h, AllPlanes, ZPixmap);    }    for (curY = y; curY < y + height; curY++) {	for (curX = x; curX < x + width; curX++) {	  _argb	= XGetPixel(image, curX, curY);		color.blue  = (_argb >> 16) & 0xff;		color.green = (_argb >> 8) & 0xff;		color.red   = _argb & 0xff;	    if (alphaFlag) {		maskOffset = curY * p->width + curX;		alpha = (unsigned char) *(p->imageMask + maskOffset);	    } else { 		alpha = 255; /* default fully opaque */	    }	    argb = (alpha << 24) | (color.red << 16) |		(color.green << 8) | color.blue;	    (*rgbBuffer)[curOffset] = argb;	    curOffset++;	}	curOffset += (scanLength - width);    }    if (p->mutable) {        XDestroyImage(image);    }}static voidsetImageColormap(imageDstPtr self, long *map, int length){    _imageDstPtr p = (_imageDstPtr)self;    p->hasColormap = KNI_TRUE;    memcpy(p->cmap, map, length * sizeof(long));}static voidsetImageTransparencyMap(imageDstPtr self, unsigned char *map,                         int length, int palLength){    _imageDstPtr p = (_imageDstPtr)self->ptr;    /* we must have a palette, so assume that everything is opaque */    if (palLength >= 0 ) {         memset(p->tmap, 0xFF, palLength);    }    memcpy(p->tmap, map, length);    p->hasTransMap = KNI_TRUE;}static XPixmapFormatValues *getPixmapFormat(int bpp) {    static XPixmapFormatValues *pixmapFormats = NULL;    static int numFormats = 0;    int i;    if (pixmapFormats == NULL) {	pixmapFormats = XListPixmapFormats(display, &numFormats);    }    if (bpp > 1) {	bpp = DefaultDepthOfScreen(screen);    }    for (i = 0; i < numFormats; ++i) {	if (bpp == pixmapFormats[i].depth) {	    return pixmapFormats + i;	}    }    return NULL;}static voidsetImageSize(imageDstPtr self, int width, int height){    /* REMIND: we're not allowing for transparency here. */    /* REMIND: yes, we are :) */    int x, y;    XImage *img;    _imageDstPtr p = (_imageDstPtr)self;    int depth = DefaultDepthOfScreen(screen);    XPixmapFormatValues *format = getPixmapFormat(depth);    int bytesPerPixel = format->bits_per_pixel >> 3;    int bytesPerLine  = (width*bytesPerPixel + 3) & ~3;    p->dataSize = sizeof(XImage) + sizeof(Pixmap);    if (! p->mutable) {        p->dataSize += bytesPerLine*height;    }    p->bitmap->width = width;    p->bitmap->height = height;    p->bitmap->mutable = p->mutable;    p->bitmap->imageMask = NULL;    p->bitmap->prop = HAS_SOLID;    img = &p->bitmap->image;    if (p->mutable) {        p->bitmap->pixmap = XCreatePixmap(display, paintWindow,                                 width, height,                                  visualDepth);	XSetClipMask(display, gc, None);        XSetForeground(display, gc, getPixelValue(0xff, 0xff, 0xff));        XFillRectangle(display, p->bitmap->pixmap, gc, 0, 0, width, height);        img->width    = width;        img->height   = height;        return;    }    img->width            = width;    img->height           = height;    img->xoffset          = 0;    img->format           = ZPixmap;    img->byte_order       = ImageByteOrder(display);    img->bitmap_unit      = BitmapUnit(display);    img->bitmap_bit_order = BitmapBitOrder(display);    img->depth            = format->depth;    img->bits_per_pixel   = format->bits_per_pixel;    img->bitmap_pad       = format->scanline_pad;    img->bytes_per_line   = bytesPerLine;    img->data             = (char *)midpMalloc(bytesPerLine * height);    if (!XInitImage(img)) {        fprintf(stderr, "XInitImage returned zero\n");        fprintf(stderr, "width            = %d\n", img->width);        fprintf(stderr, "height           = %d\n", img->height);        fprintf(stderr, "xoffset          = %d\n", img->xoffset);        fprintf(stderr, "format           = %d\n", img->format);        fprintf(stderr, "byte_order       = %d\n", img->byte_order);        fprintf(stderr, "bitmap_unit      = %d\n", img->bitmap_unit);        fprintf(stderr, "bitmap_bit_order = %d\n", img->bitmap_bit_order);        fprintf(stderr, "depth            = %d\n", img->depth);        fprintf(stderr, "bits_per_pixel   = %d\n", img->bits_per_pixel);        fprintf(stderr, "bitmap_pad       = %d\n", img->bitmap_pad);        fprintf(stderr, "bytes_per_line   = %d\n", img->bytes_per_line);    }    for (y = 0; y < height; ++y) {        for (x = 0; x < width; ++x) {            XPutPixel(img, x, y, lightPixel.pixel);        }    }    return;}static voidcopyImagePixels(imageDstPtr self, void *sourceData){    int x, y;    _imageDstPtr p = (_imageDstPtr)self;    myBitmapStruct *bitmap = (myBitmapStruct *)sourceData;    Pixmap *source = &bitmap->pixmap;    XImage *srcImg = &bitmap->image;    #if 0    if (*source == None) {        /* we're copying an immutable image! */    } else {        int w = srcImg->width, h = srcImg->height;        srcImg = XGetImage(display, *source, 0, 0, w, h, AllPlanes, ZPixmap);    }#endif    int w = srcImg->width, h = srcImg->height;    if (bitmap->mutable) {        srcImg = XGetImage(display, *source, 0, 0, w, h, AllPlanes, ZPixmap);    }    /* memcpy seems like it would be the right idea, but if srcImg doesn't */    /* exactly match p->image, we would end up with problems.  So we do it */    /* the slow way instead.                                               */    for (y = 0; y < h; ++y) {        for (x = 0; x < w; ++x) {            XPutPixel(&p->bitmap->image, x, y, XGetPixel(srcImg, x, y));        }    }    if (bitmap->mutable) {        XDestroyImage(srcImg);    }#if 0    if (*source != None) {        XDestroyImage(srcImg);    }#endif}static voidcopyPixelsTransform(imageDstPtr self, void *sourceData,		    int nXOriginSrc, int nYOriginSrc,		    int nWidth, int nHeight,		    int transform){  _imageDstPtr destP     = (_imageDstPtr)self;  myBitmapStruct *sourceBitmap = (myBitmapStruct *)sourceData;  /* --- */  int imgLen;  int srcX;  int srcY;  int xStart;  int yStart;  int xIncr;  int yIncr;  int destX;  int destY;  int yCounter;  int xCounter;      int t_width;  int t_height;  /*scan length of the source image*/  int imageWidth;  /*number of rows of the source image*/  int imageHeight;  int srcImgLen;  /* --- */  imageWidth = sourceBitmap->width;  imageHeight = sourceBitmap->height;  destP->bitmap->prop = HAS_ALPHA;  /* --- */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美激情一区二区三区| aaa亚洲精品一二三区| 中文字幕综合网| 国产欧美综合色| 国产亚洲午夜高清国产拍精品 | 在线观看日韩毛片| 成人精品免费网站| 成人高清视频在线观看| 国产老妇另类xxxxx| 一区二区三区.www| 亚洲第一会所有码转帖| 亚洲一卡二卡三卡四卡五卡| 亚洲日穴在线视频| 亚洲国产裸拍裸体视频在线观看乱了| 成人免费在线播放视频| 亚洲免费伊人电影| 亚洲在线视频网站| 日精品一区二区| 美女视频黄 久久| 国产一区二区在线视频| 国产.欧美.日韩| 91偷拍与自偷拍精品| 色诱亚洲精品久久久久久| 欧美亚洲图片小说| 欧美电影免费观看高清完整版在线| 日韩视频在线永久播放| 国产日韩欧美精品在线| 国产精品久久一级| 亚洲一区二区三区小说| 麻豆视频一区二区| 国产不卡高清在线观看视频| 色综合久久综合网97色综合| 欧美色图第一页| 日韩欧美成人激情| 中文字幕欧美一| 日韩电影在线一区二区三区| 黄色精品一二区| 波多野结衣的一区二区三区| 色噜噜狠狠色综合欧洲selulu| 日韩一区二区在线观看| 久久精品视频一区二区三区| 一区二区三区在线视频观看 | 精品国产乱码久久久久久图片 | 91精品办公室少妇高潮对白| 日韩精品在线网站| 一区二区三区成人在线视频| 麻豆精品精品国产自在97香蕉 | 欧美精选在线播放| 国产女同互慰高潮91漫画| 亚洲午夜激情网页| 国产成人午夜99999| 欧美日韩免费在线视频| 亚洲国产精品精华液2区45| 亚洲电影你懂得| 成人免费黄色在线| 亚洲精品在线观| 亚洲高清免费在线| 99re这里只有精品首页| 日韩亚洲欧美中文三级| 亚洲一区二区三区在线| 成人午夜在线免费| 26uuu色噜噜精品一区二区| 亚洲欧美日韩国产成人精品影院 | 91丨九色porny丨蝌蚪| 久久天天做天天爱综合色| 首页亚洲欧美制服丝腿| 91麻豆精东视频| 久久你懂得1024| 国产一区二区三区免费播放| 日韩视频在线永久播放| 日产精品久久久久久久性色| 欧美日韩一区 二区 三区 久久精品| 1区2区3区国产精品| 成人sese在线| 亚洲欧洲日产国码二区| 99久久国产免费看| 亚洲天堂2016| 欧美优质美女网站| 亚洲午夜一区二区| 欧美日韩卡一卡二| 日韩精品视频网站| 日韩免费观看高清完整版| 蜜桃免费网站一区二区三区| 欧美一级日韩一级| 国产在线观看一区二区| 欧美精品日日鲁夜夜添| 国产精品福利av| 蜜臀av一区二区在线免费观看| 国产成a人亚洲| 欧美成人午夜电影| 一区二区三区国产精华| 国产成人免费在线| 日韩一区和二区| 一区二区视频免费在线观看| 精品写真视频在线观看| 欧美精品 日韩| 亚洲女子a中天字幕| 国产福利电影一区二区三区| 麻豆成人91精品二区三区| 伊人色综合久久天天人手人婷| 亚洲在线免费播放| 色哟哟一区二区三区| 国产精品毛片大码女人| 美女精品自拍一二三四| 欧美老肥妇做.爰bbww视频| 亚洲免费观看高清完整版在线 | 欧美三区免费完整视频在线观看| 国产精品久久久一本精品| 国产福利一区二区三区视频在线| 在线观看视频一区二区欧美日韩| 午夜一区二区三区在线观看| 成人在线综合网| 国产婷婷色一区二区三区四区| 青青草国产精品97视觉盛宴| 99麻豆久久久国产精品免费优播| 日韩欧美电影一区| 免费高清视频精品| 欧美一级淫片007| 日韩在线a电影| 91免费精品国自产拍在线不卡| 精品噜噜噜噜久久久久久久久试看 | 亚洲一区二区精品视频| 成人网在线播放| 亚洲视频在线观看三级| 欧美一区二区三区视频| 黄页视频在线91| 亚洲国产成人高清精品| 欧美女孩性生活视频| 美国欧美日韩国产在线播放| 日韩欧美亚洲一区二区| 国产麻豆9l精品三级站| 亚洲欧美中日韩| 精品视频资源站| 亚洲综合久久久久| 国产精品久久久久毛片软件| 91成人国产精品| 污片在线观看一区二区| 亚洲精品一区二区三区四区高清| 国产呦萝稀缺另类资源| 自拍偷拍欧美精品| 日韩一区二区在线观看视频| 国产寡妇亲子伦一区二区| 亚洲欧美日韩国产综合在线| 成人福利电影精品一区二区在线观看 | 久久精品无码一区二区三区| 国产精品综合一区二区| 亚洲免费观看在线观看| 在线播放中文一区| 国产成人av电影在线播放| 亚洲在线免费播放| a美女胸又www黄视频久久| 自拍偷拍亚洲综合| 91精品国产综合久久蜜臀| 成人一区二区三区中文字幕| 亚洲一区二区三区视频在线 | 91精品国产综合久久福利 | 午夜天堂影视香蕉久久| 亚洲成人先锋电影| 中文字幕亚洲一区二区av在线| 亚洲国产成人午夜在线一区 | 国产日韩v精品一区二区| 欧美三区免费完整视频在线观看| 国产麻豆欧美日韩一区| 欧美精选午夜久久久乱码6080| 日本成人在线网站| 国产精品久久久久久福利一牛影视 | 99re视频这里只有精品| 精品一区二区久久久| 欧美日韩精品专区| 国产成人精品一区二区三区网站观看| 欧美激情资源网| 成人av资源在线| 国产综合成人久久大片91| 亚洲国产精品麻豆| 色婷婷av一区二区三区大白胸| 色婷婷精品久久二区二区蜜臀av| 国产精品自在欧美一区| 久久精品国产77777蜜臀| 亚洲小说春色综合另类电影| 中文字幕一区三区| 亚洲国产高清aⅴ视频| 欧美日韩免费观看一区三区| 国产福利91精品| 国产精品一区二区在线观看不卡 | 久久精品一级爱片| av激情综合网| 一本一本大道香蕉久在线精品| 成人激情文学综合网| 不卡视频一二三四| 成人av免费在线播放| 日本成人超碰在线观看| 国产精品污污网站在线观看| 欧美一区二区二区| 久久久久国产精品免费免费搜索| 久久在线免费观看| 中文在线免费一区三区高中清不卡| 欧美国产综合一区二区| 国产精品拍天天在线| 天天综合日日夜夜精品| 韩国女主播成人在线|