3

基本的に、私は Android プログラミングの初心者であり、他の問題の中でも特にこの問題に悩まされています。メイン レイアウトで宣言された GridView と、別の xml でこのグリッドの XML 定義を持っています。SimpleCursorAdapter (カスタム アダプターではありません) を使用してグリッドを適応させています。問題は、表示されたデータ行の 1 つのチェックボックスをタッチしたときに、対応する ROW_ID の値を覚えておきたいということです...だから、SimpleCursorAdapter をカスタマイズする必要なくこれを行うオプションはありますか (ところで、それは可能?)。

以下は、SimpleCursorAdapter でカーソルを調整するレイアウト XML ファイルとコードのスニペットです

    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#BAF0ED"
    android:gravity="right" >

    <GridView
        android:id="@+id/gridView1"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:layout_alignParentLeft="true"
        android:layout_below="@+id/view1"
        android:numColumns="2" >
    </GridView>

</RelativeLayout>

grid.xml:

    <?xml version="1.0" encoding="utf-8"?>
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent" >

    <TableRow>

        <TextView
            android:id="@+id/row_ID"
            android:layout_width="50px"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:padding="5px"
            android:textColor="#4BA79E"
            android:textSize="22dp" />

        <TextView
            android:id="@+id/name"
            android:layout_width="50px"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:padding="5px"
            android:textSize="22dp" />

        <TextView
            android:id="@+id/email"
            android:layout_width="50px"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:padding="5px"
            android:textSize="22dp" />

        <CheckBox
            android:id="@+id/chk"
            android:layout_width="10px"
            android:layout_height="wrap_content"
            android:layout_weight="1" 
            android:onClick="x"/>
    </TableRow>

</TableLayout>

SimpleCursorAdapter の使用:

    public void showGridData() {
    @SuppressWarnings("static-access")
    String[] fromColumns = { db.KEY_ROWID, db.KEY_NAME, db.KEY_EMAIL };
    int[] toViews = new int[] { R.id.row_ID, R.id.name, R.id.email };
    db.openDatabase();
    @SuppressWarnings("deprecation")
    SimpleCursorAdapter sCAdapter = new SimpleCursorAdapter(this,
            R.layout.table_row, db.getContacts(), fromColumns, toViews);
    sCAdapter.setViewResource(R.layout.table_row);
    gv.setAdapter(sCAdapter);
    db.closeDatabase();
}

...そして、chebox が配置されているのと同じレコードで ROW_ID の値を読み取るメソッド (最初、2 番目、または n 番目のチェックボックスに触れても、常に最初の ROW_ID の値を取得しています。これは問題!):

    public void x(View view) {
    TextView tv = (TextView) findViewById(R.id.row_ID);

    recordIds.add(Long.valueOf(tv.getText().toString()));
    long[] longArray = new long[recordIds.size()];
    for (int i = 0; i < recordIds.size(); i++) {
        longArray[i] = recordIds.get(i);
        Toast.makeText(this, String.valueOf(longArray[i]),Toast.LENGTH_LONG).show();

    }
}

よろしくお願いします。お手数をおかけして申し訳ありません。よろしく、Erik D.

add1 (1.編集)

