react-native-audio-api 0.8.3-nightly-ea268f4-20251006 → 0.8.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +39 -40
- package/RNAudioAPI.podspec +12 -17
- package/android/build.gradle +4 -44
- package/android/src/main/cpp/audioapi/CMakeLists.txt +0 -65
- package/android/src/main/cpp/audioapi/android/AudioAPIModule.cpp +1 -29
- package/android/src/main/cpp/audioapi/android/AudioAPIModule.h +0 -14
- package/android/src/main/cpp/audioapi/android/core/AndroidAudioRecorder.cpp +1 -7
- package/android/src/main/cpp/audioapi/android/core/AndroidAudioRecorder.h +1 -6
- package/android/src/main/cpp/audioapi/android/core/AudioPlayer.cpp +1 -1
- package/android/src/main/java/com/swmansion/audioapi/AudioAPIModule.kt +1 -11
- package/android/src/main/java/com/swmansion/audioapi/system/MediaSessionManager.kt +2 -15
- package/common/cpp/audioapi/AudioAPIModuleInstaller.h +18 -53
- package/common/cpp/audioapi/HostObjects/AnalyserNodeHostObject.h +149 -0
- package/common/cpp/audioapi/HostObjects/AudioBufferBaseSourceNodeHostObject.h +76 -0
- package/common/cpp/audioapi/HostObjects/AudioBufferHostObject.h +120 -0
- package/common/cpp/audioapi/HostObjects/AudioBufferQueueSourceNodeHostObject.h +67 -0
- package/common/cpp/audioapi/HostObjects/AudioBufferSourceNodeHostObject.h +142 -0
- package/common/cpp/audioapi/HostObjects/AudioContextHostObject.h +46 -6
- package/common/cpp/audioapi/HostObjects/AudioNodeHostObject.cpp +6 -70
- package/common/cpp/audioapi/HostObjects/AudioNodeHostObject.h +66 -10
- package/common/cpp/audioapi/HostObjects/AudioParamHostObject.h +91 -17
- package/common/cpp/audioapi/HostObjects/AudioRecorderHostObject.h +86 -0
- package/common/cpp/audioapi/HostObjects/AudioScheduledSourceNodeHostObject.h +56 -0
- package/common/cpp/audioapi/HostObjects/BaseAudioContextHostObject.cpp +6 -362
- package/common/cpp/audioapi/HostObjects/BaseAudioContextHostObject.h +241 -29
- package/common/cpp/audioapi/HostObjects/BiquadFilterNodeHostObject.h +89 -0
- package/common/cpp/audioapi/HostObjects/GainNodeHostObject.h +27 -0
- package/common/cpp/audioapi/HostObjects/OfflineAudioContextHostObject.h +50 -6
- package/common/cpp/audioapi/HostObjects/OscillatorNodeHostObject.h +65 -0
- package/common/cpp/audioapi/HostObjects/{sources/RecorderAdapterNodeHostObject.h → RecorderAdapterNodeHostObject.h} +2 -1
- package/common/cpp/audioapi/HostObjects/StereoPannerNodeHostObject.h +29 -0
- package/common/cpp/audioapi/HostObjects/StreamerNodeHostObject.h +30 -0
- package/common/cpp/audioapi/core/AudioContext.cpp +2 -3
- package/common/cpp/audioapi/core/AudioContext.h +1 -2
- package/common/cpp/audioapi/core/AudioNode.h +1 -1
- package/common/cpp/audioapi/core/AudioParam.cpp +2 -2
- package/common/cpp/audioapi/core/AudioParam.h +1 -1
- package/common/cpp/audioapi/core/{utils/AudioParamEventQueue.cpp → AudioParamEventQueue.cpp} +7 -13
- package/common/cpp/audioapi/core/BaseAudioContext.cpp +3 -47
- package/common/cpp/audioapi/core/BaseAudioContext.h +4 -13
- package/common/cpp/audioapi/core/{utils/Constants.h → Constants.h} +0 -5
- package/common/cpp/audioapi/core/OfflineAudioContext.cpp +3 -4
- package/common/cpp/audioapi/core/OfflineAudioContext.h +1 -2
- package/common/cpp/audioapi/core/effects/PeriodicWave.cpp +1 -1
- package/common/cpp/audioapi/core/effects/StereoPannerNode.cpp +1 -1
- package/common/cpp/audioapi/core/inputs/AudioRecorder.cpp +1 -1
- package/common/cpp/audioapi/core/inputs/AudioRecorder.h +2 -2
- package/common/cpp/audioapi/core/sources/AudioBufferBaseSourceNode.cpp +10 -47
- package/common/cpp/audioapi/core/sources/AudioBufferBaseSourceNode.h +3 -18
- package/common/cpp/audioapi/core/sources/AudioBufferQueueSourceNode.cpp +12 -94
- package/common/cpp/audioapi/core/sources/AudioBufferQueueSourceNode.h +2 -8
- package/common/cpp/audioapi/core/sources/AudioBufferSourceNode.cpp +42 -33
- package/common/cpp/audioapi/core/sources/AudioBufferSourceNode.h +8 -6
- package/common/cpp/audioapi/core/sources/AudioScheduledSourceNode.cpp +6 -1
- package/common/cpp/audioapi/core/sources/AudioScheduledSourceNode.h +1 -1
- package/common/cpp/audioapi/core/sources/StreamerNode.h +8 -0
- package/common/cpp/audioapi/dsp/Windows.cpp +1 -1
- package/common/cpp/audioapi/events/AudioEventHandlerRegistry.cpp +1 -1
- package/common/cpp/audioapi/events/AudioEventHandlerRegistry.h +1 -2
- package/common/cpp/audioapi/events/AudioEventHandlerRegistryHostObject.h +48 -0
- package/common/cpp/audioapi/jsi/AudioArrayBuffer.h +1 -14
- package/common/cpp/audioapi/jsi/JsiHostObject.h +12 -6
- package/common/cpp/audioapi/jsi/JsiPromise.cpp +0 -49
- package/common/cpp/audioapi/jsi/JsiPromise.h +1 -29
- package/common/cpp/audioapi/utils/AudioBus.cpp +1 -1
- package/common/cpp/test/CMakeLists.txt +3 -11
- package/common/cpp/test/GainTest.cpp +1 -2
- package/common/cpp/test/OscillatorTest.cpp +1 -2
- package/ios/audioapi/ios/AudioAPIModule.mm +5 -32
- package/ios/audioapi/ios/core/IOSAudioPlayer.mm +1 -1
- package/ios/audioapi/ios/core/IOSAudioRecorder.h +1 -2
- package/ios/audioapi/ios/core/IOSAudioRecorder.mm +1 -1
- package/ios/audioapi/ios/events/IOSAudioEventHandlerRegistry.h +7 -0
- package/ios/audioapi/ios/events/IOSAudioEventHandlerRegistry.mm +12 -0
- package/lib/commonjs/api.js +2 -36
- package/lib/commonjs/api.js.map +1 -1
- package/lib/commonjs/api.web.js +0 -8
- package/lib/commonjs/api.web.js.map +1 -1
- package/lib/commonjs/core/AudioBufferBaseSourceNode.js +7 -7
- package/lib/commonjs/core/AudioBufferBaseSourceNode.js.map +1 -1
- package/lib/commonjs/core/AudioBufferQueueSourceNode.js +6 -1
- package/lib/commonjs/core/AudioBufferQueueSourceNode.js.map +1 -1
- package/lib/commonjs/core/AudioBufferSourceNode.js +0 -15
- package/lib/commonjs/core/AudioBufferSourceNode.js.map +1 -1
- package/lib/commonjs/core/AudioContext.js +1 -10
- package/lib/commonjs/core/AudioContext.js.map +1 -1
- package/lib/commonjs/core/AudioScheduledSourceNode.js +4 -4
- package/lib/commonjs/core/AudioScheduledSourceNode.js.map +1 -1
- package/lib/commonjs/core/BaseAudioContext.js +11 -66
- package/lib/commonjs/core/BaseAudioContext.js.map +1 -1
- package/lib/commonjs/core/OfflineAudioContext.js +2 -11
- package/lib/commonjs/core/OfflineAudioContext.js.map +1 -1
- package/lib/commonjs/core/OscillatorNode.js +0 -6
- package/lib/commonjs/core/OscillatorNode.js.map +1 -1
- package/lib/commonjs/hooks/{useSystemVolume.js → useSytemVolume.js} +1 -1
- package/lib/commonjs/hooks/useSytemVolume.js.map +1 -0
- package/lib/commonjs/utils/index.js +0 -9
- package/lib/commonjs/utils/index.js.map +1 -1
- package/lib/commonjs/web-core/AudioContext.js +0 -4
- package/lib/commonjs/web-core/AudioContext.js.map +1 -1
- package/lib/commonjs/web-core/AudioScheduledSourceNode.js +1 -1
- package/lib/commonjs/web-core/AudioScheduledSourceNode.js.map +1 -1
- package/lib/commonjs/web-core/OfflineAudioContext.js +0 -4
- package/lib/commonjs/web-core/OfflineAudioContext.js.map +1 -1
- package/lib/module/api.js +2 -6
- package/lib/module/api.js.map +1 -1
- package/lib/module/api.web.js +0 -1
- package/lib/module/api.web.js.map +1 -1
- package/lib/module/core/AudioBufferBaseSourceNode.js +7 -7
- package/lib/module/core/AudioBufferBaseSourceNode.js.map +1 -1
- package/lib/module/core/AudioBufferQueueSourceNode.js +6 -1
- package/lib/module/core/AudioBufferQueueSourceNode.js.map +1 -1
- package/lib/module/core/AudioBufferSourceNode.js +0 -15
- package/lib/module/core/AudioBufferSourceNode.js.map +1 -1
- package/lib/module/core/AudioContext.js +1 -10
- package/lib/module/core/AudioContext.js.map +1 -1
- package/lib/module/core/AudioScheduledSourceNode.js +4 -4
- package/lib/module/core/AudioScheduledSourceNode.js.map +1 -1
- package/lib/module/core/BaseAudioContext.js +11 -66
- package/lib/module/core/BaseAudioContext.js.map +1 -1
- package/lib/module/core/OfflineAudioContext.js +2 -11
- package/lib/module/core/OfflineAudioContext.js.map +1 -1
- package/lib/module/core/OscillatorNode.js +0 -6
- package/lib/module/core/OscillatorNode.js.map +1 -1
- package/lib/module/hooks/{useSystemVolume.js → useSytemVolume.js} +1 -1
- package/lib/module/hooks/useSytemVolume.js.map +1 -0
- package/lib/module/utils/index.js +0 -8
- package/lib/module/utils/index.js.map +1 -1
- package/lib/module/web-core/AudioContext.js +0 -4
- package/lib/module/web-core/AudioContext.js.map +1 -1
- package/lib/module/web-core/AudioScheduledSourceNode.js +1 -1
- package/lib/module/web-core/AudioScheduledSourceNode.js.map +1 -1
- package/lib/module/web-core/OfflineAudioContext.js +0 -4
- package/lib/module/web-core/OfflineAudioContext.js.map +1 -1
- package/lib/typescript/api.d.ts +4 -8
- package/lib/typescript/api.d.ts.map +1 -1
- package/lib/typescript/api.web.d.ts +0 -1
- package/lib/typescript/api.web.d.ts.map +1 -1
- package/lib/typescript/core/AudioBufferBaseSourceNode.d.ts +2 -2
- package/lib/typescript/core/AudioBufferBaseSourceNode.d.ts.map +1 -1
- package/lib/typescript/core/AudioBufferQueueSourceNode.d.ts +1 -1
- package/lib/typescript/core/AudioBufferQueueSourceNode.d.ts.map +1 -1
- package/lib/typescript/core/AudioBufferSourceNode.d.ts +0 -4
- package/lib/typescript/core/AudioBufferSourceNode.d.ts.map +1 -1
- package/lib/typescript/core/AudioContext.d.ts +0 -1
- package/lib/typescript/core/AudioContext.d.ts.map +1 -1
- package/lib/typescript/core/AudioScheduledSourceNode.d.ts +1 -1
- package/lib/typescript/core/BaseAudioContext.d.ts +11 -19
- package/lib/typescript/core/BaseAudioContext.d.ts.map +1 -1
- package/lib/typescript/core/OfflineAudioContext.d.ts +0 -1
- package/lib/typescript/core/OfflineAudioContext.d.ts.map +1 -1
- package/lib/typescript/core/OscillatorNode.d.ts +0 -3
- package/lib/typescript/core/OscillatorNode.d.ts.map +1 -1
- package/lib/typescript/events/types.d.ts +0 -2
- package/lib/typescript/events/types.d.ts.map +1 -1
- package/lib/typescript/hooks/{useSystemVolume.d.ts → useSytemVolume.d.ts} +1 -1
- package/lib/typescript/hooks/useSytemVolume.d.ts.map +1 -0
- package/lib/typescript/interfaces.d.ts +3 -21
- package/lib/typescript/interfaces.d.ts.map +1 -1
- package/lib/typescript/types.d.ts +1 -2
- package/lib/typescript/types.d.ts.map +1 -1
- package/lib/typescript/utils/index.d.ts +0 -8
- package/lib/typescript/utils/index.d.ts.map +1 -1
- package/lib/typescript/web-core/AudioBufferSourceNode.d.ts +1 -1
- package/lib/typescript/web-core/AudioContext.d.ts +2 -4
- package/lib/typescript/web-core/AudioContext.d.ts.map +1 -1
- package/lib/typescript/web-core/AudioScheduledSourceNode.d.ts +1 -1
- package/lib/typescript/web-core/BaseAudioContext.d.ts +0 -2
- package/lib/typescript/web-core/BaseAudioContext.d.ts.map +1 -1
- package/lib/typescript/web-core/OfflineAudioContext.d.ts +2 -4
- package/lib/typescript/web-core/OfflineAudioContext.d.ts.map +1 -1
- package/package.json +2 -3
- package/src/api.ts +3 -12
- package/src/api.web.ts +0 -1
- package/src/core/AudioBufferBaseSourceNode.ts +9 -9
- package/src/core/AudioBufferQueueSourceNode.ts +9 -1
- package/src/core/AudioBufferSourceNode.ts +0 -28
- package/src/core/AudioContext.ts +1 -12
- package/src/core/AudioScheduledSourceNode.ts +5 -5
- package/src/core/BaseAudioContext.ts +13 -149
- package/src/core/OfflineAudioContext.ts +2 -18
- package/src/core/OscillatorNode.ts +0 -11
- package/src/events/types.ts +0 -2
- package/src/interfaces.ts +5 -59
- package/src/types.ts +1 -3
- package/src/utils/index.ts +0 -21
- package/src/web-core/AudioBufferSourceNode.tsx +1 -1
- package/src/web-core/AudioContext.tsx +2 -7
- package/src/web-core/AudioScheduledSourceNode.tsx +1 -1
- package/src/web-core/BaseAudioContext.tsx +0 -2
- package/src/web-core/OfflineAudioContext.tsx +2 -7
- package/android/src/main/cpp/audioapi/android/core/NativeAudioRecorder.hpp +0 -36
- package/android/src/main/java/com/swmansion/audioapi/core/NativeAudioRecorder.kt +0 -24
- package/common/cpp/audioapi/HostObjects/AudioContextHostObject.cpp +0 -57
- package/common/cpp/audioapi/HostObjects/AudioParamHostObject.cpp +0 -105
- package/common/cpp/audioapi/HostObjects/OfflineAudioContextHostObject.cpp +0 -70
- package/common/cpp/audioapi/HostObjects/WorkletNodeHostObject.h +0 -18
- package/common/cpp/audioapi/HostObjects/WorkletProcessingNodeHostObject.h +0 -18
- package/common/cpp/audioapi/HostObjects/analysis/AnalyserNodeHostObject.cpp +0 -148
- package/common/cpp/audioapi/HostObjects/analysis/AnalyserNodeHostObject.h +0 -37
- package/common/cpp/audioapi/HostObjects/effects/BiquadFilterNodeHostObject.cpp +0 -92
- package/common/cpp/audioapi/HostObjects/effects/BiquadFilterNodeHostObject.h +0 -29
- package/common/cpp/audioapi/HostObjects/effects/GainNodeHostObject.cpp +0 -20
- package/common/cpp/audioapi/HostObjects/effects/GainNodeHostObject.h +0 -19
- package/common/cpp/audioapi/HostObjects/effects/StereoPannerNodeHostObject.cpp +0 -21
- package/common/cpp/audioapi/HostObjects/effects/StereoPannerNodeHostObject.h +0 -21
- package/common/cpp/audioapi/HostObjects/events/AudioEventHandlerRegistryHostObject.cpp +0 -41
- package/common/cpp/audioapi/HostObjects/events/AudioEventHandlerRegistryHostObject.h +0 -28
- package/common/cpp/audioapi/HostObjects/inputs/AudioRecorderHostObject.cpp +0 -69
- package/common/cpp/audioapi/HostObjects/inputs/AudioRecorderHostObject.h +0 -33
- package/common/cpp/audioapi/HostObjects/sources/AudioBufferBaseSourceNodeHostObject.cpp +0 -73
- package/common/cpp/audioapi/HostObjects/sources/AudioBufferBaseSourceNodeHostObject.h +0 -29
- package/common/cpp/audioapi/HostObjects/sources/AudioBufferHostObject.cpp +0 -94
- package/common/cpp/audioapi/HostObjects/sources/AudioBufferHostObject.h +0 -46
- package/common/cpp/audioapi/HostObjects/sources/AudioBufferQueueSourceNodeHostObject.cpp +0 -60
- package/common/cpp/audioapi/HostObjects/sources/AudioBufferQueueSourceNodeHostObject.h +0 -25
- package/common/cpp/audioapi/HostObjects/sources/AudioBufferSourceNodeHostObject.cpp +0 -152
- package/common/cpp/audioapi/HostObjects/sources/AudioBufferSourceNodeHostObject.h +0 -37
- package/common/cpp/audioapi/HostObjects/sources/AudioScheduledSourceNodeHostObject.cpp +0 -52
- package/common/cpp/audioapi/HostObjects/sources/AudioScheduledSourceNodeHostObject.h +0 -25
- package/common/cpp/audioapi/HostObjects/sources/ConstantSourceNodeHostObject.cpp +0 -19
- package/common/cpp/audioapi/HostObjects/sources/ConstantSourceNodeHostObject.h +0 -21
- package/common/cpp/audioapi/HostObjects/sources/OscillatorNodeHostObject.cpp +0 -55
- package/common/cpp/audioapi/HostObjects/sources/OscillatorNodeHostObject.h +0 -27
- package/common/cpp/audioapi/HostObjects/sources/StreamerNodeHostObject.cpp +0 -22
- package/common/cpp/audioapi/HostObjects/sources/StreamerNodeHostObject.h +0 -28
- package/common/cpp/audioapi/HostObjects/sources/WorkletSourceNodeHostObject.h +0 -18
- package/common/cpp/audioapi/core/effects/WorkletNode.cpp +0 -87
- package/common/cpp/audioapi/core/effects/WorkletNode.h +0 -65
- package/common/cpp/audioapi/core/effects/WorkletProcessingNode.cpp +0 -89
- package/common/cpp/audioapi/core/effects/WorkletProcessingNode.h +0 -52
- package/common/cpp/audioapi/core/sources/ConstantSourceNode.cpp +0 -51
- package/common/cpp/audioapi/core/sources/ConstantSourceNode.h +0 -26
- package/common/cpp/audioapi/core/sources/WorkletSourceNode.cpp +0 -82
- package/common/cpp/audioapi/core/sources/WorkletSourceNode.h +0 -47
- package/common/cpp/audioapi/core/utils/worklets/SafeIncludes.h +0 -52
- package/common/cpp/audioapi/core/utils/worklets/WorkletsRunner.cpp +0 -9
- package/common/cpp/audioapi/core/utils/worklets/WorkletsRunner.h +0 -73
- package/common/cpp/audioapi/utils/ThreadPool.hpp +0 -104
- package/common/cpp/test/AudioParamTest.cpp +0 -204
- package/lib/commonjs/core/ConstantSourceNode.js +0 -17
- package/lib/commonjs/core/ConstantSourceNode.js.map +0 -1
- package/lib/commonjs/core/WorkletNode.js +0 -11
- package/lib/commonjs/core/WorkletNode.js.map +0 -1
- package/lib/commonjs/core/WorkletProcessingNode.js +0 -11
- package/lib/commonjs/core/WorkletProcessingNode.js.map +0 -1
- package/lib/commonjs/core/WorkletSourceNode.js +0 -11
- package/lib/commonjs/core/WorkletSourceNode.js.map +0 -1
- package/lib/commonjs/hooks/useSystemVolume.js.map +0 -1
- package/lib/commonjs/web-core/ConstantSourceNode.js +0 -17
- package/lib/commonjs/web-core/ConstantSourceNode.js.map +0 -1
- package/lib/module/core/ConstantSourceNode.js +0 -11
- package/lib/module/core/ConstantSourceNode.js.map +0 -1
- package/lib/module/core/WorkletNode.js +0 -5
- package/lib/module/core/WorkletNode.js.map +0 -1
- package/lib/module/core/WorkletProcessingNode.js +0 -5
- package/lib/module/core/WorkletProcessingNode.js.map +0 -1
- package/lib/module/core/WorkletSourceNode.js +0 -5
- package/lib/module/core/WorkletSourceNode.js.map +0 -1
- package/lib/module/hooks/useSystemVolume.js.map +0 -1
- package/lib/module/web-core/ConstantSourceNode.js +0 -11
- package/lib/module/web-core/ConstantSourceNode.js.map +0 -1
- package/lib/typescript/core/ConstantSourceNode.d.ts +0 -9
- package/lib/typescript/core/ConstantSourceNode.d.ts.map +0 -1
- package/lib/typescript/core/WorkletNode.d.ts +0 -4
- package/lib/typescript/core/WorkletNode.d.ts.map +0 -1
- package/lib/typescript/core/WorkletProcessingNode.d.ts +0 -4
- package/lib/typescript/core/WorkletProcessingNode.d.ts.map +0 -1
- package/lib/typescript/core/WorkletSourceNode.d.ts +0 -4
- package/lib/typescript/core/WorkletSourceNode.d.ts.map +0 -1
- package/lib/typescript/hooks/useSystemVolume.d.ts.map +0 -1
- package/lib/typescript/web-core/ConstantSourceNode.d.ts +0 -8
- package/lib/typescript/web-core/ConstantSourceNode.d.ts.map +0 -1
- package/src/core/ConstantSourceNode.ts +0 -13
- package/src/core/WorkletNode.ts +0 -3
- package/src/core/WorkletProcessingNode.ts +0 -3
- package/src/core/WorkletSourceNode.ts +0 -3
- package/src/web-core/ConstantSourceNode.tsx +0 -12
- /package/common/cpp/audioapi/HostObjects/{destinations/AudioDestinationNodeHostObject.h → AudioDestinationNodeHostObject.h} +0 -0
- /package/common/cpp/audioapi/HostObjects/{effects/PeriodicWaveHostObject.h → PeriodicWaveHostObject.h} +0 -0
- /package/common/cpp/audioapi/core/{utils/AudioParamEventQueue.h → AudioParamEventQueue.h} +0 -0
- /package/src/hooks/{useSystemVolume.ts → useSytemVolume.ts} +0 -0
|
@@ -6,12 +6,10 @@
|
|
|
6
6
|
#include <audioapi/core/inputs/AudioRecorder.h>
|
|
7
7
|
#include <audioapi/HostObjects/AudioContextHostObject.h>
|
|
8
8
|
#include <audioapi/HostObjects/OfflineAudioContextHostObject.h>
|
|
9
|
-
#include <audioapi/HostObjects/
|
|
9
|
+
#include <audioapi/HostObjects/AudioRecorderHostObject.h>
|
|
10
10
|
|
|
11
11
|
#include <audioapi/events/AudioEventHandlerRegistry.h>
|
|
12
|
-
#include <audioapi/
|
|
13
|
-
|
|
14
|
-
#include <audioapi/core/utils/worklets/SafeIncludes.h>
|
|
12
|
+
#include <audioapi/events/AudioEventHandlerRegistryHostObject.h>
|
|
15
13
|
|
|
16
14
|
#include <memory>
|
|
17
15
|
|
|
@@ -21,15 +19,10 @@ using namespace facebook;
|
|
|
21
19
|
|
|
22
20
|
class AudioAPIModuleInstaller {
|
|
23
21
|
public:
|
|
24
|
-
static void injectJSIBindings(
|
|
25
|
-
|
|
26
|
-
const std::shared_ptr<react::CallInvoker> &jsCallInvoker,
|
|
27
|
-
const std::shared_ptr<AudioEventHandlerRegistry> &audioEventHandlerRegistry,
|
|
28
|
-
std::shared_ptr<worklets::WorkletRuntime> uiRuntime = nullptr) {
|
|
29
|
-
|
|
30
|
-
auto createAudioContext = getCreateAudioContextFunction(jsiRuntime, jsCallInvoker, audioEventHandlerRegistry, uiRuntime);
|
|
22
|
+
static void injectJSIBindings(jsi::Runtime *jsiRuntime, const std::shared_ptr<react::CallInvoker> &jsCallInvoker, const std::shared_ptr<AudioEventHandlerRegistry> &audioEventHandlerRegistry) {
|
|
23
|
+
auto createAudioContext = getCreateAudioContextFunction(jsiRuntime, jsCallInvoker, audioEventHandlerRegistry);
|
|
31
24
|
auto createAudioRecorder = getCreateAudioRecorderFunction(jsiRuntime, audioEventHandlerRegistry);
|
|
32
|
-
auto createOfflineAudioContext = getCreateOfflineAudioContextFunction(jsiRuntime, jsCallInvoker, audioEventHandlerRegistry
|
|
25
|
+
auto createOfflineAudioContext = getCreateOfflineAudioContextFunction(jsiRuntime, jsCallInvoker, audioEventHandlerRegistry);
|
|
33
26
|
|
|
34
27
|
jsiRuntime->global().setProperty(*jsiRuntime, "createAudioContext", createAudioContext);
|
|
35
28
|
jsiRuntime->global().setProperty(*jsiRuntime, "createAudioRecorder", createAudioRecorder);
|
|
@@ -40,16 +33,12 @@ class AudioAPIModuleInstaller {
|
|
|
40
33
|
}
|
|
41
34
|
|
|
42
35
|
private:
|
|
43
|
-
static jsi::Function getCreateAudioContextFunction(
|
|
44
|
-
jsi::Runtime *jsiRuntime,
|
|
45
|
-
const std::shared_ptr<react::CallInvoker> &jsCallInvoker,
|
|
46
|
-
const std::shared_ptr<AudioEventHandlerRegistry> &audioEventHandlerRegistry,
|
|
47
|
-
const std::weak_ptr<worklets::WorkletRuntime> &uiRuntime) {
|
|
36
|
+
static jsi::Function getCreateAudioContextFunction(jsi::Runtime *jsiRuntime, const std::shared_ptr<react::CallInvoker> &jsCallInvoker, const std::shared_ptr<AudioEventHandlerRegistry> &audioEventHandlerRegistry) {
|
|
48
37
|
return jsi::Function::createFromHostFunction(
|
|
49
38
|
*jsiRuntime,
|
|
50
39
|
jsi::PropNameID::forAscii(*jsiRuntime, "createAudioContext"),
|
|
51
40
|
0,
|
|
52
|
-
[jsCallInvoker, audioEventHandlerRegistry
|
|
41
|
+
[jsCallInvoker, audioEventHandlerRegistry](
|
|
53
42
|
jsi::Runtime &runtime,
|
|
54
43
|
const jsi::Value &thisValue,
|
|
55
44
|
const jsi::Value *args,
|
|
@@ -57,17 +46,8 @@ class AudioAPIModuleInstaller {
|
|
|
57
46
|
std::shared_ptr<AudioContext> audioContext;
|
|
58
47
|
auto sampleRate = static_cast<float>(args[0].getNumber());
|
|
59
48
|
auto initSuspended = args[1].getBool();
|
|
49
|
+
audioContext = std::make_shared<AudioContext>(sampleRate, initSuspended, audioEventHandlerRegistry);
|
|
60
50
|
|
|
61
|
-
#if RN_AUDIO_API_ENABLE_WORKLETS
|
|
62
|
-
auto runtimeRegistry = RuntimeRegistry{
|
|
63
|
-
.uiRuntime = uiRuntime,
|
|
64
|
-
.audioRuntime = worklets::extractWorkletRuntime(runtime, args[2])
|
|
65
|
-
};
|
|
66
|
-
#else
|
|
67
|
-
auto runtimeRegistry = RuntimeRegistry{};
|
|
68
|
-
#endif
|
|
69
|
-
|
|
70
|
-
audioContext = std::make_shared<AudioContext>(sampleRate, initSuspended, audioEventHandlerRegistry, runtimeRegistry);
|
|
71
51
|
auto audioContextHostObject = std::make_shared<AudioContextHostObject>(
|
|
72
52
|
audioContext, &runtime, jsCallInvoker);
|
|
73
53
|
|
|
@@ -76,16 +56,12 @@ class AudioAPIModuleInstaller {
|
|
|
76
56
|
});
|
|
77
57
|
}
|
|
78
58
|
|
|
79
|
-
static jsi::Function getCreateOfflineAudioContextFunction(
|
|
80
|
-
jsi::Runtime *jsiRuntime,
|
|
81
|
-
const std::shared_ptr<react::CallInvoker> &jsCallInvoker,
|
|
82
|
-
const std::shared_ptr<AudioEventHandlerRegistry> &audioEventHandlerRegistry,
|
|
83
|
-
const std::weak_ptr<worklets::WorkletRuntime> &uiRuntime) {
|
|
59
|
+
static jsi::Function getCreateOfflineAudioContextFunction(jsi::Runtime *jsiRuntime, const std::shared_ptr<react::CallInvoker> &jsCallInvoker, const std::shared_ptr<AudioEventHandlerRegistry> &audioEventHandlerRegistry) {
|
|
84
60
|
return jsi::Function::createFromHostFunction(
|
|
85
61
|
*jsiRuntime,
|
|
86
62
|
jsi::PropNameID::forAscii(*jsiRuntime, "createOfflineAudioContext"),
|
|
87
63
|
0,
|
|
88
|
-
[jsCallInvoker, audioEventHandlerRegistry
|
|
64
|
+
[jsCallInvoker, audioEventHandlerRegistry](
|
|
89
65
|
jsi::Runtime &runtime,
|
|
90
66
|
const jsi::Value &thisValue,
|
|
91
67
|
const jsi::Value *args,
|
|
@@ -94,27 +70,16 @@ class AudioAPIModuleInstaller {
|
|
|
94
70
|
auto length = static_cast<size_t>(args[1].getNumber());
|
|
95
71
|
auto sampleRate = static_cast<float>(args[2].getNumber());
|
|
96
72
|
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
auto runtimeRegistry = RuntimeRegistry{};
|
|
104
|
-
#endif
|
|
105
|
-
|
|
106
|
-
auto offlineAudioContext = std::make_shared<OfflineAudioContext>(numberOfChannels, length, sampleRate, audioEventHandlerRegistry, runtimeRegistry);
|
|
107
|
-
auto audioContextHostObject = std::make_shared<OfflineAudioContextHostObject>(
|
|
108
|
-
offlineAudioContext, &runtime, jsCallInvoker);
|
|
109
|
-
|
|
110
|
-
return jsi::Object::createFromHostObject(
|
|
111
|
-
runtime, audioContextHostObject);
|
|
73
|
+
auto offlineAudioContext = std::make_shared<OfflineAudioContext>(numberOfChannels, length, sampleRate, audioEventHandlerRegistry);
|
|
74
|
+
auto audioContextHostObject = std::make_shared<OfflineAudioContextHostObject>(
|
|
75
|
+
offlineAudioContext, &runtime, jsCallInvoker);
|
|
76
|
+
|
|
77
|
+
return jsi::Object::createFromHostObject(
|
|
78
|
+
runtime, audioContextHostObject);
|
|
112
79
|
});
|
|
113
80
|
}
|
|
114
81
|
|
|
115
|
-
static jsi::Function getCreateAudioRecorderFunction(
|
|
116
|
-
jsi::Runtime *jsiRuntime,
|
|
117
|
-
const std::shared_ptr<AudioEventHandlerRegistry> &audioEventHandlerRegistry) {
|
|
82
|
+
static jsi::Function getCreateAudioRecorderFunction(jsi::Runtime *jsiRuntime, const std::shared_ptr<AudioEventHandlerRegistry> &audioEventHandlerRegistry) {
|
|
118
83
|
return jsi::Function::createFromHostFunction(
|
|
119
84
|
*jsiRuntime,
|
|
120
85
|
jsi::PropNameID::forAscii(*jsiRuntime, "createAudioRecorder"),
|
|
@@ -129,7 +94,7 @@ class AudioAPIModuleInstaller {
|
|
|
129
94
|
auto sampleRate = static_cast<float>(options.getProperty(runtime, "sampleRate").getNumber());
|
|
130
95
|
auto bufferLength = static_cast<int>(options.getProperty(runtime, "bufferLengthInSamples").getNumber());
|
|
131
96
|
|
|
132
|
-
auto audioRecorderHostObject = std::make_shared<AudioRecorderHostObject>(audioEventHandlerRegistry, sampleRate, bufferLength);
|
|
97
|
+
auto audioRecorderHostObject = std::make_shared<AudioRecorderHostObject>(&runtime, audioEventHandlerRegistry, sampleRate, bufferLength);
|
|
133
98
|
|
|
134
99
|
return jsi::Object::createFromHostObject(runtime, audioRecorderHostObject);
|
|
135
100
|
});
|
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
#pragma once
|
|
2
|
+
|
|
3
|
+
#include <audioapi/core/analysis/AnalyserNode.h>
|
|
4
|
+
#include <audioapi/HostObjects/AudioNodeHostObject.h>
|
|
5
|
+
|
|
6
|
+
#include <memory>
|
|
7
|
+
#include <string>
|
|
8
|
+
#include <vector>
|
|
9
|
+
|
|
10
|
+
namespace audioapi {
|
|
11
|
+
using namespace facebook;
|
|
12
|
+
|
|
13
|
+
class AnalyserNodeHostObject : public AudioNodeHostObject {
|
|
14
|
+
public:
|
|
15
|
+
explicit AnalyserNodeHostObject(const std::shared_ptr<AnalyserNode> &node)
|
|
16
|
+
: AudioNodeHostObject(node) {
|
|
17
|
+
addGetters(
|
|
18
|
+
JSI_EXPORT_PROPERTY_GETTER(AnalyserNodeHostObject, fftSize),
|
|
19
|
+
JSI_EXPORT_PROPERTY_GETTER(AnalyserNodeHostObject, frequencyBinCount),
|
|
20
|
+
JSI_EXPORT_PROPERTY_GETTER(AnalyserNodeHostObject, minDecibels),
|
|
21
|
+
JSI_EXPORT_PROPERTY_GETTER(AnalyserNodeHostObject, maxDecibels),
|
|
22
|
+
JSI_EXPORT_PROPERTY_GETTER(AnalyserNodeHostObject, smoothingTimeConstant),
|
|
23
|
+
JSI_EXPORT_PROPERTY_GETTER(AnalyserNodeHostObject, window));
|
|
24
|
+
|
|
25
|
+
addFunctions(
|
|
26
|
+
JSI_EXPORT_FUNCTION(
|
|
27
|
+
AnalyserNodeHostObject, getFloatFrequencyData),
|
|
28
|
+
JSI_EXPORT_FUNCTION(
|
|
29
|
+
AnalyserNodeHostObject, getByteFrequencyData),
|
|
30
|
+
JSI_EXPORT_FUNCTION(
|
|
31
|
+
AnalyserNodeHostObject, getFloatTimeDomainData),
|
|
32
|
+
JSI_EXPORT_FUNCTION(
|
|
33
|
+
AnalyserNodeHostObject, getByteTimeDomainData));
|
|
34
|
+
|
|
35
|
+
addSetters(
|
|
36
|
+
JSI_EXPORT_PROPERTY_SETTER(AnalyserNodeHostObject, fftSize),
|
|
37
|
+
JSI_EXPORT_PROPERTY_SETTER(AnalyserNodeHostObject, minDecibels),
|
|
38
|
+
JSI_EXPORT_PROPERTY_SETTER(AnalyserNodeHostObject, maxDecibels),
|
|
39
|
+
JSI_EXPORT_PROPERTY_SETTER(
|
|
40
|
+
AnalyserNodeHostObject, smoothingTimeConstant),
|
|
41
|
+
JSI_EXPORT_PROPERTY_SETTER(AnalyserNodeHostObject, window));
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
JSI_PROPERTY_GETTER(fftSize) {
|
|
45
|
+
auto analyserNode = std::static_pointer_cast<AnalyserNode>(node_);
|
|
46
|
+
return {static_cast<int>(analyserNode->getFftSize())};
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
JSI_PROPERTY_GETTER(frequencyBinCount) {
|
|
50
|
+
auto analyserNode = std::static_pointer_cast<AnalyserNode>(node_);
|
|
51
|
+
return {static_cast<int>(analyserNode->getFrequencyBinCount())};
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
JSI_PROPERTY_GETTER(minDecibels) {
|
|
55
|
+
auto analyserNode = std::static_pointer_cast<AnalyserNode>(node_);
|
|
56
|
+
return {analyserNode->getMinDecibels()};
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
JSI_PROPERTY_GETTER(maxDecibels) {
|
|
60
|
+
auto analyserNode = std::static_pointer_cast<AnalyserNode>(node_);
|
|
61
|
+
return {analyserNode->getMaxDecibels()};
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
JSI_PROPERTY_GETTER(smoothingTimeConstant) {
|
|
65
|
+
auto analyserNode = std::static_pointer_cast<AnalyserNode>(node_);
|
|
66
|
+
return {analyserNode->getSmoothingTimeConstant()};
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
JSI_PROPERTY_GETTER(window) {
|
|
70
|
+
auto analyserNode = std::static_pointer_cast<AnalyserNode>(node_);
|
|
71
|
+
auto windowType = analyserNode->getWindowType();
|
|
72
|
+
return jsi::String::createFromUtf8(runtime, windowType);
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
JSI_HOST_FUNCTION(getFloatFrequencyData) {
|
|
76
|
+
auto arrayBuffer = args[0].getObject(runtime).getPropertyAsObject(runtime, "buffer").getArrayBuffer(runtime);
|
|
77
|
+
auto data = reinterpret_cast<float *>(arrayBuffer.data(runtime));
|
|
78
|
+
auto length = static_cast<int>(arrayBuffer.size(runtime));
|
|
79
|
+
|
|
80
|
+
auto analyserNode = std::static_pointer_cast<AnalyserNode>(node_);
|
|
81
|
+
analyserNode->getFloatFrequencyData(data, length);
|
|
82
|
+
|
|
83
|
+
return jsi::Value::undefined();
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
JSI_HOST_FUNCTION(getByteFrequencyData) {
|
|
87
|
+
auto arrayBuffer = args[0].getObject(runtime).getPropertyAsObject(runtime, "buffer").getArrayBuffer(runtime);
|
|
88
|
+
auto data = arrayBuffer.data(runtime);
|
|
89
|
+
auto length = static_cast<int>(arrayBuffer.size(runtime));
|
|
90
|
+
|
|
91
|
+
auto analyserNode = std::static_pointer_cast<AnalyserNode>(node_);
|
|
92
|
+
analyserNode->getByteFrequencyData(data, length);
|
|
93
|
+
|
|
94
|
+
return jsi::Value::undefined();
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
JSI_HOST_FUNCTION(getFloatTimeDomainData) {
|
|
98
|
+
auto arrayBuffer = args[0].getObject(runtime).getPropertyAsObject(runtime, "buffer").getArrayBuffer(runtime);
|
|
99
|
+
auto data = reinterpret_cast<float *>(arrayBuffer.data(runtime));
|
|
100
|
+
auto length = static_cast<int>(arrayBuffer.size(runtime));
|
|
101
|
+
|
|
102
|
+
auto analyserNode = std::static_pointer_cast<AnalyserNode>(node_);
|
|
103
|
+
analyserNode->getFloatTimeDomainData(data, length);
|
|
104
|
+
|
|
105
|
+
return jsi::Value::undefined();
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
JSI_HOST_FUNCTION(getByteTimeDomainData) {
|
|
109
|
+
auto arrayBuffer = args[0].getObject(runtime).getPropertyAsObject(runtime, "buffer").getArrayBuffer(runtime);
|
|
110
|
+
auto data = arrayBuffer.data(runtime);
|
|
111
|
+
auto length = static_cast<int>(arrayBuffer.size(runtime));
|
|
112
|
+
|
|
113
|
+
auto analyserNode = std::static_pointer_cast<AnalyserNode>(node_);
|
|
114
|
+
analyserNode->getByteTimeDomainData(data, length);
|
|
115
|
+
|
|
116
|
+
return jsi::Value::undefined();
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
JSI_PROPERTY_SETTER(fftSize) {
|
|
120
|
+
auto analyserNode = std::static_pointer_cast<AnalyserNode>(node_);
|
|
121
|
+
auto fftSize = static_cast<int>(value.getNumber());
|
|
122
|
+
analyserNode->setFftSize(fftSize);
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
JSI_PROPERTY_SETTER(minDecibels) {
|
|
126
|
+
auto analyserNode = std::static_pointer_cast<AnalyserNode>(node_);
|
|
127
|
+
auto minDecibels = static_cast<float>(value.getNumber());
|
|
128
|
+
analyserNode->setMinDecibels(minDecibels);
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
JSI_PROPERTY_SETTER(maxDecibels) {
|
|
132
|
+
auto analyserNode = std::static_pointer_cast<AnalyserNode>(node_);
|
|
133
|
+
auto maxDecibels = static_cast<float>(value.getNumber());
|
|
134
|
+
analyserNode->setMaxDecibels(maxDecibels);
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
JSI_PROPERTY_SETTER(smoothingTimeConstant) {
|
|
138
|
+
auto analyserNode = std::static_pointer_cast<AnalyserNode>(node_);
|
|
139
|
+
auto smoothingTimeConstant = static_cast<float>(value.getNumber());
|
|
140
|
+
analyserNode->setSmoothingTimeConstant(smoothingTimeConstant);
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
JSI_PROPERTY_SETTER(window) {
|
|
144
|
+
auto analyserNode = std::static_pointer_cast<AnalyserNode>(node_);
|
|
145
|
+
analyserNode->setWindowType(value.getString(runtime).utf8(runtime));
|
|
146
|
+
}
|
|
147
|
+
};
|
|
148
|
+
|
|
149
|
+
} // namespace audioapi
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
#pragma once
|
|
2
|
+
|
|
3
|
+
#include <audioapi/core/sources/AudioBufferBaseSourceNode.h>
|
|
4
|
+
#include <audioapi/HostObjects/AudioParamHostObject.h>
|
|
5
|
+
#include <audioapi/HostObjects/AudioScheduledSourceNodeHostObject.h>
|
|
6
|
+
|
|
7
|
+
#include <memory>
|
|
8
|
+
#include <vector>
|
|
9
|
+
|
|
10
|
+
namespace audioapi {
|
|
11
|
+
using namespace facebook;
|
|
12
|
+
|
|
13
|
+
class AudioBufferBaseSourceNodeHostObject
|
|
14
|
+
: public AudioScheduledSourceNodeHostObject {
|
|
15
|
+
public:
|
|
16
|
+
explicit AudioBufferBaseSourceNodeHostObject(
|
|
17
|
+
const std::shared_ptr<AudioBufferBaseSourceNode> &node)
|
|
18
|
+
: AudioScheduledSourceNodeHostObject(node) {
|
|
19
|
+
addGetters(
|
|
20
|
+
JSI_EXPORT_PROPERTY_GETTER(AudioBufferBaseSourceNodeHostObject, detune),
|
|
21
|
+
JSI_EXPORT_PROPERTY_GETTER(AudioBufferBaseSourceNodeHostObject, playbackRate),
|
|
22
|
+
JSI_EXPORT_PROPERTY_GETTER(AudioBufferBaseSourceNodeHostObject, onPositionChangedInterval));
|
|
23
|
+
|
|
24
|
+
addSetters(
|
|
25
|
+
JSI_EXPORT_PROPERTY_SETTER(AudioBufferBaseSourceNodeHostObject, onPositionChanged),
|
|
26
|
+
JSI_EXPORT_PROPERTY_SETTER(AudioBufferBaseSourceNodeHostObject, onPositionChangedInterval));
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
~AudioBufferBaseSourceNodeHostObject() {
|
|
30
|
+
auto sourceNode =
|
|
31
|
+
std::static_pointer_cast<AudioBufferBaseSourceNode>(node_);
|
|
32
|
+
|
|
33
|
+
// When JSI object is garbage collected (together with the eventual callback),
|
|
34
|
+
// underlying source node might still be active and try to call the non-existing callback.
|
|
35
|
+
sourceNode->clearOnPositionChangedCallback();
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
JSI_PROPERTY_GETTER(detune) {
|
|
39
|
+
auto sourceNode =
|
|
40
|
+
std::static_pointer_cast<AudioBufferBaseSourceNode>(node_);
|
|
41
|
+
auto detune = sourceNode->getDetuneParam();
|
|
42
|
+
auto detuneHostObject = std::make_shared<AudioParamHostObject>(detune);
|
|
43
|
+
return jsi::Object::createFromHostObject(runtime, detuneHostObject);
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
JSI_PROPERTY_GETTER(playbackRate) {
|
|
47
|
+
auto sourceNode =
|
|
48
|
+
std::static_pointer_cast<AudioBufferBaseSourceNode>(node_);
|
|
49
|
+
auto playbackRate = sourceNode->getPlaybackRateParam();
|
|
50
|
+
auto playbackRateHostObject =
|
|
51
|
+
std::make_shared<AudioParamHostObject>(playbackRate);
|
|
52
|
+
return jsi::Object::createFromHostObject(runtime, playbackRateHostObject);
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
JSI_PROPERTY_SETTER(onPositionChanged) {
|
|
56
|
+
auto sourceNode =
|
|
57
|
+
std::static_pointer_cast<AudioBufferBaseSourceNode>(node_);
|
|
58
|
+
|
|
59
|
+
sourceNode->setOnPositionChangedCallbackId(std::stoull(value.getString(runtime).utf8(runtime)));
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
JSI_PROPERTY_GETTER(onPositionChangedInterval) {
|
|
63
|
+
auto sourceNode =
|
|
64
|
+
std::static_pointer_cast<AudioBufferBaseSourceNode>(node_);
|
|
65
|
+
return jsi::Value(sourceNode->getOnPositionChangedInterval());
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
JSI_PROPERTY_SETTER(onPositionChangedInterval) {
|
|
69
|
+
auto sourceNode =
|
|
70
|
+
std::static_pointer_cast<AudioBufferBaseSourceNode>(node_);
|
|
71
|
+
|
|
72
|
+
sourceNode->setOnPositionChangedInterval(static_cast<int>(value.getNumber()));
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
|
|
76
|
+
} // namespace audioapi
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
#pragma once
|
|
2
|
+
|
|
3
|
+
#include <audioapi/core/sources/AudioBuffer.h>
|
|
4
|
+
#include <audioapi/jsi/AudioArrayBuffer.h>
|
|
5
|
+
#include <audioapi/jsi/JsiHostObject.h>
|
|
6
|
+
|
|
7
|
+
#include <jsi/jsi.h>
|
|
8
|
+
#include <cstddef>
|
|
9
|
+
#include <memory>
|
|
10
|
+
#include <utility>
|
|
11
|
+
#include <vector>
|
|
12
|
+
|
|
13
|
+
namespace audioapi {
|
|
14
|
+
using namespace facebook;
|
|
15
|
+
|
|
16
|
+
class AudioBufferHostObject : public JsiHostObject {
|
|
17
|
+
public:
|
|
18
|
+
std::shared_ptr<AudioBuffer> audioBuffer_;
|
|
19
|
+
|
|
20
|
+
explicit AudioBufferHostObject(
|
|
21
|
+
const std::shared_ptr<AudioBuffer> &audioBuffer)
|
|
22
|
+
: audioBuffer_(audioBuffer) {
|
|
23
|
+
addGetters(
|
|
24
|
+
JSI_EXPORT_PROPERTY_GETTER(AudioBufferHostObject, sampleRate),
|
|
25
|
+
JSI_EXPORT_PROPERTY_GETTER(AudioBufferHostObject, length),
|
|
26
|
+
JSI_EXPORT_PROPERTY_GETTER(AudioBufferHostObject, duration),
|
|
27
|
+
JSI_EXPORT_PROPERTY_GETTER(AudioBufferHostObject, numberOfChannels));
|
|
28
|
+
|
|
29
|
+
addFunctions(
|
|
30
|
+
JSI_EXPORT_FUNCTION(AudioBufferHostObject, getChannelData),
|
|
31
|
+
JSI_EXPORT_FUNCTION(AudioBufferHostObject, copyFromChannel),
|
|
32
|
+
JSI_EXPORT_FUNCTION(AudioBufferHostObject, copyToChannel));
|
|
33
|
+
}
|
|
34
|
+
AudioBufferHostObject(const AudioBufferHostObject &) = delete;
|
|
35
|
+
AudioBufferHostObject &operator=(const AudioBufferHostObject &) = delete;
|
|
36
|
+
AudioBufferHostObject(AudioBufferHostObject &&other) noexcept
|
|
37
|
+
: JsiHostObject(std::move(other)),
|
|
38
|
+
audioBuffer_(std::move(other.audioBuffer_)) {}
|
|
39
|
+
AudioBufferHostObject &operator=(AudioBufferHostObject &&other) noexcept {
|
|
40
|
+
if (this != &other) {
|
|
41
|
+
JsiHostObject::operator=(std::move(other));
|
|
42
|
+
audioBuffer_ = std::move(other.audioBuffer_);
|
|
43
|
+
}
|
|
44
|
+
return *this;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
[[nodiscard]] size_t getSizeInBytes() const {
|
|
48
|
+
return audioBuffer_->getLength() * audioBuffer_->getNumberOfChannels() *
|
|
49
|
+
sizeof(float);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
JSI_PROPERTY_GETTER(sampleRate) {
|
|
53
|
+
return {audioBuffer_->getSampleRate()};
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
JSI_PROPERTY_GETTER(length) {
|
|
57
|
+
return {static_cast<double>(audioBuffer_->getLength())};
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
JSI_PROPERTY_GETTER(duration) {
|
|
61
|
+
return {audioBuffer_->getDuration()};
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
JSI_PROPERTY_GETTER(numberOfChannels) {
|
|
65
|
+
return {audioBuffer_->getNumberOfChannels()};
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
JSI_HOST_FUNCTION(getChannelData) {
|
|
69
|
+
auto channel = static_cast<int>(args[0].getNumber());
|
|
70
|
+
auto channelData =
|
|
71
|
+
reinterpret_cast<uint8_t *>(audioBuffer_->getChannelData(channel));
|
|
72
|
+
auto length = static_cast<int>(audioBuffer_->getLength());
|
|
73
|
+
auto size = static_cast<int>(length * sizeof(float));
|
|
74
|
+
|
|
75
|
+
// reading or writing from this ArrayBuffer could cause a crash
|
|
76
|
+
// if underlying channelData is deallocated
|
|
77
|
+
auto audioArrayBuffer =
|
|
78
|
+
std::make_shared<AudioArrayBuffer>(channelData, size);
|
|
79
|
+
auto arrayBuffer = jsi::ArrayBuffer(runtime, audioArrayBuffer);
|
|
80
|
+
|
|
81
|
+
auto float32ArrayCtor =
|
|
82
|
+
runtime.global().getPropertyAsFunction(runtime, "Float32Array");
|
|
83
|
+
auto float32Array = float32ArrayCtor.callAsConstructor(runtime, arrayBuffer)
|
|
84
|
+
.getObject(runtime);
|
|
85
|
+
|
|
86
|
+
return float32Array;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
JSI_HOST_FUNCTION(copyFromChannel) {
|
|
90
|
+
auto arrayBuffer = args[0]
|
|
91
|
+
.getObject(runtime)
|
|
92
|
+
.getPropertyAsObject(runtime, "buffer")
|
|
93
|
+
.getArrayBuffer(runtime);
|
|
94
|
+
auto destination = reinterpret_cast<float *>(arrayBuffer.data(runtime));
|
|
95
|
+
auto length = static_cast<int>(arrayBuffer.size(runtime));
|
|
96
|
+
auto channelNumber = static_cast<int>(args[1].getNumber());
|
|
97
|
+
auto startInChannel = static_cast<size_t>(args[2].getNumber());
|
|
98
|
+
|
|
99
|
+
audioBuffer_->copyFromChannel(
|
|
100
|
+
destination, length, channelNumber, startInChannel);
|
|
101
|
+
|
|
102
|
+
return jsi::Value::undefined();
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
JSI_HOST_FUNCTION(copyToChannel) {
|
|
106
|
+
auto arrayBuffer = args[0]
|
|
107
|
+
.getObject(runtime)
|
|
108
|
+
.getPropertyAsObject(runtime, "buffer")
|
|
109
|
+
.getArrayBuffer(runtime);
|
|
110
|
+
auto source = reinterpret_cast<float *>(arrayBuffer.data(runtime));
|
|
111
|
+
auto length = static_cast<int>(arrayBuffer.size(runtime));
|
|
112
|
+
auto channelNumber = static_cast<int>(args[1].getNumber());
|
|
113
|
+
auto startInChannel = static_cast<size_t>(args[2].getNumber());
|
|
114
|
+
|
|
115
|
+
audioBuffer_->copyToChannel(source, length, channelNumber, startInChannel);
|
|
116
|
+
|
|
117
|
+
return jsi::Value::undefined();
|
|
118
|
+
}
|
|
119
|
+
};
|
|
120
|
+
} // namespace audioapi
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
#pragma once
|
|
2
|
+
|
|
3
|
+
#include <audioapi/HostObjects/AudioBufferHostObject.h>
|
|
4
|
+
#include <audioapi/core/sources/AudioBufferQueueSourceNode.h>
|
|
5
|
+
#include <audioapi/HostObjects/AudioBufferBaseSourceNodeHostObject.h>
|
|
6
|
+
|
|
7
|
+
#include <memory>
|
|
8
|
+
#include <vector>
|
|
9
|
+
|
|
10
|
+
namespace audioapi {
|
|
11
|
+
using namespace facebook;
|
|
12
|
+
|
|
13
|
+
class AudioBufferQueueSourceNodeHostObject
|
|
14
|
+
: public AudioBufferBaseSourceNodeHostObject {
|
|
15
|
+
public:
|
|
16
|
+
explicit AudioBufferQueueSourceNodeHostObject(
|
|
17
|
+
const std::shared_ptr<AudioBufferQueueSourceNode> &node)
|
|
18
|
+
: AudioBufferBaseSourceNodeHostObject(node) {
|
|
19
|
+
addFunctions(
|
|
20
|
+
JSI_EXPORT_FUNCTION(AudioBufferQueueSourceNodeHostObject, enqueueBuffer),
|
|
21
|
+
JSI_EXPORT_FUNCTION(AudioBufferQueueSourceNodeHostObject, pause));
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
JSI_HOST_FUNCTION(pause) {
|
|
25
|
+
auto audioBufferQueueSourceNode =
|
|
26
|
+
std::static_pointer_cast<AudioBufferQueueSourceNode>(node_);
|
|
27
|
+
|
|
28
|
+
audioBufferQueueSourceNode->pause();
|
|
29
|
+
|
|
30
|
+
return jsi::Value::undefined();
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
JSI_HOST_FUNCTION(enqueueBuffer) {
|
|
34
|
+
auto audioBufferQueueSourceNode =
|
|
35
|
+
std::static_pointer_cast<AudioBufferQueueSourceNode>(node_);
|
|
36
|
+
|
|
37
|
+
auto audioBufferHostObject =
|
|
38
|
+
args[0].getObject(runtime).asHostObject<AudioBufferHostObject>(runtime);
|
|
39
|
+
|
|
40
|
+
auto bufferId = audioBufferQueueSourceNode->enqueueBuffer(audioBufferHostObject->audioBuffer_);
|
|
41
|
+
|
|
42
|
+
return jsi::String::createFromUtf8(runtime, bufferId);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
JSI_HOST_FUNCTION(dequeueBuffer) {
|
|
46
|
+
auto audioBufferQueueSourceNode =
|
|
47
|
+
std::static_pointer_cast<AudioBufferQueueSourceNode>(node_);
|
|
48
|
+
|
|
49
|
+
auto bufferId =
|
|
50
|
+
args[0].getNumber();
|
|
51
|
+
|
|
52
|
+
audioBufferQueueSourceNode->dequeueBuffer(bufferId);
|
|
53
|
+
|
|
54
|
+
return jsi::Value::undefined();
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
JSI_HOST_FUNCTION(clearBuffers) {
|
|
58
|
+
auto audioBufferQueueSourceNode =
|
|
59
|
+
std::static_pointer_cast<AudioBufferQueueSourceNode>(node_);
|
|
60
|
+
|
|
61
|
+
audioBufferQueueSourceNode->clearBuffers();
|
|
62
|
+
|
|
63
|
+
return jsi::Value::undefined();
|
|
64
|
+
}
|
|
65
|
+
};
|
|
66
|
+
|
|
67
|
+
} // namespace audioapi
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
#pragma once
|
|
2
|
+
|
|
3
|
+
#include <audioapi/HostObjects/AudioBufferHostObject.h>
|
|
4
|
+
#include <audioapi/core/sources/AudioBufferSourceNode.h>
|
|
5
|
+
#include <audioapi/HostObjects/AudioBufferBaseSourceNodeHostObject.h>
|
|
6
|
+
|
|
7
|
+
#include <memory>
|
|
8
|
+
#include <vector>
|
|
9
|
+
|
|
10
|
+
namespace audioapi {
|
|
11
|
+
using namespace facebook;
|
|
12
|
+
|
|
13
|
+
class AudioBufferSourceNodeHostObject
|
|
14
|
+
: public AudioBufferBaseSourceNodeHostObject {
|
|
15
|
+
public:
|
|
16
|
+
explicit AudioBufferSourceNodeHostObject(
|
|
17
|
+
const std::shared_ptr<AudioBufferSourceNode> &node)
|
|
18
|
+
: AudioBufferBaseSourceNodeHostObject(node) {
|
|
19
|
+
addGetters(
|
|
20
|
+
JSI_EXPORT_PROPERTY_GETTER(AudioBufferSourceNodeHostObject, loop),
|
|
21
|
+
JSI_EXPORT_PROPERTY_GETTER(AudioBufferSourceNodeHostObject, loopSkip),
|
|
22
|
+
JSI_EXPORT_PROPERTY_GETTER(AudioBufferSourceNodeHostObject, buffer),
|
|
23
|
+
JSI_EXPORT_PROPERTY_GETTER(AudioBufferSourceNodeHostObject, loopStart),
|
|
24
|
+
JSI_EXPORT_PROPERTY_GETTER(AudioBufferSourceNodeHostObject, loopEnd));
|
|
25
|
+
|
|
26
|
+
addSetters(
|
|
27
|
+
JSI_EXPORT_PROPERTY_SETTER(AudioBufferSourceNodeHostObject, loop),
|
|
28
|
+
JSI_EXPORT_PROPERTY_SETTER(AudioBufferSourceNodeHostObject, loopSkip),
|
|
29
|
+
JSI_EXPORT_PROPERTY_SETTER(AudioBufferSourceNodeHostObject, loopStart),
|
|
30
|
+
JSI_EXPORT_PROPERTY_SETTER(AudioBufferSourceNodeHostObject, loopEnd));
|
|
31
|
+
|
|
32
|
+
// start method is overridden in this class
|
|
33
|
+
functions_->erase("start");
|
|
34
|
+
|
|
35
|
+
addFunctions(
|
|
36
|
+
JSI_EXPORT_FUNCTION(AudioBufferSourceNodeHostObject, start),
|
|
37
|
+
JSI_EXPORT_FUNCTION(AudioBufferSourceNodeHostObject, setBuffer));
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
JSI_PROPERTY_GETTER(loop) {
|
|
41
|
+
auto audioBufferSourceNode =
|
|
42
|
+
std::static_pointer_cast<AudioBufferSourceNode>(node_);
|
|
43
|
+
auto loop = audioBufferSourceNode->getLoop();
|
|
44
|
+
return {loop};
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
JSI_PROPERTY_GETTER(loopSkip) {
|
|
48
|
+
auto audioBufferSourceNode =
|
|
49
|
+
std::static_pointer_cast<AudioBufferSourceNode>(node_);
|
|
50
|
+
auto loopSkip = audioBufferSourceNode->getLoopSkip();
|
|
51
|
+
return {loopSkip};
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
JSI_PROPERTY_GETTER(buffer) {
|
|
55
|
+
auto audioBufferSourceNode =
|
|
56
|
+
std::static_pointer_cast<AudioBufferSourceNode>(node_);
|
|
57
|
+
auto buffer = audioBufferSourceNode->getBuffer();
|
|
58
|
+
|
|
59
|
+
if (!buffer) {
|
|
60
|
+
return jsi::Value::null();
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
auto bufferHostObject = std::make_shared<AudioBufferHostObject>(buffer);
|
|
64
|
+
return jsi::Object::createFromHostObject(runtime, bufferHostObject);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
JSI_PROPERTY_GETTER(loopStart) {
|
|
68
|
+
auto audioBufferSourceNode =
|
|
69
|
+
std::static_pointer_cast<AudioBufferSourceNode>(node_);
|
|
70
|
+
auto loopStart = audioBufferSourceNode->getLoopStart();
|
|
71
|
+
return {loopStart};
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
JSI_PROPERTY_GETTER(loopEnd) {
|
|
75
|
+
auto audioBufferSourceNode =
|
|
76
|
+
std::static_pointer_cast<AudioBufferSourceNode>(node_);
|
|
77
|
+
auto loopEnd = audioBufferSourceNode->getLoopEnd();
|
|
78
|
+
return {loopEnd};
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
JSI_PROPERTY_SETTER(loop) {
|
|
82
|
+
auto audioBufferSourceNode =
|
|
83
|
+
std::static_pointer_cast<AudioBufferSourceNode>(node_);
|
|
84
|
+
audioBufferSourceNode->setLoop(value.getBool());
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
JSI_PROPERTY_SETTER(loopSkip) {
|
|
88
|
+
auto audioBufferSourceNode =
|
|
89
|
+
std::static_pointer_cast<AudioBufferSourceNode>(node_);
|
|
90
|
+
audioBufferSourceNode->setLoopSkip(value.getBool());
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
JSI_PROPERTY_SETTER(loopStart) {
|
|
94
|
+
auto audioBufferSourceNode =
|
|
95
|
+
std::static_pointer_cast<AudioBufferSourceNode>(node_);
|
|
96
|
+
audioBufferSourceNode->setLoopStart(value.getNumber());
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
JSI_PROPERTY_SETTER(loopEnd) {
|
|
100
|
+
auto audioBufferSourceNode =
|
|
101
|
+
std::static_pointer_cast<AudioBufferSourceNode>(node_);
|
|
102
|
+
audioBufferSourceNode->setLoopEnd(value.getNumber());
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
JSI_HOST_FUNCTION(start) {
|
|
106
|
+
auto when = args[0].getNumber();
|
|
107
|
+
auto offset = args[1].getNumber();
|
|
108
|
+
|
|
109
|
+
auto audioBufferSourceNode =
|
|
110
|
+
std::static_pointer_cast<AudioBufferSourceNode>(node_);
|
|
111
|
+
|
|
112
|
+
if (args[2].isUndefined()) {
|
|
113
|
+
audioBufferSourceNode->start(when, offset);
|
|
114
|
+
|
|
115
|
+
return jsi::Value::undefined();
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
auto duration = args[2].getNumber();
|
|
119
|
+
audioBufferSourceNode->start(when, offset, duration);
|
|
120
|
+
|
|
121
|
+
return jsi::Value::undefined();
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
JSI_HOST_FUNCTION(setBuffer) {
|
|
125
|
+
auto audioBufferSourceNode =
|
|
126
|
+
std::static_pointer_cast<AudioBufferSourceNode>(node_);
|
|
127
|
+
|
|
128
|
+
if (args[0].isNull()) {
|
|
129
|
+
audioBufferSourceNode->setBuffer(std::shared_ptr<AudioBuffer>(nullptr));
|
|
130
|
+
return jsi::Value::undefined();
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
auto bufferHostObject =
|
|
134
|
+
args[0].getObject(runtime).asHostObject<AudioBufferHostObject>(runtime);
|
|
135
|
+
thisValue.asObject(runtime).setExternalMemoryPressure(runtime,
|
|
136
|
+
bufferHostObject->getSizeInBytes() + 16);
|
|
137
|
+
audioBufferSourceNode->setBuffer(bufferHostObject->audioBuffer_);
|
|
138
|
+
return jsi::Value::undefined();
|
|
139
|
+
}
|
|
140
|
+
};
|
|
141
|
+
|
|
142
|
+
} // namespace audioapi
|