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

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

?? image.c

?? 此code含H.264解碼需要的 lib和 src
?? C
?? 第 1 頁 / 共 5 頁
字號(hào):

/*!
 ***********************************************************************
 * \file image.c
 *
 * \brief
 *    Decode a Slice
 *
 * \author
 *    Main contributors (see contributors.h for copyright, address and affiliation details)
 *    - Inge Lille-Langoy               <inge.lille-langoy@telenor.com>
 *    - Rickard Sjoberg                 <rickard.sjoberg@era.ericsson.se>
 *    - Jani Lainema                    <jani.lainema@nokia.com>
 *    - Sebastian Purreiter             <sebastian.purreiter@mch.siemens.de>
 *    - Byeong-Moon Jeon                <jeonbm@lge.com>
 *    - Thomas Wedi                     <wedi@tnt.uni-hannover.de>
 *    - Gabi Blaettermann
 *    - Ye-Kui Wang                     <wyk@ieee.org>
 *    - Antti Hallapuro                 <antti.hallapuro@nokia.com>
 *    - Alexis Tourapis                 <alexismt@ieee.org>
 *    - Jill Boyce                      <jill.boyce@thomson.net>
 *    - Saurav K Bandyopadhyay          <saurav@ieee.org>
 *    - Zhenyu Wu                       <Zhenyu.Wu@thomson.net
 *    - Purvin Pandit                   <Purvin.Pandit@thomson.net>
 *
 ***********************************************************************
 */

//#include "contributors.h"

#include <math.h>
#include <limits.h>
#include <stdlib.h>
#include <string.h>
#include <assert.h>

#if defined(WIN32) || defined(UNDER_CE)

#else
#include <unistd.h>
#endif

#include "global.h"
//#include "errorconcealment.h"
#include "image.h"
#include "mbuffer.h"
//#include "fmo.h"
#include "nalu.h"
#include "parsetcommon.h"
#include "parset.h"
#include "header.h"
//#include "rtp.h"
#include "sei.h"
//#include "output.h"
//#include "biaridecod.h"
//#include "mb_access.h"
#include "memalloc.h"
#include "annexb.h"

//#include "context_ini.h"
//#include "cabac.h"
//#include "loopfilter.h"

#include "vlc.h"

//#include "erc_api.h"
//extern objectBuffer_t *erc_object_list;
//extern ercVariables_t *erc_errorVar;
//extern frame erc_recfr;
//extern int erc_mvperMB;
//extern struct img_par *erc_img;

//extern FILE *p_out2;

extern StorablePicture **listX[6];
//extern ColocatedParams *Co_located;

extern StorablePicture *no_reference_picture;
int non_conforming_stream;

StorablePicture *dec_picture;

OldSliceParams old_slice;

#if !defined(max)
#define max( a , b ) ( (a) > (b) ? (a) : (b) )
#endif

void write_reg(int address, int data)
{
	h264_reg[h264_reg_size].address = address;
    h264_reg[h264_reg_size].data = data;
	h264_reg_size++;
	
	return;
}

//void MbAffPostProc()
//{
//  imgpel temp[16][32];
//
//  imgpel ** imgY  = dec_picture->imgY;
//  imgpel ***imgUV = dec_picture->imgUV;
//
//  int i, x, y, x0, y0, uv;
//  for (i=0; i<(int)dec_picture->PicSizeInMbs; i+=2)
//  {
//    if (dec_picture->mb_field[i])
//    {
//      get_mb_pos(i, &x0, &y0, IS_LUMA);
//      for (y=0; y<(2*MB_BLOCK_SIZE);y++)
//        for (x=0; x<MB_BLOCK_SIZE; x++)
//          temp[x][y] = imgY[y0+y][x0+x];
//
//      for (y=0; y<MB_BLOCK_SIZE;y++)
//        for (x=0; x<MB_BLOCK_SIZE; x++)
//        {
//          imgY[y0+(2*y)][x0+x]   = temp[x][y];
//          imgY[y0+(2*y+1)][x0+x] = temp[x][y+MB_BLOCK_SIZE];
//        }
//
//      if (dec_picture->chroma_format_idc != YUV400)
//      {
//        x0 = x0 / (16/img->mb_cr_size_x);
//        y0 = y0 / (16/img->mb_cr_size_y);
//
//        for (uv=0; uv<2; uv++)
//        {
//          for (y=0; y<(2*img->mb_cr_size_y);y++)
//            for (x=0; x<img->mb_cr_size_x; x++)
//              temp[x][y] = imgUV[uv][y0+y][x0+x];
//
//          for (y=0; y<img->mb_cr_size_y;y++)
//            for (x=0; x<img->mb_cr_size_x; x++)
//            {
//              imgUV[uv][y0+(2*y)][x0+x]   = temp[x][y];
//              imgUV[uv][y0+(2*y+1)][x0+x] = temp[x][y+img->mb_cr_size_y];
//            }
//        }
//      }
//    }
//  }
//}

