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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? fs2fast.c

?? 32位操作系統(tǒng)OS/2的MPEG播放機(jī)
?? C
字號:
/*
 * Copyright (c) 1992 The Regents of the University of California.
 * All rights reserved.
 * 
 * Permission to use, copy, modify, and distribute this software and its
 * documentation for any purpose, without fee, and without written agreement is
 * hereby granted, provided that the above copyright notice and the following
 * two paragraphs appear in all copies of this software.
 * 
 * IN NO EVENT SHALL THE UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY FOR
 * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING OUT
 * OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF THE UNIVERSITY OF
 * CALIFORNIA HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 * 
 * THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY WARRANTIES,
 * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
 * AND FITNESS FOR A PARTICULAR PURPOSE.  THE SOFTWARE PROVIDED HEREUNDER IS
 * ON AN "AS IS" BASIS, AND THE UNIVERSITY OF CALIFORNIA HAS NO OBLIGATION TO
 * PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
 */
#include "video.h"
#include "proto.h"
#include "dither.h"

/* Arrays containing error values for floyd-steinberg dithering. */

static int deltay[256];
static int deltau[256];
static int deltav[256];
static int deltay2[256];
static int deltau2[256];
static int deltav2[256];

/* Definitions governing number of bits used for luminance, cr, and cb. */

#define L_BITS 3
#define CR_BITS 2
#define CB_BITS 2

/* Masks for proper quantization of lum, cr, and cb values. */

#define L_MASK 0xe0
#define CR_MASK 0xc0
#define CB_MASK 0xc0



/*
 *--------------------------------------------------------------
 *
 * InitFS2FastDither --
 *
 *	Initializes structures and arrays neeeded for fast implementation
 *      of two error F-S dithering.
 *
 * Results:
 *	None.
 *
 * Side effects:
 *      None.
 *
 *--------------------------------------------------------------
 */

void InitFS2FastDither()
{
  int i;
  int lum_num, cr_num, cb_num;

  for (i=0; i<256; i++) {
    lum_num = (i >> (8-L_BITS));
    cr_num = (i >> (8-CR_BITS));
    cb_num = (i >> (8-CB_BITS));

    /* These arrays contain the error values propogated for each pixel value 
       for each channel. 
    */

    deltay[i] = (i - ((int) lum_values[lum_num])) / 2;
    deltau[i] = (i-((int) cr_values[cr_num])) / 2;
    deltav[i] = (i-((int) cb_values[cb_num])) / 2;
    deltay2[i] = (i - ((int) lum_values[lum_num])) - deltay[i];
    deltau2[i] = (i - ((int) cr_values[cr_num])) - deltau[i];
    deltav2[i] = (i - ((int) cb_values[cb_num])) - deltav[i];

  }

}

/*
 *--------------------------------------------------------------
 *
 * DitherImage --
 *
 *	Dithers an image using floyd-steinberg.
 *	Assumptions made:
 *	  1) The color space is allocated y:cr:cb = 8:4:4
 *	  2) The spatial resolution of y:cr:cb is 4:1:1
 *
 * Results:
 *	None.
 *
 * Side effects:
 *	None.
 *
 *--------------------------------------------------------------
 */
