在android中使用SQLite数据库数据显示XY图表

时间:2012-03-19 12:32:52

标签: android android-activity

我在SQLite数据库中有电池充电连接时间(日期时间字段 - 表示为字符串)和TimeToCharge(秒 - 可以显示为浮动,如果需要)。我想在X轴上显示连接时间的XY图和在y轴上充电的时间。我用Google搜索并在android中找到了很多图表api或jar,但是在实现了一些像kiChart之后,我有点困惑,这是我的要求,在android中哪个图表解决方案最适合。我不想显示一个非常动态/高细节的图表,但是然后尝试使用每个图表解决方案,会耗费大量时间。

所以,我可以肯定地尝试并实现一个能满足我要求的那个。你能指导一下,你认为哪一个是最好的免费制图解决方案。

由于 Omkar Ghaisas

public class BatteryGraph extends Activity 
{
/** Called when the activity is first created. */
private XYMultipleSeriesDataset mDataset;
private XYMultipleSeriesRenderer mRenderer;
List<double[]> values = new ArrayList<double[]>();
private GraphicalView mChartView;
private TimeSeries time_series;

// chart container
private LinearLayout layout;

@SuppressWarnings("deprecation")
@Override
protected void onCreate(Bundle savedInstanceState) {

    super.onCreate(savedInstanceState);
    setContentView(R.layout.graph);

    layout = (LinearLayout) findViewById(R.id.chart);

    // create dataset and renderer
    mDataset = new XYMultipleSeriesDataset();
    mRenderer = new XYMultipleSeriesRenderer();
    mRenderer.setAxisTitleTextSize(16);
    mRenderer.setChartTitleTextSize(20);
    mRenderer.setLabelsTextSize(15);
    mRenderer.setLegendTextSize(15);
    mRenderer.setPointSize(5f);
    mRenderer.setMargins(new int[] {0,20,20,0});

    XYSeriesRenderer r = new XYSeriesRenderer();
    r.setColor(Color.YELLOW);
    r.setPointStyle(PointStyle.POINT);
    r.setFillPoints(true);
    mRenderer.addSeriesRenderer(r);
    mRenderer.setClickEnabled(true);
    mRenderer.setSelectableBuffer(20);
    mRenderer.setPanEnabled(true);
    mRenderer.setFitLegend(true);
    mRenderer.setDisplayChartValues(true);
    mRenderer.setInScroll(true);
    mRenderer.setShowGrid(true);
    mRenderer.setOrientation(Orientation.HORIZONTAL);
    mRenderer.setShowLabels(true);
    mRenderer.setXLabelsAngle(60);
    mRenderer.setXTitle("Date");
    mRenderer.setYTitle("Time in Secs");

    time_series = new TimeSeries("Charging Date vs TimeTakenToCharge");

    mDataset.addSeries(time_series);

    fillData();

    mChartView = ChartFactory.getTimeChartView(this, mDataset, mRenderer, "dd/mm/yy");

    layout.addView(mChartView);
}

private void fillData() 
{
    DatabaseAppBlock dbHelper = new DatabaseAppBlock(getApplicationContext());
    Cursor chargeCycleData = dbHelper.getAllChargeCycleData("Asc");
    int rowCount = chargeCycleData.getCount();

    if(rowCount > 0)
    {
        chargeCycleData.moveToFirst(); 
        for (int i = 0; i < rowCount ; i++) 
        {              

time_series.add(CommonFunc.GetDateFromString(chargeCycleData.getString(chargeCycleData.getColumnIndex(Constants.colChargeConnectTime))),chargeCycleData.getDouble(chargeCycleData.getColumnIndex(Constants.colTimeToCharge))); chargeCycleData.moveToPosition(i+1); }         }
    } }

1 个答案:

答案 0 :(得分:1)

AChartEngine易于使用,并提供TimeChart类。这是一个带有时间/日期轴的XY图表,用于处理日期显示本身。 AChartEngine演示包含TimeChart的示例代码。