来自 SQLite 数据的自定义对话框

发布于 2024-10-31 17:47:42 字数 3778 浏览 1 评论 0原文

我(认为)我已经成功构建了在自定义对话框中显示 SQLite 数据所需的大部分代码,但仍然不知道如何将它们组合在一起。

我的适配器看起来像这样:

public class ScoresDisplayerAdaptor extends CursorAdapter {
    private LayoutInflater mLayoutInflater;
    private Context mContext;
    public ScoresDisplayerAdaptor(Context context, Cursor c) {
        super(context, c);
        mContext = context;
        mLayoutInflater = LayoutInflater.from(context); 
    }

    @Override
    public View newView(Context context, Cursor cursor, ViewGroup parent) {
        View v = mLayoutInflater.inflate(R.layout.playerscoresrow, parent, false);
        return v;
    }

    /**
     * @author will
     * 
     * @param   v
     *          The view in which the elements we set up here will be displayed.
     * 
     * @param   context
     *          The running context where this ListView adapter will be active.
     * 
     * @param   c
     *          The Cursor containing the query results we will display.
     */

    @Override
    public void bindView(View v, Context context, Cursor c) {
        int player1Score = c.getInt(c.getColumnIndexOrThrow(DBAdaptor.KEY_PLAYER1_SCORE));
        int player2Score = c.getInt(c.getColumnIndexOrThrow(DBAdaptor.KEY_PLAYER2_SCORE));
        int player3Score = c.getInt(c.getColumnIndexOrThrow(DBAdaptor.KEY_PLAYER3_SCORE));
        int player4Score = c.getInt(c.getColumnIndexOrThrow(DBAdaptor.KEY_PLAYER4_SCORE));

        /**
         * Next set the title of the entry.
         */

        TextView tvwPlayer1Score = (TextView) v.findViewById(R.id.tvwPlayer1score);
        TextView tvwPlayer2Score = (TextView) v.findViewById(R.id.tvwPlayer2score);
        TextView tvwPlayer3Score = (TextView) v.findViewById(R.id.tvwPlayer3score);
        TextView tvwPlayer4Score = (TextView) v.findViewById(R.id.tvwPlayer4score);
        tvwPlayer1Score.setText(player1Score);
        tvwPlayer2Score.setText(player2Score);
        tvwPlayer3Score.setText(player3Score);
        tvwPlayer4Score.setText(player4Score);
    }


}

我的 XML:

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

   <ListView android:id="@+id/android:list"
       android:layout_width="wrap_content"
        android:layout_height="wrap_content"/>
 </LinearLayout>


<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout>
<Table>
<TableRow>
<TextView android:id="@+id/tvwPlayer1score" xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"/>
<TextView android:id="@+id/tvwPlayer2score" xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"/>
<TextView android:id="@+id/tvwPlayer3score" xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"/>
<TextView android:id="@+id/tvwPlayer4score" xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"/>
</TableRow>
</Table>
</RelativeLayout>

最后,我使用它的代码是这样的:

private void showCurrentScores(){

    DBAdaptor dbAdaptor;
    Cursor scoresCursor;
    ScoresDisplayerAdaptor scoresDisplayerAdaptor;  

    dbAdaptor = new DBAdaptor(this);
    scoresCursor = dbAdaptor.getScores();

    startManagingCursor(scoresCursor);

    scoresDisplayerAdaptor = new ScoresDisplayerAdaptor(this,scoresCursor);

}

但我现在不知道在最后一行之后要放什么。

I (think) I have managed to build most of the code required to display SQLite data in a custom dialog but am still stuck on how to put it all together.

My Adaptor looks like this:

public class ScoresDisplayerAdaptor extends CursorAdapter {
    private LayoutInflater mLayoutInflater;
    private Context mContext;
    public ScoresDisplayerAdaptor(Context context, Cursor c) {
        super(context, c);
        mContext = context;
        mLayoutInflater = LayoutInflater.from(context); 
    }

    @Override
    public View newView(Context context, Cursor cursor, ViewGroup parent) {
        View v = mLayoutInflater.inflate(R.layout.playerscoresrow, parent, false);
        return v;
    }

    /**
     * @author will
     * 
     * @param   v
     *          The view in which the elements we set up here will be displayed.
     * 
     * @param   context
     *          The running context where this ListView adapter will be active.
     * 
     * @param   c
     *          The Cursor containing the query results we will display.
     */

    @Override
    public void bindView(View v, Context context, Cursor c) {
        int player1Score = c.getInt(c.getColumnIndexOrThrow(DBAdaptor.KEY_PLAYER1_SCORE));
        int player2Score = c.getInt(c.getColumnIndexOrThrow(DBAdaptor.KEY_PLAYER2_SCORE));
        int player3Score = c.getInt(c.getColumnIndexOrThrow(DBAdaptor.KEY_PLAYER3_SCORE));
        int player4Score = c.getInt(c.getColumnIndexOrThrow(DBAdaptor.KEY_PLAYER4_SCORE));

        /**
         * Next set the title of the entry.
         */

        TextView tvwPlayer1Score = (TextView) v.findViewById(R.id.tvwPlayer1score);
        TextView tvwPlayer2Score = (TextView) v.findViewById(R.id.tvwPlayer2score);
        TextView tvwPlayer3Score = (TextView) v.findViewById(R.id.tvwPlayer3score);
        TextView tvwPlayer4Score = (TextView) v.findViewById(R.id.tvwPlayer4score);
        tvwPlayer1Score.setText(player1Score);
        tvwPlayer2Score.setText(player2Score);
        tvwPlayer3Score.setText(player3Score);
        tvwPlayer4Score.setText(player4Score);
    }


}

My XMLs:

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

   <ListView android:id="@+id/android:list"
       android:layout_width="wrap_content"
        android:layout_height="wrap_content"/>
 </LinearLayout>


<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout>
<Table>
<TableRow>
<TextView android:id="@+id/tvwPlayer1score" xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"/>
<TextView android:id="@+id/tvwPlayer2score" xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"/>
<TextView android:id="@+id/tvwPlayer3score" xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"/>
<TextView android:id="@+id/tvwPlayer4score" xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"/>
</TableRow>
</Table>
</RelativeLayout>

Finally, my code where I use it is like this:

private void showCurrentScores(){

    DBAdaptor dbAdaptor;
    Cursor scoresCursor;
    ScoresDisplayerAdaptor scoresDisplayerAdaptor;  

    dbAdaptor = new DBAdaptor(this);
    scoresCursor = dbAdaptor.getScores();

    startManagingCursor(scoresCursor);

    scoresDisplayerAdaptor = new ScoresDisplayerAdaptor(this,scoresCursor);

}

But I am stuck now what to put after that last line.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

莫言歌 2024-11-07 17:47:42

首先在这里回答...
简单显示来自 SQlite 数据库的数据
这里自定义列表视图,每个项目 3 个字符串?

嗯...还不错,但这就像用猎枪杀死蚊子一样,

您不需要为此构建自己的适配器,

只需使用 SimpleCursorAdapter

dbAdaptor = new DBAdaptor(this);
//!!!!remeber scroresCursor MUST have "_id" column
scoresCursor = dbAdaptor.getScores();
listView.setAdapter(new SimpleCursorAdapter(this, 
//this is itemrow.xml
R.layout.itemrow,
scoresCursor , 
//"from" this is array of columns 
new String[]{DBAdaptor.KEY_PLAYER1_SCORE, DBAdaptor.KEY_PLAYER2_SCORE, DBAdaptor.KEY_PLAYER3_SCORE, DBAdaptor.KEY_PLAYER4_SCORE},
//"to" next goes ids in itemrow.xml, values from "from" columns are mapped to "to" Views
new int[] {R.id.tvwPlayer1score, R.id.tvwPlayer2score, R.id.tvwPlayer3score, R.id.tvwPlayer4score }));

接下来:您能够在活动(而不是对话框)的列表视图中显示此数据吗?

编辑:

    Dialog dialog = new Dialog(this);
    dialog.setContentView(R.layout.custom_dialogus);
    ListView lv = (ListView)dialog.getWindow().findViewById(R.id.listView1);
            Cursor c = managedQuery(
            Uri.parse("content://selvin.ListSyncSample/List"),
            new String[] { "_id",  "Name",
                "Description", "CreatedDate"  }, null,
            null, "Name");
    lv.setAdapter(new SimpleCursorAdapter(this, R.layout.listrow, cursor, new String[] { "Name",
            "Description", "CreatedDate" }, new int[] {
            R.id.tName, R.id.tDescription, R.id.tCreatedDate }));
    dialog.setTitle("Custom Dialog");
    dialog.show();

