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

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

?? ceglue.cpp

?? < VC++視頻音頻開發(fā)>> 這本書的源碼
?? CPP
字號:
/*
 *  @(#) ceglue.cpp, last edit: 4/9/1998
 *  @(#) Copyright (C) 1998 Syntrillium Software (www.syntrillium.com)
 *
 *  This program is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 2 of the License, or
 *  (at your option) any later version.
 *
 *  This program is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with this program; if not, write to the Free Software
 *  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 *
 * Basically we are taking what we need from mp2win.cpp and doing a 
 * non-independent-thread (non Windows GUI) version of maplay.
 *
 *
 */

#define  STRICT
#include <windows.h>
#include <commctrl.h>
#include <commdlg.h>
#include <shlobj.h>

#include "all.h"
#include "crc.h"
#include "ibitstr.h"
#include "header.h"
#include "args.h"


#include "subband.h"
#include "sublay1.h"
#include "sublay2.h"
#include "synfilt.h"
#include "ibitstr.h"
#include "obuffer.h"
#include "layer3.h"

extern "C"
{
#include "ceglue.h"
}

#include <math.h>

#define NUM_RFL_ENTRIES 4
#define REMOTE_THRESH   5


BOOL MPEG = FALSE;
enum e_channels mode = both;
// Dummy CRC pointer
//Crc16 *crc;
SynthesisFilter *filter1 = NULL, *filter2 = NULL;
Obuffer *buffer = NULL;
LayerIII_Decoder *l3decoder = NULL;
enum e_mode actualmode;


uint32 layer;
// These arguments should not change while decoding
Ibitstream *stream = NULL;
Header *header     = NULL;
enum e_channels which_channels;
BOOL bComplete=FALSE;

MPEG_Args _maplay_args;
MPEG_Args *maplay_args = &_maplay_args;

void maplay_Exit(uint32 returncode)
{

  delete buffer;
  buffer = NULL;

  delete filter1;
  filter1 = NULL;
  delete filter2;
  filter2 = NULL;

  delete l3decoder;
  l3decoder = NULL;
}


BOOL CPPMPEG_GetInfo(MPEG_INFO * mpi)
{
	if (!MPEG)
		return FALSE;
	if (!header)
		return FALSE;
	
	mpi->iLayer			=(int)header->layer();
	mpi->iVersion		=(int)header->version();
	mpi->iStereoMode	=(int)header->mode();
	mpi->iSamplerate	=(int)header->frequency();
	mpi->iChannels		=(header->mode()==single_channel)?1:2;
	mpi->bIsChecksummed	=(BOOL)header->checksums();
	mpi->bIsCopyrighted	=(BOOL)header->copyright();
	mpi->bIsOriginal	=(BOOL)header->original();
	mpi->iBitrateIndex	=(int)header->bitrate_index();
	mpi->iFrameSize		=(int)header->calculate_framesize();
	mpi->fLengthInMilliseconds=header->total_ms(stream);

	lstrcpy(mpi->szBitrate,header->bitrate_string());
	lstrcpy(mpi->szVersion,header->version_string());

	return TRUE;
}

// header_copy.total_ms(&stream_copy) in CPPMPEG_GetInfo
BOOL CPPMPEG_Open(LPSTR szName)
{
	MPEG = TRUE;
	bComplete=FALSE;
	real own_scalefactor = 32768.0f;
	//args->mutex = CreateMutex(NULL, FALSE, "m");
	stream      = new Ibitstream(szName);
	header = new Header;

   
/*	if (!header->read_header(stream, &crc)){
		return FALSE;
	}*/


	// AND GET THINGS STARTED!
//	crc         = NULL;
	which_channels = both;	// or left, right, downmix
	bComplete=FALSE;

   // get info from header of first frame:
   layer = header->layer();
   if ((actualmode=header->mode())== single_channel)
	   which_channels = left;

   // create filter(s):
   {
      real scalefactor = own_scalefactor; // insert any scal factor here

		filter1 = new SynthesisFilter(0, scalefactor);

	   if ((actualmode != single_channel) && (which_channels == both))
		   filter2 = new SynthesisFilter(1, scalefactor);
   }


   // set up args for buffer class to use
   maplay_args->MPEGheader=header;
   maplay_args->which_c=which_channels;


   // create buffer, and check to see if created ok:
//   buffer=create_CEP_Obuffer(maplay_args);

   if (buffer == NULL) {
		maplay_Exit(0);
      return 1;
   }

  // Layer III : initialize decoder

  	if (layer == 3)
      l3decoder = new LayerIII_Decoder(stream, header, filter1,
      											filter2, buffer, which_channels);

	return TRUE;
}

