首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >从数据库中检索数据,并使用android中的MPAndroidChart在条形图中显示这些数据

从数据库中检索数据,并使用android中的MPAndroidChart在条形图中显示这些数据
EN

Stack Overflow用户
提问于 2016-02-08 21:14:41
回答 1查看 5.6K关注 0票数 1

我知道如何使用MPAndroidChart在条形图中显示原始数据,但在实际场景中我遇到了问题。我在我的sqlite数据库中有一些数据,我想在条形图中显示它们。请给我一些参考或简单的例子。

数据库表有两列、月份和一些数字。例:一月= 200,二月= 300等。

我已经搜过很多次了,但找不到合适的。他们要么是2-3岁,要么不是我提到的那种。

提前谢谢。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-02-09 19:44:36

这是我问题的答案。这两种方法可以将x轴数据和y轴数据存储在数组中.

代码语言:javascript
运行
复制
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;
}

这是显示条形图的另一种方法。在您的活动中调用此方法。

代码语言:javascript
运行
复制
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);

}

如果你觉得这有帮助,请告诉我。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35279448

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档