如果每个条形的颜色不同且包含不同的值,使用Achartengine如何在条形图中制作间距?

10

我正在展示一个条形图,其中每个条形都是不同颜色的,展示了4个值。当我展示这个图时,每个条形重叠在一起。我想在条形之间留出空间,我尝试使用 setBarSpacing() 并放置不同的值,但仍然没有效果。是否有其他想法。

package com.example.barchartview;

import org.achartengine.ChartFactory;
import org.achartengine.GraphicalView;
import org.achartengine.chart.BarChart.Type;
import org.achartengine.model.CategorySeries;
import org.achartengine.model.XYMultipleSeriesDataset;
import org.achartengine.renderer.XYMultipleSeriesRenderer;
import org.achartengine.renderer.XYSeriesRenderer;
import android.os.Bundle;
import android.annotation.SuppressLint;
import android.app.Activity;
import android.graphics.Color;
import android.view.View;
import android.widget.LinearLayout;


@SuppressLint("ParserError")
public class MainActivity extends Activity {
    private GraphicalView BarChartView;


    @SuppressLint("ParserError")
    @Override
        public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        if (BarChartView==null )
        {

        XYMultipleSeriesRenderer renderer = buildBarRenderer();
        setChartSettings(renderer);
        BarChartView  = ChartFactory.getBarChartView(this, getBarDataset(), renderer, Type.DEFAULT);
        LinearLayout playout = (LinearLayout) findViewById(R.id.graph2);
        playout.addView(BarChartView);
        ;

        }
        else
        {
            BarChartView.repaint();
            BarChartView.setVisibility(View.GONE);
        }
    }

    private void setChartSettings(XYMultipleSeriesRenderer renderer)
    {
        renderer.setYTitle("Hits");
        renderer.setXAxisMin(0);
        renderer.setXAxisMax(7);
        renderer.setYAxisMin(0);
        renderer.setYAxisMax(900);
    }
    private XYMultipleSeriesDataset getBarDataset()
    {
        int[] y = {624,430,712,323};
        CategorySeries series1 = new CategorySeries("A");
        CategorySeries series2 = new CategorySeries("B");
        CategorySeries series3 = new CategorySeries("C");
        CategorySeries series4 = new CategorySeries("D");

        XYMultipleSeriesDataset dataset = new XYMultipleSeriesDataset();

        series1.add(y[0]);
        dataset.addSeries(series1.toXYSeries());

        series2.add(y[1]);
        dataset.addSeries(series2.toXYSeries());

        series3.add(y[2]);
        dataset.addSeries(series3.toXYSeries());

        series4.add(y[3]);
        dataset.addSeries(series4.toXYSeries());

        return dataset;
    }
    protected XYMultipleSeriesRenderer buildBarRenderer() {
        XYMultipleSeriesRenderer mrenderer = new XYMultipleSeriesRenderer();

        double[] range = {0,5,0,5};

        mrenderer.setAxisTitleTextSize(16);
        mrenderer.setChartTitleTextSize(20);
        mrenderer.setLabelsTextSize(15);
        mrenderer.setLegendTextSize(15);
        mrenderer.setBarSpacing(0);
        mrenderer.setXLabels(1);
        mrenderer.addXTextLabel(2.5, "");
        mrenderer.setMargins(new int[] {20, 30, 15, 0});
        mrenderer.setAxesColor(Color.WHITE);
        mrenderer.setChartTitle("");
        mrenderer.setXTitle("");
        mrenderer.setInitialRange(range, 1);

        XYSeriesRenderer renderer1 = new XYSeriesRenderer();
        renderer1.setColor(Color.GREEN);
        XYSeriesRenderer renderer2 = new XYSeriesRenderer();
        renderer2.setColor(Color.RED);
        XYSeriesRenderer renderer3 = new XYSeriesRenderer();
        renderer3.setColor(Color.BLUE);
        XYSeriesRenderer renderer4 = new XYSeriesRenderer();
        renderer4.setColor(Color.CYAN);

        mrenderer.addSeriesRenderer(renderer1);
        mrenderer.addSeriesRenderer(renderer2);
        mrenderer.addSeriesRenderer(renderer3);
        mrenderer.addSeriesRenderer(renderer4);

        return mrenderer;
    }
}

这是我的代码。

这是我的activity_main.xml文件。

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/mainActivity"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >

    <LinearLayout android:id="@+id/graph2"
       android:layout_width="160dip"
        android:layout_height="200dip"
        android:scaleType="fitEnd"
        android:layout_marginTop="40dip"
        android:layout_marginLeft="790dip"/>

  </RelativeLayout>

1
您正在调用许多方法两次,包括 setBarSpacing()。您修改的是第一个还是第二个 setBarSpacing()?(应该删除重复调用,因为它们无效。) - Sam
setBarSpacing() 方法在不同索引处的柱形之间添加缓冲区,而你的四个柱形都在相同的索引上。你可以切换到只使用一个渲染器和数据集:截图,所有柱形都具有相同的颜色。我不知道如何在相同索引的柱形之间添加间距。 - Sam
我知道如果条形图中的条柱颜色相同,如何在它们之间留出空间。但是在这个图表中,能否让每个条柱有不同的索引呢? - Abhijit Chakra
@rickky,你刚刚接受了一个几乎完全复制我的答案的回答。真是太好了! - Dan D.
我也遇到了这个问题,http://stackoverflow.com/questions/16355225/achartengine-xymultipleseriesrenderer-renderes-chart-for-null-values-and-shows-u 请分享代码。 - user2190720
显示剩余3条评论
1个回答

3

我将所有的系列更改为XYSeries并将它们简单地添加到dataset中,而无需调用额外的方法。

XYSeries series1 = new XYSeries("A");
dataset.addSeries(series1);

然后,像普通的XYChart那样添加数据,如下所示:
series1.add(1, value);
series2.add(2, value);

你能帮我吗?这是我的问题链接:https://dev59.com/mW7Xa4cB1Zd3GeqPpWnN - moDev

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接