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

📄 samplebuffer.cpp

📁 改写的qtopia录音放音程序
💻 CPP
字号:
/************************************************************************ Copyright (C) 2000-2002 Trolltech AS.  All rights reserved.**** This file is part of the Qtopia Environment.**** This file may be distributed and/or modified under the terms of the** GNU General Public License version 2 as published by the Free Software** Foundation and appearing in the file LICENSE.GPL included in the** packaging of this file.**** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.**** See http://www.trolltech.com/gpl/ for GPL licensing information.**** Contact info@trolltech.com if any conditions of this licensing are** not clear to you.************************************************************************/#include <stdlib.h>#include "samplebuffer.h"SampleBuffer::SampleBuffer( unsigned int _blockSize, unsigned int _maxBlocks ){    blockSize = _blockSize;    maxBlocks = _maxBlocks;    init();}SampleBuffer::~SampleBuffer(){    clearAll();}bool SampleBuffer::nextWriteBuffer( short *& buf, unsigned int& length ){    if ( writePosn ) {	buf = writePosn->data;	length = blockSize;	return TRUE;    } else {	// The sample buffer ran out of memory or reached the block limit.	return FALSE;    }}void SampleBuffer::commitWriteBuffer ( unsigned int length ){    // Bail out if nothing to commit.    if ( !writePosn || !length )	return;    // Update the current block size.    writePosn->size = length;    // Allocate space for the next block.    if ( !maxBlocks || numBlocks < maxBlocks ) {	BufferBlock *block;	block = (BufferBlock *)malloc( sizeof(BufferBlock) +				       ( blockSize - 1 ) * sizeof( short ) );	if ( block ) {	    writePosn->next = block;	    block->next = 0;	    block->size = 0;	    writePosn = block;	    ++numBlocks;	} else {	    // The process is out of memory.	    writePosn = 0;	}    } else {	// We've reached the maximum block limit.	writePosn = 0;    }}void SampleBuffer::rewind(){    readPosn = first;}bool SampleBuffer::nextReadBuffer( short *& buf, unsigned int& length ){    while ( readPosn ) {	buf = readPosn->data;	length = readPosn->size;	readPosn = readPosn->next;	if ( length > 0 )	    return TRUE;    }    return FALSE;}void SampleBuffer::clear(){    clearAll();    init();}void SampleBuffer::init(){    first = (BufferBlock *)malloc( sizeof(BufferBlock) +				   ( blockSize - 1 ) * sizeof( short ) );    readPosn = first;    writePosn = first;    if ( first ) {	first->next = 0;	first->size = 0;	numBlocks = 1;    } else {	numBlocks = 0;    }}void SampleBuffer::clearAll(){    BufferBlock *block, *next;    block = first;    while ( block ) {	next = block->next;	free( block );	block = next;    }    first = 0;    readPosn = 0;    writePosn = 0;    numBlocks = 0;}

⌨️ 快捷键说明

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