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

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

?? putpic.c

?? MPEG2解編碼程序源代碼
?? C
字號:
/* putpic.c, block and motion vector encoding routines                      */

/* Copyright (C) 1996, MPEG Software Simulation Group. All Rights Reserved. */

/*
 * Disclaimer of Warranty
 *
 * These software programs are available to the user without any license fee or
 * royalty on an "as is" basis.  The MPEG Software Simulation Group disclaims
 * any and all warranties, whether express, implied, or statuary, including any
 * implied warranties or merchantability or of fitness for a particular
 * purpose.  In no event shall the copyright-holder be liable for any
 * incidental, punitive, or consequential damages of any kind whatsoever
 * arising from the use of these programs.
 *
 * This disclaimer of warranty extends to the user of these programs and user's
 * customers, employees, agents, transferees, successors, and assigns.
 *
 * The MPEG Software Simulation Group does not represent or warrant that the
 * programs furnished hereunder are free of infringement of any third-party
 * patents.
 *
 * Commercial implementations of MPEG-1 and MPEG-2 video, including shareware,
 * are subject to royalty fees to patent holders.  Many of these patents are
 * general enough such that they are unavoidable regardless of implementation
 * design.
 *
 */

#include <stdio.h>
#include "config.h"
#include "global.h"

/* private prototypes */
static void putmvs _ANSI_ARGS_((int MV[2][2][2], int PMV[2][2][2],
  int mv_field_sel[2][2], int dmvector[2], int s, int motion_type,
  int hor_f_code, int vert_f_code));