親愛なる友人!回答いただきありがとうございますが、残念ながらこの提案は私にはうまくいきません。「setOnItemClickListener(new OnItemClickListener()」で変更したコード全体を投稿させてください。それでも機能しません...誰かが見る暇がある場合は、コード全体 (xml と Java) を投稿しています。それは--何が悪いのかわかりません。

* *activity_main.xml**

    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:gravity="right" >

    <GridView
        android:id="@+id/gridView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_below="@+id/editText2"
        android:layout_marginTop="20dp"
        android:numColumns="3" />

    <EditText
        android:id="@+id/editText2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@+id/button1"
        android:layout_toRightOf="@+id/button1"
        android:ems="10"
        android:inputType="textEmailAddress" />

    <EditText
        android:id="@+id/editText1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_above="@+id/gridView1"
        android:layout_toLeftOf="@+id/button1"
        android:ems="10"
        android:inputType="textPersonName" />

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true"
        android:layout_marginTop="20dp"
        android:onClick="AddRecord"
        android:text="Insert" />

</RelativeLayout>

* *table_row.xml**

    <?xml version="1.0" encoding="utf-8"?>
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent" >

    <TableRow>

        <TextView
            android:id="@+id/row_ID"
            android:layout_width="50px"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:clickable="true"
            android:padding="5px"
            android:textSize="22dp" />

        <TextView
            android:id="@+id/name"
            android:layout_width="50px"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:clickable="true"
            android:padding="5px"
            android:textSize="22dp" />

        <TextView
            android:id="@+id/email"
            android:layout_width="50px"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:clickable="true"
            android:padding="5px"
            android:textSize="22dp" />

        <CheckBox
            android:id="@+id/chk"
            android:layout_width="10px"
            android:layout_height="wrap_content"
            android:layout_weight="1" />
    </TableRow>

</TableLayout>

* MainActivity.java *

> package net.learn2develop.databases;

import android.app.Activity;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.GridView;
import android.widget.SimpleCursorAdapter;
import android.widget.TextView;
import android.widget.Toast;

public class MainActivity extends Activity {
    DBAdapter db;
    EditText name, mail;
    GridView gv;
    Button button;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        name = (EditText) findViewById(R.id.editText1);
        mail = (EditText) findViewById(R.id.editText2);
        db = new DBAdapter(this);
        gv = (GridView) findViewById(R.id.gridView1);
        showGridData();
    }

    public void AddRecord(View view) {
        if (!(name.getText().toString().isEmpty())
                && !(mail.getText().toString().isEmpty())) {
            db.openDatabase();
            if (db.insertContact(name.getText().toString(), mail.getText()
                    .toString()) >= 0) {
                showMessage("Record added succesfully!", "Inserting...");
                db.closeDatabase();
                showGridData();
            }
        } else {
            showMessage("You can't add empty record!", "Inserting...");
        }
    }

    public void showGridData() {
        String[] fromColumns = { db.KEY_ROWID, db.KEY_NAME, db.KEY_EMAIL };
        int[] toViews = new int[] { R.id.row_ID, R.id.name, R.id.email };
        db.openDatabase();
        SimpleCursorAdapter sCAdapter = new SimpleCursorAdapter(this,
                R.layout.table_row, db.getContacts(), fromColumns, toViews);
        sCAdapter.setViewResource(R.layout.table_row);
        gv.setAdapter(sCAdapter);
        // Implement On Item click listener
        gv.setOnItemClickListener(new OnItemClickListener() {
            public void onItemClick(AdapterView<?> parent, View v,
                    int position, long id) {
                Toast.makeText(getApplicationContext(),
                        ((TextView) v).getText(), Toast.LENGTH_SHORT).show();
            }
        });
        db.closeDatabase();
    }

    public void showMessage(String message, String source) {
        AlertDialog.Builder dlgAlert = new AlertDialog.Builder(this);
        dlgAlert.setCancelable(false);
        dlgAlert.setMessage(message);
        dlgAlert.setTitle(source);
        dlgAlert.setPositiveButton("Ok", new DialogInterface.OnClickListener() {
            public void onClick(DialogInterface dialog, int which) {
                dialog.dismiss();
            }
        });
        dlgAlert.setCancelable(true);
        dlgAlert.create().show();
    }
}

* DBAdapter.java *

    package net.learn2develop.databases;

import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.util.Log;

public class DBAdapter {
    static final String KEY_ROWID = "_id";
    static final String KEY_NAME = "name";
    static final String KEY_EMAIL = "email";
    static final String TAG = "DBAdapter";