itemrow.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent" android:layout_height="wrap_content"
    android:padding="6dip">
    <ImageView android:id="@+id/icon" android:layout_width="wrap_content"
        android:layout_height="wrap_content" android:layout_marginRight="6dip"
        android:src="@drawable/icon" android:layout_centerVertical="true" />
    <TextView android:id="@+id/tName" android:layout_width="fill_parent"
        android:layout_height="wrap_content" android:layout_toRightOf="@id/icon"
        android:layout_alignParentRight="true" android:layout_alignParentTop="true"
        android:textAppearance="?android:attr/textAppearanceLarge"
        android:singleLine="true" android:ellipsize="marquee" />
    <TextView android:id="@+id/tDescription" android:layout_width="fill_parent"
        android:layout_height="wrap_content" android:layout_toRightOf="@id/icon"
        android:layout_alignParentRight="true" android:layout_below="@id/tName" />
    <TextView android:id="@+id/tCreatedDate" android:layout_width="fill_parent"
        android:layout_height="wrap_content" android:layout_toRightOf="@id/icon"
        android:layout_alignParentRight="true" android:layout_below="@id/tDescription"
        android:singleLine="true" android:ellipsize="marquee" />
</RelativeLayout>

custom_dialogus.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent" android:layout_height="fill_parent"
    android:orientation="vertical">
    <ListView android:id="@+id/listView1" android:layout_width="fill_parent"
        android:layout_height="fill_parent"/>
</LinearLayout>

而不是 Cursor c = ManagedQuery ...使用光标

first answer here ...
Simple display of data from SQlite database or
here Custom listviews, 3 Strings per item?

well ... were not bad, but it were like killing mosquito with shotgun

you don't need to build your own Adapter for that

just use SimpleCursorAdapter

dbAdaptor = new DBAdaptor(this);
//!!!!remeber scroresCursor MUST have "_id" column
scoresCursor = dbAdaptor.getScores();
listView.setAdapter(new SimpleCursorAdapter(this, 
//this is itemrow.xml
R.layout.itemrow,
scoresCursor , 
//"from" this is array of columns 
new String[]{DBAdaptor.KEY_PLAYER1_SCORE, DBAdaptor.KEY_PLAYER2_SCORE, DBAdaptor.KEY_PLAYER3_SCORE, DBAdaptor.KEY_PLAYER4_SCORE},
//"to" next goes ids in itemrow.xml, values from "from" columns are mapped to "to" Views
new int[] {R.id.tvwPlayer1score, R.id.tvwPlayer2score, R.id.tvwPlayer3score, R.id.tvwPlayer4score }));

next: are you able to display this data in listview in activity (not dialog) ?

EDIT:

    Dialog dialog = new Dialog(this);
    dialog.setContentView(R.layout.custom_dialogus);
    ListView lv = (ListView)dialog.getWindow().findViewById(R.id.listView1);
            Cursor c = managedQuery(
            Uri.parse("content://selvin.ListSyncSample/List"),
            new String[] { "_id",  "Name",
                "Description", "CreatedDate"  }, null,
            null, "Name");
    lv.setAdapter(new SimpleCursorAdapter(this, R.layout.listrow, cursor, new String[] { "Name",
            "Description", "CreatedDate" }, new int[] {
            R.id.tName, R.id.tDescription, R.id.tCreatedDate }));
    dialog.setTitle("Custom Dialog");
    dialog.show();

itemrow.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent" android:layout_height="wrap_content"
    android:padding="6dip">
    <ImageView android:id="@+id/icon" android:layout_width="wrap_content"
        android:layout_height="wrap_content" android:layout_marginRight="6dip"
        android:src="@drawable/icon" android:layout_centerVertical="true" />
    <TextView android:id="@+id/tName" android:layout_width="fill_parent"
        android:layout_height="wrap_content" android:layout_toRightOf="@id/icon"
        android:layout_alignParentRight="true" android:layout_alignParentTop="true"
        android:textAppearance="?android:attr/textAppearanceLarge"
        android:singleLine="true" android:ellipsize="marquee" />
    <TextView android:id="@+id/tDescription" android:layout_width="fill_parent"
        android:layout_height="wrap_content" android:layout_toRightOf="@id/icon"
        android:layout_alignParentRight="true" android:layout_below="@id/tName" />
    <TextView android:id="@+id/tCreatedDate" android:layout_width="fill_parent"
        android:layout_height="wrap_content" android:layout_toRightOf="@id/icon"
        android:layout_alignParentRight="true" android:layout_below="@id/tDescription"
        android:singleLine="true" android:ellipsize="marquee" />
</RelativeLayout>

custom_dialogus.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent" android:layout_height="fill_parent"
    android:orientation="vertical">
    <ListView android:id="@+id/listView1" android:layout_width="fill_parent"
        android:layout_height="fill_parent"/>
</LinearLayout>

instead of Cursor c = managedQuery ... use your cursor

自由如风 2024-11-07 17:47:42

你的活动在哪里?活动是将要显示的“屏幕”。

Where's your activity? The activity is the "screen" that will be displayed.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文