android: arrayadapter显示数据到listview

一,代码:

线上的数据:

activity

package com.example.okdemo1.activity;

import android.graphics.Color;
import android.os.Build;
import android.os.Bundle;
import android.transition.Transition;
import android.transition.TransitionInflater;
import android.view.View;
import android.view.Window;
import android.widget.ListView;

import androidx.activity.EdgeToEdge;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;

import com.example.okdemo1.R;
import com.example.okdemo1.adapter.UserAdapter;
import com.example.okdemo1.model.UserListEntity;
import com.example.okdemo1.model.UserListItemEntity;
import com.google.gson.Gson;

import java.io.IOException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import okhttp3.Call;
import okhttp3.Callback;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;

public class MylistActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        EdgeToEdge.enable(this);

        setContentView(R.layout.activity_mylist);
        doGetData();
    }

    //以get方式访问互联网上的页面,并返回数据
    private void doGetData() {
        //Toast.makeText(MainActivity.this, "按钮被点击了!", Toast.LENGTH_LONG).show();
        //1.创建HttpClient对象
        OkHttpClient okHttpClient = new OkHttpClient();
        //2.获取request对象
        Request.Builder builder = new Request.Builder().url("http://www.test.net/json.php");
        Request request = builder.build();
        //3.异步请求发起
        okHttpClient.newCall(request).enqueue(new Callback() {
            @Override
            public void onFailure(@NonNull Call call, @NonNull IOException e) {

            }

            @Override
            public void onResponse(@NonNull Call call, @NonNull Response response) throws IOException {
                try {
                    String result = response.body().string();
                    //解析json到entity对象中

                    Gson gson = new Gson();
                    UserListEntity person = gson.fromJson(result, UserListEntity.class);

                    List<UserListItemEntity> listUser = person.getData().getList();

                    runOnUiThread(new Runnable() {
                        @Override
                        public void run() {
                            // 更新UI,例如显示数据
                            UserAdapter adapter = new UserAdapter(MylistActivity.this, listUser);

                            // 将 UserAdapter 设置为 ListView 的适配器
                            ListView listView = findViewById(R.id.list);
                            listView.setAdapter(adapter);
                        }
                    });

                } catch (IOException e) {
                    throw new RuntimeException(e);
                }
            }
        });
    }

}

 UserAdapter.java

package com.example.okdemo1.adapter;

import android.content.Context;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.TextView;

import com.bumptech.glide.Glide;
import com.bumptech.glide.load.engine.DiskCacheStrategy;
import com.example.okdemo1.R;
import com.example.okdemo1.model.UserListItemEntity;

import java.util.List;

public class UserAdapter extends ArrayAdapter<UserListItemEntity> {

    private Context context;

    public UserAdapter(Context context, List<UserListItemEntity> users) {
        super(context, 0, users);
        this.context = context;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        // 获取当前用户对象
        UserListItemEntity user = getItem(position);

        // 如果视图为空,创建新视图
        if (convertView == null) {
            convertView = LayoutInflater.from(getContext()).inflate(R.layout.item_user, parent, false);
        }

        // 获取视图中的 TextView
        ImageView userImage = convertView.findViewById(R.id.userImage);

        TextView usernameTextView = convertView.findViewById(R.id.userId);
        TextView emailTextView = convertView.findViewById(R.id.userName);

        //设置图片内容:
        Glide.with(this.context)
                .load(user.getImage())
                //.apply(RequestOptions.circleCropTransform()) // 使用 circleCropTransform() 方法设置圆形图片,也可以使用圆角半径的方法设置圆角
                .diskCacheStrategy(DiskCacheStrategy.ALL) // 缓存原始图片和转换后的图片到磁盘
                .skipMemoryCache(false) // 不跳过内存缓存
                .into(userImage);
        // 设置 TextView 的内容
        usernameTextView.setText(String.valueOf(user.getId()));
        emailTextView.setText(user.getName());

        return convertView;
    }
}

单条内容对应的xml

item_user.xml

<?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:orientation="horizontal"
    android:padding="10dp">

    <ImageView
        android:id="@+id/userImage"
        android:layout_width="80dp"
        android:layout_height="80dp"
        android:src="@drawable/ic_launcher_foreground" />

    <LinearLayout
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:orientation="vertical"
        android:paddingStart="16dp"
        android:paddingEnd="16dp"
        android:gravity="center_vertical">

        <TextView
            android:id="@+id/userId"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="商品名"
            android:textSize="18sp"
            android:textColor="@android:color/black" />

        <TextView
            android:id="@+id/userName"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="描述"
            android:textSize="14sp"
            android:textColor="@android:color/darker_gray" />
    </LinearLayout>
</LinearLayout>

model:

package com.example.okdemo1.model;

public class UserListItemEntity {
    private int id;
    private String name;
    private String image;

    public UserListItemEntity(int id, String name) {
        this.id = id;
        this.name = name;
        this.image = image;
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getImage() {
        return image;
    }

    public void setImage(String image) {
        this.image = image;
    }
}

二,测试效果:

 

posted @ 2025-05-17 08:20  刘宏缔的架构森林  阅读(18)  评论(0)    收藏  举报