Hej、現在 AudioRecord を動作させようとしています。より大きなプロジェクトで必要だからです。でもめちゃくちゃ混むらしい。私は多くのことを試してきたので、このバグを追跡したときに基本に戻りました. Samsung Galaxy S をデバッグデバイスとして使用しています。
私の問題は、デバイスの再起動後に初めて、作成した AudioRecord オブジェクトを問題なく初期化できることです。しかし、2 回目に実行すると、AudioRecord オブジェクトが初期化されません。私はいくつかの周波数を試しました。
これが私のコードです:
package android.audiorecordtest;
import android.app.Activity;
import android.media.AudioFormat;
import android.media.AudioRecord;
import android.media.MediaRecorder;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;
public class AudioRecordTest extends Activity {
int frequency;
AudioRecord audRec;
TextView txtVw;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
txtVw = (TextView) findViewById(R.id.txtVw);
frequency=8000;
int bufferSize=(AudioRecord.getMinBufferSize(frequency, AudioFormat.CHANNEL_IN_MONO, AudioFormat.ENCODING_PCM_16BIT))*2;
if (bufferSize>0) {
audRec = new AudioRecord(MediaRecorder.AudioSource.MIC, frequency, AudioFormat.CHANNEL_IN_MONO, AudioFormat.ENCODING_PCM_16BIT, bufferSize);
int status = audRec.getState();
if (status == AudioRecord.STATE_INITIALIZED) {
txtVw.setText("Initialized" + frequency);
} else {
txtVw.setText("Not Initialized i=" + frequency);
}
}
logcat情報を数時間調べた後、このイベントを見つけました
02-28 10:46:37.048: DEBUG/dalvikvm(4477): GC_EXPLICIT freed 1801 objects / 98944 bytes in 97ms
02-28 10:46:37.048: VERBOSE/AudioRecord(4477): stop
「AudioRecordのネイティブホールドを解放するようです。だから、Audiorecord object.release()でファイナライズのオーバーライドを試みました。しかし、これはうまくいきませんでした..誰かに何か考えがありますか?