004 Android之其他控件

ListView

ListView常用属性

属性说明
divider设置分割线的颜色
dividerHeight设置分割线的高度
Scrollbars设置滚动条的显示或者隐藏
Fadescrollbars设置滚动条自动隐藏或者显示
Entries引用一个将使用在此ListView里的数组,若数组是固定的,使用此属性将比在程序中写入更为简单

ListView基本使用

设置基础属性

  <ListView
        android:id="@+id/lv1"
        android:divider="#FF00FF"
        android:dividerHeight="10dp"
        android:layout_width="match_parent"
        android:layout_height="wrap_content">
		android:entries="@array/names"
    </ListView>

设置字符串数组

 <string-array name="names">
    <item>Tome</item>
    <item>Andy</item>
    <item>GuiShou</item>
    <item>Jack</item>
    <item>Andy</item>
    <item>Niko</item>
    </string-array>

效果如图:

在这里插入图片描述

ListView动态插入数据

想要在ListView中动态插入数据,需要下面几个步骤

  1. 在布局文件中编写代码
  2. 在xml中添加ListView标签
  3. 在Activity中编写代码
  4. 获取ListView对象
  5. 准备数据源(Array数组)
  6. 配置适配器(ArrayAdapter)
  7. 将适配器关联到ListView中

什么是适配器

适配器是数据和视图间的桥梁,它负责把数据所提供的内容显示到视图所定义的外观中

在这里插入图片描述

示例代码如下:

private void InitListView() {
        //获取界面对象
        ListView listview=findViewById(R.id.lv1);

        //准备数据源
        String data[]={"上海","北京","广州","武汉","三亚","成都","南昌","厦门","福建","海口","南昌"};

        //创建适配器
        ArrayAdapter<String> adaper=new ArrayAdapter<String>(this,
                android.R.layout.simple_list_item_1,android.R.id.text1,data);

        //将适配器和ListView关联
        listview.setAdapter(adaper);
    }

实际效果如图:

在这里插入图片描述

ListView实现图文混排

首先新建一个layout文件,实现一个单一的ListView样式,代码如下:

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

    <ImageView
        android:id="@+id/logo"
        android:layout_margin="5dp"
        android:src="@mipmap/ic_launcher"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />

    <LinearLayout
        android:orientation="vertical"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content">
        <TextView
            android:id="@+id/title"
            android:text="王者荣耀"
            android:textSize="20dp"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />

        <TextView
            android:id="@+id/version"
            android:text="版本:1.8.8"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />

        <TextView
            android:id="@+id/size"
            android:text="大小:1998MB"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />

    </LinearLayout>


    <Button
        android:id="@+id/btn1"
        android:layout_margin="5dp"
        android:text="卸载应用"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
</LinearLayout>

预览效果如图:

在这里插入图片描述

接着编写JAVA代码

private void InitListView() {
        //获取界面对象
        ListView listview=findViewById(R.id.lv1);

        //准备数据源
        List<Map<String,Object>> maplist=new ArrayList<>();

        Map<String,Object> map1=new HashMap<>();
        map1.put("logo",R.mipmap.ic_launcher);
        map1.put("title","王者荣耀");
        map1.put("version","1.8.8");
        map1.put("size","1178M");



        Map<String,Object> map2=new HashMap<>();
        map2.put("logo",R.mipmap.ic_launcher);
        map2.put("title","炉石传说");
        map2.put("version","2.8.8");
        map2.put("size","1878M");

        Map<String,Object> map3=new HashMap<>();
        map3.put("logo",R.mipmap.ic_launcher);
        map3.put("title","极品飞车");
        map3.put("version","2.8.8");
        map3.put("size","2478M");

        maplist.add(map1);
        maplist.add(map2);
        maplist.add(map3);

        //创建适配器
        SimpleAdapter adaper=new SimpleAdapter(this,
                maplist,R.layout.list_item,
                new String[]{"logo","title","version","size"},
                new int[]{R.id.logo,R.id.title,R.id.version,R.id.size}
                );

        //将适配器和ListView关联
        listview.setAdapter(adaper);
    }

实现效果如图:

在这里插入图片描述

Adapter

