android 实例-个人理财工具 之六,Android 个人理财工具五:显示账单明细 上

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

下图是最终的效果图:

6b2d9f7d309961d3e4a4362bbb661344.gif

在设计该界面时我考虑过好几个方案。本来准备使用一个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代码

android:orientation="horizontal" android:layout_width="fill_parent"

android:layout_height="fill_parent">

android:layout_width="wrap_content" android:width="20dip"

/>

android:layout_height="fill_parent"

android:text="账目"

android:width="60dip" android:layout_width="wrap_content"/>

/>

android:text="费用(元)"

android:textSize="14dip" android:width="60dip" android:layout_width="wrap_content"

android:layout_height="fill_parent" android:textStyle="bold|italic"

/>

android:layout_height="fill_parent"

android:text="日期"

android:width="80dip"

android:layout_width="wrap_content"

/>

android:layout_height="fill_parent"

android:text="备注"

android:width="100dip" android:layout_width="wrap_content"

/>

在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代码

android:orientation="vertical"

android:layout_height="fill_parent" android:layout_width="fill_parent">

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">

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">

android:layout_width="wrap_content" android:width="20dip"

/>

android:layout_height="fill_parent"

android:text="账目"

android:textStyle="bold" android:width="60dip" android:layout_width="wrap_content"/>

/>

android:text="费用(元)"

android:textSize="14dip" android:textStyle="bold" android:width="60dip" android:layout_width="wrap_content"

android:layout_height="fill_parent"/>

android:layout_height="fill_parent"

android:text="日期"

android:textSize="14dip" android:textStyle="bold" android:width="80dip" android:layout_width="wrap_content"

/>

android:layout_height="fill_parent"

android:text="备注"

android:textSize="14dip" android:textStyle="bold" android:width="100dip" android:layout_width="wrap_content"

/>

android:layout_width="fill_parent"

android:layout_height="wrap_content" android:background="#ffCded8b">

android:layout_height="fill_parent"

android:text="当月收入:2009.33 支出:3000.87 小计:-1000.9"

android:textStyle="bold" android:layout_width="fill_parent" />

/>

这次我在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的方法。

系列文章:

以上就是关于显示账单明细的功能实现,后续继续添加相关功能,谢谢大家对本站的支持!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值