void
FS2FastDitherImage (lum, cr, cb, out, h, w)
    unsigned char *lum;
    unsigned char *cr;
    unsigned char *cb;
    unsigned char *out;
    int w, h;
{
    int i, j, idx, idx2;
    int y, u, v;
    int dy, du, dv;
    int code;
    static int *yerr1;
    static int *yerr2;
    static int *uerr1;
    static int *uerr2;
    static int *verr1;
    static int *verr2;
    int *ye1, *ue1, *ve1;
    int *ye2, *ue2, *ve2;
    unsigned char *o, *l, *r, *b;
    static int first = 1;

    /* If first time called, allocate error arrays. */

    if (first) {
      first = 0;
      yerr1 = (int *) malloc((w+5)*sizeof(int));
      yerr2 = (int *) malloc((w+5)*sizeof(int));
      uerr1 = (int *) malloc((w+5)*sizeof(int));
      uerr2 = (int *) malloc((w+5)*sizeof(int));
      verr1 = (int *) malloc((w+5)*sizeof(int));
      verr2 = (int *) malloc((w+5)*sizeof(int));
    }

    /*
     * Init error arrays and variables.
     */
    memset ((char *)yerr1, 0, (w+5)*sizeof(int));
    memset ((char *)yerr2, 0, (w+5)*sizeof(int));
    memset ((char *)uerr1, 0, (w+5)*sizeof(int));
    memset ((char *)uerr2, 0, (w+5)*sizeof(int));
    memset ((char *)verr1, 0, (w+5)*sizeof(int));
    memset ((char *)verr2, 0, (w+5)*sizeof(int));
    du = dv = dy = 0;

    for (j=0; j<h; j+=2) {
	ye1 = yerr1;
	ue1 = uerr1;
	ve1 = verr1;
	ye2 = yerr2;
	ue2 = uerr2;
	ve2 = verr2;
	idx = j*w;
	idx2 = idx/4;
	o = out+idx;
	l = lum+idx;
	r = cr+idx2;
	b = cb+idx2;
	/* Do the top row in forward order. */
	for (i=0; i<w; i+=2) {
	    /* Do left side of this pair... */
	    y = *l++ + dy + *ye1++;
	    u = *r + du + *ue1++;
	    v = *b + dv + *ve1++;

	    if (y < 0) y = 0;
	    else if (y > 255) y = 255;
	    if (u < 0) u = 0;
	    else if (u > 255) u = 255;
	    if (v < 0) v = 0;
	    else if (v > 255) v = 255;

	    /*
	     * Construct a code using:
	     *	high order 3 bits of y, 
	     *	high order 2 bits of u, 
	     *	high order 2 bits of v
	     */
	    code = (((y & L_MASK) | ((u & CR_MASK) >> L_BITS) | (v >> (L_BITS+CR_BITS))) 
		    >> (8-(L_BITS+CR_BITS+CB_BITS)));
	    *o++ = PIXEL(code);
	    *ye2++ = deltay[y];
	    *ue2++ = deltau[u];
	    *ve2++ = deltav[v];
	    dy = deltay2[y];
	    du = deltau2[u];
	    dv = deltav2[v];

	    /* Do right side of this pair... */
	    y = *l++ + dy + *ye1++;
	    u = *r++ + du + *ue1++;
	    v = *b++ + dv + *ve1++;

	    if (y < 0) y = 0;
	    else if (y > 255) y = 255;
	    if (u < 0) u = 0;
	    else if (u > 255) u = 255;
	    if (v < 0) v = 0;
	    else if (v > 255) v = 255;

	    code = (((y & L_MASK) | ((u & CR_MASK) >> L_BITS) | (v >> (L_BITS+CR_BITS))) 
		    >> (8-(L_BITS+CR_BITS+CB_BITS)));
	    *o++ = PIXEL(code);
	    *ye2++ = deltay[y];
	    *ue2++ = deltau[u];
	    *ve2++ = deltav[v];
	    dy = deltay2[y];
	    du = deltau2[u];
	    dv = deltav2[v];

	}
	
	ye1 = yerr1+w-1;
	ue1 = uerr1+w-1;
	ve1 = verr1+w-1;
	ye2 = yerr2+w-1;
	ue2 = uerr2+w-1;
	ve2 = verr2+w-1;
	l += w-1;
	o += w-1;
	r--;
	b--;
	dy = du = dv = 0;

	/* Do bottom part of row, in right to left order. */
	for (i=w-1; i>0; i-=2) {
	    /* Do right side of this pair... */
	    y = *l-- + dy + *ye2--;
	    u = *r + du + *ue2--;
	    v = *b + dv + *ve2--;

     	    if (y < 0) y = 0;
	    else if (y > 255) y = 255;
	    if (u < 0) u = 0;
	    else if (u > 255) u = 255;
	    if (v < 0) v = 0;
	    else if (v > 255) v = 255;

	    /*
	     * Construct a code using:
	     *	high order 3 bits of y, 
	     *	high order 2 bits of u, 
	     *	high order 2 bits of v
	     */
	    code = (((y & L_MASK) | ((u & CR_MASK) >> L_BITS) | (v >> (L_BITS+CR_BITS))) 
		    >> (8-(L_BITS+CR_BITS+CB_BITS)));
	    *o-- = PIXEL(code);
	    *ye1-- = deltay[y];
	    *ue1-- = deltau[u];
	    *ve1-- = deltav[v];
	    dy = deltay2[y];
	    du = deltau2[u];
	    dv = deltav2[v];

	    /* Do left side of this pair... */
	    y = *l-- + dy + *ye2--;
	    u = *r-- + du + *ue2--;
	    v = *b-- + dv + *ve2--;

	    if (y < 0) y = 0;
	    else if (y > 255) y = 255;
	    if (u < 0) u = 0;
	    else if (u > 255) u = 255;
	    if (v < 0) v = 0;
	    else if (v > 255) v = 255;

	    code = (((y & L_MASK) | ((u & CR_MASK) >> L_BITS) | (v >> (L_BITS+CR_BITS))) 
		    >> (8-(L_BITS+CR_BITS+CB_BITS)));
	    *o-- = PIXEL(code);
	    *ye1-- = deltay[y];
	    *ue1-- = deltau[u];
	    *ve1-- = deltav[v];
	    dy = deltay2[y];
	    du = deltau2[u];
	    dv = deltav2[v];

	}
    }
}