/* quantization / variable length encoding of a complete picture */
void putpict(frame)
unsigned char *frame;
{
  int i, j, k, comp, cc;
  int mb_type;
  int PMV[2][2][2];
  int prev_mquant;
  int cbp, MBAinc;

  rc_init_pict(frame); /* set up rate control */

  /* picture header and picture coding extension */
  putpicthdr();

  if (!mpeg1)
    putpictcodext();

  prev_mquant = rc_start_mb(); /* initialize quantization parameter */

  k = 0;

  for (j=0; j<mb_height2; j++)
  {
    /* macroblock row loop */

    for (i=0; i<mb_width; i++)
    {
      /* macroblock loop */
      if (i==0)
      {
        /* slice header (6.2.4) */
        alignbits();

        if (mpeg1 || vertical_size<=2800)
          putbits(SLICE_MIN_START+j,32); /* slice_start_code */
        else
        {
          putbits(SLICE_MIN_START+(j&127),32); /* slice_start_code */
          putbits(j>>7,3); /* slice_vertical_position_extension */
        }
  
        /* quantiser_scale_code */
        putbits(q_scale_type ? map_non_linear_mquant[prev_mquant]
                             : prev_mquant >> 1, 5);
  
        putbits(0,1); /* extra_bit_slice */
  
        /* reset predictors */

        for (cc=0; cc<3; cc++)
          dc_dct_pred[cc] = 0;

        PMV[0][0][0]=PMV[0][0][1]=PMV[1][0][0]=PMV[1][0][1]=0;
        PMV[0][1][0]=PMV[0][1][1]=PMV[1][1][0]=PMV[1][1][1]=0;
  
        MBAinc = i + 1; /* first MBAinc denotes absolute position */
      }

      mb_type = mbinfo[k].mb_type;

      /* determine mquant (rate control) */
      mbinfo[k].mquant = rc_calc_mquant(k);

      /* quantize macroblock */
      if (mb_type & MB_INTRA)
      {
        for (comp=0; comp<block_count; comp++)
          quant_intra(blocks[k*block_count+comp],blocks[k*block_count+comp],
                      dc_prec,intra_q,mbinfo[k].mquant);
        mbinfo[k].cbp = cbp = (1<<block_count) - 1;
      }
      else
      {
        cbp = 0;
        for (comp=0;comp<block_count;comp++)
          cbp = (cbp<<1) | quant_non_intra(blocks[k*block_count+comp],
                                           blocks[k*block_count+comp],
                                           inter_q,mbinfo[k].mquant);

        mbinfo[k].cbp = cbp;

        if (cbp)
          mb_type|= MB_PATTERN;
      }

      /* output mquant if it has changed */
      if (cbp && prev_mquant!=mbinfo[k].mquant)
        mb_type|= MB_QUANT;

      /* check if macroblock can be skipped */
      if (i!=0 && i!=mb_width-1 && !cbp)
      {
        /* no DCT coefficients and neither first nor last macroblock of slice */

        if (pict_type==P_TYPE && !(mb_type&MB_FORWARD))
        {
          /* P picture, no motion vectors -> skip */

          /* reset predictors */

          for (cc=0; cc<3; cc++)
            dc_dct_pred[cc] = 0;

          PMV[0][0][0]=PMV[0][0][1]=PMV[1][0][0]=PMV[1][0][1]=0;
          PMV[0][1][0]=PMV[0][1][1]=PMV[1][1][0]=PMV[1][1][1]=0;

          mbinfo[k].mb_type = mb_type;
          mbinfo[k].skipped = 1;
          MBAinc++;
          k++;
          continue;
        }

        if (pict_type==B_TYPE && pict_struct==FRAME_PICTURE
            && mbinfo[k].motion_type==MC_FRAME
            && ((mbinfo[k-1].mb_type^mb_type)&(MB_FORWARD|MB_BACKWARD))==0
            && (!(mb_type&MB_FORWARD) ||
                (PMV[0][0][0]==mbinfo[k].MV[0][0][0] &&
                 PMV[0][0][1]==mbinfo[k].MV[0][0][1]))
            && (!(mb_type&MB_BACKWARD) ||
                (PMV[0][1][0]==mbinfo[k].MV[0][1][0] &&
                 PMV[0][1][1]==mbinfo[k].MV[0][1][1])))
        {
          /* conditions for skipping in B frame pictures:
           * - must be frame predicted
           * - must be the same prediction type (forward/backward/interp.)
           *   as previous macroblock
           * - relevant vectors (forward/backward/both) have to be the same
           *   as in previous macroblock
           */

          mbinfo[k].mb_type = mb_type;
          mbinfo[k].skipped = 1;
          MBAinc++;
          k++;
          continue;
        }

        if (pict_type==B_TYPE && pict_struct!=FRAME_PICTURE
            && mbinfo[k].motion_type==MC_FIELD
            && ((mbinfo[k-1].mb_type^mb_type)&(MB_FORWARD|MB_BACKWARD))==0
            && (!(mb_type&MB_FORWARD) ||
                (PMV[0][0][0]==mbinfo[k].MV[0][0][0] &&
                 PMV[0][0][1]==mbinfo[k].MV[0][0][1] &&
                 mbinfo[k].mv_field_sel[0][0]==(pict_struct==BOTTOM_FIELD)))
            && (!(mb_type&MB_BACKWARD) ||
                (PMV[0][1][0]==mbinfo[k].MV[0][1][0] &&
                 PMV[0][1][1]==mbinfo[k].MV[0][1][1] &&
                 mbinfo[k].mv_field_sel[0][1]==(pict_struct==BOTTOM_FIELD))))
        {
          /* conditions for skipping in B field pictures:
           * - must be field predicted
           * - must be the same prediction type (forward/backward/interp.)
           *   as previous macroblock
           * - relevant vectors (forward/backward/both) have to be the same
           *   as in previous macroblock
           * - relevant motion_vertical_field_selects have to be of same
           *   parity as current field
           */

          mbinfo[k].mb_type = mb_type;
          mbinfo[k].skipped = 1;
          MBAinc++;
          k++;
          continue;
        }
      }

      /* macroblock cannot be skipped */
      mbinfo[k].skipped = 0;

      /* there's no VLC for 'No MC, Not Coded':
       * we have to transmit (0,0) motion vectors
       */
      if (pict_type==P_TYPE && !cbp && !(mb_type&MB_FORWARD))
        mb_type|= MB_FORWARD;

      putaddrinc(MBAinc); /* macroblock_address_increment */
      MBAinc = 1;

      putmbtype(pict_type,mb_type); /* macroblock type */

      if (mb_type & (MB_FORWARD|MB_BACKWARD) && !frame_pred_dct)
        putbits(mbinfo[k].motion_type,2);

      if (pict_struct==FRAME_PICTURE && cbp && !frame_pred_dct)
        putbits(mbinfo[k].dct_type,1);

      if (mb_type & MB_QUANT)
      {
        putbits(q_scale_type ? map_non_linear_mquant[mbinfo[k].mquant]
                             : mbinfo[k].mquant>>1,5);
        prev_mquant = mbinfo[k].mquant;
      }

      if (mb_type & MB_FORWARD)
      {
        /* forward motion vectors, update predictors */
        putmvs(mbinfo[k].MV,PMV,mbinfo[k].mv_field_sel,mbinfo[k].dmvector,0,
          mbinfo[k].motion_type,forw_hor_f_code,forw_vert_f_code);
      }

      if (mb_type & MB_BACKWARD)
      {
        /* backward motion vectors, update predictors */
        putmvs(mbinfo[k].MV,PMV,mbinfo[k].mv_field_sel,mbinfo[k].dmvector,1,
          mbinfo[k].motion_type,back_hor_f_code,back_vert_f_code);
      }

      if (mb_type & MB_PATTERN)
      {
        putcbp((cbp >> (block_count-6)) & 63);
        if (chroma_format!=CHROMA420)
          putbits(cbp,block_count-6);
      }

      for (comp=0; comp<block_count; comp++)
      {
        /* block loop */
        if (cbp & (1<<(block_count-1-comp)))
        {
          if (mb_type & MB_INTRA)
          {
            cc = (comp<4) ? 0 : (comp&1)+1;
            putintrablk(blocks[k*block_count+comp],cc);
          }
          else
            putnonintrablk(blocks[k*block_count+comp]);
        }
      }

      /* reset predictors */
      if (!(mb_type & MB_INTRA))
        for (cc=0; cc<3; cc++)
          dc_dct_pred[cc] = 0;

      if (mb_type & MB_INTRA || (pict_type==P_TYPE && !(mb_type & MB_FORWARD)))
      {
        PMV[0][0][0]=PMV[0][0][1]=PMV[1][0][0]=PMV[1][0][1]=0;
        PMV[0][1][0]=PMV[0][1][1]=PMV[1][1][0]=PMV[1][1][1]=0;
      }

      mbinfo[k].mb_type = mb_type;
      k++;
    }
  }

  rc_update_pict();
  vbv_end_of_picture();
}