// Returns number of bytes, or zero for complete
int CPPMPEG_Read(BYTE * pBuffer)
{
	bool read_ready = false, write_ready = false;
   	int iRead;

	if (bComplete)
		return 0;
	// is there a change in important parameters?
	// (bitrate switching is allowed)
	if (header->layer() != layer)
	{
		// layer switching is allowed
	  if (header->layer() == 3) {
         l3decoder = new LayerIII_Decoder(stream, header,
           											filter1, filter2,
                                          buffer, which_channels);
      } else if (layer == 3) {
      	delete l3decoder;
         l3decoder = NULL;
      }

		layer = header->layer();
	 }

	 if (layer != 3) {

	    Subband *subbands[32];
	    uint32 num_subbands = header->number_of_subbands();
       uint32 i;
       actualmode = header->mode();

		 // create subband objects:
		 if (layer == 1)
		 {
			if (actualmode == single_channel)
				for (i = 0; i < num_subbands; ++i)
				  subbands[i] = new SubbandLayer1(i);
			else if (actualmode == joint_stereo) {
				for (i = 0; i < header->intensity_stereo_bound(); ++i)
				  subbands[i] = new SubbandLayer1Stereo(i);
				for (; i < num_subbands; ++i)
				  subbands[i] = new SubbandLayer1IntensityStereo(i);
			} else {
				for (i = 0; i < num_subbands; ++i)
				  subbands[i] = new SubbandLayer1Stereo(i);
	      }

		 } else { // Layer II
			if (actualmode == single_channel)
				for (i = 0; i < num_subbands; ++i)
		   	  subbands[i] = new SubbandLayer2(i);
			else if (actualmode == joint_stereo)
			{
				for (i = 0; i < header->intensity_stereo_bound(); ++i)
			 	    subbands[i] = new SubbandLayer2Stereo(i);
				for (; i < num_subbands; ++i)
				    subbands[i] = new SubbandLayer2IntensityStereo(i);
			} else {
				for (i = 0; i < num_subbands; ++i)
				    subbands[i] = new SubbandLayer2Stereo(i);
         }
	 	 }

  	    // start to read audio data:
	    for (i = 0; i < num_subbands; ++i)
//	       subbands[i]->read_allocation(stream, header, crc);

		 if (layer == 2)
			for (i = 0; i < num_subbands; ++i)
				//((SubbandLayer2 *)subbands[i])->read_scalefactor_selection(stream,
            	//																	     crc);

/*		 if (!crc || header->checksum_ok())
		 {
			// no checksums or checksum ok, continue reading from stream:
			for (i = 0; i < num_subbands; ++i)
				subbands[i]->read_scalefactor(stream, header);

			do
			{
				for (i = 0; i < num_subbands; ++i)
					read_ready = subbands[i]->read_sampledata(stream);

				do
				{
					for (i = 0; i < num_subbands; ++i)
						write_ready = subbands[i]->put_next_sample(which_channels,
   	                                                       filter1, filter2);

					filter1->calculate_pcm_samples(buffer);
					if ((which_channels == both) && (actualmode!= single_channel))
               	filter2->calculate_pcm_samples(buffer);
				} while (!write_ready);
			} while (!read_ready);

	      buffer->write_buffer(1);

		 } // checksum ok*/
	 // Jeff : Don't let user know if crc violated.
//	    else
		// Sh*t! Wrong crc checksum in frame!
//		cerr << "WARNING: frame contains wrong crc checksum! (throwing frame away)\n";

       for (i = 0; i < num_subbands; ++i)
			delete subbands[i];

    } else {  // Layer III
	   l3decoder->decode();
    }

/*   if (!header->read_header(stream, &crc))
	   bComplete=TRUE;*/

//	BYTE * pBuf=buffer->get_buffer(&iRead);
//    CopyMemory(pBuffer,pBuf,iRead);

	return iRead;
}

void CPPMPEG_Close()
{	
	maplay_Exit(0);

	if (MPEG) 
	{
   		delete stream;
		stream = NULL;

		delete header;
		header = NULL;
	}
}

// To interface with the Cool Edit File Filters API, we make "C" callable functions

extern "C" {

	void MPEG_Close()
	{
		CPPMPEG_Close();
	}

	int MPEG_Read(BYTE * pBuffer)
	{
		return CPPMPEG_Read(pBuffer);
	}

	BOOL MPEG_Open(LPSTR szName)
	{
		return CPPMPEG_Open(szName);
	}

	BOOL MPEG_GetInfo(MPEG_INFO * mpi)
	{
		return CPPMPEG_GetInfo(mpi);
	}

}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美巨大另类极品videosbest| 国产一区美女在线| 欧美性感一类影片在线播放| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆 | 精品久久久久久最新网址| 青青草精品视频| 欧美videos中文字幕| 成人亚洲一区二区一| 自拍偷在线精品自拍偷无码专区| 在线观看区一区二| 男女激情视频一区| 欧美激情资源网| 在线这里只有精品| 麻豆精品国产91久久久久久| 国产精品无圣光一区二区| 成人精品小蝌蚪| 午夜视频在线观看一区| 精品免费日韩av| 91在线观看成人| 五月婷婷激情综合网| 国产清纯白嫩初高生在线观看91| 99久久精品久久久久久清纯| 天使萌一区二区三区免费观看| 久久久亚洲精品石原莉奈| 99国产精品久久久久| 日本特黄久久久高潮| 国产欧美视频在线观看| 欧美又粗又大又爽| 国产揄拍国内精品对白| 一区二区三区成人| 久久只精品国产| 欧亚洲嫩模精品一区三区| 精品一区二区三区在线播放| 亚洲品质自拍视频| 日韩精品最新网址| 色老汉一区二区三区| 国产精品中文字幕日韩精品| 亚洲午夜在线电影| 国产精品伦一区| 日韩一二三四区| 欧美亚洲免费在线一区| 成人免费视频免费观看| 毛片av一区二区三区| 亚洲免费观看高清完整版在线观看 | 国产99久久久精品| 五月综合激情日本mⅴ| 国产精品福利一区| 久久嫩草精品久久久精品一| 欧美日韩激情一区| 一本一道久久a久久精品| 国产一区中文字幕| 日本不卡高清视频| 亚洲一区中文在线| 中文字幕在线播放不卡一区| www欧美成人18+| 日韩欧美一级特黄在线播放| 欧美精品九九99久久| 色视频欧美一区二区三区| 丁香六月综合激情| 国产精品一区二区黑丝 | 久久se精品一区二区| 五月天中文字幕一区二区| 亚洲激情男女视频| 国产精品初高中害羞小美女文| 久久久久亚洲综合| 精品国产sm最大网站免费看| 7777女厕盗摄久久久| 欧美视频一区二区| 欧美午夜免费电影| 在线观看日韩毛片| 精品视频123区在线观看| 日本丶国产丶欧美色综合| 91蜜桃婷婷狠狠久久综合9色| a亚洲天堂av| 99久久综合国产精品| 成人黄色在线看| 不卡一区中文字幕| 99久久免费精品| 91黄色免费看| 欧美视频在线播放| 在线播放91灌醉迷j高跟美女 | 精品国产欧美一区二区| 2021久久国产精品不只是精品| 欧美大白屁股肥臀xxxxxx| 精品久久久久久久久久久久久久久 | 欧美日韩亚洲综合一区| 欧美裸体一区二区三区| 制服丝袜国产精品| 2022国产精品视频| 国产精品久久久久影院| 一区二区三区电影在线播| 午夜精品久久久久久久久久久| 日本免费新一区视频| 狠狠色综合色综合网络| 国产不卡视频在线播放| 91小视频免费观看| 欧美区在线观看| 久久中文字幕电影| 亚洲视频1区2区| 午夜视频在线观看一区二区| 久88久久88久久久| 丁香六月综合激情| 欧美视频一区在线| 欧美不卡在线视频| 中文字幕一区二区三区在线播放| 一区二区三区免费在线观看| 蜜臂av日日欢夜夜爽一区| 丰满亚洲少妇av| 欧美性xxxxxxxx| 国产视频一区不卡| 亚洲国产精品麻豆| 国产91精品一区二区麻豆网站| 91在线视频免费91| 欧美一区二区三区在线| 欧美激情在线一区二区| 午夜精品久久久久影视| 国产福利视频一区二区三区| 欧美少妇xxx| 国产午夜三级一区二区三| 午夜精品久久久久久久久久| 国产成人无遮挡在线视频| 欧美丝袜自拍制服另类| 国产欧美在线观看一区| 午夜免费欧美电影| 暴力调教一区二区三区| 欧美www视频| 亚洲mv在线观看| eeuss影院一区二区三区| 精品国产91亚洲一区二区三区婷婷 | 26uuu国产日韩综合| 午夜视频在线观看一区二区| www.日韩精品| 国产午夜精品理论片a级大结局| 亚洲成va人在线观看| 成人性生交大合| 欧美va亚洲va香蕉在线| 亚洲v中文字幕| 日本乱人伦aⅴ精品| 中文无字幕一区二区三区 | 成人免费av在线| 欧美本精品男人aⅴ天堂| 午夜视频一区在线观看| 一本大道av一区二区在线播放| 久久免费国产精品| 麻豆91在线播放免费| 91麻豆精品久久久久蜜臀| 一区二区三区精品在线| 99精品视频一区二区三区| 久久―日本道色综合久久| 另类调教123区| 91精品国产综合久久福利软件| 一区二区三区免费| 91免费国产在线| 亚洲欧美视频一区| 成人性生交大片| 亚洲国产成人午夜在线一区| 国产高清不卡一区二区| 久久久www免费人成精品| 国产一区二区三区黄视频| 欧美精品一区二区不卡 | 中文字幕一区二区三区色视频| 国产精品原创巨作av| 国产三级精品在线| 国产成人免费高清| 国产精品三级电影| 91在线你懂得| 亚洲精品国产一区二区精华液 | 高清不卡一区二区| 亚洲国产电影在线观看| 成人app下载| 亚洲女女做受ⅹxx高潮| 日本精品免费观看高清观看| 一区二区三区四区不卡视频| 精品视频1区2区3区| 五月天激情小说综合| 欧美一区二区大片| 韩国成人在线视频| 亚洲综合网站在线观看| 欧美视频在线观看一区| 日本成人中文字幕在线视频| 精品免费日韩av| 成人性生交大片免费看中文网站| 一区在线中文字幕| 欧美亚洲国产怡红院影院| 免费在线观看一区二区三区| 精品av综合导航| 成人污视频在线观看| 夜夜爽夜夜爽精品视频| 911精品国产一区二区在线| 久久国产精品99精品国产| 欧美激情一区二区三区在线| 色综合中文综合网| 日韩电影在线一区| 久久久亚洲精品一区二区三区| proumb性欧美在线观看| 亚洲一区二区三区小说| 精品国产一区久久| www.性欧美| 免费在线观看日韩欧美| 国产精品美女久久久久久2018|