0

simplecursadapter と listview について見つけることができるすべての投稿を読みましたが、それでも私の問題に対する答えが見つからないようです。多数のラジオ ボタン、ボタン、およびリストビューを含むアクティビティがあります。アクティビティは、最初に Web サーバーに対して http 要求を行い、データを取得します。サーバーからのデータは、デバイス上の sqlite db に書き込まれます。データが db に書き込まれると、Activity は制御を取り戻し、db から Cursor、SimpleCursorAdapter を作成し、アダプターをリストビュー アダプターとして設定します。すべてのデータは正常にデータベースに書き込まれます。カーソル内の要素をループして、期待されるすべての要素が含まれていますが、リストビューに要素が表示されません。

Activity.java:

public class MyActivity extends Activity {
private RadioButton rb1, rb2;
private Button addBut;
private ListView lv;
private LinearLayout statusLayout;
private ScrollView scroll;
private String username;
private DBHelper db;
private Cursor cursor;
private static final String userfk = "1";

/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.mylayout);

    rb1 = (RadioButton)findViewById(R.id.rb1);
    rb1.setChecked(true);
    rb2 = (RadioButton)findViewById(R.id.rb2);
    addBut = (Button)findViewById(R.id.addButton);
    statusLayout = (LinearLayout)findViewById(R.id.statusLayout);
    scroll = (ScrollView)findViewById(R.id.configscroll);
    lv = (ListView)findViewById(R.id.profilesll);
    //get data from server, made in asynchtask   
    getData();
}

AsynchTask コードから呼び出される MessageHandler:

private class MyHandler extends Handler {
public MyHandler() {
}
public void handleMessage(Message msg) {
        final Bundle b = msg.getData();
        if (b.getString("result").equalsIgnoreCase(MyResult.ERROR) || b.getString("result").equalsIgnoreCase(MyResult.FAIL)) {
                 //Handle error
        } else {
            handleList();
            statusLayout.setVisibility(View.GONE);
            scroll.setVisibility(View.VISIBLE);
        }
    }
}

private void handleList() {
    if (db == null) {
        db = new DBHelper(this);
    }
    if (cursor == null) {
        try {
            cursor = db.getListCursor(userfk);
        } catch (Exception e) {
            err = e.getMessage();
        }
        if (cursor == null) {
       Toast.makeText(MyActivity.this, err != null ? err : getResources().getString(R.string.myerror), Toast.LENGTH_LONG).show();
        } else {
            try {
                SimpleCursorAdapter adapter = new SimpleCursorAdapter(this, android.R.layout.simple_list_item_1, cursor, new String[] {DBHelper.COLUMN_ID}, new int[] {android.R.id.text1});
                lv.setAdapter(adapter);
            } catch (RuntimeException e) {
                Log.e("test", e.getMessage());
            } catch (Exception e) {
                Log.e("test", e.getMessage());
            }
        }
    }
}

DBHelper クラス

public Cursor getListCursor(String userfk) throws Exception {
    StringBuilder builder = new StringBuilder("select name as _id from mytable where  userfk=?");
    List<String> values = new ArrayList<String>();
    values.add(userfk);
    try {
        return this.getReadableDatabase().rawQuery(builder.toString(), values.toArray(new String[values.size()]));
    } catch (Exception e) {
        Log.d("test", e.getMessage());
        throw e;
    }
}

誰かが私が間違っていることについてのヒントを教えてくれることを願っています! ご協力いただきありがとうございます!

4

0 に答える 0