在VisualizerView中增加条的高度

时间:2015-02-04 08:43:33

标签: android bar-chart visualizer

我在我的应用中使用this visualizerView。我想知道如何增加酒吧的高度。

public class BarGraphRenderer extends Renderer
{
  private int mDivisions;
  private Paint mPaint;
  private boolean mTop;

  /**
   * Renders the FFT data as a series of lines, in histogram form
   * @param divisions - must be a power of 2. Controls how many lines to draw
   * @param paint - Paint to draw lines with
   * @param top - whether to draw the lines at the top of the canvas, or the bottom
   */
  public BarGraphRenderer(int divisions,
                          Paint paint,
                          boolean top)
  {
    super();
    mDivisions = divisions;
    mPaint = paint;
    mTop = top;
  }

  @Override
  public void onRender(Canvas canvas, AudioData data, Rect rect)
  {
    // Do nothing, we only display FFT data
  }

  @Override
  public void onRender(Canvas canvas, FFTData data, Rect rect)
  {
    for (int i = 0; i < data.bytes.length / mDivisions; i++) {
      mFFTPoints[i * 4] = i * 4 * mDivisions;
      mFFTPoints[i * 4 + 2] = i * 4 * mDivisions;
      byte rfk = data.bytes[mDivisions * i];
      byte ifk = data.bytes[mDivisions * i + 1];
      float magnitude = (rfk * rfk + ifk * ifk);
      int dbValue = (int) (10 * Math.log10(magnitude));

      if(mTop)
      {
        mFFTPoints[i * 4 + 1] = 0;
        mFFTPoints[i * 4 + 3] = (dbValue * 2 - 10);
      }
      else
      {
        mFFTPoints[i * 4 + 1] = rect.height();
        mFFTPoints[i * 4 + 3] = rect.height() - (dbValue * 2 - 10);
      }
    }

    canvas.drawLines(mFFTPoints, mPaint);
  }
}

2 个答案:

答案 0 :(得分:0)

尝试使用以下代码

int size=3; 
if(mTop)
  {
    mFFTPoints[i * 4 + 1] = 0;
    mFFTPoints[i * 4 + 3] = (dbValue * size - 10);
  }
  else
  {
    mFFTPoints[i * 4 + 1] = rect.height();
    mFFTPoints[i * 4 + 3] = rect.height() - (dbValue * size - 10);
  }
}

您可以更改增加VisualizerView栏的值(大小)

答案 1 :(得分:0)

这对我有用......

只需更改代码中的值(即10)即可。为了更大的价值。我使用了100对我来说很好用。希望有所帮助!

int dbValue = (int) (10 * Math.log10(magnitude));