/*!
 ***********************************************************************
 * \brief
 *    decodes one I- or P-frame
 *
 ***********************************************************************
 */
//int decode_one_frame(struct img_par *img,struct inp_par *inp/*, struct snr_par *snr*/)
//{
//  int current_header;
//  Slice *currSlice = img->currentSlice;
//  int i;
//
//  img->current_slice_nr = 0;
//  img->current_mb_nr = -4711;     // initialized to an impossible value for debugging -- correct value is taken from slice header
//  currSlice->next_header = -8888; // initialized to an impossible value for debugging -- correct value is taken from slice header
//  img->num_dec_mb = 0;
//  img->newframe = 1;
//
//  while (1/*(currSlice->next_header != EOS && currSlice->next_header != SOP)*/)
//  {
//    current_header = read_new_slice();
//
//    // error tracking of primary and redundant slices.
//    Error_tracking();
//
//    // If primary and redundant are received and primary is correct, discard the redundant
//    // else, primary slice will be replaced with redundant slice.
//    if(img->frame_num == previous_frame_num && img->redundant_pic_cnt !=0
//      && Is_primary_correct !=0 && current_header != EOS)
//    {
//      continue;
//    }
//
//    // update reference flags and set current ref_flag
//    if(!(img->redundant_pic_cnt != 0 && previous_frame_num == img->frame_num))
//    {
//      for(i=16;i>0;i--)
//      {
//        ref_flag[i] = ref_flag[i-1];
//      }
//    }
//    ref_flag[0] = img->redundant_pic_cnt==0 ? Is_primary_correct : Is_redundant_correct;
//
//    previous_frame_num = img->frame_num;
//
//    if (current_header == EOS)
//    {
//      exit_picture();
//      return EOS;
//    }
//
//    decode_slice(img, inp, current_header);
//
//    img->newframe = 0;
//    img->current_slice_nr++;
//  }
//
//  exit_picture();
//
//  return (SOP);
//}
//

/*!
 ************************************************************************
 * \brief
 *    Convert file read buffer to source picture structure
 * \param imgX
 *    Pointer to image plane
 * \param buf
 *    Buffer for file output
 * \param size_x
 *    horizontal image size in pixel
 * \param size_y
 *    vertical image size in pixel
 * \param symbol_size_in_bytes
 *    number of bytes used per pel
 ************************************************************************
 */
