安卓实现电脑端的QQ登录界面 自动提示+点击按钮提示输入记录

最近在论坛里面有人提出一个问题,要实现类似于电脑端QQ的登录界面的输入样式,


大概就是上面这个效果,下面我给大家大概讲一下思路:

很多人都说用Editext还有spinner来完成,大家可能都忽略了一个控件叫做AutoComleteTextView:这是一个带自动提示框的输入View,下面看代码吧:

public class QQLoginDemoActivity extends AppCompatActivity {


    private AutoCompleteTextView view;
    MyAdapter arrayAdapter;
    List<String> dd = new ArrayList<>();

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

        dd.add("283426462");
        dd.add("2339124534");
        dd.add("32132465411");
        dd.add("321324654");
        view = ((AutoCompleteTextView) findViewById(R.id.atv));
        arrayAdapter = new MyAdapter(this, R.layout.item, view);
        view.setAdapter(arrayAdapter);

    }

    public void click(View view) {
        this.view.showDropDown();//这个方法是主动弹出提示
    }

    class MyAdapter extends ArrayAdapter<String> {
        private Context context;
        private int resourse;
        private AutoCompleteTextView act;

        public MyAdapter(Context context, int resource, AutoCompleteTextView view) {
            super(context, resource);
            this.context = context;
            this.resourse = resource;
            this.act = view;
        }

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

        @Override
        public String getItem(int i) {
            return dd.get(i);
        }

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

        @Override
        public View getView(final int i, View view, ViewGroup viewGroup) {
            ViewHolder holder;
            if (null == view) {
                view = LayoutInflater.from(context).inflate(resourse, viewGroup, false);
                holder = new ViewHolder(view);
                view.setTag(holder);
            } else {
                holder = (ViewHolder) view.getTag();
            }
            holder.textView.setText((getItem(i)));
            holder.button.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View view) {
                    dd.remove(i);
                    notifyDataSetChanged();
                }
            });
            return view;
        }

        class ViewHolder {

            private final TextView textView;
            private final TextView button;

            public ViewHolder(View view) {
                textView = ((TextView) view.findViewById(R.id.text));
                button = ((TextView) view.findViewById(R.id.delete));
            }
        }
    }
}


布局文件很简单:activity_demo.xml

<?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_demo"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.lixuce.kotlindemo.DemoActivity">

   <AutoCompleteTextView
       android:id="@+id/atv"
       android:layout_width="300dp"
       android:layout_height="wrap_content" />
   <Button
       android:id="@+id/button"
       android:onClick="click"
       android:layout_toRightOf="@+id/atv"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content" />
</RelativeLayout>

item的布局:

<?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="match_parent"
    android:orientation="horizontal">

    <TextView
        android:text="提示"
        android:id="@+id/text"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1" />

    <TextView
        android:id="@+id/delete"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="删除" />
</LinearLayout>

大概的实现过程就是这样了,因为是Demo,布局需要自己调整一下。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值