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代码
<?xml version="1.0" encoding="utf-8"?> <linearlayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="horizontal" android:layout_width="fill_parent" android:layout_height="fill_parent"> <textview android:id="@+id/item1" android:layout_height="fill_parent" android:layout_width="wrap_content" android:width="20dip" /> <textview android:id="@+id/item2" android:layout_height="fill_parent" android:text="账目" android:width="60dip" android:layout_width="wrap_content"/> /> <textview android:id="@+id/item3" android:text="费用(元)" android:textsize="14dip" android:width="60dip" android:layout_width="wrap_content" android:layout_height="fill_parent" android:textstyle="bold|italic" /> <textview android:id="@+id/item4" android:layout_height="fill_parent" android:text="日期" android:width="80dip" android:layout_width="wrap_content" /> <textview android:id="@+id/item5" android:layout_height="fill_parent" android:text="备注" android:width="100dip" android:layout_width="wrap_content" /> </linearlayout>
在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代码
<?xml version="1.0" encoding="utf-8"?> <scrollview xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_height="fill_parent" android:layout_width="fill_parent"> <linearlayout android:id="@+id/linearlayout01" xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_height="fill_parent" android:layout_width="fill_parent"> <linearlayout android:id="@+id/layouthead" android:background="#ffcded8b" android:layout_height="fill_parent" android:layout_width="fill_parent" android:focusable="true" android:clickable="true" android:focusableintouchmode="true" android:keepscreenon="true"> <textview android:id="@+id/item1" android:layout_height="fill_parent" android:layout_width="wrap_content" android:width="20dip" /> <textview android:id="@+id/item2" android:layout_height="fill_parent" android:text="账目" android:textstyle="bold" android:width="60dip" android:layout_width="wrap_content"/> /> <textview android:id="@+id/item3" android:text="费用(元)" android:textsize="14dip" android:textstyle="bold" android:width="60dip" android:layout_width="wrap_content" android:layout_height="fill_parent"/> <textview android:id="@+id/item4" android:layout_height="fill_parent" android:text="日期" android:textsize="14dip" android:textstyle="bold" android:width="80dip" android:layout_width="wrap_content" /> <textview android:id="@+id/item5" android:layout_height="fill_parent" android:text="备注" android:textsize="14dip" android:textstyle="bold" android:width="100dip" android:layout_width="wrap_content" /> </linearlayout> <view android:layout_width="fill_parent" android:layout_height="1dip" android:background="?android:attr/listdivider"/> <linearlayout android:id="@+id/layout" android:layout_width="wrap_content" android:layout_height="fill_parent" android:minheight="372dip"> <listview android:id="@+id/listview" android:layout_height="fill_parent" android:layout_width="fill_parent"></listview> </linearlayout> <linearlayout android:id="@+id/layoutfoot" android:layout_width="fill_parent" android:layout_height="wrap_content" android:background="#ffcded8b"> <textview android:id="@+id/totalitem" android:layout_height="fill_parent" android:text="当月收入:2009.33 支出:3000.87 小计:-1000.9" android:textstyle="bold" android:layout_width="fill_parent" /> /> </linearlayout> </linearlayout> </scrollview>
这次我在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 个人理财工具二:使用sqlite实现启动时初始化数据
以上就是关于显示账单明细的功能实现,后续继续添加相关功能,谢谢大家对本站的支持!
上一篇: ASP.NET中使用GridView实现分级显示的代码
下一篇: Java观察者模式例子