我知道如何使用MPAndroidChart在条形图中显示原始数据但我在实际场景中遇到了问题。我的sqlite数据库中有一些数据,我想在条形图中显示它们。请给我一些参考或简单的例子。
数据库表有两个月的月份和一些数字。例如:Jan = 200,Feb = 300等。
我搜索了很多但找不到合适的。它们要么是2-3岁,要么不是我提到的类型。
提前致谢。
答案 0 :(得分:4)
以下是我的问题的答案。 这两种方法可以将x轴数据和y轴数据存储在数组中。
public ArrayList<String> queryXData(){
ArrayList<String> xNewData = new ArrayList<String>();
String query = "SELECT " + DAILY_DATE + " FROM " + TABLE_DAILY_FRAG;
Cursor cursor = mSQLiteDatabase.rawQuery(query, null);
for (cursor.moveToFirst(); !cursor.isAfterLast(); cursor.moveToNext()) {
xNewData.add(cursor.getString(cursor.getColumnIndex(DAILY_DATE)));
}
cursor.close();
return xNewData;
}
public ArrayList<Float> queryYData(){
ArrayList<Float> yNewData = new ArrayList<Float>();
String query = "SELECT " + DAILY_TOTAL + " FROM " + TABLE_DAILY_FRAG;
Cursor cursor = mSQLiteDatabase.rawQuery(query, null);
for (cursor.moveToFirst(); !cursor.isAfterLast(); cursor.moveToNext()) {
yNewData.add(cursor.getFloat(cursor.getColumnIndex(DAILY_TOTAL)));
}
cursor.close();
return yNewData;
}
这是显示条形图的另一种方法。在您的活动中调用此方法。
private void addData(){
ArrayList<BarEntry> yVals = new ArrayList<BarEntry>();
for (int i = 0; i < mExpenseDB.queryYData().size(); i++)
yVals.add(new BarEntry(mExpenseDB.queryYData().get(i), i));
ArrayList<String> xVals = new ArrayList<String>();
for(int i = 0; i < mExpenseDB.queryXData().size(); i++)
xVals.add(mExpenseDB.queryXData().get(i));
BarDataSet dataSet = new BarDataSet(yVals, "expense values");
dataSet.setColors(ColorTemplate.COLORFUL_COLORS);
BarData data = new BarData(xVals, dataSet);
LimitLine line = new LimitLine(12f, "average daily expense");
line.setTextSize(12f);
line.setLineWidth(4f);
YAxis leftAxis = barChart.getAxisLeft();
leftAxis.addLimitLine(line);
barChart.setData(data);
barChart.setDescription("The expenses chart.");
barChart.animateY(2000);
}
如果您发现这有用,请与我们联系。