Android 用ListView获取系统应用列表以及BaseAdapter适配器的实现

本文介绍如何在Android中使用ListView获取并显示系统应用列表,同时讲解BaseAdapter的实现细节,包括主函数代码、XML布局配置以及ListView的DEMO展示。
摘要由CSDN通过智能技术生成

代码如下,内有详细注释

主函数

package com.example.homework;

import android.content.ComponentName;
import android.content.Context;
import android.content.Intent;
import android.content.pm.ResolveInfo;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.TextView;

import java.util.List;

public class MainActivity extends AppCompatActivity {
    private ListView mListView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mListView = findViewById(R.id.list_text);

        //LayoutInflater layoutInflater = (LayoutInflater) getSystemService(Context.LAYOUT_INFLATER_SERVICE);

        List<ResolveInfo> infos = getAppInfos();
        mListView.setAdapter(new AppListAdapter(getAppInfos()));
    }

    //拿到系统应用所有信息
    private List<ResolveInfo> getAppInfos(){
        Intent intent = new Intent(Intent.ACTION_MAIN,null);
        intent.addCategory(Intent.CATEGORY_LAUNCHER);
        return getPackageManager().queryIntentActivities(intent, 0);
    }

    //配置ListView的适配器
    private class AppListAdapter extends BaseAdapter{

        List<ResolveInfo> mAppNames;
        public AppListAdapter(List<ResolveInfo> AppNames){
            mAppNames = AppNames;
        }

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

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

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

        @Override
        public View getView(final int position, View convertView, ViewGroup parent) {
            ViewHolder viewHolder;
            LayoutInflater layoutInflater = (LayoutInflater)getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            //判断是否为空,为空的话
            if(convertView == null){
                viewHolder = new ViewHolder();
                convertView = layoutInflater.inflate(R.layout.item_item, null);
                // 获取控件
                viewHolder.nameTextView =  convertView.findViewById(R.id.title_text_view);
                viewHolder.avatarImageView = convertView.findViewById(R.id.icon_image_view);
                convertView.setTag(viewHolder);
            } else {
                viewHolder = (ViewHolder) convertView.getTag();
            }
            // 和数据之间进行绑定
            //获取应用名字
            viewHolder.nameTextView.setText(mAppNames.get(position).activityInfo.loadLabel(getPackageManager()));
            //获取应用图片
            viewHolder.avatarImageView.setImageDrawable(mAppNames.get(position).activityInfo.loadIcon(getPackageManager()));

            //对系统应用设置点击事件
            convertView.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    ResolveInfo info = mAppNames.get(position);

                    //该应用的包名
                    String pkg = info.activityInfo.packageName;
                    //应用的主activity类
                    String cls = info.activityInfo.name;

                    ComponentName componet = new ComponentName(pkg, cls);

                    Intent intent = new Intent();
                    intent.setComponent(componet);
                    startActivity(intent);
                }
            });
            return convertView;
        }
        
        class ViewHolder {
            ImageView avatarImageView;
            TextView nameTextView;
        }
    }

}

主函数XML

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

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

        <ImageView
            android:layout_width="50dp"
            android:layout_height="50dp"
            android:src="@mipmap/sousuo" />
        <EditText
            android:id="@+id/edtext_sosuo"
            android:layout_width="match_parent"
            android:layout_height="50dp"
            android:hint="请输入~~~~~~"
            />
    </LinearLayout>

    <ListView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/list_text">

    </ListView>


</LinearLayout>

配置ListView的DEMO,图片自己可以换

<?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">
    <ImageView
        android:id="@+id/icon_image_view"
        android:layout_width="60dp"
        android:layout_height="60dp"
        android:src="@mipmap/ic_launcher"/>
    <TextView
        android:id="@+id/title_text_view"
        android:layout_width="match_parent"
        android:layout_height="60dp"
        android:text="@string/app_name"
        android:minHeight="30dp"
        android:layout_centerVertical="true"
        android:gravity="left|center"
        android:textColor="#494949"
        android:singleLine="true"
        android:layout_marginLeft="16dp"
        android:layout_toRightOf="@+id/icon_image_view"
        android:textSize="18sp"/>
</LinearLayout>

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个简单的使用自定义适配器实现列表Android代码示例: 1. 首先,我们需要创建一个布局文件,用来定义列表项的显示样式。比如,我们可以创建一个名为list_item.xml的布局文件,定义一个简单的TextView用于显示列表项的内容: ```xml <TextView xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/textView" android:layout_width="match_parent" android:layout_height="wrap_content" android:padding="10dp" android:textSize="16sp" /> ``` 2. 接下来,我们需要创建一个自定义适配器类,用于将数据源中的数据绑定到列表项上。比如,我们可以创建一个名为MyAdapter的适配器类,继承自BaseAdapter类,并实现其中的几个方法: ```java public class MyAdapter extends BaseAdapter { private Context mContext; private String[] mData; public MyAdapter(Context context, String[] data) { mContext = context; mData = data; } @Override public int getCount() { return mData.length; } @Override public Object getItem(int position) { return mData[position]; } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder holder; if (convertView == null) { convertView = LayoutInflater.from(mContext).inflate(R.layout.list_item, parent, false); holder = new ViewHolder(); holder.textView = convertView.findViewById(R.id.textView); convertView.setTag(holder); } else { holder = (ViewHolder) convertView.getTag(); } holder.textView.setText(mData[position]); return convertView; } private static class ViewHolder { TextView textView; } } ``` 以上代码中,我们定义了一个MyAdapter类,并在其中实现BaseAdapter类中的几个重要方法。其中,getCount()方法用于获取数据源中的数据数量,getItem()方法用于获取数据源中指定位置的数据项,getItemId()方法用于获取指定位置的数据项的ID。最重要的是getView()方法,它用于将数据源中的数据绑定到列表项上,并返回一个View对象。 在getView()方法中,我们首先判断convertView是否为空。如果为空,说明当前列表项还没有被创建过,我们就需要通过LayoutInflater从布局文件中加载一个新的View对象,并将其缓存起来。这样,在下次需要显示同样的列表项时,就可以直接从缓存中取出View对象,而不需要重新创建。如果convertView不为空,说明当前列表项已经被创建过,我们可以直接从缓存中取出它的View对象。 接着,我们通过ViewHolder模式,将列表项中的TextView控件缓存起来,避免在每次getView()方法被调用时都需要通过findViewById()方法来查找它。最后,我们将数据源中当前位置的数据绑定到TextView控件上,并返回这个View对象。 3. 最后,我们在Activity中使用自定义适配器,并将它设置到ListView中: ```java ListView listView = findViewById(R.id.listView); String[] data = {"Item 1", "Item 2", "Item 3", "Item 4", "Item 5"}; MyAdapter adapter = new MyAdapter(this, data); listView.setAdapter(adapter); ``` 以上代码中,我们创建了一个MyAdapter适配器对象,并将其设置到ListView中。此时,ListView就会根据适配器中的数据源,创建了对应数量的列表项,并使用自定义的布局文件来显示每个列表项的内容。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值