    static final String DATABASE_NAME = "MyDB";
    static final String DATABASE_TABLE = "contacts";
    static final int DATABASE_VERSION = 1;

    static final String DATABASE_CREATE = "create table " + DATABASE_TABLE
            + " (" + KEY_ROWID + " integer primary key autoincrement, "
            + KEY_NAME + " text not null, " + KEY_EMAIL + " text not null);";

    final Context context;

    DatabaseHelper DBHelper;
    SQLiteDatabase db;

    public DBAdapter(Context ctx) {// CONSTRUCTOR!!
        this.context = ctx;

        DBHelper = new DatabaseHelper(context);
    }

    private static class DatabaseHelper extends SQLiteOpenHelper {
        DatabaseHelper(Context context) {
            super(context, DATABASE_NAME, null, DATABASE_VERSION);
        }

        @Override
        public void onCreate(SQLiteDatabase db) {
            try {
                db.execSQL(DATABASE_CREATE);
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }

        @Override
        public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
            Log.w(TAG, "Upgrading database from version " + oldVersion + " to "
                    + newVersion + ", which will destroy all old data");
            db.execSQL("DROP TABLE IF EXISTS contacts");
            onCreate(db);
        }
    }

    public DBAdapter openDatabase() throws SQLException {
        db = DBHelper.getWritableDatabase();
        return this;
    }

    public void closeDatabase() {
        DBHelper.close();
    }

    public long insertContact(String name, String email) {

        ContentValues initialValues = new ContentValues();
        initialValues.put(KEY_NAME, name);
        initialValues.put(KEY_EMAIL, email);
        return db.insert(DATABASE_TABLE, null, initialValues);
    }

    public boolean deleteContact(long rowId) {
        return db.delete(DATABASE_TABLE, KEY_ROWID + "=" + rowId, null) > 0;
    }

    public Cursor getContacts() {
        return db.query(DATABASE_TABLE, new String[] { KEY_ROWID, KEY_NAME,
                KEY_EMAIL }, null, null, null, null, null);
    }

    public Cursor getContact(long rowId) throws SQLException {

        Cursor mCursor = db.query(true, DATABASE_TABLE, new String[] {
                KEY_ROWID, KEY_NAME, KEY_EMAIL }, KEY_ROWID + "=" + rowId,
                null, null, null, null, null);
        if (mCursor != null) {
            mCursor.moveToFirst();
        }
        return mCursor;
    }

    public boolean updateContact(long rowId, String name, String email) {
        ContentValues args = new ContentValues();
        args.put(KEY_NAME, name);
        args.put(KEY_EMAIL, email);
        return db.update(DATABASE_TABLE, args, KEY_ROWID + "=" + rowId, null) > 0;
    }
}

親愛なる友人たち、もう一度前もって感謝します、よろしく、Erik D.

4

3 に答える 3

1

ItemClickListener を実装する必要があります。onItemClick は、グリッドビューでクリックされた各アイテムに対して呼び出され、クリックの位置を提供します。

実装方法については、このサンプル コードを確認してください。この位置データをアダプタから取得します。

于 2013-09-12T22:35:10.313 に答える
1

setTagクラスのおよびgetTagメソッドを使用しViewて、情報をビューに関連付けることができます。

于 2013-09-12T22:26:05.247 に答える
0

私は問題の原因を見つけました - 基本的には、GridView のビュー要素を次のように定義するだけです: android:focusable="false" android:focusableInTouchMode="false" たとえば:

<TextView
    android:id="@+id/row_ID"
    android:layout_width="50px"
    android:layout_height="wrap_content"
    android:focusable="false"
    android:focusableInTouchMode="false"
    android:textSize="20dp" />

これら 2 つのパラメーターを使用すると、GridView の要素はグリッドのフォーカスを奪うことはなく、グリッド上のリスナーは機能します。

楽しい時間をお過ごしください、エリック D.

于 2013-09-13T23:32:31.247 に答える