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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? assembler.cpp

?? JMVM MPEG MVC/3DAV 測試平臺 國際通用標準
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
/*
********************************************************************************
********************************************************************************

This software module was originally developed by

CHEN Ying (ying.chen@tut.fi, Nokia & Tempere University of Technology )

********************************************************************************
********************************************************************************
*/



#include "AssemblerParameter.h"
#include "Assembler.h"
#include "ReadBitstreamFile.h"
#include "MVCScalableModifyCode.h"
#include "MVCScalableTestCode.h"
#include <math.h>



Assembler::Assembler()
: m_ppcReadBitstream      (  0   )
, pcTmpViewScalInfoSei	  (  0   ) //SEI LSJ
, m_pcWriteBitstream      (  0   )
, m_pcAssemblerParameter  (  0   )
, m_pcTraceFile           (  0   )
, m_pcAssemblerTraceFile  (  0   )
, m_uiNumViews            (  0   )
, m_uiTempViewDecOrder    (  0   )
, m_bSuffix               ( true )
{
}



Assembler::~Assembler()
{
}



ErrVal
Assembler::create( Assembler*& rpcAssembler )
{
  rpcAssembler = new Assembler;
  ROT( NULL == rpcAssembler );
  return Err::m_nOK;
}

ErrVal
Assembler::init( AssemblerParameter *pcAssemblerParameter )
{
  
  ROT( NULL == pcAssemblerParameter );

  m_pcAssemblerParameter  = pcAssemblerParameter;
  m_pcAssemblerParameter->setResult( -1 );

  m_uiNumViews        = m_pcAssemblerParameter->getNumViews(); 
  m_ppcReadBitstream  = new ReadBitstreamIf * [m_uiNumViews]; 
  pcTmpViewScalInfoSei = new h264::SEI::ViewScalabilityInfoSei * [m_uiNumViews]; //SEI 
//  m_bSuffix           = m_pcAssemblerParameter->getSuffix() > 0; 
  m_bSuffix           = true; // it is mandatory to be true;
  for( UInt uiV=0; uiV <m_uiNumViews ; uiV++)
  {
    ReadBitstreamFile*  pcReadBitstreamFile;
    RNOKS( ReadBitstreamFile::create( pcReadBitstreamFile ) );
    RNOKS( pcReadBitstreamFile->init( m_pcAssemblerParameter->getInFile(uiV) ) );
    m_ppcReadBitstream [uiV] = (ReadBitstreamIf*)pcReadBitstreamFile;
  }

  WriteBitstreamToFile*  pcWriteBitstreamFile;
  RNOKS( WriteBitstreamToFile::create( pcWriteBitstreamFile ) );
  RNOKS( pcWriteBitstreamFile->init( m_pcAssemblerParameter->getOutFile() ) );
  m_pcWriteBitstream = (WriteBitstreamIf*)pcWriteBitstreamFile;
  RNOK( h264::H264AVCPacketAnalyzer::create( m_pcH264AVCPacketAnalyzer ) );      //SEI 
  m_aucStartCodeBuffer[0] = 0;
  m_aucStartCodeBuffer[1] = 0;
  m_aucStartCodeBuffer[2] = 0;
  m_aucStartCodeBuffer[3] = 1;
  m_cBinDataStartCode.reset();
  m_cBinDataStartCode.set( m_aucStartCodeBuffer, 4 );

  return Err::m_nOK;
}

ErrVal
Assembler::destroy()
{
  m_cBinDataStartCode.reset();


  if( NULL != m_ppcReadBitstream )
  {
    for( UInt uiV=0; uiV <m_uiNumViews ; uiV++)
    {
      RNOK( m_ppcReadBitstream[uiV]->uninit() );
      RNOK( m_ppcReadBitstream[uiV]->destroy() );
    }
    m_ppcReadBitstream = NULL;
  }

  if( NULL != m_pcH264AVCPacketAnalyzer )
  {
    RNOK( m_pcH264AVCPacketAnalyzer->destroy() );
  } //SEI 


  delete this;

  return Err::m_nOK;
}

