android - 如何将 Edittext 和 Button 添加到具有图标和文本的 Efficient Adapter

标签 android listview textview android-edittext imageview

我想创建一个布局,使顶部的编辑文本和按钮应该排成一行。 我在 editext 中输入的搜索文本,然后单击搜索按钮。然后我想显示一个自定义 ListView ,其中每一行都包含图像和文本。(根据我尝试过的 API 演示示例 list14)。但是当我运行应用程序时,按钮和编辑文本被添加到每一行(即,每一行包含一个图像、文本、编辑文本、按钮。任何人都可以指导如何解决这个问题。

下面是我的xml文件:

<!--
    <FrameLayout android:layout_width="wrap_content"
    android:layout_height="0dip" android:layout_weight="1"></FrameLayout>
-->
<ImageView android:id="@+id/icon" android:layout_width="48dip"
    android:layout_height="48dip" />

<TextView android:id="@+id/text" android:layout_gravity="center_vertical"
    android:layout_width="0dip" android:layout_weight="1.0"
    android:layout_height="wrap_content" />


<!--
    <EditText android:layout_width="wrap_content"
    android:layout_height="wrap_content" android:id="@+id/prdsearchtb"
    android:text="@string/tb_prd_search_lbl"></EditText>
-->
<!--
    <TableLayout android:id="@+id/TableLayout01"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"> <TableRow>
-->
<Button android:id="@+id/prdsrcbutton" android:layout_width="wrap_content"
    android:layout_height="wrap_content" android:text="@string/btn_lbl_prd_search"
    android:layout_x="2px" android:layout_y="410px"></Button>
<!-- </TableRow>
</TableLayout>

-->

和 Java 文件: /** * */ 包 org.techdata.activity;

导入android.app.AlertDialog; 导入 android.app.ListActivity; 导入 android.content.Context; 导入 android.content.Intent; 导入 android.graphics.Bitmap; 导入 android.graphics.BitmapFactory; 导入 android.os.Bundle; 导入 android.util.Log; 导入 android.view.LayoutInflater; 导入 android.view.View; 导入 android.view.ViewGroup; 导入 android.widget.BaseAdapter; 导入 android.widget.Button; 导入 android.widget.EditText; 导入 android.widget.ImageView; 导入 android.widget.ListView; 导入 android.widget.TextView;

/** * @author jayanthg * */ 公共(public)类 ProductSearch 扩展了 ListActivity {

private static class ProductSearchAdapter extends BaseAdapter {

    private LayoutInflater mInflater;
    private Bitmap mIcon1;
    private Bitmap mIcon2;

    public ProductSearchAdapter(Context context) {

        mInflater = LayoutInflater.from(context);

        // Icons bound to the rows.
        mIcon1 = BitmapFactory.decodeResource(context.getResources(),
                R.drawable.icon48x48_1);
        mIcon2 = BitmapFactory.decodeResource(context.getResources(),
                R.drawable.icon48x48_2);
    }

    @Override
    public int getCount() {

        return DATA.length;
    }

    @Override
    public Object getItem(int position) {

        return position;
    }

    @Override
    public long getItemId(int position) {

        return position;
    }

    @Override
    public View getView(final int position, View convertView,
            ViewGroup parent) {
        ViewHolder holder;
        Button btn=null;

        if (convertView == null) {
            convertView = mInflater.inflate(R.layout.productsearch, null);

            // Creates a ViewHolder and store references to the two children
            // views
            // we want to bind data to.
            holder = new ViewHolder();
            holder.text = (TextView) convertView.findViewById(R.id.text);
            holder.icon = (ImageView) convertView.findViewById(R.id.icon);
            btn=(Button)convertView.findViewById(R.id.prdsrcbutton);
            convertView.setTag(holder);
        } else {
            // Get the ViewHolder back to get fast access to the TextView
            // and the ImageView.
            holder = (ViewHolder) convertView.getTag();
        }

        // Bind the data efficiently with the holder.
        holder.text.setText(DATA[position]);
        holder.icon.setImageBitmap((position & 1) == 1 ? mIcon1 : mIcon2);

        holder.icon.setOnClickListener(new View.OnClickListener() {

            @Override
            public void onClick(View v) {
                Log.i("image", " u clicked on icon Position" + position);

            }
        });
        holder.text.setOnClickListener(new View.OnClickListener() {

            @Override
            public void onClick(View v) {
                Log.i("Text", " u clicked on text Position" + position);

            }
        });

        btn.setOnClickListener(new View.OnClickListener() {

            @Override
            public void onClick(View v) {
                Log.i("Button","U clicked on button");

            }
        });


        return convertView;
    }

    static class ViewHolder {
        TextView text;
        ImageView icon;
    }

    private static final String[] DATA = { "Abbaye de Belloc",
            "Abbaye du Mont des Cats" };

}

ListView product_search_list;
Button srch_btn;
EditText srch_text;

@Override
protected void onCreate(Bundle savedInstanceState) {

    super.onCreate(savedInstanceState);
    setListAdapter(new ProductSearchAdapter(this));
    // setContentView(R.layout.productsearch);
    // getListView().setEmptyView(findViewById(R.id.text));
    // srch_text = (EditText)findViewById(R.id.prdsearchtb);
    // srch_btn = (Button) findViewById(R.id.prdsearchtb);
    // srch_btn.setOnClickListener(new View.OnClickListener() {
    //      
    // @Override
    // public void onClick(View v) {
    // callProductSearchAdapter();
    //
    // }
    // });

}

void callProductSearchAdapter() {
    setListAdapter(new ProductSearchAdapter(this));
}

private void createDialog(String title, String text, final Intent i) {
    if (i == null) {
        AlertDialog ad = new AlertDialog.Builder(this).setIcon(
                R.drawable.alert_dialog_icon).setPositiveButton("Ok", null)
                .setTitle(title).setMessage(text).create();
        ad.show();
    }
}

问候: 贾扬斯

最佳答案

您正在做的是修改它用于各个行的布局,这就是按钮出现在每一行上的原因。您需要做的是为带有按钮和 TextView 的主布局创建一个 XML 文件,然后在其中嵌套一个 ListView。例如,像这样创建一个 main.xml 文件:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical">

    <LinearLayout android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal">

        <TextView android:layout_height="wrap_content"
            android:layout_width="wrap_content"
            android:text="Bla"/>

        <EditText android:layout_height="wrap_content"
            android:layout_width="wrap_content"
            android:text="Bla"/>

    </LinearLayout>

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

重要的是 ListView 的 ID 与上面完全相同 (@android:id/list)。如果您不使用它,您定制的“高效适配器”将无法找到它。完成后,您只需将 setContentView(R.layout.main); 添加到 super.onCreate(...) 行之后的 onCreate 方法中。

关于android - 如何将 Edittext 和 Button 添加到具有图标和文本的 Efficient Adapter,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2667470/

相关文章:

android - 有什么方法可以避免 Android XML 布局文件中的 "android:"语句?

android - Google Place api for android : How to know which is address, 城市或郊区从谷歌返回

java - 安卓 : getting data from cursor

android-layout - 根据android应用程序中的自定义主题在自定义textviews之间切换

android - 为什么应用程序在尝试初始化 textview 时停止?

java - 保存少量数据的最佳方法

Java 循环故障排除

Android:线程从网络加载数据后更新Listview

Android:将 ListView 项设置为 "selected"(突出显示)

java - 如何在按下按钮后延迟一行代码