|
Blender
V2.59
|
00001 /* 00002 * $Id: AUD_SinusReader.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_SinusReader.h" 00033 00034 #include <cmath> 00035 00036 #ifndef M_PI 00037 #define M_PI 3.14159265358979323846 00038 #endif 00039 00040 AUD_SinusReader::AUD_SinusReader(float frequency, AUD_SampleRate sampleRate) : 00041 m_frequency(frequency), 00042 m_position(0), 00043 m_sampleRate(sampleRate) 00044 { 00045 } 00046 00047 bool AUD_SinusReader::isSeekable() const 00048 { 00049 return true; 00050 } 00051 00052 void AUD_SinusReader::seek(int position) 00053 { 00054 m_position = position; 00055 } 00056 00057 int AUD_SinusReader::getLength() const 00058 { 00059 return -1; 00060 } 00061 00062 int AUD_SinusReader::getPosition() const 00063 { 00064 return m_position; 00065 } 00066 00067 AUD_Specs AUD_SinusReader::getSpecs() const 00068 { 00069 AUD_Specs specs; 00070 specs.rate = m_sampleRate; 00071 specs.channels = AUD_CHANNELS_MONO; 00072 return specs; 00073 } 00074 00075 void AUD_SinusReader::read(int & length, sample_t* & buffer) 00076 { 00077 // resize if necessary 00078 if(m_buffer.getSize() < length * sizeof(sample_t)) 00079 m_buffer.resize(length * sizeof(sample_t)); 00080 00081 // fill with sine data 00082 buffer = m_buffer.getBuffer(); 00083 for(int i = 0; i < length; i++) 00084 { 00085 buffer[i] = sin((m_position + i) * 2 * M_PI * m_frequency / 00086 (float)m_sampleRate); 00087 } 00088 00089 m_position += length; 00090 }