目录
1.adpter的创建以及listview的使用
1.1 adapter的创建
首先先创建一个java class文件
然后这个类需要继承于BaseAdapter
将鼠标放置在adpter上,会发现有许多未实现的接口,然后点击下方的Implement methods,就可以添加这些接口了
1.2 adapter中方法的介绍
@Override
public int getCount() {
return 0;
}
这个方法可以获得List中有多少条数据
@Override
public Object getItem(int position) {
return null;
}
返回某一个数据集的对象
@Override
public long getItemId(int position) {
return 0;
}
返回某一个数据集的对象的id
@Override
public View getView(int position, View convertView, ViewGroup parent) {
return null;
}
返回一个视图
1.3 adapter的改造
既然知道这些方法的作用,我们就可以对这些方法进行改造,以此来适配我们,我们传入的数据
首先我们要把视图读取进去
public lianxiren_adapter() {
}
按住ctrl+insert来定义一个构造器
private Context mcontext;
private LayoutInflater mlayoutInflater;
public lianxiren_adapter(Context context) {
mcontext = context;
mlayoutInflater = (LayoutInflater) mcontext.getSystemService(context.LAYOUT_INFLATER_SERVICE);
}
接下来我们来改造我们的构造函数,mcontext通过用户传参获得并初始化,Layoutinflater可以通过获得系统的服务来进行初始化
@Override
public View getView(int position, View convertView, ViewGroup parent) {
convertView=mlayoutInflater.inflate(R.layout.item,null);
TextView item_textview=(TextView) convertView.findViewById(R.id.textView_item);
return convertView;
}
这样就完成了adapter的基本设置,adapter就可以完成基本的视图创建
1.4 adapter数据的传入及显示
首先我们添加一个listview,然后在fragment中进行声明和初始化
private ListView mlistview;
mlistview=view.findViewById(R.id.lianxiren_listview);
lianxiren_adapter lianxirenAdapter=new lianxiren_adapter(getContext());
这样就完成了adapter的创建及初始化
那么我们该如何传入数据呢,首先打开我们的apapter
private List<UserInfo> muserinfo=new ArrayList<>();
首先定义一个用户传入数据的格式,然后再将其添加至构造函数中进行初始化
public int getCount() {
//有多少条数据
return muserinfo.size();
}
返回用户数据的数量
public Object getItem(int position) {
//获取其中一条数据对象
return muserinfo.get(position);
}
获取其中一条数据对象
item_textview.setText(muserinfo.get(position).getMname());
在view中通过这个方式就可以进行数据的绑定
List<UserInfo> muserinfo=new ArrayList<>();
muserinfo.add(new UserInfo("WRS","男",20));
muserinfo.add(new UserInfo("DJY","男",20));
muserinfo.add(new UserInfo("RS","男",20));
lianxiren_adapter lianxirenAdapter=new lianxiren_adapter(getContext(),muserinfo);
创建一个userinfo的list列表并添加几个数据,并将其传入adapter
然后通过setadapter的方法将包装好的页面发给listview视图
mlistview.setAdapter(lianxirenAdapter);
这样就实现了adpater完整的数据传入
1.5 item的改造
首先对item进行下简单的设计
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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:layout_width="match_parent"
android:layout_height="wrap_content"
>
<ImageView
android:id="@+id/avater_imageView_item"
android:layout_width="120dp"
android:layout_height="120dp"
tools:srcCompat="@tools:sample/avatars" />
<TextView
android:id="@+id/textView_name_item"
android:layout_width="wrap_content"
android:layout_height="40dp"
android:layout_toRightOf="@+id/avater_imageView_item"
android:layout_weight="1"
android:gravity="center"
android:text="name"
android:textSize="35dp" />
<TextView
android:id="@+id/textView_age_item"
android:layout_width="wrap_content"
android:layout_height="40dp"
android:layout_below="@+id/textView_name_item"
android:layout_toRightOf="@+id/avater_imageView_item"
android:layout_weight="1"
android:gravity="center"
android:text="age"
android:textSize="35dp" />
<TextView
android:id="@+id/textView_sex_item"
android:layout_width="wrap_content"
android:layout_height="40dp"
android:layout_below="@+id/textView_age_item"
android:layout_toRightOf="@+id/avater_imageView_item"
android:layout_weight="1"
android:gravity="center"
android:text="sex"
android:textSize="35dp" />
</RelativeLayout>
效果大概是这样的
然后在getview中进行数据的绑定
@Override
public View getView(int position, View convertView, ViewGroup parent) {
convertView=mlayoutInflater.inflate(R.layout.item,null);
TextView item_name_textview=(TextView)
convertView.findViewById(R.id.textView_name_item);
item_name_textview.setText(muserinfo.get(position).getMname());
TextView item_age_textview=(TextView)
convertView.findViewById(R.id.textView_age_item);
item_age_textview.setText(muserinfo.get(position).getMage());
TextView item_sex_textview=(TextView)
convertView.findViewById(R.id.textView_sex_item);
item_sex_textview.setText(muserinfo.get(position).getMsex());
ImageView avater_imageview=convertView.findViewById(R.id.avater_imageView_item);
avater_imageview.setImageResource(R.drawable.moka);
return convertView;
}
实现效果,总的来说还是挺不错的
1.6 代码汇总
package com.example.work;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;
import java.util.ArrayList;
import java.util.List;
public class lianxiren_adapter extends BaseAdapter {
private Context mcontext;
private final LayoutInflater mlayoutInflater;
private List<UserInfo> muserinfo=new ArrayList<>();
public lianxiren_adapter(Context context,List<UserInfo> userInfos) {
mcontext = context;
mlayoutInflater = (LayoutInflater) mcontext.getSystemService(context.LAYOUT_INFLATER_SERVICE);
muserinfo=userInfos;
}
@Override
public int getCount() {
//有多少条数据
return muserinfo.size();
}
@Override
public Object getItem(int position) {
//获取其中一条数据对象
return muserinfo.get(position);
}
@Override
public long getItemId(int position) {
return 0;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
convertView=mlayoutInflater.inflate(R.layout.item,null);
TextView item_name_textview=(TextView) convertView.findViewById(R.id.textView_name_item);
item_name_textview.setText(muserinfo.get(position).getMname());
TextView item_age_textview=(TextView) convertView.findViewById(R.id.textView_age_item);
item_age_textview.setText(muserinfo.get(position).getMage()+"");
TextView item_sex_textview=(TextView) convertView.findViewById(R.id.textView_sex_item);
item_sex_textview.setText(muserinfo.get(position).getMsex());
ImageView avater_imageview=convertView.findViewById(R.id.avater_imageView_item);
avater_imageview.setImageResource(R.drawable.moka);
return convertView;
}
}
package com.example.work;
import android.content.Context;
import android.content.Intent;
import android.graphics.Color;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;
import androidx.activity.result.ActivityResult;
import androidx.activity.result.ActivityResultCallback;
import androidx.activity.result.ActivityResultLauncher;
import androidx.activity.result.contract.ActivityResultContracts;
import androidx.annotation.Nullable;
import androidx.fragment.app.Fragment;
import androidx.recyclerview.widget.LinearLayoutManager;
import androidx.recyclerview.widget.RecyclerView;
import java.util.ArrayList;
import java.util.List;
public class lianxiren_Fragment extends Fragment {
// TODO: Rename parameter arguments, choose names that match
// the fragment initialization parameters, e.g. ARG_ITEM_NUMBER
private ListView mlistview;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
// Inflate the layout for this fragment
View view;
view = inflater.inflate(R.layout.fragment_lianxiren_, container, false);
mlistview=view.findViewById(R.id.lianxiren_listview);
List<UserInfo> muserinfo=new ArrayList<>();
muserinfo.add(new UserInfo("WRS","男",20));
muserinfo.add(new UserInfo("DJY","男",20));
muserinfo.add(new UserInfo("RS","男",20));
lianxiren_adapter lianxirenAdapter=new lianxiren_adapter(getContext(),muserinfo);
mlistview.setAdapter(lianxirenAdapter);
return view;
}
}