6c7ea6e0a01204db216ec5d6eb8650505f413c1f
[blender-staging.git] / intern / audaspace / FX / AUD_FaderReader.cpp
1 /*
2  * $Id$
3  *
4  * ***** BEGIN LGPL LICENSE BLOCK *****
5  *
6  * Copyright 2009 Jörg Hermann Müller
7  *
8  * This file is part of AudaSpace.
9  *
10  * AudaSpace is free software: you can redistribute it and/or modify
11  * it under the terms of the GNU Lesser General Public License as published by
12  * the Free Software Foundation, either version 3 of the License, or
13  * (at your option) any later version.
14  *
15  * AudaSpace is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU Lesser General Public License for more details.
19  *
20  * You should have received a copy of the GNU Lesser General Public License
21  * along with AudaSpace.  If not, see <http://www.gnu.org/licenses/>.
22  *
23  * ***** END LGPL LICENSE BLOCK *****
24  */
25
26 #include "AUD_FaderReader.h"
27 #include "AUD_Buffer.h"
28
29 #include <cstring>
30
31 AUD_FaderReader::AUD_FaderReader(AUD_IReader* reader, AUD_FadeType type,
32                                                                  float start,float length) :
33                 AUD_EffectReader(reader),
34                 m_type(type),
35                 m_start(start),
36                 m_length(length)
37 {
38         m_buffer = new AUD_Buffer(); AUD_NEW("buffer")
39 }
40
41 AUD_FaderReader::~AUD_FaderReader()
42 {
43         delete m_buffer; AUD_DELETE("buffer")
44 }
45
46 bool AUD_FaderReader::notify(AUD_Message &message)
47 {
48         return m_reader->notify(message);
49 }
50
51 void AUD_FaderReader::read(int & length, sample_t* & buffer)
52 {
53         int position = m_reader->getPosition();
54         AUD_Specs specs = m_reader->getSpecs();
55         int samplesize = AUD_SAMPLE_SIZE(specs);
56
57         m_reader->read(length, buffer);
58
59         if(m_buffer->getSize() < length * samplesize)
60                 m_buffer->resize(length * samplesize);
61
62         if((position + length) / (float)specs.rate <= m_start)
63         {
64                 if(m_type != AUD_FADE_OUT)
65                 {
66                         buffer = m_buffer->getBuffer();
67                         memset(buffer, 0, length * samplesize);
68                 }
69         }
70         else if(position / (float)specs.rate >= m_start+m_length)
71         {
72                 if(m_type == AUD_FADE_OUT)
73                 {
74                         buffer = m_buffer->getBuffer();
75                         memset(buffer, 0, length * samplesize);
76                 }
77         }
78         else
79         {
80                 sample_t* buf = m_buffer->getBuffer();
81                 float volume;
82
83                 for(int i = 0; i < length * specs.channels; i++)
84                 {
85                         if(i % specs.channels == 0)
86                         {
87                                 volume = (((position+i)/(float)specs.rate)-m_start) / m_length;
88                                 if(volume > 1.0f)
89                                         volume = 1.0f;
90                                 else if(volume < 0.0f)
91                                         volume = 0.0f;
92
93                                 if(m_type == AUD_FADE_OUT)
94                                         volume = 1.0f - volume;
95                         }
96
97                         buf[i] = buffer[i] * volume;
98                 }
99
100                 buffer = buf;
101         }
102 }