Blender  V2.59
AUD_SinusReader.cpp
Go to the documentation of this file.
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 }