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

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

?? rpng2-x.c

?? ImagePrinter 把wowd文件打印成png圖片
?? C
?? 第 1 頁 / 共 4 頁
字號:
        }        fprintf(stderr, "done.\n");        fflush(stderr);    }/*---------------------------------------------------------------------------    Blast background image to display buffer before beginning PNG decode.  ---------------------------------------------------------------------------*/    if (depth == 24 || depth == 32) {        ulg red, green, blue;        for (row = 0;  row < rpng2_info.height;  ++row) {            src = bg_data + row*bg_rowbytes;            dest = ximage->data + row*ximage_rowbytes;            for (i = rpng2_info.width;  i > 0;  --i) {                red   = *src++;                green = *src++;                blue  = *src++;                pixel = (red   << RShift) |                        (green << GShift) |                        (blue  << BShift);                /* recall that we set ximage->byte_order = MSBFirst above */                /* GRR BUG:  this assumes bpp == 32, but may be 24: */                *dest++ = (char)((pixel >> 24) & 0xff);                *dest++ = (char)((pixel >> 16) & 0xff);                *dest++ = (char)((pixel >>  8) & 0xff);                *dest++ = (char)( pixel        & 0xff);            }        }    } else if (depth == 16) {        ush red, green, blue;        for (row = 0;  row < rpng2_info.height;  ++row) {            src = bg_data + row*bg_rowbytes;            dest = ximage->data + row*ximage_rowbytes;            for (i = rpng2_info.width;  i > 0;  --i) {                red   = ((ush)(*src) << 8);  ++src;                green = ((ush)(*src) << 8);  ++src;                blue  = ((ush)(*src) << 8);  ++src;                pixel = ((red   >> RShift) & RMask) |                        ((green >> GShift) & GMask) |                        ((blue  >> BShift) & BMask);                /* recall that we set ximage->byte_order = MSBFirst above */                *dest++ = (char)((pixel >>  8) & 0xff);                *dest++ = (char)( pixel        & 0xff);            }        }    } else /* depth == 8 */ {        /* GRR:  add 8-bit support */    }    XPutImage(display, window, gc, ximage, 0, 0, 0, 0, rpng2_info.width,      rpng2_info.height);    return 0;} /* end function rpng2_x_load_bg_image() */static void rpng2_x_display_row(ulg row){    uch bg_red   = rpng2_info.bg_red;    uch bg_green = rpng2_info.bg_green;    uch bg_blue  = rpng2_info.bg_blue;    uch *src, *src2=NULL;    char *dest;    uch r, g, b, a;    int ximage_rowbytes = ximage->bytes_per_line;    ulg i, pixel;    static int rows=0, prevpass=(-1);    static ulg firstrow;/*---------------------------------------------------------------------------    rows and firstrow simply track how many rows (and which ones) have not    yet been displayed; alternatively, we could call XPutImage() for every    row and not bother with the records-keeping.  ---------------------------------------------------------------------------*/    Trace((stderr, "beginning rpng2_x_display_row()\n"))    if (rpng2_info.pass != prevpass) {        if (pause_after_pass && rpng2_info.pass > 0) {            XEvent e;            KeySym k;            fprintf(stderr,              "%s:  end of pass %d of 7; click in image window to continue\n",              PROGNAME, prevpass + 1);            do                XNextEvent(display, &e);            while (!(e.type == ButtonPress && e.xbutton.button == Button1)                   && !(e.type == KeyPress &&                   ((k = XLookupKeysym(&e.xkey, 0)) == XK_q                    || k == XK_Escape) )) ;        }        fprintf(stderr, "%s:  pass %d of 7\r", PROGNAME, rpng2_info.pass + 1);        fflush(stderr);        prevpass = rpng2_info.pass;    }    if (rows == 0)        firstrow = row;   /* first row that is not yet displayed */    ++rows;   /* count of rows received but not yet displayed *//*---------------------------------------------------------------------------    Aside from the use of the rpng2_info struct, the lack of an outer loop    (over rows) and moving the XPutImage() call outside the "if (depth)"    tests, this routine is identical to rpng_x_display_image() in the non-    progressive version of the program.  ---------------------------------------------------------------------------*/    if (depth == 24 || depth == 32) {        ulg red, green, blue;        src = rpng2_info.image_data + row*rpng2_info.rowbytes;        if (bg_image)            src2 = bg_data + row*bg_rowbytes;        dest = ximage->data + row*ximage_rowbytes;        if (rpng2_info.channels == 3) {            for (i = rpng2_info.width;  i > 0;  --i) {                red   = *src++;                green = *src++;                blue  = *src++;                pixel = (red   << RShift) |                        (green << GShift) |                        (blue  << BShift);                /* recall that we set ximage->byte_order = MSBFirst above */                /* GRR BUG:  this assumes bpp == 32, but may be 24: */                *dest++ = (char)((pixel >> 24) & 0xff);                *dest++ = (char)((pixel >> 16) & 0xff);                *dest++ = (char)((pixel >>  8) & 0xff);                *dest++ = (char)( pixel        & 0xff);            }        } else /* if (rpng2_info.channels == 4) */ {            for (i = rpng2_info.width;  i > 0;  --i) {                r = *src++;                g = *src++;                b = *src++;                a = *src++;                if (bg_image) {                    bg_red   = *src2++;                    bg_green = *src2++;                    bg_blue  = *src2++;                }                if (a == 255) {                    red   = r;                    green = g;                    blue  = b;                } else if (a == 0) {                    red   = bg_red;                    green = bg_green;                    blue  = bg_blue;                } else {                    /* this macro (from png.h) composites the foreground                     * and background values and puts the result into the                     * first argument */                    alpha_composite(red,   r, a, bg_red);                    alpha_composite(green, g, a, bg_green);                    alpha_composite(blue,  b, a, bg_blue);                }                pixel = (red   << RShift) |                        (green << GShift) |                        (blue  << BShift);                /* recall that we set ximage->byte_order = MSBFirst above */                /* GRR BUG:  this assumes bpp == 32, but may be 24: */                *dest++ = (char)((pixel >> 24) & 0xff);                *dest++ = (char)((pixel >> 16) & 0xff);                *dest++ = (char)((pixel >>  8) & 0xff);                *dest++ = (char)( pixel        & 0xff);            }        }    } else if (depth == 16) {        ush red, green, blue;        src = rpng2_info.row_pointers[row];        if (bg_image)            src2 = bg_data + row*bg_rowbytes;        dest = ximage->data + row*ximage_rowbytes;        if (rpng2_info.channels == 3) {            for (i = rpng2_info.width;  i > 0;  --i) {                red   = ((ush)(*src) << 8);                ++src;                green = ((ush)(*src) << 8);                ++src;                blue  = ((ush)(*src) << 8);                ++src;                pixel = ((red   >> RShift) & RMask) |                        ((green >> GShift) & GMask) |                        ((blue  >> BShift) & BMask);                /* recall that we set ximage->byte_order = MSBFirst above */                *dest++ = (char)((pixel >>  8) & 0xff);                *dest++ = (char)( pixel        & 0xff);            }        } else /* if (rpng2_info.channels == 4) */ {            for (i = rpng2_info.width;  i > 0;  --i) {                r = *src++;                g = *src++;                b = *src++;                a = *src++;                if (bg_image) {                    bg_red   = *src2++;                    bg_green = *src2++;                    bg_blue  = *src2++;                }                if (a == 255) {                    red   = ((ush)r << 8);                    green = ((ush)g << 8);                    blue  = ((ush)b << 8);                } else if (a == 0) {                    red   = ((ush)bg_red   << 8);                    green = ((ush)bg_green << 8);                    blue  = ((ush)bg_blue  << 8);                } else {                    /* this macro (from png.h) composites the foreground                     * and background values and puts the result back into                     * the first argument (== fg byte here:  safe) */                    alpha_composite(r, r, a, bg_red);                    alpha_composite(g, g, a, bg_green);                    alpha_composite(b, b, a, bg_blue);                    red   = ((ush)r << 8);                    green = ((ush)g << 8);                    blue  = ((ush)b << 8);                }                pixel = ((red   >> RShift) & RMask) |                        ((green >> GShift) & GMask) |                        ((blue  >> BShift) & BMask);                /* recall that we set ximage->byte_order = MSBFirst above */                *dest++ = (char)((pixel >>  8) & 0xff);                *dest++ = (char)( pixel        & 0xff);            }        }    } else /* depth == 8 */ {        /* GRR:  add 8-bit support */    }/*---------------------------------------------------------------------------    Display after every 16 rows or when on one of last two rows.  (Region    may include previously displayed lines due to interlacing--i.e., not    contiguous.  Also, second-to-last row is final one in interlaced images    with odd number of rows.)  For demos, flush (and delay) after every 16th    row so "sparse" passes don't go twice as fast.  ---------------------------------------------------------------------------*/    if (demo_timing && (row - firstrow >= 16 || row >= rpng2_info.height-2)) {        XPutImage(display, window, gc, ximage, 0, (int)firstrow, 0,          (int)firstrow, rpng2_info.width, row - firstrow + 1);        XFlush(display);        rows = 0;        usleep(usleep_duration);    } else    if (!demo_timing && ((rows & 0xf) == 0 || row >= rpng2_info.height-2)) {        XPutImage(display, window, gc, ximage, 0, (int)firstrow, 0,          (int)firstrow, rpng2_info.width, row - firstrow + 1);        XFlush(display);        rows = 0;    }}static void rpng2_x_finish_display(void){    Trace((stderr, "beginning rpng2_x_finish_display()\n"))    /* last row has already been displayed by rpng2_x_display_row(), so we     * have nothing to do here except set a flag and let the user know that     * the image is done */    rpng2_info.done = TRUE;    printf(      "Done.  Press Q, Esc or mouse button 1 (within image window) to quit.\n");    fflush(stdout);}static void rpng2_x_cleanup(void){    if (bg_image && bg_data) {        free(bg_data);        bg_data = NULL;    }    if (rpng2_info.image_data) {        free(rpng2_info.image_data);        rpng2_info.image_data = NULL;    }    if (rpng2_info.row_pointers) {        free(rpng2_info.row_pointers);        rpng2_info.row_pointers = NULL;    }    if (ximage) {        if (ximage->data) {            free(ximage->data);           /* we allocated it, so we free it */            ximage->data = (char *)NULL;  /*  instead of XDestroyImage() */        }        XDestroyImage(ximage);        ximage = NULL;    }    if (have_gc)        XFreeGC(display, gc);    if (have_window)        XDestroyWindow(display, window);    if (have_colormap)        XFreeColormap(display, colormap);    if (have_nondefault_visual)        XFree(visual_list);}static int rpng2_x_msb(ulg u32val){    int i;    for (i = 31;  i >= 0;  --i) {        if (u32val & 0x80000000L)            break;        u32val <<= 1;    }    return i;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
午夜精品一区二区三区免费视频| 亚洲综合在线五月| 日本成人在线看| 91麻豆精品国产自产在线观看一区| 午夜精品免费在线| 日韩精品中文字幕在线不卡尤物 | 成人精品视频一区二区三区尤物| 久久在线观看免费| 国产宾馆实践打屁股91| 亚洲精品乱码久久久久久久久| 欧洲一区二区三区在线| 日本最新不卡在线| 中文字幕欧美三区| 欧美天天综合网| 狠狠色伊人亚洲综合成人| 国产精品美女久久久久久久网站| 在线免费精品视频| 激情深爱一区二区| 国产精品不卡一区| 国产亲近乱来精品视频 | 久久噜噜亚洲综合| 成人动漫在线一区| 午夜精品aaa| 日韩你懂的电影在线观看| 国产成人精品影院| 亚洲一区二区精品久久av| 久久综合久久综合久久| 色综合天天综合网天天狠天天| 日韩精品午夜视频| 自拍偷自拍亚洲精品播放| 欧美精品久久一区| 波多野结衣中文一区| 日韩制服丝袜av| 国产精品久线观看视频| 欧美一区二区三区视频免费播放| 成人在线综合网站| 亚洲成av人片一区二区梦乃| 中文一区在线播放| 欧美一区日韩一区| 91尤物视频在线观看| 黄色精品一二区| 国产精品久久久久久久午夜片| 日韩精品一区第一页| 国产精品网站在线| 欧美成人精品1314www| 色久优优欧美色久优优| 国产一区二区电影| 丝袜亚洲另类丝袜在线| 亚洲免费观看在线观看| 久久精品综合网| 欧美一二三四在线| 欧美性猛交xxxxxxxx| 不卡电影免费在线播放一区| 精品一区二区三区免费视频| 亚瑟在线精品视频| 亚洲女爱视频在线| 亚洲国产激情av| 久久久一区二区三区捆绑**| 日韩一级黄色片| 8x8x8国产精品| 欧美日韩国产在线观看| 色婷婷国产精品| 91在线视频官网| av中文字幕不卡| aaa欧美色吧激情视频| 国产福利一区在线| 国产一二精品视频| 韩国成人在线视频| 久久66热偷产精品| 极品美女销魂一区二区三区免费| 全国精品久久少妇| 欧美aaaaaa午夜精品| 青青草国产精品亚洲专区无| 图片区小说区区亚洲影院| 一区二区三区在线免费| 亚洲色图都市小说| 亚洲综合色自拍一区| 一区二区免费看| 午夜精品久久久久久久久久| 日韩中文字幕不卡| 久久精品久久99精品久久| 老司机一区二区| 韩国女主播一区二区三区| 国产精品一级在线| yourporn久久国产精品| 色综合久久久久久久久久久| 在线国产亚洲欧美| 欧美猛男男办公室激情| 欧美成人video| 国产精品午夜电影| 一区二区三区在线免费观看| 午夜精品福利久久久| 久久99精品网久久| 成人激情视频网站| 欧美视频在线一区| 日韩三级免费观看| 国产日本亚洲高清| 亚洲黄色在线视频| 日本aⅴ免费视频一区二区三区 | 国产aⅴ综合色| 91美女视频网站| 777午夜精品视频在线播放| 久久综合色之久久综合| 国产精品免费丝袜| 首页综合国产亚洲丝袜| 国产一区二区看久久| 色网综合在线观看| 日韩欧美电影一二三| 中文av一区特黄| 三级在线观看一区二区| 国产精品伊人色| 欧美日韩视频不卡| 久久久综合激的五月天| 一个色综合网站| 国产精品1区二区.| 欧美日韩国产中文| 中文字幕免费不卡| 日韩黄色免费电影| 不卡的电影网站| 精品毛片乱码1区2区3区| 亚洲人一二三区| 狠狠色伊人亚洲综合成人| 日本电影欧美片| 2020日本不卡一区二区视频| 亚洲永久精品国产| 粉嫩嫩av羞羞动漫久久久| 欧美另类高清zo欧美| 国产精品美女久久福利网站| 美女视频网站久久| 欧美亚洲一区二区在线观看| 国产偷v国产偷v亚洲高清| 五月天国产精品| 色久优优欧美色久优优| 国产精品私人影院| 国产在线精品一区二区三区不卡 | 欧美一区二区三区成人| 亚洲美女少妇撒尿| 成人毛片在线观看| 日韩免费电影网站| 天天影视网天天综合色在线播放| 色综合天天天天做夜夜夜夜做| ww久久中文字幕| 青椒成人免费视频| 欧美日韩精品福利| 亚洲色图欧美激情| 成人黄色软件下载| 国产嫩草影院久久久久| 蜜桃在线一区二区三区| 欧美日韩三级在线| 一区二区三区四区在线免费观看| 成人av电影观看| 中文在线一区二区 | 日韩黄色免费电影| 欧美日韩久久一区| 亚洲日本在线视频观看| 成人国产在线观看| 欧美国产97人人爽人人喊| 国产电影精品久久禁18| 亚洲精品一线二线三线无人区| 视频在线观看一区| 91精品国产色综合久久不卡蜜臀| 亚洲国产中文字幕在线视频综合| 在线观看三级视频欧美| 亚洲精品欧美激情| 国产精品福利影院| 久久人人超碰精品| 精品一区二区在线视频| 欧美一区二区三区思思人| 日韩成人伦理电影在线观看| 欧美丰满一区二区免费视频| 日韩黄色一级片| 日韩一区二区影院| 麻豆国产欧美一区二区三区| 日韩欧美国产三级| 国产乱码精品一区二区三区五月婷| 久久蜜臀精品av| 不卡av电影在线播放| 亚洲男女毛片无遮挡| 色婷婷av一区二区三区gif| 亚洲国产成人va在线观看天堂| 欧美日韩激情一区二区| 男女性色大片免费观看一区二区| 日韩视频免费直播| 高清免费成人av| 亚洲欧美日本韩国| 在线播放/欧美激情| 麻豆精品一二三| 国产精品萝li| 欧美日韩色综合| 国产老女人精品毛片久久| 中文字幕在线观看一区| 欧美撒尿777hd撒尿| 久久爱www久久做| 中文字幕在线观看一区| 欧美精品18+| 国产精品一区二区久久精品爱涩| 中文字幕一区二区三中文字幕| 欧美性生活久久| 国产在线视频一区二区| 亚洲欧美日韩在线|