/* output motion vectors (6.2.5.2, 6.3.16.2)
 *
 * this routine also updates the predictions for motion vectors (PMV)
 */
 
static void putmvs(MV,PMV,mv_field_sel,dmvector,s,motion_type,
  hor_f_code,vert_f_code)
int MV[2][2][2],PMV[2][2][2];
int mv_field_sel[2][2];
int dmvector[2];
int s,motion_type,hor_f_code,vert_f_code;
{
  if (pict_struct==FRAME_PICTURE)
  {
    if (motion_type==MC_FRAME)
    {
      /* frame prediction */
      putmv(MV[0][s][0]-PMV[0][s][0],hor_f_code);
      putmv(MV[0][s][1]-PMV[0][s][1],vert_f_code);
      PMV[0][s][0]=PMV[1][s][0]=MV[0][s][0];
      PMV[0][s][1]=PMV[1][s][1]=MV[0][s][1];
    }
    else if (motion_type==MC_FIELD)
    {
      /* field prediction */
      putbits(mv_field_sel[0][s],1);
      putmv(MV[0][s][0]-PMV[0][s][0],hor_f_code);
      putmv((MV[0][s][1]>>1)-(PMV[0][s][1]>>1),vert_f_code);
      putbits(mv_field_sel[1][s],1);
      putmv(MV[1][s][0]-PMV[1][s][0],hor_f_code);
      putmv((MV[1][s][1]>>1)-(PMV[1][s][1]>>1),vert_f_code);
      PMV[0][s][0]=MV[0][s][0];
      PMV[0][s][1]=MV[0][s][1];
      PMV[1][s][0]=MV[1][s][0];
      PMV[1][s][1]=MV[1][s][1];
    }
    else
    {
      /* dual prime prediction */
      putmv(MV[0][s][0]-PMV[0][s][0],hor_f_code);
      putdmv(dmvector[0]);
      putmv((MV[0][s][1]>>1)-(PMV[0][s][1]>>1),vert_f_code);
      putdmv(dmvector[1]);
      PMV[0][s][0]=PMV[1][s][0]=MV[0][s][0];
      PMV[0][s][1]=PMV[1][s][1]=MV[0][s][1];
    }
  }
  else
  {
    /* field picture */
    if (motion_type==MC_FIELD)
    {
      /* field prediction */
      putbits(mv_field_sel[0][s],1);
      putmv(MV[0][s][0]-PMV[0][s][0],hor_f_code);
      putmv(MV[0][s][1]-PMV[0][s][1],vert_f_code);
      PMV[0][s][0]=PMV[1][s][0]=MV[0][s][0];
      PMV[0][s][1]=PMV[1][s][1]=MV[0][s][1];
    }
    else if (motion_type==MC_16X8)
    {
      /* 16x8 prediction */
      putbits(mv_field_sel[0][s],1);
      putmv(MV[0][s][0]-PMV[0][s][0],hor_f_code);
      putmv(MV[0][s][1]-PMV[0][s][1],vert_f_code);
      putbits(mv_field_sel[1][s],1);
      putmv(MV[1][s][0]-PMV[1][s][0],hor_f_code);
      putmv(MV[1][s][1]-PMV[1][s][1],vert_f_code);
      PMV[0][s][0]=MV[0][s][0];
      PMV[0][s][1]=MV[0][s][1];
      PMV[1][s][0]=MV[1][s][0];
      PMV[1][s][1]=MV[1][s][1];
    }
    else
    {
      /* dual prime prediction */
      putmv(MV[0][s][0]-PMV[0][s][0],hor_f_code);
      putdmv(dmvector[0]);
      putmv(MV[0][s][1]-PMV[0][s][1],vert_f_code);
      putdmv(dmvector[1]);
      PMV[0][s][0]=PMV[1][s][0]=MV[0][s][0];
      PMV[0][s][1]=PMV[1][s][1]=MV[0][s][1];
    }
  }
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本久久电影网| 国产精品日日摸夜夜摸av| 欧美一级免费大片| 国产欧美综合在线观看第十页| 一级做a爱片久久| 国产精品亚洲一区二区三区妖精| 一本高清dvd不卡在线观看| 欧美一区二区三区喷汁尤物| 亚洲人成在线播放网站岛国| 国产一区不卡视频| 欧美日韩精品一区二区三区 | 欧美精品一区二区不卡 | 精品久久久久香蕉网| 一区二区高清在线| jlzzjlzz欧美大全| 国产午夜精品在线观看| 一区二区三区在线免费| 懂色av中文字幕一区二区三区| 欧美一级二级在线观看| 一区二区欧美精品| 日本久久一区二区三区| 国产精品久久久久久久第一福利| 福利一区在线观看| 久久精品一区二区三区不卡| 麻豆精品在线观看| 日韩一区二区在线看| 日韩精品视频网站| 4438x亚洲最大成人网| 一区二区三区在线高清| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 国产美女久久久久| 日韩欧美成人激情| 精品一区二区久久久| 日韩一级二级三级| 蜜桃精品视频在线观看| 日韩亚洲欧美综合| 美女高潮久久久| 欧美电影免费观看完整版| 免费观看成人鲁鲁鲁鲁鲁视频| 91精品国产综合久久福利软件| 亚洲成av人影院| 欧美日韩亚洲国产综合| 午夜伊人狠狠久久| 欧美一区二区观看视频| 麻豆一区二区在线| 久久九九全国免费| 99麻豆久久久国产精品免费| 国产精品福利影院| 欧美三区在线视频| 男人的j进女人的j一区| 国产精品久久久久三级| 99久久久久免费精品国产| 亚洲日本免费电影| 欧美日韩一级二级| 精品午夜一区二区三区在线观看 | 国产日韩影视精品| 色综合夜色一区| 丝袜美腿亚洲一区二区图片| 777亚洲妇女| 国产一区二区看久久| 亚洲欧洲精品天堂一级| 欧美特级限制片免费在线观看| 美女视频网站久久| 精品美女一区二区三区| 成人午夜av影视| 亚洲成人福利片| 久久久久高清精品| 欧美亚洲国产一区二区三区| 日韩成人免费电影| 国产精品激情偷乱一区二区∴| 欧美三级视频在线| 成人午夜精品在线| 日韩av在线发布| ...中文天堂在线一区| 欧美群妇大交群中文字幕| 国产酒店精品激情| 亚洲高清在线精品| 国产精品三级视频| 欧美一区二区视频在线观看2020| 国产99久久久国产精品免费看| 一区二区高清视频在线观看| 精品国产乱码91久久久久久网站| 色视频成人在线观看免| 国内精品伊人久久久久av一坑| 一区二区三区高清| 国产日韩欧美电影| 色妞www精品视频| 亚洲福利视频三区| 欧美高清一级片在线| 国产精品亚洲一区二区三区在线| 亚洲国产视频一区二区| 国产精品视频观看| 2017欧美狠狠色| 69精品人人人人| 在线免费观看不卡av| 亚洲精品在线观看网站| 亚洲国产综合人成综合网站| 91精品国产品国语在线不卡| 另类欧美日韩国产在线| 国产色产综合产在线视频| 成人在线视频一区| 亚洲国产综合在线| 精品国产一区二区三区久久久蜜月 | 亚洲精品一区二区三区福利| 国产精品99久久久久| 国产精品免费丝袜| 欧美嫩在线观看| 国产精品综合视频| 亚洲成人7777| 中文字幕第一区二区| 欧美色涩在线第一页| 黑人巨大精品欧美一区| 国产精品入口麻豆九色| 欧美日免费三级在线| 国产精品一区二区无线| 亚洲午夜激情av| 久久精品视频免费| 欧美日韩情趣电影| 成人99免费视频| 久久电影国产免费久久电影| 国产精品久久久久aaaa樱花| 日韩欧美在线123| 日韩精品最新网址| aa级大片欧美| 激情综合五月婷婷| 亚洲高清一区二区三区| 国产女主播视频一区二区| 欧美视频一区二区在线观看| 岛国av在线一区| 蜜臀久久99精品久久久画质超高清 | 亚洲永久精品大片| 久久女同精品一区二区| 欧美性受极品xxxx喷水| 国产成人精品www牛牛影视| 欧美一级免费大片| 欧美日韩国产高清一区二区三区 | 久久综合色播五月| 欧美军同video69gay| 成人激情免费网站| 国产精品一区2区| 韩国av一区二区| 久久精品国产成人一区二区三区 | 日韩福利电影在线观看| 亚洲免费观看高清| 中文字幕一区二区三区在线不卡| 精品久久一二三区| 精品国产污网站| 国产精品视频一二三| 久久久亚洲午夜电影| 欧美videos大乳护士334| 欧美日韩电影一区| 3atv一区二区三区| 欧美一级欧美一级在线播放| 欧美色涩在线第一页| 欧美调教femdomvk| 欧美日韩dvd在线观看| 欧美三级资源在线| 欧美久久一二区| 日韩欧美在线影院| 精品国内二区三区| 久久久不卡网国产精品一区| 精品国产免费视频| 国产午夜精品一区二区| 中文字幕欧美国产| 日韩理论在线观看| 亚洲国产视频网站| 美女网站色91| 国产91富婆露脸刺激对白| 国产iv一区二区三区| va亚洲va日韩不卡在线观看| 99re这里都是精品| 欧美色视频在线| 精品久久久久久最新网址| 久久色在线视频| 亚洲人快播电影网| 免费看欧美美女黄的网站| 青椒成人免费视频| 国产成人午夜视频| 欧美视频中文字幕| 91精品国产乱| 中文在线免费一区三区高中清不卡| 亚洲欧洲av另类| 日韩电影免费一区| 国产一区二区三区精品欧美日韩一区二区三区 | 亚洲尤物视频在线| 久久精品国产999大香线蕉| 国产九色sp调教91| va亚洲va日韩不卡在线观看| 欧美丝袜自拍制服另类| 2023国产一二三区日本精品2022| 国产精品久线观看视频| 日韩精品一区二区三区在线观看| 国产欧美一区视频| 五月激情综合婷婷| 99麻豆久久久国产精品免费| 制服.丝袜.亚洲.另类.中文 | 日本高清视频一区二区| 欧美刺激脚交jootjob| 亚洲私人影院在线观看| 蜜臀av亚洲一区中文字幕|