2

アンドロイドの棒グラフの棒の間のスペースに言及する方法は?

ここに画像の説明を入力してください 前もって感謝します!..

画像の上に、私の疑問がはっきりとわかります。

青いバーは実際には対応するx軸の値に適合していません。ここに(Ord_1、Ord_2、Ord_3、Ord_4)があります。

これらのバーをx軸の値に合わせて表示する必要があります。これを行うにはどうすればよいですか?

以下の私の情報源を見つけてください

BarChart.java

public class BarChart extends Activity 
{
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) 
{
    super.onCreate(savedInstanceState);
    Intent intent = createIntent();
    startActivity(intent);
}

public Intent createIntent() 
{
    String[] titles = new String[] { "Profits per order", " " };

    List<double[]> values = new ArrayList<double[]>();

    values.add(new double[] { 6, 9, 21, 3 });
    values.add(new double[] { 0, 0, 0, 0});


    int[] colors = new int[] { Color.BLUE, Color.BLACK };

    XYMultipleSeriesRenderer renderer = buildBarRenderer(colors);
    renderer.setOrientation(Orientation.HORIZONTAL);

    setChartSettings(renderer, "Profit of the year 2012", " ", " ", 0,30, 0,30, Color.GRAY, Color.LTGRAY);

    renderer.setXLabels(1);
    renderer.setYLabels(10);

    renderer.addXTextLabel(2.75, "Ord_1");
    renderer.addXTextLabel(6.75, "Ord_2");
    renderer.addXTextLabel(10.75, "Ord_3");
    renderer.addXTextLabel(14.75,"Ord_4");

    renderer.setBarSpacing(-1.75);

    int length = renderer.getSeriesRendererCount();

    for (int i = 0; i < length; i++) 
    {
      SimpleSeriesRenderer seriesRenderer = renderer.getSeriesRendererAt(i);
      seriesRenderer.setDisplayChartValues(false);
    }

    return ChartFactory.getBarChartIntent(this, buildBarDataset(titles, values), renderer,
        Type.DEFAULT);
  }

protected XYMultipleSeriesRenderer buildBarRenderer(int[] colors) 
{

    // creates a SeriesRenderer and initializes it with useful default values as well as colors

    XYMultipleSeriesRenderer renderer = new XYMultipleSeriesRenderer();

    renderer.setAxisTitleTextSize(16);
    renderer.setChartTitleTextSize(20);
    renderer.setLabelsTextSize(15);
    renderer.setLegendTextSize(15);

    int length = colors.length;

    for (int i = 0; i < length; i++) 
    {
      SimpleSeriesRenderer r = new SimpleSeriesRenderer();
      r.setColor(colors[i]);
      renderer.addSeriesRenderer(r);
    }
    return renderer;
  }

protected void setChartSettings(XYMultipleSeriesRenderer renderer, String title, String xTitle,
          String yTitle, double xMin, double xMax, double yMin, double yMax, int axesColor,
          int labelsColor) 
{
// sets lots of default values for this renderer

    renderer.setChartTitle(title);
    renderer.setXTitle(xTitle);
    renderer.setYTitle(yTitle);
    renderer.setXAxisMin(xMin);
    renderer.setXAxisMax(xMax);
    renderer.setYAxisMin(yMin);
    renderer.setYAxisMax(yMax);
    renderer.setAxesColor(axesColor);
    renderer.setLabelsColor(labelsColor);

    renderer.setApplyBackgroundColor(true);
    renderer.setBackgroundColor(Color.BLACK);


}

protected XYMultipleSeriesDataset buildBarDataset(String[] titles, List<double[]> values) 
{

    // adds the axis titles and values into the dataset

    XYMultipleSeriesDataset dataset = new XYMultipleSeriesDataset();
    int length = titles.length;

    for (int i = 0; i < length; i++) 
    {
      CategorySeries series = new CategorySeries(titles[i]);
      double[] v = values.get(i);
      int seriesLength = v.length;

      for (int k = 0; k < seriesLength; k++) 
      {
        series.add(v[k]);
      }
      dataset.addSeries(series.toXYSeries());
     }
    return dataset;
}
}
4

1 に答える 1

2

setChartSettingsX軸の視覚的範囲を0〜30に設定し、Y軸にも同じように設定するいくつかのパラメーターを使用して呼び出しています。これらのパラメータを微調整して、よりリラックスした表示にすることができます。

renderer.setBarSpacing()負の値で呼び出しています。正の値を使用し、最初に0.5f(間隔がバーの厚さの半分に等しいことを意味します)、必要に応じて微調整します。

于 2012-08-28T10:16:12.967 に答える