-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathShoutVSTEncoderMP3.cpp
100 lines (93 loc) · 2.76 KB
/
ShoutVSTEncoderMP3.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
#include "ShoutVSTEncoderMP3.h"
#include <string>
ShoutVSTEncoderMP3::ShoutVSTEncoderMP3(LibShoutWrapper& ls)
: ShoutVSTEncoder(ls) {}
ShoutVSTEncoderMP3::~ShoutVSTEncoderMP3() { Close(); }
bool ShoutVSTEncoderMP3::Initialize(const int bitrate, const int samplerate,
const int target_samplerate) {
guard lock(mtx_);
if (bInitialized) {
return false;
}
bInitialized = false;
k = 0;
gfp = lame_init();
if (!gfp) {
return false;
}
lame_set_in_samplerate(gfp, samplerate);
lame_set_preset(gfp, bitrate);
lame_set_bWriteVbrTag(gfp, 0);
lame_set_VBR(gfp, vbr_off);
lame_set_mode(gfp, JOINT_STEREO);
lame_set_num_channels(gfp, 2);
lame_set_brate(gfp, bitrate);
lame_set_original(gfp, 0);
lame_set_error_protection(gfp, 1);
lame_set_extension(gfp, 0);
lame_set_strict_ISO(gfp, 0);
lame_set_out_samplerate(gfp, target_samplerate);
if (lame_init_params(gfp) != 0) {
lame_close(gfp);
gfp = nullptr;
return false;
}
// LAME encoding call will accept any number of samples.
if (0 == lame_get_version(gfp)) {
// For MPEG-II, only 576 samples per frame per channel
wavBufferSize = 576 * lame_get_num_channels(gfp);
} else {
// For MPEG-I, 1152 samples per frame per channel
wavBufferSize = 1152 * lame_get_num_channels(gfp);
}
// Set MP3 buffer size, conservative estimate
mp3BufferSize =
(int)(1.25 * (wavBufferSize / lame_get_num_channels(gfp)) + 7200);
pMP3Buffer = new unsigned char[mp3BufferSize];
pWAVBuffer = new float[wavBufferSize];
bInitialized = true;
return true;
}
int ShoutVSTEncoderMP3::getBitrate() {
guard lock(mtx_);
if (!gfp) {
return 0;
}
return lame_get_brate(gfp);
}
bool ShoutVSTEncoderMP3::Close() {
guard lock(mtx_);
if (!bInitialized) {
return true;
}
bInitialized = false;
const int nOutputSamples = lame_encode_flush(gfp, pMP3Buffer, 0);
if (nOutputSamples > 0) {
libshout.SendDataToICE(pMP3Buffer, nOutputSamples);
}
lame_close(gfp);
delete[] pWAVBuffer;
delete[] pMP3Buffer;
return true;
}
bool ShoutVSTEncoderMP3::Process(float** inputs, VstInt32 sampleFrames) {
guard lock(mtx_);
if (!bInitialized) return false;
for (VstInt32 i(0); i < sampleFrames; i++) {
pWAVBuffer[k++] = inputs[0][i];
pWAVBuffer[k++] = inputs[1][i];
if (k >= wavBufferSize) {
k = 0;
const int len = lame_encode_buffer_interleaved_ieee_float(
gfp, pWAVBuffer, wavBufferSize / lame_get_num_channels(gfp),
pMP3Buffer, mp3BufferSize);
if (len < 0) {
return false;
}
if (!libshout.SendDataToICE(pMP3Buffer, len)) {
return false;
}
}
}
return true;
}