android Handler okhttp

package com.example.mepositry.fragment;

import android.os.Bundle;
import android.os.Handler;
import android.os.Looper;
import android.os.Message;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;

import com.example.mepositry.R;
import com.example.mepositry.bean.AdBean;
import com.google.gson.Gson;

import java.io.IOException;
import java.util.List;

import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.fragment.app.Fragment;
import okhttp3.Call;
import okhttp3.Callback;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;

public class EntertainmentFragment extends Fragment {
    private String mUrl2 = "http://test/api/po/hg";
    private OkHttpClient mOkHttpClient;
    private Button btn;

    final Handler handler = new Handler(Looper.getMainLooper()) {
        @Override
        public void handleMessage(Message msg) {
            String stringJson = (String) msg.obj;
            Gson gson = new Gson();
            AdBean mAdBean = gson.fromJson(stringJson, AdBean.class);
            List<AdBean.DataBean> list = mAdBean.getData();
            System.out.println(list);
        }
    };

    @Nullable
    @Override
    public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.fragment_entertainment, container, false);

        btn = view.findViewById(R.id.btn);
        mOkHttpClient = new OkHttpClient();
        btn.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                updateWeatherDataCoordinates();
            }
        });
        return view;
    }

    public void updateWeatherDataCoordinates() {
        Request request = new Request.Builder()
                .url(mUrl2)
                .build();
        mOkHttpClient.newCall(request).enqueue(new Callback() {
            @Override
            public void onFailure(Call call, IOException e) {
                Log.e("TAG", "onFailure");
            }

            @Override
            public void onResponse(Call call, final Response response) throws IOException {
                final String stringJson = response.body().string();
                Log.e("TAG", "GetActivity2_onResponse" + stringJson);

                Message msg = new Message();
                msg.obj = stringJson;
                handler.sendMessage(msg);

            }
        });
    }
}
  <com.google.android.material.tabs.TabLayout
        android:id="@+id/main_tablayout"
        android:layout_width="match_parent"
        android:layout_height="50dp"
        android:textSize="15sp"
        app:tabBackground="@color/blue"
        app:tabIndicatorColor="@color/orange"
        app:tabIndicatorHeight="2dp"
        app:tabMode="auto"
        app:tabSelectedTextColor="@color/red"
        app:tabTextColor="@color/white" />

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 ListView 中显示多张图片,可以使用 OkHttp 进行网络请求获取图片,并使用 ViewHolder 模式对 ListView 进行优化,以提高列表的滑动流畅性。具体实现步骤如下: 1. 在 Adapter 中定义 ViewHolder,用于缓存 item 中的控件: ```java private static class ViewHolder { ImageView imageView; } ``` 2. 在 getView() 方法中获取 ViewHolder,如果 convertView 为 null,则新建一个 ViewHolder,并使用 LayoutInflater 加载布局文件: ```java @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder holder; if (convertView == null) { convertView = LayoutInflater.from(mContext).inflate(R.layout.item_layout, parent, false); holder = new ViewHolder(); holder.imageView = convertView.findViewById(R.id.image_view); convertView.setTag(holder); } else { holder = (ViewHolder) convertView.getTag(); } // 加载图片并设置到 ImageView 中 loadImage(holder.imageView, imageUrlList.get(position)); return convertView; } ``` 3. 在 loadImage() 方法中使用 OkHttp 进行网络请求,获取图片并设置到 ImageView 中: ```java private void loadImage(final ImageView imageView, String imageUrl) { OkHttpClient client = new OkHttpClient(); Request request = new Request.Builder() .url(imageUrl) .build(); client.newCall(request).enqueue(new Callback() { @Override public void onFailure(Call call, IOException e) { e.printStackTrace(); } @Override public void onResponse(Call call, Response response) throws IOException { InputStream inputStream = response.body().byteStream(); final Bitmap bitmap = BitmapFactory.decodeStream(inputStream); mHandler.post(new Runnable() { @Override public void run() { imageView.setImageBitmap(bitmap); } }); } }); } ``` 其中,`imageUrlList` 是存储图片 URL 地址的列表,`mContext` 是 Context 对象,`mHandler` 是 Handler 对象,用于在子线程中更新 UI。首先创建一个 OkHttpClient 对象,然后使用 Request.Builder 构建一个请求,设置请求的 URL 地址。接着使用 `newCall(request).enqueue()` 方法异步执行请求,并在回调方法中获取响应的结果,将 InputStream 转换成 Bitmap,并使用 Handler 将 Bitmap 设置到 ImageView 中,以更新 UI。 需要注意的是,由于网络请求是异步执行的,因此需要使用 Handler 来更新 UI,否则会出现异常。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值