MPAndroidChart BarChart Grouped DataSet

时间:2014-11-11 23:50:19

标签: android mpandroidchart

我正在使用MPAndroidChart library版本v2。我正在尝试显示3个条形图,数据来自数据库。 不幸的是,不是看到3个条形数据,而是使用相同的结果查看它们。查看截图。谢谢你的帮助。

int [] x = {1,2,3};
Cursor c = db.rawQuery(sql, null);
        int count = c.getCount();

        float value1 ;
        float value2 ;
        float value3 ;
        String[] mesi = new String[count];

        for(int n=0; n<count; n++) {
            c.moveToNext();     
            mesi[n]= c.getString(0);              
            value1 = c.getFloat(1);
            value2 = c.getFloat(2);
            value3 = c.getFloat(3);

            ArrayList<String> xVals = new ArrayList<String>();
            for (int i = 0; i <x.length; i++) {
                 xVals.add(x.length + " " + mChart.getUnit());              
            }

            ArrayList<BarEntry> yVals1 = new ArrayList<BarEntry>();
            ArrayList<BarEntry> yVals2 = new ArrayList<BarEntry>();
            ArrayList<BarEntry> yVals3 = new ArrayList<BarEntry>();

            for (int i = 0; i < x.length; i++) {                  
                yVals1.add(new BarEntry(value1, i));
            }

            for (int i = 0; i < x.length; i++) {                
                yVals2.add(new BarEntry(value2, i));
            }

            for (int i = 0; i < x.length; i++) {                  
                yVals3.add(new BarEntry(value3, i));
            }

         // create 3 datasets with different types
            BarDataSet set1 = new BarDataSet(yVals1, "Company A");
            set1.setColor(Color.rgb(104, 241, 175));
            BarDataSet set2 = new BarDataSet(yVals2, "Company B");
            set2.setColor(Color.rgb(164, 228, 251));
            BarDataSet set3 = new BarDataSet(yVals3, "Company C");
            set3.setColor(Color.rgb(242, 247, 158));

            ArrayList<BarDataSet> dataSets = new ArrayList<BarDataSet>();
            dataSets.add(set1);
            dataSets.add(set2);
            dataSets.add(set3);

            BarData data = new BarData(xVals, dataSets);

            // add space between the dataset groups in percent of bar-width
            data.setGroupSpace(0);

            mChart.setData(data);
            mChart.invalidate();

}               
        c.close();  
    db.close();

}

结果enter image description here

1 个答案:

答案 0 :(得分:4)

您是否对图表应显示的值进行了logcat输出? 也许它们没有正确存储在数据库中。

您的代码对我来说似乎是正确的。

您也可以通过简单地提供预定义的值来测试它,例如所有条形图都是50,看它是否正确绘制。

更改颜色调用:

BarDataSet.setColor(...);

更新:现在有一个非常详细的教程,介绍如何根据版本v3.0.0在库的官方GitHub页面上创建可用的分组BarCharts:{{3} }