正如问题所指示的,我需要显示数据库中的记录,每个孩子的不同记录。即孩子 1 = 记录 1 数据。child 2 =record 2 data.so 等等。我想出了以下显示代码:
package com.example.moolah;
import android.app.ListActivity;
import android.content.Intent;
import android.database.Cursor;
import android.os.Bundle;
import android.support.v4.widget.SimpleCursorAdapter;
import android.view.View;
import android.widget.Button;
public class DisplayActivity extends ListActivity {
DBAdapter db=new DBAdapter(this);
@Override
public void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_display_cursor);
Button viewbutton=(Button)findViewById(R.id.button2);
// viewbutton.setOnClickListener(new Buttonx());
}
public class Buttonx extends DisplayActivity implements Button.OnClickListener{
@SuppressWarnings("deprecation")
@Override
public void onClick(View v)
{
Button viewbutton=(Button)v.findViewById(R.id.button2);
Object viewid=viewbutton.getTag();
int i=Integer.parseInt(viewid.toString());
MyCustomAdapter c=new MyCustomAdapter();
long id=c.getChildId(0,i);
//DisplayCursor d;
//d.filldata();
db.open();
// View view;
Cursor cursor = db.getRecord(id);
startManagingCursor(cursor);
String[] columns = new String[] {DBAdapter.invest_type,DBAdapter.curr_per_share_price, DBAdapter.share_name,
DBAdapter.no_of_shares,DBAdapter.share_identity,DBAdapter.purchase_price,
DBAdapter.purchase_from,DBAdapter.purchase_date,DBAdapter.purchase_contact};
int[] to = new int[] { R.id.investmenttype,R.id.currpershareprice,R.id.sharename,R.id.shareno,R.id.shareid, R.id.purprice,
R.id.purfrom,R.id.purdate,R.id.purcon};
SimpleCursorAdapter mAdapter = new SimpleCursorAdapter( this, R.layout.row, cursor, columns, to);
this.setListAdapter(mAdapter);
db.close();
}
}
这会在文本中显示“无数据”,尽管我的数据库有数据,正如使用命令提示符 adb shell 确认的那样。所以我认为它无权访问 onClick 方法。现在,如果我取消注释 onCreate 方法中注释的行,它可以访问,但会在 viewbutton.setOnClickListener(new Buttonx());//onCreate 方法处导致 NullPointerException
如何在不生成此异常的情况下访问 onClick 并根据需要显示记录?我想我在某个地方根本就错了。如果有人能指出我会很感激的缺陷。你看,这件事让我发疯了。:/
日志猫:
06-17 17:33:32.444: E/AndroidRuntime(569):
FATAL EXCEPTION: main
06-17 17:33:32.444: E/AndroidRuntime(569): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.moolah/com.example.moolah.DisplayActivity}: java.lang.NullPointerException
06-17 17:33:32.444: E/AndroidRuntime(569): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1955)
06-17 17:33:32.444: E/AndroidRuntime(569): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1980)
06-17 17:33:32.444: E/AndroidRuntime(569): at android.app.ActivityThread.access$600(ActivityThread.java:122)
06-17 17:33:32.444: E/AndroidRuntime(569): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1146)
06-17 17:33:32.444: E/AndroidRuntime(569): at android.os.Handler.dispatchMessage(Handler.java:99)
06-17 17:33:32.444: E/AndroidRuntime(569): at android.os.Looper.loop(Looper.java:137)
06-17 17:33:32.444: E/AndroidRuntime(569): at android.app.ActivityThread.main(ActivityThread.java:4340)
06-17 17:33:32.444: E/AndroidRuntime(569): at java.lang.reflect.Method.invokeNative(Native Method)
06-17 17:33:32.444: E/AndroidRuntime(569): at java.lang.reflect.Method.invoke(Method.java:511)
06-17 17:33:32.444: E/AndroidRuntime(569): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
06-17 17:33:32.444: E/AndroidRuntime(569): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
06-17 17:33:32.444: E/AndroidRuntime(569): at dalvik.system.NativeStart.main(Native Method)
06-17 17:33:32.444: E/AndroidRuntime(569): Caused by: java.lang.NullPointerException
06-17 17:33:32.444: E/AndroidRuntime(569): at com.example.moolah.DisplayActivity.onCreate(DisplayActivity.java:21)
06-17 17:33:32.444: E/AndroidRuntime(569): at android.app.Activity.performCreate(Activity.java:4465)
06-17 17:33:32.444: E/AndroidRuntime(569): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
06-17 17:33:32.444: E/AndroidRuntime(569): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1919)
06-17 17:33:32.444: E/AndroidRuntime(569): ... 11 more