下拉展示条目

下拉展示条目

布局文件

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:background="#000000"
tools:context="com.example.a2_.MainActivity">

<EditText
    android:id="@+id/et_input"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:textColor="#fff"
    android:text="请输入内容" />

<ImageButton
    android:padding="6dp"
    android:background="@null"
    android:layout_alignRight="@id/et_input"
    android:id="@+id/ib"
    android:src="@mipmap/down_arrow"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content" />
</RelativeLayout>

条目布局文件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="5dp"
android:descendantFocusability="blocksDescendants"
android:orientation="horizontal">

<ImageView

    android:src="@mipmap/user"
    android:id="@+id/iv_user"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content" />

<TextView
    android:layout_weight="1"
    android:id="@+id/tv_data"
    android:text="100"
    android:textColor="#000000"
    android:gravity="center_horizontal"
    android:layout_width="0dp"
    android:layout_height="wrap_content" />

<ImageButton
    android:background="@null"
    android:src="@mipmap/delete"
    android:id="@+id/iv_delete"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content" />

</LinearLayout>

核心代码

package com.example.a2_;

import android.graphics.drawable.ColorDrawable;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.EditText;
import android.widget.ImageButton;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.PopupWindow;
import android.widget.TextView;

import java.util.ArrayList;

public class MainActivity extends AppCompatActivity {

private EditText et_input;
private PopupWindow popupWindow;
private ListView lv_list;
private ArrayList<String> data;
private MyAdapter myAdapter;

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

    //初始化控件
    et_input = (EditText) findViewById(R.id.et_input);
    ImageButton ib = (ImageButton) findViewById(R.id.ib);

    //初始化数据源
    initData();
    //创建一个listView
    lv_list = new ListView(this);
    //给listview设置背景
    lv_list.setBackgroundResource(R.mipmap.listview_background);
    //给listview设置适配器
    myAdapter = new MyAdapter();
    lv_list.setAdapter(myAdapter);
    //给listview设置条目点击事件
    lv_list.setOnItemClickListener(new AdapterView.OnItemClickListener() {
        @Override
        public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
            //当点击到一个条目的时候,就把这个条目的内容显示在输入框中
            et_input.setText(data.get(position));
            popupWindow.dismiss();
        }
    });

    //给按钮设置点击事件
    ib.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            //当点击下拉按钮时,显示列表选项
            showPopup();
        }
    });

}

//初始化数据
private void initData() {
    //创建一个集合,用来存储数据
    data = new ArrayList<>();
    //通过for循环创建数据
    for (int i = 1;i<20;i++){
        data.add(100+i+"");
    }
}

//显示下拉的列表条目
private void showPopup() {
    //创建PopupWindow对象
    popupWindow =  new PopupWindow(lv_list,et_input.getWidth(),500,true);
    //为了在点击列表条目之外的区域能够让列表条目隐藏,为列表条目设置一个背景
    popupWindow.setBackgroundDrawable(new ColorDrawable());
    //让列表条目显示  并指定在哪个列表条目下展示
    popupWindow.showAsDropDown(et_input);
}

//创建一个适配器
class MyAdapter extends BaseAdapter{

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

    @Override
    public String getItem(int position) {
        return data.get(position);
    }

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

    @Override
    public View getView(final int position, View convertView, ViewGroup parent) {
        //判断convertView是否为空
        if (convertView==null){
            convertView = View.inflate(MainActivity.this,R.layout.lv_item,null);

        }
        //找到控件
        TextView tv_data = (TextView) convertView.findViewById(R.id.tv_data);
        ImageView iv_delete = (ImageView) convertView.findViewById(R.id.iv_delete);

        //设置点击事件
        iv_delete.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                //删除集合里面的数据
                data.remove(position);
                //刷新页面
                myAdapter.notifyDataSetChanged();
            }
        });
        //获取数据
        String data = getItem(position);
        //设置数据
        tv_data.setText(data);
        return convertView;
    }
}

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值