自定义微调器,其中数据来自具有多行的SQLite数据库?

时间:2014-01-19 17:45:56

标签: android sqlite arraylist spinner

我正在寻找一些有关如何让微调器显示多个项目的帮助,但是,从SQLitedatabase中获取数据。

我已经能够从数据库中获取数据并将其放入带有一个项目的微调器中。我这样做是通过从数据库中将列拉到ArrayList然后将ArrayList添加到数组适配器,如下所示,这是我当前的代码:

spinner = (Spinner) view.findViewById(R.id.Spinner);
ArrayAdapter<String> catAdapter = new ArrayAdapter<String>(getActivity(), android.R.layout.simple_spinner_item, ArrayListNames);
catAdapter.setDropDownViewResource(R.layout.spinner_item);
spinner.setAdapter(catAdapter);

然而,我需要的是微调器每行显示两个项目。现在,我正在拉一个名为&#39; Names&#39;来自数据库。我希望能够显示专栏&#39;年龄&#39;随之而来的。

所以微调器看起来像这样:

Item 1: John
        33

Item 2: Dave
        24

然后,用户可以从微调器中选择John或Dave。我只是希望能够在每一行中显示多个信息。问题在于,它是从数据库进入ArrayList然后进入微调器的适配器。

有谁知道如何为Age添加额外的行?

我真的很感激一些帮助,谢谢!

编辑:我现在如何获取数据。

ArrayList<String> ArrayListNames = new ArrayList<String>();

    Cursor c = db.rawQuery("SELECT * FROM table_one", null);
    if (c.moveToFirst()) {
        do {
            ArrayListNames.add(c.getString(c.getColumnIndex("name")));
            ArrayListNames.add(c.getString(c.getColumnIndex("age")));
        }
        while (c.moveToNext());
    }
    c.close();

2 个答案:

答案 0 :(得分:0)

我设法做到这一点是我自己的应用程序。变化:

catAdapter.setDropDownViewResource(R.layout.spinner_item);
spinner.setAdapter(catAdapter);

catAdapter.setDropDownViewResource(R.layout.multiline_spinner_dropdown_item);
spinner.setAdapter(catAdapter);

并在布局文件夹中创建一个名为multiline_spinner_dropdown_item.xml的xml文件,其中包含以下内容

<CheckedTextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/text1"
style="?android:attr/spinnerDropDownItemStyle"
android:layout_width="match_parent"
android:layout_height="?android:attr/listPreferredItemHeight"
android:ellipsize="none"
android:singleLine="false"
android:textSize="15sp" />

编辑:这就像下面的代码

Spinner spinner = (Spinner)findViewById(R.id.spinner);
    ArrayAdapter<String> catAdapter= new ArrayAdapter<String>(this, android.R.layout.simple_spinner_item, android.R.id.text1);
    catAdapter.setDropDownViewResource(R.layout.multiline_spinner_dropdown_item);
    spinner.setAdapter(catAdapter);
    catAdapter.add("value");
    catAdapter.add("v \n alue");
    catAdapter.add("value");
    catAdapter.add("value");
    catAdapter.notifyDataSetChanged();

数组中的第二个条目在一行上有“v”,在第二行上有“alu”。

答案 1 :(得分:0)

我已在chat room中发布了代码和说明。以下代码经过修改,仅供custom spinner in android

用于个人用途
import android.widget.ArrayAdapter;
import android.widget.Spinner;
import android.widget.TextView;

import java.util.ArrayList;

public class customSpinner extends Activity
{
ArrayList<String> name = new ArrayList<String>();
ArrayList<String> age = new ArrayList<String>();

@Override
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.customspinner);
for (int i =0 ;i<=2;i++){
name.add(""+i);
age.add(""+i);
}
Spinner mySpinner = (Spinner)findViewById(R.id.spinner);
mySpinner.setAdapter(new MyAdapter(this, R.layout.spinnerrow, name));
}

public class MyAdapter extends ArrayAdapter<String>
{

public MyAdapter(Context context, int textViewResourceId, ArrayList<String> objects)
{
super(context, textViewResourceId, objects);
}

@Override
public View getDropDownView(int position, View convertView,ViewGroup parent)
{
return getCustomView(position, convertView, parent);
}

@Override
public View getView(int position, View convertView, ViewGroup parent)
{
return getCustomView(position, convertView, parent);
}

public View getCustomView(int position, View convertView, ViewGroup parent)
{

LayoutInflater inflater=getLayoutInflater();
View row=inflater.inflate(R.layout.spinnerrow, parent, false);
TextView label=(TextView)row.findViewById(R.id.company);
label.setText(name.get(position));

TextView sub=(TextView)row.findViewById(R.id.sub);
sub.setText(age.get(position));


return row;
}
}
}

您可以使用ArrayListdatabase获取值,也可以手动提供,而不是使用for循环将项目添加到cursors。只需根据自己的需要进行修改。