OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2010, Google Inc. All rights reserved. | 2 * Copyright (C) 2010, Google Inc. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions | 5 * modification, are permitted provided that the following conditions |
6 * are met: | 6 * are met: |
7 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
(...skipping 18 matching lines...) Expand all Loading... |
29 #include <algorithm> | 29 #include <algorithm> |
30 #include <cmath> | 30 #include <cmath> |
31 | 31 |
32 namespace blink { | 32 namespace blink { |
33 | 33 |
34 EqualPowerPanner::EqualPowerPanner(float sampleRate) | 34 EqualPowerPanner::EqualPowerPanner(float sampleRate) |
35 : Panner(PanningModelEqualPower) | 35 : Panner(PanningModelEqualPower) |
36 { | 36 { |
37 } | 37 } |
38 | 38 |
39 void EqualPowerPanner::pan(double azimuth, double /*elevation*/, const AudioBus*
inputBus, AudioBus* outputBus, size_t framesToProcess) | 39 void EqualPowerPanner::pan(double azimuth, double /*elevation*/, const AudioBus*
inputBus, AudioBus* outputBus, size_t framesToProcess, AudioBus::ChannelInterpr
etation) |
40 { | 40 { |
41 bool isInputSafe = inputBus && (inputBus->numberOfChannels() == 1 || inputBu
s->numberOfChannels() == 2) && framesToProcess <= inputBus->length(); | 41 bool isInputSafe = inputBus && (inputBus->numberOfChannels() == 1 || inputBu
s->numberOfChannels() == 2) && framesToProcess <= inputBus->length(); |
42 ASSERT(isInputSafe); | 42 ASSERT(isInputSafe); |
43 if (!isInputSafe) | 43 if (!isInputSafe) |
44 return; | 44 return; |
45 | 45 |
46 unsigned numberOfInputChannels = inputBus->numberOfChannels(); | 46 unsigned numberOfInputChannels = inputBus->numberOfChannels(); |
47 | 47 |
48 bool isOutputSafe = outputBus && outputBus->numberOfChannels() == 2 && frame
sToProcess <= outputBus->length(); | 48 bool isOutputSafe = outputBus && outputBus->numberOfChannels() == 2 && frame
sToProcess <= outputBus->length(); |
49 ASSERT(isOutputSafe); | 49 ASSERT(isOutputSafe); |
(...skipping 96 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
146 // sourceR -> destR and "equal-power pan" sourceL as in mono case | 146 // sourceR -> destR and "equal-power pan" sourceL as in mono case |
147 // by transforming the "azimuth" value from 0 -> +90 degrees into th
e range -90 -> +90. | 147 // by transforming the "azimuth" value from 0 -> +90 degrees into th
e range -90 -> +90. |
148 desiredPanPosition = azimuth / 90; | 148 desiredPanPosition = azimuth / 90; |
149 } | 149 } |
150 } | 150 } |
151 | 151 |
152 desiredGainL = std::cos(piOverTwoDouble * desiredPanPosition); | 152 desiredGainL = std::cos(piOverTwoDouble * desiredPanPosition); |
153 desiredGainR = std::sin(piOverTwoDouble * desiredPanPosition); | 153 desiredGainR = std::sin(piOverTwoDouble * desiredPanPosition); |
154 } | 154 } |
155 | 155 |
156 void EqualPowerPanner::panWithSampleAccurateValues(double* azimuth, double* /*el
evation*/, const AudioBus* inputBus, AudioBus* outputBus, size_t framesToProcess
) | 156 void EqualPowerPanner::panWithSampleAccurateValues(double* azimuth, double* /*el
evation*/, const AudioBus* inputBus, AudioBus* outputBus, size_t framesToProcess
, AudioBus::ChannelInterpretation) |
157 { | 157 { |
158 bool isInputSafe = inputBus && (inputBus->numberOfChannels() == 1 || inputBu
s->numberOfChannels() == 2) && framesToProcess <= inputBus->length(); | 158 bool isInputSafe = inputBus && (inputBus->numberOfChannels() == 1 || inputBu
s->numberOfChannels() == 2) && framesToProcess <= inputBus->length(); |
159 DCHECK(isInputSafe); | 159 DCHECK(isInputSafe); |
160 if (!isInputSafe) | 160 if (!isInputSafe) |
161 return; | 161 return; |
162 | 162 |
163 unsigned numberOfInputChannels = inputBus->numberOfChannels(); | 163 unsigned numberOfInputChannels = inputBus->numberOfChannels(); |
164 | 164 |
165 bool isOutputSafe = outputBus && outputBus->numberOfChannels() == 2 && frame
sToProcess <= outputBus->length(); | 165 bool isOutputSafe = outputBus && outputBus->numberOfChannels() == 2 && frame
sToProcess <= outputBus->length(); |
166 DCHECK(isOutputSafe); | 166 DCHECK(isOutputSafe); |
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
203 float inputR = *sourceR++; | 203 float inputR = *sourceR++; |
204 *destinationL++ = static_cast<float>(inputL * desiredGainL); | 204 *destinationL++ = static_cast<float>(inputL * desiredGainL); |
205 *destinationR++ = static_cast<float>(inputR + inputL * desiredGa
inR); | 205 *destinationR++ = static_cast<float>(inputR + inputL * desiredGa
inR); |
206 } | 206 } |
207 } | 207 } |
208 } | 208 } |
209 } | 209 } |
210 | 210 |
211 } // namespace blink | 211 } // namespace blink |
212 | 212 |
OLD | NEW |