Adapter(适配器种类)

  1. ArrayAdapter:适用于简单的文字列表
  2. SimpleAdapter:适用于简单的图文混排
  3. SimpleCursorAdapter:适用于数据源是数据库的列表
  4. 自定义Adapter(继承自BaseAdapter):最灵活的适配器,适用于绝大多数情况

自定义Adapter的使用

之前我们已经用过ArrayAdapter和SimpleAdapter,现在来学习一下自定义自定义Adapter的使用。

在这里插入图片描述

首先创建一个类,继承自BaseAdapter,

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-jKqLM4HU-1623032124581)(004 Android之其他控件.assets/1622808098021.png)]

BaseAdapter是个抽象类,需要重写这个类下面的方法

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

    @Override
    public Object getItem(int i) {
        return mList.get(i);
    }

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

    @Override
    public View getView(int i, View view, ViewGroup viewGroup) {
        //输出日志
        Log.d("GuiShou","位置"+i+"view"+view);

        //加载一个列表项的布局文件,获取界面对象
        //获取布局管理器
        LayoutInflater layoutInflater=LayoutInflater.from(mContext);

        View iview=layoutInflater.inflate(R.layout.list_item,null);

        //将数据添加到布局对象中
        Map<String,Object> map=mList.get(i);
        int resid= (int)map.get("logo");
        String version =(String)map.get("version");
        String title=(String)map.get("title");
        String Size=(String)map.get("size");

        //获取界面对象
        ImageView ilogo=iview.findViewById(R.id.logo);
        TextView ititle=iview.findViewById(R.id.showTitle);
        TextView iversion=iview.findViewById(R.id.version);
        TextView isize=iview.findViewById(R.id.size);

        //将数据设置到界面上
        ilogo.setImageResource(resid);
        ititle.setText(title);
        iversion.setText(version);
        isize.setText(Size);


        //返回对象
        return iview;
    }

在类内创建两个成员变量,并填写构造方法,用于将数据传输到界面

   private List<Map<String,Object>> mList;
    private Context mContext;

    public MyAdapter(List<Map<String,Object>> mList,Context mContext) {
        this.mList=mList;
        this.mContext=mContext;
    }

然后创建适配器关联ListView即可

        //创建适配器
       MyAdapter adaper=new MyAdapter(maplist,this);

        //将适配器和ListView关联
        listview.setAdapter(adaper);

Spinner下拉列表

Spinner和ListView很相似,使用步骤都差不多

   <Spinner
       android:id="@+id/spinner"
       android:layout_width="match_parent"
       android:layout_height="wrap_content"></Spinner>

首先准备控件,接着编写代码,关联适配器

 private void InitSpinner() {
        //自己准备一个下拉列表
        final String[] strings={"北京","上海","广州","深圳"};

        //获取控件对象
        Spinner spinner=(Spinner)findViewById(R.id.spinner);


        //创建适配器
        ArrayAdapter<String> adapter=new ArrayAdapter<String>(this,
                android.R.layout.simple_list_item_1,android.R.id.text1,strings);

        //关联适配器
        spinner.setAdapter(adapter);

        //设置监听器
        spinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
            @Override
            public void onItemSelected(AdapterView<?> adapterView, View view, int i, long l) {
                String sel=strings[i];
                Toast.makeText(MainActivity.this,sel,Toast.LENGTH_LONG);

            }

            @Override
            public void onNothingSelected(AdapterView<?> adapterView) {

            }
        });

    }

实际效果如图:

在这里插入图片描述

AutoCompleteTextView自动补全

控件代码如下:

   <AutoCompleteTextView
       android:id="@+id/auto1"
       android:completionThreshold="1"
       android:layout_width="match_parent"
       android:layout_height="wrap_content" />

completionThreshold属性表示输入第几个字符开始提示。

Activity设置代码如下:

private void InitAutoText() {
        //获取界面对象
        AutoCompleteTextView actv=(AutoCompleteTextView)findViewById(R.id.auto1);

        //准备数据源
        String[] objects=new String[]{"hello1","hello2","hello3","world"};

        //创建适配器 设置数据
        //创建适配器
        ArrayAdapter<String> adapter=new ArrayAdapter<String>(this,
                android.R.layout.simple_list_item_1,android.R.id.text1,objects);

        //关联适配器
        actv.setAdapter(adapter);
    }

实际效果如图:

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鬼手56

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值