如何创建一个连续多个视图的listView。

时间:2013-08-02 17:22:05

标签: android listview runtime

我正在编写一个应用程序,要求用户在表单中输入一些细节。表单最初连续有3个EditText视图。当用户在最后一个editText中输入一些数据时,onFocusChangeListener应该启动一个新行。

这就是我想要做的。 如何在运行时在单个listView行中创建3个editText视图?

1 个答案:

答案 0 :(得分:0)

要创建一个连续多个视图的listView,您需要自定义您的适配器,因此它可以采用源XML的行形式 - 您应该创建 - 并将其放入listView,这是一个基于BaseAdapter的示例:

这是包含行形式的Xml源:

espaceclientuploadsource.xml:

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

<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:addStatesFromChildren="true" >

    <ImageView
        android:id="@+id/Uplodimage"
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:layout_marginLeft="15dp"
        android:src="@drawable/bingo" />

    <TextView
        android:id="@+id/UploadedProductName"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:layout_marginLeft="20dp"
        android:layout_marginTop="24dp"
        android:layout_toRightOf="@+id/Uplodimage"
        android:text="Medium Text"
        android:textAppearance="?android:attr/textAppearanceMedium" />

    <TextView
        android:id="@+id/UplodedProductPrice"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignLeft="@+id/UploadedProductName"
        android:layout_below="@+id/UploadedProductName"
        android:layout_marginTop="16dp"
        android:text="Small Text"
        android:textAppearance="?android:attr/textAppearanceSmall" />

    <ImageView
        android:id="@+id/UploadedStatus"
        android:layout_width="15dp"
        android:layout_height="15dp"
        android:layout_above="@+id/UplodedProductPrice"
        android:layout_alignParentRight="true"
        android:layout_alignTop="@+id/UploadedProductName"
        android:layout_marginRight="27dp"
        android:src="@drawable/bingo" />

    <ImageView
        android:id="@+id/ImageViewDelete"
        android:layout_width="15dp"
        android:layout_height="15dp"
        android:layout_alignBottom="@+id/UplodedProductPrice"
        android:layout_alignLeft="@+id/UploadedStatus"
        android:clickable="true"
        android:src="@drawable/bingo" />

</RelativeLayout>

然后,您需要创建一个包含ListView的XML文件:

<强> espaceclientuploads:          

<EditText
    android:id="@+id/login"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:ems="10" >

    <requestFocus />
</EditText>

<EditText
    android:id="@+id/password"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:ems="10"
    android:inputType="textPassword" />

<Button
    android:id="@+id/submit"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:onClick="submit"
    android:text="Button" />
</LinearLayout>

接下来是你的适配器,它的作用是使用你的sourceXML作为行格式,

UploadedAdapter:

public class UploadedAdapter extends BaseAdapter
{   
List<Article> lesArticles;
DataSource produitSource;
LayoutInflater inflater;
String path= Environment.getExternalStorageDirectory().toString()+File.separator+"Bingo";


public UploadedAdapter(Context context, List<Article> lesArticles) 
{
    inflater=LayoutInflater.from(context);
    this.lesArticles = lesArticles;

}


@Override
public int getCount() 
{
    return lesArticles.size();
}

@Override
public Object getItem(int position) 
{
    return lesArticles.get(position);
}

@Override
public long getItemId(int position) 
{
    return position;
}

private class ViewHolder 
{
    TextView nomduProduit;
    TextView prixDuProduit;
    ImageView status;
    ImageView imageDuProduit;
    ImageView delete;
}
@Override

public View getView(final int position, View convertView, ViewGroup parent) {

    ViewHolder holder;
    if (convertView==null)
    {
        holder=new ViewHolder();
        convertView = inflater.inflate(R.layout.espaceclientuploadsource, null);
        holder.nomduProduit = (TextView)convertView.findViewById(R.id.UploadedProductName);
        holder.prixDuProduit = (TextView)convertView.findViewById(R.id.UplodedProductPrice);
        holder.imageDuProduit = (ImageView)convertView.findViewById(R.id.Uplodimage);
        holder.status = (ImageView)convertView.findViewById(R.id.UploadedStatus);
        holder.delete=(ImageView)convertView.findViewById(R.id.ImageViewDelete);
        convertView.setTag(holder);
    }

    else
    {
        holder = (ViewHolder) convertView.getTag();
    }
    Drawable drawableImage = new BitmapDrawable(bitmapImage);
    holder.imageDuProduit.setImageDrawable(drawableImage);
    holder.nomduProduit.setText(lesArticles.get(position).getNomArticle());
    holder.prixDuProduit.setText(lesArticles.get(position).getPrix());
    holder.delete.setImageResource(R.drawable.delete);
    return convertView;
}
}       

如您所见,您的适配器扩展了baseAdapter,这是一个抽象类,因此您需要覆盖其方法。

最后,您的活动将显示您的listView:

public class EspaceClientUplodedProducts extends Activity{

List<Article> lesArticle= new ArrayList<Article>();
ListView lvListe;

UploadedAdapter adapter;

@Override
protected void onCreate(Bundle savedInstanceState) 
{
    super.onCreate(savedInstanceState);
    setContentView(R.layout.espaceclientuploads);

    lvListe= (ListView)findViewById(R.id.UploadListView);
    adapter = new UploadedAdapter(this, lesArticle);
    lvListe.setAdapter(adapter);
    lvListe.setOnItemClickListener(this);
}
}