Android 个人理财工具显示账单明细

时间:2022-07-01 23:53:29 理财 我要投稿
  • 相关推荐

Android 个人理财工具显示账单明细

  前面我们已经将每个月的收支明细存入到SQLite的数据表中,本文将实现从SQLite的数据表中取出这些数据显示为账单明细界面。

  下图是最终的效果图:

  在设计该界面时我考虑过好几个方案。本来准备使用一个gridview,因为觉得名字很像我需要的东西。可是后来查了一些资料,并且做了点实验,发现和我想象的有些差距。于是采用了目前这种方式。使用Listview。

  这个界面布局实际上很简单,就是上面一个表头(Linearlayout),中间一个Listview,下面是一个脚注(Linearlayout)。

  如何实现listview其中内容?这个主要就是要理解Adapter的用法。

  SimpleCursorAdapter(Context context, int layout, Cursor c, String[] from, int[] to)

  Java代码

  String[] from=new String[] {"rowid","name", "fee","sdate","desc" }; int[] to=new int[] { R.id.item1, R.id.item2,R.id.item3,R.id.item4,R.id.item5 }; SimpleCursorAdapter mAdapter=new SimpleCursorAdapter(this,R.layout.grid_items, cur,from, to); lv.setAdapter(mAdapter);

  这里我们只需要准备好view的样式和cursor就可以了。

  例如本例中的

  R.layout.grid_items是

  XML/HTML代码

  <"1.0" encoding="utf-8">/>

  在Adapter中的to 参数中,指定这些TextView使用那些Cursor的值。

  我的cursor就是含有这些字段"rowid","name","fee","sdate","desc"。

  准备好这些,使用lv.setAdapter(mAdapter)方法就可以绑定了。

  下面给出具体代码文件:

  Grid_bills.java

  Java代码

  package com.cola.ui; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import android.app.Activity; import android.database.Cursor; import android.os.Bundle; import android.util.Log; import android.view.KeyEvent; import android.view.View; import android.widget.AbsoluteLayout; import android.widget.EditText; import android.widget.GridView; import android.widget.LinearLayout; import android.widget.ListView; import android.widget.SimpleCursorAdapter; import android.widget.TextView; public class Grid_bills extends Activity { BilldbHelper billdb; View sv; EditText edit; AbsoluteLayout alayout; int a=10,b=10; GridView grd; TextView total; protected GridView listHands = null ; public void onCreate(Bundle icicle) { super.onCreate(icicle); setTitle("ColaBox-账单明细(2008-11月)"); setContentView( R.layout.grid_bills) ; billdb = new BilldbHelper(this); Cursor cur=billdb.getBills(); ListView lv=(ListView)findViewById(R.id.listview); String[] from=new String[] {"rowid","name", "fee","sdate","desc" }; int[] to=new int[] { R.id.item1, R.id.item2,R.id.item3,R.id.item4,R.id.item5 }; SimpleCursorAdapter mAdapter=new SimpleCursorAdapter(this,R.layout.grid_items, cur,from, to); lv.setAdapter(mAdapter); //getBillsTotal total=(TextView)findViewById(R.id.totalitem); total.setText(billdb.getBillsTotal("2008-11")); }

  grid_item.xml

  XML/HTML代码

  <"1.0" encoding="utf-8">/>/>

  这次我在sqlite的sql上面遇到点麻烦,目前还没搞定,就是我保存在数据库中的费用是int型,分为单位。我从数据库中取出来是 select fee/100 from bills ;但是显示的却是取整后的数值。

  不知道正确语法应该是什么样子,后面我想拼成字符显示应该可以,我就试了 select fee/100||' from bills;,这样就可以在listview上面输出小数。可是我发现999999.99/100 输出却是1000000。我在adb shell里面查询还是999999.99,到了listview时就变成了1000000,我估计可能是Adapter 里面的字符取出来用了getString的方法。

【Android 个人理财工具显示账单明细 】相关文章:

Extjs Panel 显示多行工具栏07-09

大数据分析工具minitab:[1]显示描述性统计07-10

重庆社保个人账户明细07-07

android 责任链模式07-02

android项目责任描述07-02

android就业前景201607-03

个人如何理财07-03

android转正自我鉴定07-02

2016android就业前景07-03

个人如何理财投资07-03