-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathdevice.cpp
156 lines (131 loc) · 4.73 KB
/
device.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
#include <stdio.h>
#include <fstream>
#include <string>
// #include "./compile_unit/GHeadlessUnit.h" // you can also use the compile_unit version and link against it to speed up things
#include "./GHeadless.h"
#define MINIAUDIO_IMPLEMENTATION
#define MA_NO_DECODING
#include "../../thirdparty/miniaudio.h"
#include "../../thirdparty/soundwoofer/soundwooferFile.h"
guitard::GuitarDHeadless headless;
#define CHANNEL_COUNT 2
#define MAX_BLOCK_SIZE 1024
#define MONO_IN // Means it still is a stereo device, but only the left input will be used
guitard::sample buffers[CHANNEL_COUNT * 2][MAX_BLOCK_SIZE];
guitard::sample* in[CHANNEL_COUNT] = { buffers[0], buffers[1] };
guitard::sample* out[CHANNEL_COUNT] = { buffers[2], buffers[3] };
/**
* Audio callback from miniaudio
*/
void data_callback(ma_device* pDevice, void* pOutput, const void* pInput, ma_uint32 frameCount) {
MA_ASSERT(pDevice->capture.format == pDevice->playback.format);
MA_ASSERT(pDevice->capture.channels == pDevice->playback.channels);
const guitard::sample* inF = static_cast<const guitard::sample*>(pInput);
guitard::sample* outF = static_cast<guitard::sample*>(pOutput);
#ifdef MONO_IN
for (unsigned int s = 0; s < frameCount; s++) {
in[0][s] = inF[s * 2];
in[1][s] = inF[s * 2];
}
#else
for (unsigned int s = 0; s < frameCount * CHANNEL_COUNT; s++) {
const unsigned int channel = s % CHANNEL_COUNT;
const unsigned int sample = s / CHANNEL_COUNT;
in[channel][sample] = inF[s];
}
#endif
headless.process(in, out, frameCount);
for (int i = 0, j = 0; i < frameCount; i++, j += CHANNEL_COUNT) {
outF[j] = out[0][i] * 0.6;
outF[j + 1] = out[1][i] * 0.6;
}
}
/**
* Takes a few arguments
* First one is
*/
int main(int argc, char** argv) {
std::string folder = "../../thirdparty/soundwoofer/dummy_backend/presets/";
if (argc == 4) {
folder = argv[3];
}
std::vector<soundwoofer::file::FileInfo> presets = soundwoofer::file::scanDir(folder);
int currentPresetIndex = 0;
if (presets.empty()) {
printf("Preset folder not found!\n");
return -1;
}
ma_backend backends[] = { ma_backend_alsa, ma_backend_wasapi, ma_backend_coreaudio };
ma_context context;
if (ma_context_init(backends, 3, NULL, &context) != MA_SUCCESS) {
printf("Failed to initialize context.\n");
return -2;
}
ma_device_info* pPlaybackDeviceInfos;
ma_uint32 playbackDeviceCount;
ma_device_info* pCaptureDeviceInfos;
ma_uint32 captureDeviceCount;
ma_result result = ma_context_get_devices(&context, &pPlaybackDeviceInfos, &playbackDeviceCount, &pCaptureDeviceInfos, &captureDeviceCount);
if (result != MA_SUCCESS) {
printf("Failed to retrieve device information.\n");
return -3;
}
ma_uint32 iDevice;
printf("Playback Devices\n");
for (iDevice = 0; iDevice < playbackDeviceCount; ++iDevice) {
printf(" %u: %s\n", iDevice, pPlaybackDeviceInfos[iDevice].name);
}
printf("\n");
printf("Capture Devices\n");
for (iDevice = 0; iDevice < captureDeviceCount; ++iDevice) {
printf(" %u: %s\n", iDevice, pCaptureDeviceInfos[iDevice].name);
}
ma_device_config deviceConfig;
ma_device device;
deviceConfig = ma_device_config_init(ma_device_type_duplex);
deviceConfig.capture.pDeviceID = NULL;
deviceConfig.capture.format = ma_format_f32;
deviceConfig.capture.channels = CHANNEL_COUNT;
deviceConfig.capture.shareMode = ma_share_mode_exclusive;
deviceConfig.playback.pDeviceID = NULL;
deviceConfig.playback.format = ma_format_f32;
deviceConfig.playback.channels = CHANNEL_COUNT;
deviceConfig.dataCallback = data_callback;
if (argc > 1) {
deviceConfig.periodSizeInFrames = atoi(argv[1]);
}
else {
deviceConfig.periodSizeInFrames = 128;
}
if (argc > 2) {
deviceConfig.sampleRate = atoi(argv[2]);
}
else {
deviceConfig.sampleRate = 44100;
}
result = ma_device_init(&context, &deviceConfig, &device);
if (result != MA_SUCCESS) {
return result;
}
ma_device_start(&device);
printf("\nFramesize: %u Samplerate: %u\n", deviceConfig.periodSizeInFrames, deviceConfig.sampleRate);
headless.setConfig(device.sampleRate, device.playback.channels, device.capture.channels);
while (42) {
std::ifstream file(presets[currentPresetIndex].absolute);
std::string contents((std::istreambuf_iterator<char>(file)), std::istreambuf_iterator<char>());
headless.load(contents.c_str());
printf("Loaded Preset %i ", currentPresetIndex);
printf("%s\n", presets[currentPresetIndex].name.c_str());
printf("Press to load the next preset\n");
getchar();
currentPresetIndex++;
if (currentPresetIndex >= presets.size()) {
currentPresetIndex = 0;
}
}
ma_device_uninit(&device);
ma_context_uninit(&context);
(void)argc;
(void)argv;
return 0;
}