|
Blender
V2.59
|
00001 /* 00002 * $Id: AUD_BufferReader.cpp 35141 2011-02-25 10:21:56Z jesterking $ 00003 * 00004 * ***** BEGIN GPL LICENSE BLOCK ***** 00005 * 00006 * Copyright 2009-2011 Jörg Hermann Müller 00007 * 00008 * This file is part of AudaSpace. 00009 * 00010 * Audaspace is free software; you can redistribute it and/or modify 00011 * it under the terms of the GNU General Public License as published by 00012 * the Free Software Foundation; either version 2 of the License, or 00013 * (at your option) any later version. 00014 * 00015 * AudaSpace is distributed in the hope that it will be useful, 00016 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00017 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00018 * GNU General Public License for more details. 00019 * 00020 * You should have received a copy of the GNU General Public License 00021 * along with Audaspace; if not, write to the Free Software Foundation, 00022 * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. 00023 * 00024 * ***** END GPL LICENSE BLOCK ***** 00025 */ 00026 00032 #include "AUD_BufferReader.h" 00033 #include "AUD_Buffer.h" 00034 #include "AUD_Space.h" 00035 00036 AUD_BufferReader::AUD_BufferReader(AUD_Reference<AUD_Buffer> buffer, 00037 AUD_Specs specs) : 00038 m_position(0), m_buffer(buffer), m_specs(specs) 00039 { 00040 } 00041 00042 bool AUD_BufferReader::isSeekable() const 00043 { 00044 return true; 00045 } 00046 00047 void AUD_BufferReader::seek(int position) 00048 { 00049 m_position = position; 00050 } 00051 00052 int AUD_BufferReader::getLength() const 00053 { 00054 return m_buffer.get()->getSize() / AUD_SAMPLE_SIZE(m_specs); 00055 } 00056 00057 int AUD_BufferReader::getPosition() const 00058 { 00059 return m_position; 00060 } 00061 00062 AUD_Specs AUD_BufferReader::getSpecs() const 00063 { 00064 return m_specs; 00065 } 00066 00067 void AUD_BufferReader::read(int & length, sample_t* & buffer) 00068 { 00069 int sample_size = AUD_SAMPLE_SIZE(m_specs); 00070 00071 buffer = m_buffer.get()->getBuffer() + m_position * m_specs.channels; 00072 00073 // in case the end of the buffer is reached 00074 if(m_buffer.get()->getSize() < (m_position + length) * sample_size) 00075 length = m_buffer.get()->getSize() / sample_size - m_position; 00076 00077 if(length < 0) 00078 length = 0; 00079 m_position += length; 00080 }