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

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

?? fblin1.c

?? mini gui 1.6.8 lib and source
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/*** $Id: fblin1.c,v 1.7 2004/04/19 09:08:21 snig Exp $** ** fblin1.c: Frame buffer 1 bpp linear video driver for MiniGUI**  This driver is suitable for the most significant bit being right.**** Original author: Wang Jianwei, derived from fblin2.c.** Rewritten by Feynman Software.**** Copyright (C) 2003 Feynman Software.** Copyright (C) 2002 Wang Jianwei.**** 2002/01/13: Create by Wang Jianwei.** 2003/07/10: Cleanup by Wei Yongming.*//*** 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 <stdlib.h>#include <string.h>#include "native.h"#include "fb.h"#ifdef _FBLIN1R_SUPPORT#define SHIFT(x) (x&7)static unsigned char pixmask [] = {0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};static unsigned char pixnotmask [] = {0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};#define normalize_pixel(c) (c & 0x01)static inline gal_uint8* get_pixel_address (PSD psd, int x, int y){    return (gal_uint8 *) psd->addr + y*psd->linelen + (x >> 3);}static inline void xsetpixel_in_byte (int x, gal_pixel c, gal_uint8 *byte){    *byte = (*byte & (pixnotmask[x&7])) | ((c << SHIFT(x))^(*byte & pixmask[x&7]));}static inline void setpixel_in_byte (int x, gal_pixel c, gal_uint8 *byte){    *byte = (*byte & (pixnotmask[x&7])) | (c << SHIFT(x));}static inline gal_pixel getpixel_in_byte (int x, const gal_uint8 *byte){    gal_uint8 tmp = *byte;    tmp = tmp & pixmask[x&7];    return (tmp >> SHIFT(x));}static int fblin1_init (PSD psd){    if (!psd->size) {        psd->size = psd->yres * psd->linelen;        return 1;    }    return 1;}/* Set pixel at x, y, to gal_pixel c */static void fblin1_drawpixel (PSD psd, int x, int y, gal_pixel c){    c = normalize_pixel (c);    if (psd->gr_mode == MODE_XOR)        xsetpixel_in_byte (x, c, get_pixel_address (psd, x, y));    else        setpixel_in_byte (x, c, get_pixel_address (psd, x, y));}/* Read pixel at x, y */static gal_pixel fblin1_readpixel (PSD psd, int x, int y){    return getpixel_in_byte (x, get_pixel_address (psd, x, y));}/* Draw horizontal line from x1,y to x2,y including final point */static void fblin1_drawhline (PSD psd, int x, int y, int w, gal_pixel c){    gal_uint8 *addr;    int cc, i;    c = normalize_pixel (c);    cc = c  | (c << 1);    cc = cc | (cc << 2);    cc = cc | (cc << 4);        addr = get_pixel_address (psd, x, y);    if (psd->gr_mode == MODE_XOR) {        if (x & 7) {            for (i = x & 7; i & 7 && w > 0; i++) {                xsetpixel_in_byte (i, c, addr);                w--;            }            addr++;        }                while (w > 7) {            *addr++ ^= cc;            w -= 8;        }                if (w > 0) {            for (i = 0; i < w; i++)                xsetpixel_in_byte (i, c, addr);        }            } else {        if (x & 7) {            for (i = x & 7; i & 7 && w > 0; i++) {                setpixel_in_byte (i, c, addr);                w--;            }            addr++;        }                while (w > 7) {            *addr++ = cc;            w -= 8;        }                if (w > 0) {            for (i = 0; i < w; i++)                setpixel_in_byte (i, c, addr);        }    }}static void fblin1_drawvline (PSD psd, int x, int y, int h, gal_pixel c){    gal_uint8 *addr;    c = normalize_pixel (c);    addr = get_pixel_address (psd, x, y);        if (psd->gr_mode == MODE_XOR) {        while (h--) {            xsetpixel_in_byte (x, c, addr);            addr += psd->linelen;        }    }    else {        while (h--) {            setpixel_in_byte (x, c, addr);            addr += psd->linelen;        }    }}/* clip to screen */static void fblin1_getbox (PSD psd, int x, int y, int w, int h, void* buf){    int i;    gal_uint8 *dst = (gal_uint8*) buf;    const gal_uint8 *src;    int d_pitch = w;    if (y < 0) {        h += y;        dst -= y * d_pitch;        y = 0;    }    if (x < 0) {        w += x;        dst -= x;        x = 0;    }    if (y + h - 1 >= psd->yres)         h = psd->yres - y ;    if (x + w - 1 >= psd->xres)         w = psd->xres - x ;        if (w <= 0 || h <= 0) return;    w += x;    src = get_pixel_address (psd, x, y);    while (h--) {        const gal_uint8 *s_line = src;        gal_uint8 *d_line = dst;        i = x;        while (i < w) {            *d_line = getpixel_in_byte (i, s_line);            d_line++; i++;            if (!(i&7)) s_line++;        }        src += psd->linelen;        dst += d_pitch;    }}/* do clip */static void fblin1_putbox (PSD psd, int x, int y, int w, int h, void *buf){    int i;    const gal_uint8 *src = (gal_uint8*) buf;    gal_uint8 *dst;    int s_pitch = w;    if (psd->doclip) {        if (y < psd->clipminy) {            h -= psd->clipminy - y;            src += (psd->clipminy - y) * s_pitch;            y = psd->clipminy;        }        if (x < psd->clipminx) {            w -= psd->clipminx - x;            src += psd->clipminx - x;            x = psd->clipminx;        }        if (y + h - 1 >= psd->clipmaxy)            h = psd->clipmaxy- y;        if (x + w - 1 >= psd->clipmaxx)            w = psd->clipmaxx- x;    }    else {        if ( y < 0 ) {            h += y;            src += -y * s_pitch;            y = 0;        }        if ( x < 0 ) {            w += x;            src += -x;            x = 0;        }        if ( y + h  -1 >= psd->yres)            h = psd->yres - y;        if ( x + w  -1 >= psd->xres)            w = psd->xres - x;    }    if (w <= 0 || h <= 0) return;    w += x;    dst = get_pixel_address (psd, x, y);    while (h--) {        const gal_uint8 *s_line = src;        gal_uint8 *d_line = dst;        i = x;        while (i < w) {            setpixel_in_byte (i, normalize_pixel (*s_line), d_line);            s_line ++; i ++;            if (!(i&7)) d_line++;        }        dst += psd->linelen;        src += s_pitch;    }}/* do clip */static void fblin1_putboxmask (PSD psd, int x, int y, int w, int h, void *buf, gal_pixel cxx){    int i;    gal_uint8 *src = (gal_uint8*) buf;    gal_uint8 *dst;    int s_pitch =  w ;    if (psd->doclip) {            if (y < psd->clipminy) {            h -= psd->clipminy - y;            src += (psd->clipminy - y) * s_pitch;            y = psd->clipminy;        }        if (x < psd->clipminx) {            w -= psd->clipminx - x;            src += psd->clipminx - x;            x = psd->clipminx;        }                if (y + h - 1 >= psd->clipmaxy)             h =  psd->clipmaxy- y;        if (x + w - 1 >= psd->clipmaxx)             w =  psd->clipmaxx- x;    }    else {        if ( y < 0 ) {            h += y;            src += -y * s_pitch;            y = 0;        }        if ( x < 0 ) {            w += x;            src += -x;            x = 0;        }                if ( y + h  -1 >= psd->yres)             h = psd->yres - y ;        if ( x + w  -1 >= psd->xres)             w = psd->xres - x ;    }    if (w <= 0 || h <= 0) return;    cxx = normalize_pixel (cxx);    w += x;    dst = get_pixel_address (psd, x, y);    while (h--) {        gal_uint8 *s_line = src;        gal_uint8 *d_line = dst;        i = x;        while (i < w) {            gal_uint8 spix = normalize_pixel (*s_line);            if (spix != cxx)                setpixel_in_byte (i, spix, d_line);            s_line++; i++;            if (!(i&7)) d_line ++;        }        dst += psd->linelen;        src += s_pitch;    }}static unsigned char right_side_mask [] = {0xff,0xfe,0xfc,0xf8,0xf0,0xe0,0xc0,0x80};static unsigned char left_side_mask [] = {0x00,0x01,0x03,0x07,0x0f,0x1f,0x3f,0x7f};static unsigned char right_ban_mask [] = {0x00,0x80,0xc0,0xe0,0xf0,0xf8,0xfc,0xfe,0xff};static unsigned char left_ban_mask [] = {0x00,0x01,0x03,0x07,0x0f,0x1f,0x3f,0x7f,0xff};/* copy line from left to right */static void fblin1_copyline_lr (gal_uint8 *src, int x1, gal_uint8 *dst, int x2, int w){    int s_head = x1 & 7;    int d_head = x2 & 7;

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91一区二区三区在线观看| 国产精品久久三区| 精品国产免费一区二区三区香蕉| 丁香网亚洲国际| 午夜精品影院在线观看| 国产精品私人影院| 欧美一区二区视频免费观看| 99久久精品99国产精品| 国产成人免费高清| 国产精品久久久久久久久晋中| 91麻豆精品国产91久久久使用方法| 97成人超碰视| 成人黄色在线看| 国产成人免费视频| 国产一区视频导航| 久久69国产一区二区蜜臀| 亚洲午夜激情网站| 午夜精品在线看| 午夜不卡在线视频| 午夜视频在线观看一区二区三区 | 欧美午夜不卡视频| 99久久婷婷国产精品综合| 成人精品在线视频观看| 国产不卡视频在线播放| 成人激情开心网| 成人av在线影院| 9l国产精品久久久久麻豆| 成人福利视频在线| 91色.com| 在线观看一区二区精品视频| 国产不卡视频在线播放| 风间由美一区二区三区在线观看| 国产精品99久久久久久久女警| 国产成人av电影在线播放| 国产91富婆露脸刺激对白| 国产福利一区二区三区在线视频| 国产自产v一区二区三区c| 国产高清亚洲一区| 色哟哟欧美精品| 欧美三级电影一区| 精品成人免费观看| 亚洲欧美日韩国产综合| 亚洲国产精品一区二区久久| 蜜桃精品视频在线观看| 成人av综合在线| 欧美精品自拍偷拍动漫精品| 欧美精品自拍偷拍动漫精品| 久久美女艺术照精彩视频福利播放 | av在线不卡免费看| 色88888久久久久久影院野外 | 欧美国产1区2区| 中文字幕亚洲区| 视频一区在线视频| 国产精品白丝av| 欧美三级午夜理伦三级中视频| 欧美一区二区国产| 综合分类小说区另类春色亚洲小说欧美| 日韩久久一区二区| 久久99久久久久久久久久久| 成人午夜激情在线| 日韩一卡二卡三卡国产欧美| 国产精品丝袜一区| 视频一区在线播放| www.亚洲精品| 日韩一区和二区| 一区二区三区欧美日韩| 狠狠狠色丁香婷婷综合激情| 91精品福利在线| 中文字幕乱码久久午夜不卡| 亚洲另类中文字| 国产高清无密码一区二区三区| 欧美精品日韩一本| 最近中文字幕一区二区三区| 狠狠v欧美v日韩v亚洲ⅴ| 欧美高清视频在线高清观看mv色露露十八| 国产无一区二区| 免费高清视频精品| 欧美乱妇一区二区三区不卡视频| 国产精品美女久久久久aⅴ国产馆| 蜜臀av性久久久久蜜臀aⅴ四虎| 色呦呦日韩精品| 亚洲欧美视频在线观看视频| 精品亚洲免费视频| 日韩一区二区在线播放| 亚洲午夜久久久久久久久电影网| 一区二区在线观看av| 亚欧色一区w666天堂| jlzzjlzz欧美大全| 亚洲视频免费看| 欧美调教femdomvk| 青椒成人免费视频| 久久毛片高清国产| av成人免费在线观看| 一区二区三国产精华液| 欧美日本视频在线| 国产一区二区精品久久91| 亚洲国产电影在线观看| 一本色道亚洲精品aⅴ| 爽爽淫人综合网网站| 久久奇米777| 91小视频免费观看| 日本不卡中文字幕| 国产精品美女久久久久aⅴ国产馆| 91欧美激情一区二区三区成人| 亚洲最大成人综合| 日韩精品资源二区在线| 99视频超级精品| 日韩激情中文字幕| 国产精品久久久久久户外露出| 欧美午夜精品免费| 国产福利一区二区三区视频 | 8x福利精品第一导航| 激情综合色播激情啊| 怡红院av一区二区三区| 亚洲精品一区二区三区影院| 色999日韩国产欧美一区二区| 久久国产综合精品| 亚洲精品久久7777| 亚洲国产成人一区二区三区| 欧美日本视频在线| 91免费精品国自产拍在线不卡| 麻豆免费精品视频| 亚洲精品日日夜夜| 国产欧美一区二区三区鸳鸯浴| 欧美情侣在线播放| 91免费看视频| 成人小视频在线| 国产麻豆视频一区二区| 免费观看成人av| 亚洲第一狼人社区| 亚洲精品视频在线观看免费| 久久精品视频在线看| 91精品国产高清一区二区三区蜜臀| 99热在这里有精品免费| 丰满亚洲少妇av| 激情六月婷婷久久| 精品一区二区免费| 毛片av中文字幕一区二区| 亚洲黄色免费网站| 亚洲精品少妇30p| 亚洲免费av高清| 亚洲精品综合在线| 亚洲欧美国产毛片在线| 国产精品欧美极品| 国产精品成人一区二区艾草 | 一区二区在线观看视频| 中文字幕日本乱码精品影院| 国产农村妇女精品| 国产精品久久久一本精品| 国产日韩一级二级三级| 精品99999| 精品国产乱码久久久久久浪潮| 欧美一级高清片| 久久这里只有精品视频网| 精品免费国产二区三区| 精品免费99久久| 亚洲国产经典视频| 国产精品福利电影一区二区三区四区 | 久久久精品免费观看| 精品成人私密视频| 欧美高清在线一区| 亚洲三级在线看| 五月综合激情日本mⅴ| 天天色综合成人网| 免费看欧美女人艹b| 黄色小说综合网站| av动漫一区二区| 欧洲一区二区三区在线| 欧美一区二区性放荡片| 337p日本欧洲亚洲大胆精品| 国产精品私人影院| 亚洲最大成人综合| 韩国女主播成人在线观看| 大美女一区二区三区| 欧洲av一区二区嗯嗯嗯啊| 国产亚洲综合在线| 一区二区三区国产精品| 偷拍亚洲欧洲综合| 国产suv精品一区二区883| 91色乱码一区二区三区| 91精品国产综合久久福利软件 | 99精品欧美一区二区三区小说| 欧美系列亚洲系列| 91精品国产麻豆| 中文字幕亚洲一区二区av在线| 丝袜美腿亚洲色图| 成人av在线影院| 欧美挠脚心视频网站| 久久精品人人做| 亚洲成人激情综合网| 国产成人免费视频一区| 欧美日韩久久不卡| 中文字幕一区二区在线播放| 丝袜美腿亚洲一区二区图片| 成人激情免费视频| 欧美一卡二卡三卡四卡| 亚洲品质自拍视频| 丰满放荡岳乱妇91ww| 日韩一级片网址| 亚洲精品伦理在线|