无法使用MPAndroidChart绘制甜甜圈图像,类似于饼图

4

我正在使用MPAndroidChart,并尝试使用mpandroidchart库创建一个类似甜甜圈的饼图,但是无论如何我都无法做到。 以下是我的代码-

ArrayList<Entry> entries = new ArrayList<>();
        entries.add(new Entry((float) 20.0, 0));
        entries.add(new Entry((float) 30.0, 1));

        int colors[] = {Color.parseColor("#DCDEE0"),Color.parseColor("#466A80"),Color.parseColor("#0078CA"),Color.parseColor("#5BC2E7"),Color.parseColor("#99E4FF")};
        PieDataSet dataset = new PieDataSet(entries, "# of Calls");
        dataset.setColors(colors);
        dataset.setSliceSpace(3f);
        ArrayList<String> labels = new ArrayList<String>();
        labels.add("January"); 
        labels.add("February"); 
    /*  labels.add("March"); 
        labels.add("April"); 
        labels.add("May");
        labels.add("June");*/

        PieChart chart1 = new PieChart(this);
        chart1.setLayoutParams(new LinearLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT, 0.5f));
        chart1.setHoleRadius(60f);
        chart1.setHoleColorTransparent(false);
        chart1.setDrawHoleEnabled(true);
        chart1.setUsePercentValues(true);
        chart1.setHoleColor(Color.WHITE);
        PieChart chart2 = new PieChart(this);
        chart2.setLayoutParams(new LinearLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT, 0.5f));
        LinearLayout chart = (LinearLayout)findViewById(R.id.chart);
        chart.addView(chart1);
        chart.addView(chart2);

        PieData data = new PieData(labels, dataset);
        chart1.setData(data);
        chart2.setData(data);

我能画出饼图,但无法让它看起来像一个甜甜圈。请参考附加的屏幕截图。有人可以帮忙吗?

你使用的是哪个Android版本? - Philipp Jahoda
我使用的是Android 2.3。 - Agr1909
3个回答

3

是的,尝试使用这段代码:=

public class piechart extends ActionBarActivity {

    RelativeLayout mainLayout;
   PieChart mChart;
    // we're going to display pie chart for smartphones martket shares
   float[] yData = { 15, 10, 15, 8, 4,10 };
   String[] xData = { "Technical excellence", "Nimble", "Innovation", "Integrity", "Colloboration","Passion" };

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_piechart);
        mainLayout = (RelativeLayout) findViewById(R.id.mainLayout);
        mChart = new PieChart(this);

        mainLayout.addView(mChart);
        mainLayout.setBackgroundColor(Color.parseColor("#ffffff"));

        // configure pie chart
        mChart.setUsePercentValues(true);
        mChart.setDescription("Employee Analysis");

        // enable hole and configure
        mChart.setDrawHoleEnabled(true);
        mChart.setHoleColorTransparent(true);
        mChart.setHoleRadius(7);
        mChart.setTransparentCircleRadius(10);

        // enable rotation of the chart by touch
        mChart.setRotationAngle(0);
        mChart.setRotationEnabled(true);

        // set a chart value selected listener
        mChart.setOnChartValueSelectedListener(new OnChartValueSelectedListener() {

            @Override
            public void onValueSelected(Entry e, int dataSetIndex, Highlight h) {
                // display msg when value selected
                if (e == null)
                    return;

                Intent i=new Intent(piechart.this,Nimble.class);
                startActivity(i);
            }

            @Override
            public void onNothingSelected() {

            }
        });

        // add data
        addData();

        // customize legends
        Legend l = mChart.getLegend();
        l.setPosition(Legend.LegendPosition.RIGHT_OF_CHART);
        l.setXEntrySpace(7);
        l.setYEntrySpace(5);

    }

    private void addData() {
        ArrayList<Entry> yVals1 = new ArrayList<Entry>();

        for (int i = 0; i < yData.length; i++)
            yVals1.add(new Entry(yData[i], i));

        ArrayList<String> xVals = new ArrayList<String>();

        for (int i = 0; i < xData.length; i++)
            xVals.add(xData[i]);

        // create pie data set
        PieDataSet dataSet = new PieDataSet(yVals1, "Market Share");
        dataSet.setSliceSpace(3);
        dataSet.setSelectionShift(5);

        // add many colors
        ArrayList<Integer> colors = new ArrayList<Integer>();

        for (int c : ColorTemplate.VORDIPLOM_COLORS)
            colors.add(c);

        for (int c : ColorTemplate.JOYFUL_COLORS)
            colors.add(c);

        for (int c : ColorTemplate.COLORFUL_COLORS)
            colors.add(c);

        for (int c : ColorTemplate.LIBERTY_COLORS)
            colors.add(c);

        for (int c : ColorTemplate.PASTEL_COLORS)
            colors.add(c);

        colors.add(ColorTemplate.getHoloBlue());
        dataSet.setColors(colors);

        // instantiate pie data object now
        PieData data = new PieData(xVals, dataSet);
        data.setValueFormatter(new PercentFormatter());
        data.setValueTextSize(11f);
        data.setValueTextColor(Color.GRAY);

        mChart.setData(data);

        // undo all highlights
        mChart.highlightValues(null);

        // update pie chart
        mChart.invalidate();
        mChart.getLegend().setEnabled(false);
    }

2

感谢 @philipp,我会在最新版本上检查这个问题。 - Agr1909

1

我面临同样的问题,以下是解决方法

    final int[] My_COLORS = { Color.rgb(206, 37, 42), Color.rgb(0, 255, 0), Color.rgb(0, 0, 255)
};

    ArrayList<Integer> colors = new ArrayList<Integer>(); 

    for (int c : My_COLORS)
        colors.add(c);
    dataSet.setColors(colors);

你能解释一下你的答案吗?仅仅发布代码通常不足以解释解决方案。 - SuperBiasedMan

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