svn merge -r39781:39792 https://svn.blender.org/svnroot/bf-blender/trunk/blender...
[blender-staging.git] / intern / audaspace / intern / AUD_Mixer.cpp
1 /*
2  * $Id$
3  *
4  * ***** BEGIN GPL LICENSE BLOCK *****
5  *
6  * Copyright 2009-2011 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 General Public License as published by
12  * the Free Software Foundation; either version 2 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 General Public License for more details.
19  *
20  * You should have received a copy of the GNU General Public License
21  * along with Audaspace; if not, write to the Free Software Foundation,
22  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
23  *
24  * ***** END GPL LICENSE BLOCK *****
25  */
26
27 /** \file audaspace/intern/AUD_Mixer.cpp
28  *  \ingroup audaspaceintern
29  */
30
31
32 #include "AUD_Mixer.h"
33 #include "AUD_IReader.h"
34
35 #include <cstring>
36
37 AUD_Mixer::AUD_Mixer(AUD_DeviceSpecs specs) :
38         m_specs(specs)
39 {
40         int bigendian = 1;
41         bigendian = (((char*)&bigendian)[0]) ? 0: 1; // 1 if Big Endian
42
43         switch(m_specs.format)
44         {
45         case AUD_FORMAT_U8:
46                 m_convert = AUD_convert_float_u8;
47                 break;
48         case AUD_FORMAT_S16:
49                 m_convert = AUD_convert_float_s16;
50                 break;
51         case AUD_FORMAT_S24:
52                 if(bigendian)
53                         m_convert = AUD_convert_float_s24_be;
54                 else
55                         m_convert = AUD_convert_float_s24_le;
56                 break;
57         case AUD_FORMAT_S32:
58                 m_convert = AUD_convert_float_s32;
59                 break;
60         case AUD_FORMAT_FLOAT32:
61                 m_convert = AUD_convert_copy<float>;
62                 break;
63         case AUD_FORMAT_FLOAT64:
64                 m_convert = AUD_convert_float_double;
65                 break;
66         default:
67                 break;
68         }
69 }
70
71 AUD_DeviceSpecs AUD_Mixer::getSpecs() const
72 {
73         return m_specs;
74 }
75
76 void AUD_Mixer::setSpecs(AUD_Specs specs)
77 {
78         m_specs.specs = specs;
79 }
80
81 void AUD_Mixer::clear(int length)
82 {
83         m_buffer.assureSize(length * m_specs.channels * AUD_SAMPLE_SIZE(m_specs));
84
85         m_length = length;
86
87         memset(m_buffer.getBuffer(), 0, length * m_specs.channels * AUD_SAMPLE_SIZE(m_specs));
88 }
89
90 void AUD_Mixer::mix(sample_t* buffer, int start, int length, float volume)
91 {
92         sample_t* out = m_buffer.getBuffer();
93
94         length = (AUD_MIN(m_length, length + start) - start) * m_specs.channels;
95         start *= m_specs.channels;
96
97         for(int i = 0; i < length; i++)
98                 out[i + start] += buffer[i] * volume;
99 }
100
101 void AUD_Mixer::read(data_t* buffer, float volume)
102 {
103         sample_t* out = m_buffer.getBuffer();
104
105         for(int i = 0; i < m_length * m_specs.channels; i++)
106                 out[i] *= volume;
107
108         m_convert(buffer, (data_t*) out, m_length * m_specs.channels);
109 }