ErrVal
Assembler::xPreAnalyse ()
{
  UInt uiNumVCLUnits=0;
  BinData*                pcBinData     = 0;
  for (UInt i=0; i< m_uiNumViews; i++)
  {
    Bool bEOS = false;
    printf("view %d\n",i);
    while( ! bEOS )
    {
    
    //===== get packet =====
    RNOK( m_ppcReadBitstream[i]->extractPacket( pcBinData, bEOS ) );
    if( bEOS )
    {
      RNOK( m_ppcReadBitstream[i]->releasePacket( pcBinData ) );
      pcBinData = NULL;
      continue;
    }

    //===== get NAL Unit type only =====
    //----------------------------assembling ----------------------------------------------
    UChar       ucByte        = (pcBinData->data())[0];
    NalUnitType eNalUnitType  = NalUnitType ( ucByte  & 0x1F );
    
    if ( NAL_UNIT_CODED_SLICE == eNalUnitType          || NAL_UNIT_CODED_SLICE_IDR == eNalUnitType 
       ||NAL_UNIT_CODED_SLICE_SCALABLE == eNalUnitType || NAL_UNIT_CODED_SLICE_IDR_SCALABLE  == eNalUnitType )
    {
      uiNumVCLUnits++;
      printf("%d\n", eNalUnitType);
    }
    if(pcBinData)
    {
      RNOK( m_ppcReadBitstream[i]->releasePacket( pcBinData ) );
      pcBinData = NULL;
    }
   }
  }
  printf("Number of total VCL NAL Units: %d\n", uiNumVCLUnits);
  
  return Err::m_nOK;
}

//SEI {
ErrVal 
Assembler::xWriteViewScalSEIToBuffer(h264::SEI::ViewScalabilityInfoSei *pcViewScalSei, BinData *pcBinData)
{
	const UInt uiSEILength = 1000;
	UChar		pulStreamPacket[uiSEILength];
	pcBinData->reset();
	pcBinData->set( new UChar[uiSEILength], uiSEILength );

	UChar *m_pucBuffer = pcBinData->data();

	MVCScalableModifyCode cMVCScalableModifyCode;
	MVCScalableTestCode cMVCScalableTestCode;
	RNOK( cMVCScalableTestCode.init() );
	RNOK( cMVCScalableModifyCode.init( (ULong*) pulStreamPacket ) );
	RNOK( cMVCScalableTestCode.SEICode( pcViewScalSei, &cMVCScalableTestCode ) );
	UInt uiBits = cMVCScalableTestCode.getNumberOfWrittenBits();
	UInt uiSize = (uiBits+7)/8;
	RNOK( cMVCScalableModifyCode.WriteFlag( 0 ) );
	RNOK( cMVCScalableModifyCode.WriteCode( 0 ,2 ) );
	RNOK( cMVCScalableModifyCode.WriteCode( NAL_UNIT_SEI, 5 ) );
	RNOK( cMVCScalableModifyCode.WritePayloadHeader( pcViewScalSei->getMessageType(), uiSize ) );
	RNOK( cMVCScalableModifyCode.SEICode( pcViewScalSei, &cMVCScalableModifyCode ) );
	uiBits = cMVCScalableModifyCode.getNumberOfWrittenBits();
	uiSize = (uiBits+7)/8;
	UInt uiAlignedBits = 8 - (uiBits&7);
	if( uiAlignedBits != 0 && uiAlignedBits != 8 )
	{
		RNOK( cMVCScalableModifyCode.WriteCode( 1 << (uiAlignedBits-1), uiAlignedBits ) );
	}
	RNOK ( cMVCScalableModifyCode.WriteTrailingBits() );
	RNOK ( cMVCScalableModifyCode.flushBuffer() );
	uiBits = cMVCScalableModifyCode.getNumberOfWrittenBits();
	uiBits              = ( uiBits >> 3 ) + ( 0 != ( uiBits & 0x07 ) );
	uiSize = uiBits;
	RNOK( cMVCScalableModifyCode.ConvertRBSPToPayload( m_pucBuffer, pulStreamPacket, uiSize, 2 ) );
	pcBinData->decreaseEndPos( uiSEILength - uiSize );
	return Err::m_nOK;
}
//SEI }

