Я использую собственный код LAME для части моего приложения для Android. Этот код должен принимать строку, указывающую на входной файл (M4A), и строку на выходной файл (MP3). Я нашел некоторый код, который, кажется, из того, что я могу собрать, чтобы сделать такую вещь. Однако при воспроизведении файлов MP3 все, что я слышу, - это ZIP! звук. Независимо от того, как долго длится запись, я получаю один и тот же звук.
Я думал, что это как-то связано с частотой дискретизации, поэтому я попробовал все стандартные и получил почти такой же результат (некоторые почтовые индексы меньше ... молнии).
Вот единственный C-код, который мне удалось найти, однако я также открыт для использования C ++-решения.
#include <jni.h>
#include <string.h>
#include <stdio.h>
#include <android/log.h>
#include "lame.h"
#define DEBUG_TAG "WBA"
void Java_net_smartnotes_media_RawAudioRecorder_transcode(JNIEnv * env, jobject this, jstring from, jstring to) {
jboolean isCopy;
const char * szFrom = (*env)->GetStringUTFChars(env, from, &isCopy);
const char * szTo = (*env)->GetStringUTFChars(env, to, &isCopy);
__android_log_print(ANDROID_LOG_DEBUG, DEBUG_TAG, "NDK:LC: [%s]", szFrom);
__android_log_print(ANDROID_LOG_DEBUG, DEBUG_TAG, "NDK:LC: [%s]", szTo);
int read, write;
FILE *pcm = fopen(szFrom, "rb");
FILE *mp3 = fopen(szTo, "wb");
const int PCM_SIZE = 8192;
const int MP3_SIZE = 8192;
short int pcm_buffer[PCM_SIZE*2];
unsigned char mp3_buffer[MP3_SIZE];
lame_t lame = lame_init();
lame_set_in_samplerate(lame, 44100);
lame_set_VBR(lame, vbr_default);
lame_init_params(lame);
do {
read = fread(pcm_buffer, 2*sizeof(short int), PCM_SIZE, pcm);
if (read == 0)
write = lame_encode_flush(lame, mp3_buffer, MP3_SIZE);
else
write = lame_encode_buffer_interleaved(lame, pcm_buffer, read, mp3_buffer, MP3_SIZE);
fwrite(mp3_buffer, write, 1, mp3);
} while (read != 0);
lame_close(lame);
fclose(mp3);
fclose(pcm);
(*env)->ReleaseStringUTFChars(env, from, szFrom);
(*env)->ReleaseStringUTFChars(env, to, szTo);
}