質問が示すように、データベースからレコードを表示する必要があります。子ごとに異なるレコードです。つまり、子 1 = レコード 1 データです。子 2 = レコード 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シェルを使用して確認したように、データベースにはデータがありますが、これはテキストに「データなし」と表示します。だから私はそれが 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