ErrVal
Assembler::xAnalyse()
{
//  Bool                    bNewPicture   = false;
//Bool                    bApplyToNext  = false;
  Bool                    bEOS          = false;
  Bool                    bNewAUStart   = true;
  BinData*                pcBinData     = 0;

  m_uiTempViewDecOrder                  = 0; 
  UInt                    uiFrames      = 0; 
  UInt                    uiNumVCLUnits = 0;
  UInt                    uiNumOtherNalU= 0;

//SEI { 
  h264::SEI::ViewScalabilityInfoSei*  pcViewScalInfoSei = 0;
  Bool					  bViewScalSei = false;
  Bool					  bFinalViewScalSei = false;
  Bool					  bScanViewScalSei = false;
  h264::SEI::ViewScalabilityInfoSei*  pcFinalViewScalSei;
  RNOK( h264::SEI::ViewScalabilityInfoSei::create(pcFinalViewScalSei) );
//SEI }
  UInt                    uiPosSPS = 0; 
  Int64                   i64Start;
//  UInt                    uiEnd;
// Dec. 1
  while( ! bEOS )
  {
    Bool bKeep       = false;

    UInt uiProcessingView = m_uiTempViewDecOrder;
//SEI { 
   uiProcessingView = 0;
   while(uiProcessingView < m_uiNumViews && !bScanViewScalSei)
   {
     RNOK( m_pcH264AVCPacketAnalyzer->init() );
     //--- get first packet ---
	 Int iPos;
	 m_ppcReadBitstream[uiProcessingView]->getPosition( iPos );
     RNOK( m_ppcReadBitstream[uiProcessingView]->extractPacket( pcBinData, bEOS ) );
   
     //--- analyse packet ---
     RNOK( m_pcH264AVCPacketAnalyzer ->processSEIAndMVC( pcBinData, pcViewScalInfoSei) );
	 
	 if( uiProcessingView == m_uiNumViews-1)
		bScanViewScalSei = true;
	 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国内精品伊人久久久久av一坑 | 日韩免费观看2025年上映的电影| 欧美va亚洲va国产综合| 综合久久久久久| 国产激情91久久精品导航| 欧美系列亚洲系列| 亚洲欧洲日本在线| 国产精品一区二区免费不卡| 欧美一区国产二区| 亚洲精选免费视频| 99免费精品视频| 国产精品久久久久久久久动漫| 久久疯狂做爰流白浆xx| 91超碰这里只有精品国产| 一区二区国产盗摄色噜噜| 成人国产精品视频| 亚洲国产精品激情在线观看| 精品一区二区三区在线播放视频| 欧美影院精品一区| 一区二区高清视频在线观看| 91看片淫黄大片一级| 国产精品久99| proumb性欧美在线观看| 国产精品久久久久久户外露出 | 国产视频一区二区在线| 经典三级一区二区| 久久一留热品黄| 国产激情视频一区二区在线观看| 欧美大片一区二区| 九九视频精品免费| 久久美女艺术照精彩视频福利播放 | 国模无码大尺度一区二区三区| 欧美一区二区免费| 另类中文字幕网| 欧美精品一区二区三区在线播放 | 偷偷要91色婷婷| 欧美一区二区在线播放| 蜜桃视频一区二区| 精品国产凹凸成av人网站| 国内精品久久久久影院色| 久久亚洲免费视频| 成人午夜av影视| 亚洲乱码国产乱码精品精小说| 一本到不卡精品视频在线观看| 亚洲精品免费一二三区| 欧美高清dvd| 国产呦萝稀缺另类资源| 国产日产精品1区| 色婷婷久久综合| 日韩福利视频导航| 26uuu国产日韩综合| 白白色亚洲国产精品| 亚洲成av人片在www色猫咪| 欧美一级片免费看| 国产成a人亚洲| 亚洲一线二线三线视频| 日韩视频123| 99久久免费国产| 天堂蜜桃一区二区三区 | 日韩精品一区二区三区视频在线观看 | 国内精品第一页| 亚洲免费在线电影| 欧美一区二区日韩一区二区| 风间由美性色一区二区三区| 一区二区三区四区国产精品| 欧美一区二区三区免费视频 | 精品亚洲国内自在自线福利| 国产精品久久久久久久久搜平片| 国产精品夫妻自拍| 9191久久久久久久久久久| 国产成人亚洲综合a∨婷婷| 亚洲电影在线播放| 国产亚洲精品aa| 制服视频三区第一页精品| 大陆成人av片| 精品一区二区在线视频| 亚洲美腿欧美偷拍| 久久久久9999亚洲精品| 欧美二区在线观看| 99re热视频精品| 国产一区二区精品久久| 亚洲6080在线| 亚洲乱码国产乱码精品精可以看| 日韩视频一区在线观看| 欧美天堂亚洲电影院在线播放| 岛国精品在线观看| 国产一区二区91| 免费日本视频一区| 无吗不卡中文字幕| 亚洲自拍偷拍图区| 自拍偷在线精品自拍偷无码专区| 久久日一线二线三线suv| 欧美人妇做爰xxxⅹ性高电影| 99精品黄色片免费大全| 丁香桃色午夜亚洲一区二区三区| 日本伊人色综合网| 同产精品九九九| 一级日本不卡的影视| 椎名由奈av一区二区三区| 欧美激情一区二区三区蜜桃视频| 日韩精品影音先锋| 日韩欧美一区二区久久婷婷| 欧美肥胖老妇做爰| 91精品国产色综合久久久蜜香臀| 在线观看欧美日本| 欧美性猛交xxxx黑人交| 色先锋aa成人| 欧美三区在线视频| 欧美日本国产一区| 欧美精品高清视频| 日韩欧美在线观看一区二区三区| 日韩一区二区麻豆国产| 日韩免费看的电影| 精品免费99久久| 2021久久国产精品不只是精品| 日韩视频一区二区三区| 精品电影一区二区三区| 久久久久久久久久久久电影| 久久久国产精品不卡| 欧美激情综合五月色丁香| 国产精品天干天干在线综合| 亚洲欧洲精品成人久久奇米网| 亚洲素人一区二区| 亚洲免费观看高清| 三级欧美在线一区| 裸体在线国模精品偷拍| 国产在线国偷精品免费看| 国产高清一区日本| 一本大道久久a久久精二百| 欧美性大战久久| 日韩欧美综合在线| 国产人妖乱国产精品人妖| 中文字幕中文字幕在线一区 | 亚洲一区影音先锋| 肉色丝袜一区二区| 国产福利91精品| 91丨九色丨国产丨porny| 欧美三级日韩三级国产三级| 欧美一级二级在线观看| 亚洲国产精品传媒在线观看| 一区二区三区高清| 狠狠狠色丁香婷婷综合激情| 99视频有精品| 日韩三区在线观看| 国产精品日产欧美久久久久| 性感美女极品91精品| 国产一区二区不卡| 欧美视频在线一区| 国产网站一区二区| 午夜精品福利在线| 成人sese在线| 日韩欧美一区二区三区在线| 亚洲欧洲一区二区三区| 精品一区二区在线视频| 色婷婷狠狠综合| 久久久久久久久久看片| 亚洲第一狼人社区| 国产成人在线观看免费网站| 欧美三级在线看| 国产精品网友自拍| 蜜臀精品久久久久久蜜臀| 91蜜桃传媒精品久久久一区二区| 欧美一级精品大片| 一区二区中文视频| 国产一区视频导航| 4hu四虎永久在线影院成人| **网站欧美大片在线观看| 国精产品一区一区三区mba视频 | 亚洲超丰满肉感bbw| av在线播放一区二区三区| 欧美一级日韩不卡播放免费| 一区二区三区四区不卡在线 | 国产最新精品精品你懂的| 欧美日韩一区 二区 三区 久久精品| 国产日韩欧美在线一区| 免费成人av资源网| 欧美日产在线观看| 亚洲精品老司机| av毛片久久久久**hd| 日本一区二区免费在线| 经典三级在线一区| 欧美刺激脚交jootjob| 日韩精品乱码免费| 欧美日韩国产欧美日美国产精品| 亚洲特级片在线| 97精品电影院| 成人免费小视频| 成人国产在线观看| 国产精品久久久一本精品| 岛国精品一区二区| 国产精品视频九色porn| 成人午夜激情视频| 国产精品久久久久久久岛一牛影视 | 成人激情小说网站| 欧美激情中文字幕一区二区| 国产九九视频一区二区三区| 精品国产在天天线2019| 黄色资源网久久资源365| 精品电影一区二区| 国产成人午夜精品5599 |