//void buf2img (imgpel** imgX, unsigned char* buf, int size_x, int size_y, int symbol_size_in_bytes)
//{
//  int i,j;
//
//  unsigned short tmp16, ui16;
//  unsigned long  tmp32, ui32;
//
//  if (symbol_size_in_bytes> sizeof(imgpel))
//  {
//    error ("Source picture has higher bit depth than imgpel data type. Please recompile with larger data type for imgpel.", 500);
//  }
//
//  if (( sizeof(char) == sizeof (imgpel)) && ( sizeof(char) == symbol_size_in_bytes))
//  {
//    // imgpel == pixel_in_file == 1 byte -> simple copy
//    for(j=0;j<size_y;j++)
//      memcpy(&imgX[j][0], buf+j*size_x, size_x);
//  }
//  else
//  {
//    // sizeof (imgpel) > sizeof(char)
//    if (testEndian())
//    {
//      // big endian
//      switch (symbol_size_in_bytes)
//      {
//      case 1:
//        {
//          for(j=0;j<size_y;j++)
//            for(i=0;i<size_x;i++)
//            {
//              imgX[j][i]= buf[i+j*size_x];
//            }
//          break;
//        }
//      case 2:
//        {
//          for(j=0;j<size_y;j++)
//            for(i=0;i<size_x;i++)
//            {
//              memcpy(&tmp16, buf+((i+j*size_x)*2), 2);
//              ui16  = (tmp16 >> 8) | ((tmp16&0xFF)<<8);
//              imgX[j][i] = (imgpel) ui16;
//            }
//          break;
//        }
//      case 4:
//        {
//          for(j=0;j<size_y;j++)
//            for(i=0;i<size_x;i++)
//            {
//              memcpy(&tmp32, buf+((i+j*size_x)*4), 4);
//              ui32  = ((tmp32&0xFF00)<<8) | ((tmp32&0xFF)<<24) | ((tmp32&0xFF0000)>>8) | ((tmp32&0xFF000000)>>24);
//              imgX[j][i] = (imgpel) ui32;
//            }
//        }
//      default:
//        {
//           error ("reading only from formats of 8, 16 or 32 bit allowed on big endian architecture", 500);
//           break;
//        }
//      }
//
//    }
//    else
//    {
//      // little endian
//      if (symbol_size_in_bytes == 1)
//      {
//        for (j=0; j < size_y; j++)
//        {
//          for (i=0; i < size_x; i++)
//          {
//            imgX[j][i]=*(buf++);
//          }
//        }
//      }
//      else
//      {
//        for (j=0; j < size_y; j++)
//        {
//          int jpos = j*size_x;
//          for (i=0; i < size_x; i++)
//          {
//            imgX[j][i]=0;
//            memcpy(&(imgX[j][i]), buf +((i+jpos)*symbol_size_in_bytes), symbol_size_in_bytes);
//          }
//        }
//      }
//
//    }
//  }
//}


