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

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

?? mb_ordered.c

?? MPEG2 PLAYER in linux
?? C
字號(hào):
/* * mb_ordered.c * *      This file contains C code to implement an macroblock ordered dither. * *//*   * Copyright (c) 1995 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. *//* * Portions of this software Copyright (c) 1995 Brown University. * 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 BROWN UNIVERSITY 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 BROWN * UNIVERSITY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *  * BROWN UNIVERSITY 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 BROWN UNIVERSITY HAS NO OBLIGATION TO PROVIDE MAINTENANCE, * SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS. */#include "video.h"#include "proto.h"#include "dither.h"/*   Changes to make the code reentrant:     ditherFlags now not global, passed to MBOrderedDitherImage     -lsh@cs.brown.edu (Loring Holden) */#define DITH_SIZE 16/* Structures used to implement macroblock ordered   dither algorithm.*/static unsigned char ***ditherPtr[DITH_SIZE];/* *-------------------------------------------------------------- * *  InitMBOrderedDither-- * *    Structures intialized for ordered dithering.  * * Results: *    None. * * Side effects: *      None. * *-------------------------------------------------------------- */voidInitMBOrderedDither(){  unsigned char ****pos_2_cb;  unsigned char ***cb_2_cr;  unsigned char **cr_2_l;  int cb_val, cb_rval, cr_val, cr_rval, l_val, l_rval;  int i, j, pos;  int err_range, threshval;  pos_2_cb = (unsigned char ****) malloc (DITH_SIZE*sizeof(unsigned char ***));  cb_2_cr = (unsigned char ***) malloc(CB_RANGE*sizeof(unsigned char **));  cr_2_l = (unsigned char **) malloc(CR_RANGE*sizeof(unsigned char *));  for (pos=0; pos<DITH_SIZE; pos++) {        pos_2_cb[pos] = (unsigned char ***) malloc(256*(sizeof(unsigned char **)));    for (j=0; j<CB_RANGE; j++) {      cb_2_cr[j] = (unsigned char **) malloc(256*(sizeof(unsigned char *)));    }    for (cb_val=0; cb_val<cb_values[0]; cb_val++) {      (pos_2_cb[pos])[cb_val] = cb_2_cr[0];    }    for (cb_rval=0; cb_rval<(CB_RANGE-1); cb_rval++) {      err_range = cb_values[cb_rval+1] - cb_values[cb_rval];      threshval = ((pos*err_range)/DITH_SIZE)+cb_values[cb_rval];      for (cb_val=cb_values[cb_rval]; cb_val<cb_values[cb_rval+1]; cb_val++) {    if (cb_val>threshval) (pos_2_cb[pos])[cb_val] = cb_2_cr[cb_rval+1];    else (pos_2_cb[pos])[cb_val] = cb_2_cr[cb_rval];      }    }    for (cb_val=cb_values[CB_RANGE-1]; cb_val<256; cb_val++) {      (pos_2_cb[pos])[cb_val] = cb_2_cr[CB_RANGE-1];    }    for (cb_rval=0; cb_rval<CB_RANGE; cb_rval++) {            for (j=0; j<CR_RANGE; j++) {    cr_2_l[j] = (unsigned char *) malloc(256*(sizeof(unsigned char)));      }      for (cr_val=0; cr_val < cr_values[0]; cr_val++) {    (cb_2_cr[cb_rval])[cr_val] = cr_2_l[0];      }      for (cr_rval=0; cr_rval<(CR_RANGE-1); cr_rval++) {    err_range = cr_values[cr_rval+1] - cr_values[cr_rval];    threshval = ((pos*err_range)/DITH_SIZE)+cr_values[cr_rval];        for (cr_val=cr_values[cr_rval]; cr_val<cr_values[cr_rval+1]; cr_val++) {      if (cr_val>threshval) (cb_2_cr[cb_rval])[cr_val] = cr_2_l[cr_rval+1];      else (cb_2_cr[cb_rval])[cr_val] = cr_2_l[cr_rval];    }      }            for (cr_val=cr_values[CR_RANGE-1]; cr_val<256; cr_val++) {    (cb_2_cr[cb_rval])[cr_val] = cr_2_l[CR_RANGE-1];      }            for (cr_rval=0; cr_rval<CR_RANGE; cr_rval++) {        for (l_val = 0; l_val < lum_values[0]; l_val++) {      (cr_2_l[cr_rval])[l_val] = pixel[cb_rval+(cr_rval*CB_RANGE)+                        (0*CR_RANGE*CB_RANGE)];    }    for (l_rval=0; l_rval<(LUM_RANGE-1); l_rval++) {      err_range = lum_values[l_rval+1] - lum_values[l_rval];      threshval = ((pos*err_range) /DITH_SIZE) + lum_values[l_rval];      for (l_val = lum_values[l_rval]; l_val < lum_values[l_rval+1]; l_val++) {        if (l_val>threshval) (cr_2_l[cr_rval])[l_val] =           pixel[cb_rval+(cr_rval*CB_RANGE)+((l_rval+1)*CR_RANGE*CB_RANGE)];        else (cr_2_l[cr_rval])[l_val] =          pixel[cb_rval+(cr_rval*CB_RANGE)+(l_rval*CR_RANGE*CB_RANGE)];      }    }    for (l_val = lum_values[LUM_RANGE-1]; l_val < 256; l_val++) {      (cr_2_l[cr_rval])[l_val] =         pixel[cb_rval+(cr_rval*CB_RANGE)+((LUM_RANGE-1)*CR_RANGE*CB_RANGE)];    }      }    }  }  for (i=0; i<DITH_SIZE; i++) {    ditherPtr[i] = pos_2_cb[i];  }}/* *-------------------------------------------------------------- * * MBOrderedDitherImage -- * *    Dithers an image using an ordered dither at macroblock level. *    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 *      The channels are dithered based on the standard *      ordered dither pattern for a 4x4 area.  * * Results: *    None. * * Side effects: *    None. * *-------------------------------------------------------------- */voidMBOrderedDitherImage (lum, cr, cb, out, h, w, ditherFlags)    unsigned char *lum;    unsigned char *cr;    unsigned char *cb;    unsigned char *out;    int h, w;    char *ditherFlags;{  unsigned char *l, *r, *b, *o1, *o2;  unsigned char *l2;  unsigned char L, R, B;  int i, j, mbaddr, mbwidth;  unsigned char ***dp0 = ditherPtr[0];  unsigned char ***dp2 = ditherPtr[2];  unsigned char ***dp4 = ditherPtr[4];  unsigned char ***dp6 = ditherPtr[6];  unsigned char ***dp8 = ditherPtr[8];  unsigned char ***dp10 = ditherPtr[10];  unsigned char ***dp12 = ditherPtr[12];  unsigned char ***dp14 = ditherPtr[14];  unsigned char ***dp1 = ditherPtr[1];  unsigned char ***dp3 = ditherPtr[3];  unsigned char ***dp5 = ditherPtr[5];  unsigned char ***dp7 = ditherPtr[7];  unsigned char ***dp9 = ditherPtr[9];  unsigned char ***dp11 = ditherPtr[11];  unsigned char ***dp13 = ditherPtr[13];  unsigned char ***dp15 = ditherPtr[15];  l = lum;  l2 = lum + w;  r = cr;  b = cb;  o1 = out;  o2 = out+w;  mbwidth = w / 16;  for (i=0; i<h; i+=4) {    mbaddr = (i / 16) * mbwidth ;    for (j=0; j<w; j+=8) {      if (ditherFlags[mbaddr+(j/16)]) {    R = r[0]; B = b[0];        L = l[0];    o1[0] = ((dp0[B])[R])[L];    L = l[1];    o1[1] = ((dp8[B])[R])[L];    L = l2[0];    o2[0] = ((dp12[B])[R])[L];    L = l2[1];    o2[1] = ((dp4[B])[R])[L];        R = r[1]; B = b[1];        L = l[2];    o1[2] = ((dp2[B])[R])[L];    L = l[3];    o1[3] = ((dp10[B])[R])[L];    L = l2[2];    o2[2] = ((dp14[B])[R])[L];    L = l2[3];    o2[3] = ((dp6[B])[R])[L];        R = r[2]; B = b[2];        L = l[4];    o1[4] = ((dp0[B])[R])[L];    L = l[5];    o1[5] = ((dp8[B])[R])[L];    L = l2[4];    o2[4] = ((dp12[B])[R])[L];    L = l2[5];    o2[5] = ((dp4[B])[R])[L];        R = r[3]; B = b[3];        L = l[6];    o1[6] = ((dp2[B])[R])[L];    L = l[7];    o1[7] = ((dp10[B])[R])[L];    L = l2[6];    o2[6] = ((dp14[B])[R])[L];    L = l2[7];    o2[7] = ((dp6[B])[R])[L];      }            l += 8;      l2 += 8;      r += 4;      b += 4;      o1 += 8;      o2 += 8;    }        l += w; l2 += w;    o1 += w; o2 += w;    for (j=0; j<w; j+=8) {      if (ditherFlags[mbaddr+(j/16)]) {    R = r[0]; B = b[0];        L = l[0];    o1[0] = ((dp3[B])[R])[L];    L = l[1];    o1[1] = ((dp11[B])[R])[L];    L = l2[0];    o2[0] = ((dp15[B])[R])[L];    L = l2[1];    o2[1] = ((dp7[B])[R])[L];        R = r[1]; B = b[1];        L = l[2];    o1[2] = ((dp1[B])[R])[L];    L = l[3];    o1[3] = ((dp9[B])[R])[L];    L = l2[2];    o2[2] = ((dp13[B])[R])[L];    L = l2[3];    o2[3] = ((dp5[B])[R])[L];        R = r[2]; B = b[2];        L = l[4];    o1[4] = ((dp3[B])[R])[L];    L = l[5];    o1[5] = ((dp11[B])[R])[L];    L = l2[4];    o2[4] = ((dp15[B])[R])[L];    L = l2[5];    o2[5] = ((dp7[B])[R])[L];        R = r[3]; B = b[3];        L = l[6];    o1[6] = ((dp1[B])[R])[L];    L = l[7];    o1[7] = ((dp9[B])[R])[L];    L = l2[6];    o2[6] = ((dp13[B])[R])[L];    L = l2[7];    o2[7] = ((dp5[B])[R])[L];      }      l += 8;      l2 += 8;      r += 4;      b += 4;      o1 += 8;      o2 += 8;    }        l += w; l2 += w;    o1 += w; o2 += w;  }}/* *-------------------------------------------------------------- * * MBOrderedDitherDisplayCopy -- * *    Copies an image to the display (?) * * Results: *    None. * * Side effects: *    None. * *-------------------------------------------------------------- */voidMBOrderedDitherDisplayCopy(vid_stream, mb_addr, motion_forw, r_right_forw,        r_down_forw, motion_back, r_right_back, r_down_back, past, future)    VidStream *vid_stream;    int mb_addr;    int motion_forw, r_right_forw, r_down_forw;    int motion_back, r_right_back, r_down_back;    unsigned char *past, *future;{  int right_back = 0, right_forw = 0, down_back, down_forw;  unsigned char *dest;  unsigned char *src1 = 0, *src2 = 0;  int row, col, row_size, rr;  int mc, mr;  row = (mb_addr / vid_stream->mb_width) << 4;  col = (mb_addr % vid_stream->mb_width) << 4;  row_size = vid_stream->mb_width << 4;  dest = vid_stream->current->display + (row * row_size) + col;  if (motion_forw) {    right_forw = r_right_forw >> 1;    down_forw = r_down_forw >> 1;    src1 = past + ((row + down_forw) * row_size) + (col + right_forw);  }  if (motion_back) {    right_back = r_right_back >> 1;    down_back = r_down_back >> 1;    src2 = future + ((row + down_back) * row_size) + (col + right_back);  }     if (motion_forw) {    if (motion_back) {      for (rr = 0; rr<16; rr++) {        dest[0] = src1[0];      dest[1] = src2[1];        dest[2] = src1[2];      dest[3] = src2[3];        dest[4] = src1[4];      dest[5] = src2[5];        dest[6] = src1[6];      dest[7] = src2[7];        dest[8] = src1[8];      dest[9] = src2[9];        dest[10] = src1[10];    dest[11] = src2[11];        dest[12] = src1[12];    dest[13] = src2[13];        dest[14] = src1[14];    dest[15] = src2[15];        dest += row_size;        src1 += row_size;        src2 += row_size;      }    }    else {      mc = col & 0x3;      mr = right_forw & 0x3;      if (!mc && !mr) {    /* Use 32 bit copy */    int *d, *s;    d = (int *) dest;    s = (int *) src1;    row_size /= 4;        for (rr = 0; rr < 16; rr++) {      d[0] = s[0];      d[1] = s[1];      d[2] = s[2];      d[3] = s[3];       d += row_size;      s += row_size;    }      } else if ((!mc || (mc == 2)) &&         (!mr || (mr == 2))) {    /* Use 16 bit copy */    short int *d, * s;        d = (short int *) dest;    s = (short int *) src1;    row_size /= 2;        for (rr = 0; rr < 16; rr++) {      d[0] = s[0];      d[1] = s[1];      d[2] = s[2];      d[3] = s[3];       d[4] = s[4];      d[5] = s[5];      d[6] = s[6];      d[7] = s[7];       d += row_size;      s += row_size;    }      }      else {    for (rr = 0; rr < 16; rr++) {      dest[0] = src1[0];      dest[1] = src1[1];      dest[2] = src1[2];      dest[3] = src1[3];      dest[4] = src1[4];      dest[5] = src1[5];      dest[6] = src1[6];      dest[7] = src1[7];      dest[8] = src1[8];      dest[9] = src1[9];      dest[10] = src1[10];      dest[11] = src1[11];      dest[12] = src1[12];      dest[13] = src1[13];      dest[14] = src1[14];      dest[15] = src1[15];            dest += row_size;      src1 += row_size;    }      }    }  } else if (motion_back) {    mc = col & 0x3;    mr = right_back & 0x3;    if (!mc && !mr) {      /* Use 32 bit copy */      int *d, *s;            d = (int *) dest;      s = (int *) src2;      row_size /= 4;            for (rr = 0; rr < 16; rr++) {        d[0] = s[0];        d[1] = s[1];        d[2] = s[2];        d[3] = s[3];         d += row_size;        s += row_size;      }    }    else if ((!mc || mc == 2) &&         (!mr || mr == 2)) {      /* Use 8 bit copy */      short int *d, *s;            d = (short int *) dest;      s = (short int *) src2;      row_size /= 2;            for (rr = 0; rr < 16; rr++) {        d[0] = s[0];        d[1] = s[1];        d[2] = s[2];        d[3] = s[3];         d[4] = s[4];        d[5] = s[5];        d[6] = s[6];        d[7] = s[7];         d += row_size;        s += row_size;      }    }    else {      for (rr = 0; rr < 16; rr++) {        /* Use 8 bit copy */        dest[0] = src2[0];        dest[1] = src2[1];        dest[2] = src2[2];        dest[3] = src2[3];        dest[4] = src2[4];        dest[5] = src2[5];        dest[6] = src2[6];        dest[7] = src2[7];        dest[8] = src2[8];        dest[9] = src2[9];        dest[10] = src2[10];        dest[11] = src2[11];        dest[12] = src2[12];        dest[13] = src2[13];        dest[14] = src2[14];        dest[15] = src2[15];        dest += row_size;        src2 += row_size;      }    }  }}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91麻豆精品国产综合久久久久久| 欧美精选在线播放| 亚洲香蕉伊在人在线观| 日韩精品一区二区三区蜜臀| av午夜一区麻豆| 日本成人中文字幕| 亚洲视频在线一区观看| 日韩精品一区在线观看| 在线视频国产一区| 成人性生交大片免费看中文网站| 视频在线观看国产精品| 中文字幕一区av| 久久影院视频免费| 制服丝袜国产精品| 91免费版在线看| 国产成人av影院| 久久国产精品一区二区| 一区二区久久久| 国产精品国产精品国产专区不蜜| 精品国产电影一区二区| 欧美日韩国产高清一区二区| 色婷婷久久久亚洲一区二区三区 | 欧美精彩视频一区二区三区| 在线成人av网站| 日本韩国欧美一区| fc2成人免费人成在线观看播放| 久久国产综合精品| 日韩av网站免费在线| 一区二区三区 在线观看视频| 国产精品二区一区二区aⅴ污介绍| 欧美精品一区二区在线播放| 欧美一区二区三区性视频| 欧美日韩一区二区三区不卡| 欧美综合一区二区三区| 色欧美片视频在线观看| 99久精品国产| 成人av电影在线| 成人性生交大片免费看中文| 成人午夜在线视频| 成人午夜免费av| 成人精品免费看| 成人自拍视频在线| 成人午夜又粗又硬又大| 成人伦理片在线| 99久久伊人精品| av影院午夜一区| 色乱码一区二区三区88| 欧洲一区二区三区在线| 欧美午夜精品电影| 欧美日韩国产不卡| 欧美一级理论片| 精品久久国产老人久久综合| www久久精品| 久久久久久久电影| 国产精品成人免费精品自在线观看| 中文字幕久久午夜不卡| 国产精品电影院| 亚洲精品福利视频网站| 亚洲高清免费视频| 日本欧美一区二区在线观看| 精品亚洲成a人| 成人午夜激情片| 欧美性大战久久久| 欧美一级黄色录像| 国产欧美精品日韩区二区麻豆天美| 国产精品少妇自拍| 一区二区三区美女视频| 天天综合网 天天综合色| 蜜桃视频在线观看一区| 国产美女久久久久| 99久久99久久综合| 欧美日韩大陆一区二区| 日韩欧美黄色影院| 中文av字幕一区| 亚洲自拍偷拍网站| 男人操女人的视频在线观看欧美| 国产在线视频不卡二| av在线不卡电影| 欧美一级片免费看| 中文字幕+乱码+中文字幕一区| 一区二区在线观看免费 | 亚洲精品欧美激情| 丝袜诱惑亚洲看片| 国产成人精品免费一区二区| 欧美性色黄大片手机版| 久久久精品人体av艺术| 亚洲一级二级三级在线免费观看| 狠狠色狠狠色综合日日91app| 不卡一区二区中文字幕| 日韩一区和二区| 1000精品久久久久久久久| 日韩福利电影在线观看| 99久久er热在这里只有精品15| 日韩一级黄色片| 亚洲精品中文字幕在线观看| 狠狠色丁香久久婷婷综| 在线一区二区视频| 久久久www成人免费毛片麻豆| 亚洲第一二三四区| 成人毛片在线观看| 日韩欧美高清在线| 亚洲国产精品一区二区www| 国产成人免费在线| 欧美一区永久视频免费观看| 亚洲欧美福利一区二区| 国产一区不卡在线| 欧美丰满少妇xxxxx高潮对白| 国产精品久久久久久久久果冻传媒 | 欧美亚洲高清一区二区三区不卡| 欧美影视一区在线| 中文字幕乱码日本亚洲一区二区 | 综合电影一区二区三区| 精品午夜一区二区三区在线观看| 91福利在线导航| 中文字幕视频一区二区三区久| 久久se这里有精品| 欧美福利一区二区| 亚洲一区二区三区四区在线观看| 岛国av在线一区| 26uuuu精品一区二区| 麻豆精品在线看| 91麻豆精品91久久久久久清纯| 亚洲精品免费电影| 99r国产精品| 中文字幕久久午夜不卡| 国产suv精品一区二区三区| 精品毛片乱码1区2区3区| 亚洲妇女屁股眼交7| 91成人网在线| 一区二区视频在线| 色综合天天综合网天天看片 | 久久精品国产一区二区三区免费看 | 亚洲欧美区自拍先锋| 久久国产综合精品| 日韩片之四级片| 日本免费在线视频不卡一不卡二 | 91精品婷婷国产综合久久 | 亚洲婷婷综合色高清在线| 国产成人在线视频网址| 亚洲精品在线网站| 韩国毛片一区二区三区| 精品剧情v国产在线观看在线| 久久精品999| 久久精品一区二区三区不卡 | youjizz国产精品| 国产精品国产三级国产有无不卡| 成人国产一区二区三区精品| 国产精品美女一区二区三区| 99久久99久久精品国产片果冻| 亚洲另类在线一区| 欧美亚一区二区| 日韩在线一区二区三区| 欧美成人官网二区| 国产精品77777| 国产精品国产三级国产普通话蜜臀 | 秋霞午夜av一区二区三区| 91精品麻豆日日躁夜夜躁| 麻豆成人久久精品二区三区小说| 欧美一区二区免费| 久久66热re国产| 国产精品污网站| 欧洲视频一区二区| 午夜精品久久久| 精品精品国产高清a毛片牛牛| 国产精品资源在线看| 亚洲欧洲三级电影| 欧美色大人视频| 麻豆91精品91久久久的内涵| 国产婷婷色一区二区三区| 色一区在线观看| 日本不卡不码高清免费观看| 久久久www免费人成精品| 91日韩精品一区| 日本成人中文字幕在线视频| 中文字幕免费不卡| 欧美美女视频在线观看| 国产一区免费电影| 亚洲精品一二三四区| 日韩欧美高清一区| av在线综合网| 久久精品国产在热久久| 亚洲精品综合在线| 亚洲精品在线电影| 91精彩视频在线| 国产jizzjizz一区二区| 午夜在线成人av| 国产精品久久免费看| 欧美一级日韩不卡播放免费| 91亚洲永久精品| 美女网站色91| 亚洲美女精品一区| wwww国产精品欧美| 在线中文字幕一区| 国产乱码精品一品二品| 亚洲电影在线播放| 国产精品视频第一区| 欧美va亚洲va国产综合| 色偷偷88欧美精品久久久| 精品一区二区日韩| 亚洲图片自拍偷拍|