?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产高清不卡一区| 蜜桃久久精品一区二区| 91精品黄色片免费大全| 国产成人在线网站| 亚洲成人资源在线| 国产精品久久久久永久免费观看 | 国产精品一区在线| 亚洲主播在线播放| 国产精品美女久久久久久久网站| 欧美二区三区的天堂| 97久久精品人人爽人人爽蜜臀| 欧美aⅴ一区二区三区视频| 中文字幕一区不卡| 国产欧美视频一区二区三区| 欧美午夜不卡视频| 在线免费观看日韩欧美| 成人av免费观看| av一二三不卡影片| 福利电影一区二区| 国产一区二区三区免费| 欧美高清精品3d| 久久国产剧场电影| 国产精品久99| 亚洲欧美一区二区久久| 国产精品成人免费| 国产精品久久99| 亚洲主播在线观看| 石原莉奈在线亚洲三区| 亚洲成人免费看| 免费观看一级特黄欧美大片| 亚洲电影第三页| 日日夜夜一区二区| 精品写真视频在线观看| 国产在线不卡一区| 东方欧美亚洲色图在线| 91久久一区二区| 欧美日韩成人综合天天影院| 欧美日韩一区二区三区四区五区| 欧美三级中文字| 欧美成人精品二区三区99精品| 7777精品伊人久久久大香线蕉经典版下载 | 波多野结衣的一区二区三区| 国产精品一卡二卡在线观看| 国内外成人在线视频| av不卡免费电影| 6080午夜不卡| 亚洲日本成人在线观看| 三级久久三级久久久| 国产精品一级片在线观看| 日本精品视频一区二区三区| 在线综合+亚洲+欧美中文字幕| 久久综合色之久久综合| 亚洲男人的天堂在线aⅴ视频| 日本大胆欧美人术艺术动态| 国产东北露脸精品视频| 欧美日韩亚洲综合在线 | 欧美国产精品一区二区三区| 亚洲一区二区三区爽爽爽爽爽| 极品瑜伽女神91| 欧美高清视频在线高清观看mv色露露十八 | 91免费观看视频| 国产精品久久久久久亚洲毛片| 一区av在线播放| av在线播放一区二区三区| 8x8x8国产精品| 一区二区三区鲁丝不卡| 国产精品亚洲а∨天堂免在线| 欧美剧情片在线观看| 亚洲视频免费看| av男人天堂一区| 国产精品久久久久久久久果冻传媒 | 欧美成人aa大片| 老司机精品视频导航| 8v天堂国产在线一区二区| 亚洲第一二三四区| 欧美色综合网站| 秋霞国产午夜精品免费视频| 欧美高清性hdvideosex| 青草av.久久免费一区| 欧美乱妇23p| 久久丁香综合五月国产三级网站| 欧美一区在线视频| 另类欧美日韩国产在线| 亚洲精品一区二区三区香蕉| 国产一区二区三区精品视频| 久久亚洲精品小早川怜子| 成人综合婷婷国产精品久久| 欧美国产综合色视频| 日韩欧美的一区| 国产电影一区二区三区| 一区视频在线播放| 欧美精品v国产精品v日韩精品| 热久久一区二区| 国产精品美女久久久久久| 在线看一区二区| 久久国产精品99精品国产| 中文字幕永久在线不卡| 欧美日韩精品专区| 高清不卡一区二区| 亚洲大片在线观看| 中文字幕乱码久久午夜不卡 | 成人午夜碰碰视频| 日日夜夜精品视频免费| 国产女人水真多18毛片18精品视频| 91色在线porny| 美女mm1313爽爽久久久蜜臀| 中文字幕一区二区三区四区| 欧美一区二区高清| 久久亚洲二区三区| 国产高清亚洲一区| 亚洲一区在线看| 国产精品国产三级国产有无不卡 | 欧美丰满高潮xxxx喷水动漫| 粉嫩av一区二区三区在线播放| 91丨九色丨蝌蚪富婆spa| 三级在线观看一区二区 | 午夜久久久久久| 亚洲精品综合在线| 中文字幕一区视频| 亚洲国产高清不卡| 久久久久99精品国产片| 日韩一级大片在线| 欧美日韩精品一区二区三区蜜桃 | 福利一区福利二区| 激情综合色综合久久| 亚洲午夜激情av| 亚洲网友自拍偷拍| 亚洲综合色婷婷| 亚洲自拍偷拍网站| 天堂va蜜桃一区二区三区漫画版| 夜夜嗨av一区二区三区中文字幕| 中文字幕欧美一| 亚洲午夜免费视频| 亚洲成人免费观看| 一区二区三区四区五区视频在线观看| 中文字幕第一区二区| 日韩美女视频一区二区| 一区二区三区在线视频免费观看| 免费观看久久久4p| 国v精品久久久网| 99久久伊人精品| 欧美日韩一区视频| 欧美精品一区二区三区高清aⅴ| 日韩欧美一卡二卡| 中文字幕av免费专区久久| 亚洲视频你懂的| 免费成人性网站| 99精品视频在线免费观看| 欧美高清一级片在线| 国产日韩亚洲欧美综合| 一区二区理论电影在线观看| 日本欧美一区二区| 91蜜桃在线观看| 久久综合五月天婷婷伊人| 亚洲精品中文字幕乱码三区| 日韩福利视频导航| 成人动漫在线一区| 91精品国产综合久久蜜臀| 久久久久久久久久久久电影| 成人欧美一区二区三区在线播放| 亚洲成人av免费| 91最新地址在线播放| 精品日本一线二线三线不卡| 亚洲男人的天堂av| 国产精品456| 精品国产自在久精品国产| 五月婷婷欧美视频| 色哟哟日韩精品| 自拍偷拍欧美精品| 成人性生交大片| 精品国精品国产| 国内精品嫩模私拍在线| 日韩美女在线视频| 精品一区精品二区高清| 欧美一区二区三区四区视频| 亚洲成av人片观看| 欧美日韩一区二区在线观看| 亚洲va欧美va天堂v国产综合| 一本一道波多野结衣一区二区| 亚洲欧美日韩国产综合| 国产一区二区h| 久久视频一区二区| 成人午夜在线播放| 日韩理论片在线| 欧美亚洲国产bt| 奇米影视一区二区三区小说| 91精品中文字幕一区二区三区| 麻豆成人在线观看| 久久老女人爱爱| 99国产精品国产精品久久| 一区二区三区在线视频免费 | 成人中文字幕电影| 亚洲免费观看高清完整版在线观看 | 一区二区三区中文字幕电影| 欧美性受极品xxxx喷水| 美女视频免费一区| 亚洲嫩草精品久久| 日韩限制级电影在线观看| 成a人片亚洲日本久久| 亚洲国产日日夜夜|