/*!
************************************************************************
* \brief
*    Find PSNR for all three components.Compare decoded frame with
*    the original sequence. Read inp->jumpd frames to reflect frame skipping.
************************************************************************
*/
//void find_snr(
//              struct snr_par  *snr,   //!< pointer to snr parameters
//              StorablePicture *p,     //!< picture to be compared
//              int p_ref)              //!< open reference YUV file
//{
//  static const int SubWidthC  [4]= { 1, 2, 2, 1};
//  static const int SubHeightC [4]= { 1, 2, 1, 1};
//  int crop_left, crop_right, crop_top, crop_bottom;
//
//  int i,j, k;
//  int64 diff_comp[3] = {0};
//  int64  status;
//  int symbol_size_in_bytes = img->pic_unit_bitsize_on_disk/8;
//  int comp_size_x[3], comp_size_y[3];
//  int64 framesize_in_bytes;
//
//  unsigned int max_pix_value_sqd[3] = {iabs2(img->max_imgpel_value),  iabs2(img->max_imgpel_value_uv), iabs2(img->max_imgpel_value_uv)};
//
//  Boolean rgb_output = (Boolean) (active_sps->vui_seq_parameters.matrix_coefficients==0);
//  unsigned char *buf;
//  imgpel **cur_ref[3]  = {imgY_ref, imgUV_ref[0], imgUV_ref[1]};
//  imgpel **cur_comp[3] = {p->imgY, p->imgUV[0], p->imgUV[1]};
//
//  // picture error concealment
//  char yuv_types[4][6]= {"4:0:0","4:2:0","4:2:2","4:4:4"};
//
//  // calculate frame number
//  int  psnrPOC = active_sps->mb_adaptive_frame_field_flag ? p->poc /(input->poc_scale) : p->poc/(input->poc_scale);
//
//  // cropping for luma
//  if (p->frame_cropping_flag)
//  {
//    crop_left   = SubWidthC[p->chroma_format_idc] * p->frame_cropping_rect_left_offset;
//    crop_right  = SubWidthC[p->chroma_format_idc] * p->frame_cropping_rect_right_offset;
//    crop_top    = SubHeightC[p->chroma_format_idc]*( 2 - p->frame_mbs_only_flag ) *  p->frame_cropping_rect_top_offset;
//    crop_bottom = SubHeightC[p->chroma_format_idc]*( 2 - p->frame_mbs_only_flag ) *  p->frame_cropping_rect_bottom_offset;
//  }
//  else
//  {
//    crop_left = crop_right = crop_top = crop_bottom = 0;
//  }
//
//  comp_size_x[0] = p->size_x - crop_left - crop_right;
//  comp_size_y[0] = p->size_y - crop_top - crop_bottom;
//
//  // cropping for chroma
//  if (p->frame_cropping_flag)
//  {
//    crop_left   = p->frame_cropping_rect_left_offset;
//    crop_right  = p->frame_cropping_rect_right_offset;
//    crop_top    = ( 2 - p->frame_mbs_only_flag ) *  p->frame_cropping_rect_top_offset;
//    crop_bottom = ( 2 - p->frame_mbs_only_flag ) *   p->frame_cropping_rect_bottom_offset;
//  }
//  else
//  {
//    crop_left = crop_right = crop_top = crop_bottom = 0;
//  }

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产三级精品视频| 国产精品视频yy9299一区| 国内偷窥港台综合视频在线播放| 国产色婷婷亚洲99精品小说| 国产一区免费电影| 亚洲人成网站在线| 日韩片之四级片| av一区二区三区在线| 亚洲午夜羞羞片| 亚洲影视在线观看| 久久综合色天天久久综合图片| 91在线一区二区三区| 免费在线观看精品| 亚洲欧美日韩国产综合| 欧美va亚洲va| 国产不卡在线视频| 日韩激情视频在线观看| 中文字幕中文字幕一区二区| 日韩午夜三级在线| 91成人免费在线视频| 国产老女人精品毛片久久| 亚洲影院久久精品| 中文字幕中文在线不卡住| 精品盗摄一区二区三区| 日本韩国精品一区二区在线观看| 国产成人精品影院| 蜜桃久久精品一区二区| 亚洲欧美一区二区不卡| 3d动漫精品啪啪| 色综合久久中文综合久久97| 国产精品一二三四五| 视频一区二区欧美| 亚洲制服欧美中文字幕中文字幕| 久久久亚洲午夜电影| 欧美精品色综合| 在线亚洲+欧美+日本专区| 国产精品一区二区在线观看不卡 | 琪琪一区二区三区| 精品国产电影一区二区 | 日韩三级中文字幕| 欧美三级中文字| 91天堂素人约啪| 成人精品视频.| 国产不卡视频在线播放| 国产精品伊人色| 久久99精品国产.久久久久| 亚洲v中文字幕| 亚洲狠狠丁香婷婷综合久久久| 欧美高清在线精品一区| 国产亚洲欧洲一区高清在线观看| 精品国产免费一区二区三区四区| 欧美精品99久久久**| 精品视频免费在线| 欧美日韩在线免费视频| 91久久香蕉国产日韩欧美9色| 91日韩在线专区| 色综合视频在线观看| 99久久精品国产一区| aaa亚洲精品| 一本久久a久久精品亚洲 | 国产精品伊人色| 精品在线视频一区| 韩国三级在线一区| 国产精品1024| 国产在线精品国自产拍免费| 国产做a爰片久久毛片| 久99久精品视频免费观看| 久久激五月天综合精品| 极品少妇xxxx精品少妇| 精品系列免费在线观看| 国产伦精品一区二区三区免费| 国产精品一区一区| 波波电影院一区二区三区| 91在线看国产| 欧美日韩亚洲国产综合| 欧美一区永久视频免费观看| 日韩精品中午字幕| 国产三级精品三级在线专区| 1024国产精品| 午夜日韩在线观看| 精品在线播放午夜| 成人福利视频在线| 在线观看免费亚洲| 日韩一区二区三| 久久久国产精品不卡| 日本一区二区综合亚洲| 亚洲精选视频在线| 免费高清成人在线| 精品999在线播放| 国产精品色在线观看| 国产精品另类一区| 亚洲图片欧美视频| 国产精品66部| 在线看一区二区| 欧美成人精品1314www| 国产精品美女久久久久久久久 | 国产成人亚洲综合a∨婷婷图片 | 色婷婷av一区| 91精品久久久久久蜜臀| 亚洲国产激情av| 亚洲国产人成综合网站| 国产一区二区三区精品欧美日韩一区二区三区 | 91精品国产91久久久久久一区二区| 久久色中文字幕| 一区二区三区免费观看| 麻豆成人久久精品二区三区小说| 国产综合久久久久久鬼色| 色哟哟国产精品| 欧美成人在线直播| 亚洲免费av网站| 精品亚洲porn| 欧美日韩亚洲另类| 国产精品久久三区| 蜜臀av一区二区在线观看| 国产欧美一区二区精品性色超碰 | 色综合咪咪久久| 欧美精品一区二区三区蜜臀| 成人欧美一区二区三区视频网页| 日韩电影在线看| 99久久久精品免费观看国产蜜| 日韩欧美综合在线| 亚洲伦理在线免费看| 婷婷久久综合九色综合伊人色| 成人午夜精品一区二区三区| 日韩欧美在线不卡| 亚洲午夜在线电影| 成人动漫一区二区在线| 精品国产3级a| 天堂资源在线中文精品| 97久久精品人人澡人人爽| 久久先锋影音av| 免费不卡在线视频| 欧美午夜精品一区二区蜜桃 | 欧美中文字幕一区| 国产精品素人视频| 国产二区国产一区在线观看| 日韩一区国产二区欧美三区| 亚洲精品伦理在线| 国产99久久久精品| 欧美www视频| 日韩经典中文字幕一区| 成人国产一区二区三区精品| 久久一区二区三区国产精品| 久久精品国产一区二区| 67194成人在线观看| 亚洲午夜精品久久久久久久久| 欧美亚洲精品一区| 日韩一区精品字幕| 欧美v日韩v国产v| 国产成人精品一区二区三区四区 | 狠狠色丁香久久婷婷综| 欧美精品一区二区三区蜜桃视频| 精品一区二区日韩| 国产欧美日本一区二区三区| 波多野结衣91| 香蕉久久夜色精品国产使用方法| 欧美肥妇bbw| 国产精品综合网| 亚洲欧美中日韩| 欧美日韩激情一区| 久久99精品久久久久久| 国产午夜久久久久| 91麻豆国产在线观看| 午夜一区二区三区视频| 亚洲精品一区二区三区四区高清| 成人涩涩免费视频| 亚洲成在人线在线播放| 日韩欧美成人激情| 97超碰欧美中文字幕| 首页国产丝袜综合| 久久久精品国产免大香伊| 日本道色综合久久| 久久99国内精品| 亚洲视频综合在线| 日韩一区二区三区视频在线 | 美国精品在线观看| 国产精品萝li| 欧美一区二区不卡视频| 成人性生交大片免费看中文| 亚洲国产毛片aaaaa无费看| 日韩一区二区在线看| 91在线免费播放| 久久99精品国产麻豆婷婷洗澡| 中文字幕一区二区在线观看| 91麻豆精品91久久久久久清纯| 成人午夜免费av| 免费看黄色91| 综合激情成人伊人| 精品处破学生在线二十三| 色www精品视频在线观看| 久久精品噜噜噜成人av农村| 亚洲欧美日韩国产另类专区| 精品国内二区三区| 欧美群妇大交群中文字幕| 成人午夜在线播放| 久久成人免费网| 无吗不卡中文字幕| 亚洲图片激情小说| 国产无人区一区二区三区| 欧美理论片在线|