任何人都可以通过编程方式帮助我如何将.mid
文件转换为.wav
或.mp3
格式的任何音频格式。
答案 0 :(得分:5)
我认为可以使用AudioRecorder直接从MediaPlayer录制,将Mediaplayer设置为录制器的音频源,但似乎有no way这样做。所以,我想到了两种非常不干净的方式:
1-大多数设备都有一个带3个通道的3.5mm插孔,2个用于立体声输出,1个用于麦克风输入。您需要的是一根电缆,它可以将三个信号分开,以便您可以将立体声输出连接到输入,进行短路,并从麦克风输入端录制midi。我用它将音频流源传递给手机,详细说明然后将其发送到第三台设备。我所说的电线非常类似于带有立体声音频+视频的RCA连接器,我知道这听起来很疯狂,但这取决于你正在做什么。
2-假设您在实际播放时不需要录制midi,您可以阅读midi文件,然后自己合成声音。这真的很难,特别是当必须处理不同乐器(琴弦,鼓等)的声音时,使用样本可能会减少工作量。
我知道这不是预期的答案,但它总比没有好,如果你非常渴望尝试其中一种方法,我可以提供一些示例代码和链接。
编辑:
好吧,那太疯了。我发现了另一种方法,使用Visualizer类。可视化器的目的不是让PCM记录它,而是(令人惊讶地)可视化声波,因此可能存在一些质量问题。但是,您可以将PCM保存为波形格式,为此,您必须向原始PCM阵列添加标头。对于wave文件格式,请查看here。这里有一个例子,它只是显示了在TextView中从MediaPlayer获取的字节数组,但它似乎有用......!android.permission.RECORD_AUDIO
android.permission.MODIFY_AUDIO_SETTINGS
activity_main.xml中
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity" >
<Button
android:id="@+id/btn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Play" />
<Button
android:id="@+id/btn2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Pause" />
<ScrollView
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<TextView
android:id="@+id/textview"
android:layout_width="fill_parent"
android:layout_height="wrap_content" />
</ScrollView>
MainActivity.java
package com.example.midify;
import java.util.Arrays;
import android.media.MediaPlayer;
import android.media.audiofx.Visualizer;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.app.Activity;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;
public class MainActivity extends Activity {
MediaPlayer mp;
TextView tv;
Visualizer mVisualizer;
Handler handler = new Handler() {
@Override
public void handleMessage(Message msg) {
tv.setText((String) msg.obj);
}
};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mp = MediaPlayer.create(this, R.raw.midi);
Button btn = (Button) findViewById(R.id.btn);
Button btn2 = (Button) findViewById(R.id.btn2);
tv = (TextView) findViewById(R.id.textview);
btn.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View arg0) {
if (!mp.isPlaying()) {
mp.start();
init_visualizer();
}
}
});
btn2.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View arg0) {
if (mp.isPlaying()) {
mp.pause();
mVisualizer.release();
}
}
});
}
@Override
public void finish() {
mp.release();
mVisualizer.release();
super.finish();
}
private void PassData(byte[] data) {
String txt = Arrays.toString(data);
Message msg = handler.obtainMessage();
msg.obj = txt;
handler.sendMessage(msg);
}
public void init_visualizer() {
mVisualizer = new Visualizer(mp.getAudioSessionId());
mVisualizer.setCaptureSize(Visualizer.getCaptureSizeRange()[1]);
Visualizer.OnDataCaptureListener captureListener = new Visualizer.OnDataCaptureListener() {
@Override
public void onWaveFormDataCapture(Visualizer visualizer,
byte[] bytes, int samplingRate) {
PassData(bytes);
}
@Override
public void onFftDataCapture(Visualizer visualizer, byte[] bytes,
int samplingRate) {
}
};
mVisualizer.setDataCaptureListener(captureListener,
Visualizer.getMaxCaptureRate(), true, false);
mVisualizer.setEnabled(true);
mp.setOnCompletionListener(new MediaPlayer.OnCompletionListener() {
@Override
public void onCompletion(MediaPlayer mediaPlayer) {
mVisualizer.setEnabled(false);
}
});
}
}