⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cfaac.cpp

📁 dsp上用c语言实现的aac音频算法的编解码器代码
💻 CPP
📖 第 1 页 / 共 2 页
字号:
/*CFAAC - set of classes to import/export .aac/.mp4 filesCopyright (C) 2004 Antonio ForannaThis program is free software; you can redistribute it and/or modifyit under the terms of the GNU General Public License as published bythe Free Software Foundation.	This program is distributed in the hope that it will be useful,but WITHOUT ANY WARRANTY; without even the implied warranty ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See theGNU General Public License for more details.		You should have received a copy of the GNU General Public Licensealong with this program; if not, write to the Free SoftwareFoundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.			The author can be contacted at:ntnfrn_email-temp@yahoo.it*/#include "Cfaac.h"// *********************************************************************************************//										CMyEncCfg// *********************************************************************************************void CMyEncCfg::getCfg(CMyEncCfg *cfg){ CRegistry reg;	if(reg.OpenCreate(HKEY_CURRENT_USER, REGISTRY_PROGRAM_NAME "\\FAAC"))	{		cfg->AutoCfg=reg.GetSetBool(REG_AUTO,DEF_AUTO);		cfg->SaveMP4=reg.GetSetByte(REG_WRITEMP4,DEF_WRITEMP4);		cfg->EncCfg.mpegVersion=reg.GetSetDword(REG_MPEGVER,DEF_MPEGVER); 		cfg->EncCfg.aacObjectType=reg.GetSetDword(REG_PROFILE,DEF_PROFILE); 		cfg->EncCfg.allowMidside=reg.GetSetDword(REG_MIDSIDE,DEF_MIDSIDE); 		cfg->EncCfg.useTns=reg.GetSetDword(REG_TNS,DEF_TNS); 		cfg->EncCfg.useLfe=reg.GetSetDword(REG_LFE,DEF_LFE);		cfg->UseQuality=reg.GetSetBool(REG_USEQUALTY,DEF_USEQUALTY);		cfg->EncCfg.quantqual=reg.GetSetDword(REG_QUALITY,DEF_QUALITY); 		cfg->EncCfg.bitRate=reg.GetSetDword(REG_BITRATE,DEF_BITRATE); 		cfg->EncCfg.bandWidth=reg.GetSetDword(REG_BANDWIDTH,DEF_BANDWIDTH); 		cfg->EncCfg.outputFormat=reg.GetSetDword(REG_HEADER,DEF_HEADER); 		FREE_ARRAY(cfg->OutDir);		cfg->OutDir=reg.GetSetStr(REG_OutFolder,"");		cfg->TagOn=reg.GetSetByte(REG_TAGON,0);#ifdef USE_IMPORT_TAG		cfg->TagImport=reg.GetSetByte(REG_TAGIMPORT,0);	#ifdef USE_PATHEXT		FREE_ARRAY(cfg->TagSrcPath);		FREE_ARRAY(cfg->TagSrcExt);		cfg->TagSrcPath=reg.GetSetStr(REG_InFolder,"");		cfg->TagSrcExt=reg.GetSetStr(REG_SrcExt,"");	#endif#endif		cfg->Tag.artist=reg.GetSetStr(REG_ARTIST,"");		cfg->Tag.title=reg.GetSetStr(REG_TITLE,"");		cfg->Tag.album=reg.GetSetStr(REG_ALBUM,"");		cfg->Tag.year=reg.GetSetStr(REG_YEAR,"");		cfg->Tag.genre=reg.GetSetStr(REG_GENRE,"");		cfg->Tag.writer=reg.GetSetStr(REG_WRITER,"");		cfg->Tag.comment=reg.GetSetStr(REG_COMMENT,"");		cfg->Tag.trackno=reg.GetSetWord(REG_TRACK,0);		cfg->Tag.ntracks=reg.GetSetWord(REG_NTRACKS,0);		cfg->Tag.discno=reg.GetSetWord(REG_DISK,0);		cfg->Tag.ndiscs=reg.GetSetWord(REG_NDISKS,0);		cfg->Tag.compilation=reg.GetSetByte(REG_COMPILATION,0);		cfg->Tag.artFilename=reg.GetSetStr(REG_ARTFILE,"");	}	else		MessageBox(0,"Can't open registry!",0,MB_OK|MB_ICONSTOP);}// -----------------------------------------------------------------------------------------------void CMyEncCfg::setCfg(CMyEncCfg *cfg){ CRegistry reg;	if(reg.OpenCreate(HKEY_CURRENT_USER, REGISTRY_PROGRAM_NAME "\\FAAC"))	{		reg.SetBool(REG_AUTO,cfg->AutoCfg);		reg.SetByte(REG_WRITEMP4,cfg->SaveMP4);		reg.SetDword(REG_MPEGVER,cfg->EncCfg.mpegVersion);		reg.SetDword(REG_PROFILE,cfg->EncCfg.aacObjectType);		reg.SetDword(REG_MIDSIDE,cfg->EncCfg.allowMidside);		reg.SetDword(REG_TNS,cfg->EncCfg.useTns);		reg.SetDword(REG_LFE,cfg->EncCfg.useLfe);		reg.SetBool(REG_USEQUALTY,cfg->UseQuality);		reg.SetDword(REG_QUALITY,cfg->EncCfg.quantqual);		reg.SetDword(REG_BITRATE,cfg->EncCfg.bitRate);		reg.SetDword(REG_BANDWIDTH,cfg->EncCfg.bandWidth);		reg.SetDword(REG_HEADER,cfg->EncCfg.outputFormat);		reg.SetStr(REG_OutFolder,cfg->OutDir);		reg.SetByte(REG_TAGON,cfg->TagOn);#ifdef USE_IMPORT_TAG		reg.SetByte(REG_TAGIMPORT,cfg->TagImport);	#ifdef USE_PATHEXT		reg.SetStr(REG_InFolder,cfg->TagSrcPath);		reg.SetStr(REG_SrcExt,cfg->TagSrcExt);	#endif#endif		reg.SetStr(REG_ARTIST,cfg->Tag.artist);		reg.SetStr(REG_TITLE,cfg->Tag.title);		reg.SetStr(REG_ALBUM,cfg->Tag.album);		reg.SetStr(REG_YEAR,cfg->Tag.year);		reg.SetStr(REG_GENRE,cfg->Tag.genre);		reg.SetStr(REG_WRITER,cfg->Tag.writer);		reg.SetStr(REG_COMMENT,cfg->Tag.comment);		reg.SetWord(REG_TRACK,cfg->Tag.trackno);		reg.SetWord(REG_NTRACKS,cfg->Tag.ntracks);		reg.SetWord(REG_DISK,cfg->Tag.discno);		reg.SetWord(REG_NDISKS,cfg->Tag.ndiscs);		reg.SetByte(REG_COMPILATION,cfg->Tag.compilation);		reg.SetStr(REG_ARTFILE,cfg->Tag.artFilename);	}	else		MessageBox(0,"Can't open registry!",0,MB_OK|MB_ICONSTOP);}// *********************************************************************************************//											Cfaac// *********************************************************************************************Cfaac::Cfaac(HANDLE hOut){	if(hOut)	{		hOutput=hOut;		return;	}    if(!(hOutput=GlobalAlloc(GMEM_MOVEABLE|GMEM_SHARE|GMEM_ZEROINIT,sizeof(MYOUTPUT))))	{		MessageBox(0, "Memory allocation error: hOutput", APP_NAME " plugin", MB_OK|MB_ICONSTOP); \		return;	}//	dontAskGetFilename=false;}// -----------------------------------------------------------------------------------------------Cfaac::~Cfaac(){	if(!hOutput)		return;MYOUTPUT *mo;	GLOBALLOCK(mo,hOutput,MYOUTPUT,return);		if(mo->WrittenSamples)	{	int	BytesWritten;		if(mo->bytes_into_buffer>0)			memset(mo->bufIn+mo->bytes_into_buffer, 0, (mo->samplesInput*(mo->BitsPerSample>>3))-mo->bytes_into_buffer);		do		{			if((BytesWritten=processData(hOutput,mo->bufIn,mo->bytes_into_buffer))<0)				MessageBox(0, "~Cfaac: processData", APP_NAME " plugin", MB_OK|MB_ICONSTOP);			mo->bytes_into_buffer=0;		}while(BytesWritten>0);	}	if(mo->aacFile)	{		fclose(mo->aacFile);		mo->aacFile=0;	CMyEncCfg cfg(false);		if(cfg.TagOn && mo->OutFilename)		{		int error=0;#ifdef USE_IMPORT_TAG			if(cfg.TagImport && mo->InFilename)			{			int l=strlen(mo->InFilename);				if(	!strcmpi(mo->InFilename+l-4,".mp4") ||					!strcmpi(mo->InFilename+l-4,".m4a") ||					!strcmpi(mo->InFilename+l-4,".m4b"))					error=cfg.Tag.ReadMp4Tag(mo->InFilename);				else					error=cfg.Tag.ReadAacTag(mo->InFilename);			}#endif			if(!error)				cfg.Tag.WriteAacTag(mo->OutFilename);		}	}	else	{		MP4Close(mo->MP4File);		mo->MP4File=0;	}		if(mo->hEncoder)		faacEncClose(mo->hEncoder);		FREE_ARRAY(mo->bitbuf)	FREE_ARRAY(mo->buf32bit)	FREE_ARRAY(mo->bufIn)	FREE_ARRAY(mo->OutFilename)	FREE_ARRAY(mo->InFilename)	GlobalUnlock(hOutput);	GlobalFree(hOutput);}// *********************************************************************************************//									Utilities// *********************************************************************************************char *Cfaac::getSourceFilename(char *path, char *src, char *ext){char	*dst, chExt,		*pname, *pext;	if(!src)		return NULL;	if(!path)		path="";	if(!ext)		ext="";	pname=pext=src+strlen(src);	while(pname!=src && *pname!='\\' && *pname!='/')		pname--;	if(*pname=='\\' || *pname=='/')		pname++;	while(pext!=src && *pext!='.')		pext--;	chExt=*pext;	if(chExt=='.')		*pext='\0';	if(*path)	{	int l;		if(!(dst=(char *)malloc(strlen(path)+strlen(pname)+strlen(ext)+3))) // '\0','\\','.'			return dst;		l=strlen(path);		if(l>0 && path[l-1]=='\\')			sprintf(dst,"%s%s.%s",path,pname,ext);		else			sprintf(dst,"%s\\%s.%s",path,pname,ext);	}	else	{		if(!(dst=(char *)malloc(strlen(pname)+strlen(ext)+2)))			return dst;		sprintf(dst,"%s.%s",pname,ext);	}	*pext=chExt;	if(!strcmpi(src,dst))	{//		if(!dontAskGetFilename)		{		char buf[MAX_PATH+100];			sprintf(buf,"%s\nSource file=Destination file...aborting!\n\n\tSuppress this warning?",dst);//			if(MessageBox(NULL,buf,NULL,MB_YESNO)==IDYES)//				dontAskGetFilename=true;		}		FREE_ARRAY(dst);		return NULL;	}	return dst;}// *********************************************************************************************#define SWAP32(x) (((x & 0xff) << 24) | ((x & 0xff00) << 8) \	| ((x & 0xff0000) >> 8) | ((x & 0xff000000) >> 24))#define SWAP16(x) (((x & 0xff) << 8) | ((x & 0xff00) >> 8))void Cfaac::To32bit(int32_t *buf, BYTE *bufi, int size, BYTE samplebytes, BYTE bigendian){int i;	switch(samplebytes)	{	case 1:		// this is endian clean		for (i = 0; i < size; i++)			buf[i] = (bufi[i] - 128) * 65536;		break;			case 2:#ifdef WORDS_BIGENDIAN		if (!bigendian)#else			if (bigendian)#endif			{				// swap bytes				for (i = 0; i < size; i++)				{					int16_t s = ((int16_t *)bufi)[i];										s = SWAP16(s);										buf[i] = ((u_int32_t)s) << 8;				}			}			else			{				// no swap				for (i = 0; i < size; i++)				{					int s = ((int16_t *)bufi)[i];										buf[i] = s << 8;				}			}			break;				case 3:		if (!bigendian)		{			for (i = 0; i < size; i++)			{				int s = bufi[3 * i] | (bufi[3 * i + 1] << 8) | (bufi[3 * i + 2] << 16);								// fix sign				if (s & 0x800000)					s |= 0xff000000;								buf[i] = s;			}		}		else // big endian input		{			for (i = 0; i < size; i++)			{				int s = (bufi[3 * i] << 16) | (bufi[3 * i + 1] << 8) | bufi[3 * i + 2];								// fix sign				if (s & 0x800000)					s |= 0xff000000;								buf[i] = s;			}		}		break;			case 4:		#ifdef WORDS_BIGENDIAN		if (!bigendian)#else			if (bigendian)

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -