2

私はAndroidプログラミングとオーディオの視覚化に不慣れです。MediaPlayerVisualizerクラスを使用して、簡単なオーディオビジュアライザーを作成したいと思います。wave form data私の問題は、私は本当に何であるかわからないということです。オーディオを視覚化するために使用する必要がありますか?以下のコードを使用しています。問題は、ファイルの最初の10〜12秒間だけオーディオを視覚化することです。その後、それ以上のデータをキャプチャできなくなります。どこで私は間違えましたか?

public void attachVisualizer()
{
    Visualizer vis = new Visualizer(mPlayer.getAudioSessionId());

    vis.setCaptureSize(Visualizer.getCaptureSizeRange()[0]);
    vis.setDataCaptureListener(new Visualizer.OnDataCaptureListener() {
        public void onWaveFormDataCapture(Visualizer visualizer, byte[] bytes, int samplingRate) {
            int sum = 0;

            for(int i = 0; i < bytes.length; i++) {
                sum += bytes[i];
            }

            if(sum > 8000) {
                // Do something which uses mPlayer.getCurrentPosition() in mathematics
            }
        }

        public void onFftDataCapture(Visualizer visualizer, byte[] fft, int samplingRate) {}
    }, Visualizer.getMaxCaptureRate() , true, false);

    vis.setEnabled(true);
}

編集
そして私の心のもう一つの質問は、どのように私は与えられたオーディオセグメントに含まれる時間の長さを記録するのですか?

4

1 に答える 1

3

私はこれをします:

visualizer = new Visualizer(0);
    visualizer.setEnabled(false);

    visualizer.setCaptureSize(Visualizer.getCaptureSizeRange()[0]);
    visualizer.setDataCaptureListener(
            new Visualizer.OnDataCaptureListener() {

                public void onWaveFormDataCapture(Visualizer visualizer,
                        byte[] bytes, int samplingRate) {
                    eqview.setVSWaveForm(bytes);
                }

                public void onFftDataCapture(Visualizer visualizer,
                        byte[] bytes, int samplingRate) {
                    fftview.setVSFftData(bytes);
                }
            }, Visualizer.getMaxCaptureRate(), true, true);
    visualizer.setEnabled(true);

ビジュアライザー ビューについては、このコードをオンラインで見つけました。私は書いていません。

package app.util;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Rect;
import android.util.AttributeSet;
import android.view.View;

/***
* 
* 
* @author yokmama
* 
*/
public class VisualizerView extends View {

private byte[] mBytes;

private float[] mPoints;

private Rect mRect = new Rect();
//SharedPreferences prefs;
private Paint mForePaint = new Paint();

public VisualizerView(Context context, AttributeSet attrs) {
    super(context, attrs);
    //prefs = PreferenceManager.getDefaultSharedPreferences(context);
    init();
}

private void init() {
    mBytes = null;
    //int colorchosen = prefs.getInt("COLOR_PREFERENCE_KEY",
    //      Color.WHITE);
    mForePaint.setStrokeWidth(1);
    //mForePaint.setAntiAlias(true);
    mForePaint.setColor(Color.WHITE);
    //mForePaint.setMaskFilter(new BlurMaskFilter(1, Blur.INNER));

}

public void updateVisualizer(byte[] bytes) {
    mBytes = bytes;
    invalidate();
}

@Override
protected void onDraw(Canvas canvas) {
    super.onDraw(canvas);

    if (mBytes == null) {
        return;
    }

    if (mPoints == null || mPoints.length < mBytes.length * 4) {
        mPoints = new float[mBytes.length * 4];
    }

    mRect.set(0, 0, getWidth(), getHeight());

    for (int i = 0; i < mBytes.length - 1; i++) {
        mPoints[i * 4] = mRect.width() * i / (mBytes.length - 1);
        mPoints[i * 4 + 1] = mRect.height() / 2
                + ((byte) (mBytes[i] + 128)) * (mRect.height() / 2) / 128;
        mPoints[i * 4 + 2] = mRect.width() * (i + 1) / (mBytes.length - 1);
        mPoints[i * 4 + 3] = mRect.height() / 2
                + ((byte) (mBytes[i + 1] + 128)) * (mRect.height() / 2)
                / 128;
    }

    canvas.drawLines(mPoints, mForePaint);
    //canvas.drawPoints(mPoints, mForePaint);
}

}

于 2012-08-11T07:16:09.863 に答える