interface回调获取网络数据listview展示,解决image显示错乱

本文主要是介绍interface回调获取网络数据listview展示,解决image显示错乱,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

工具类NetUtil

package com.example.loadimage;import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.AsyncTask;
import android.util.Log;
import android.util.LruCache;
import android.widget.ImageView;import com.google.gson.Gson;import java.io.BufferedReader;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLConnection;
import java.security.MessageDigest;
import java.util.HashMap;
import java.util.LinkedHashMap;public class NetUtil {//单例private static NetUtil instance;//图片内存缓存private LruCache<String, Bitmap> cache;//HashMap<String, Bitmap> m;//无序的//LinkedHashMap<String, Bitmap>m;//有序的private File saveDir;//私有构造方法private NetUtil(Context context) {int size = (int)(Runtime.getRuntime().freeMemory() * 0.3);cache = new LruCache<>(size);//图片文件缓存目录saveDir = new File(context.getCacheDir(), "img_cache");//不存在,创建if(!saveDir.exists()) {saveDir.mkdirs();}}//提供方法,获取对象public static NetUtil getInstance(Context context) {if(instance == null) {instance = new NetUtil(context);}return instance;}/*public interface ImageCallbak2 {void onStartLoadImage(String url, ImageView imageView);void onLoadImageSuccess(String url, Bitmap bitmap, ImageView imageView);}public void displayBitmap3(final String urlStr, final ImageView imageView) {displayBitmap(urlStr, imageView, new ImageCallbak2() {@Overridepublic void onStartLoadImage(String url, ImageView imageView) {imageView.setTag(url);}@Overridepublic void onLoadImageSuccess(String url, Bitmap bitmap, ImageView imageView) {if(imageView.getTag().equals(url)) {imageView.setImageBitmap(bitmap);} else {Log.i("TEST", "错乱");}}});}public void displayBitmap(final String url, final ImageView imageView, final ImageCallbak2 callbak2) {callbak2.onStartLoadImage(url, imageView);new AsyncTask<String, Void, Bitmap>(){@Overrideprotected Bitmap doInBackground(String... strings) {return getBitmap(strings[0]);}@Overrideprotected void onPostExecute(Bitmap bitmap) {callbak2.onLoadImageSuccess(url, bitmap, imageView);}};}*///1 定义接口:合同public interface ImageCallback {void loadImageSuccess(String url, Bitmap bitmap);}//接口回调public void getBitmap(final String urlStr, final ImageCallback callback) {new AsyncTask<String, Void, Bitmap>(){@Overrideprotected Bitmap doInBackground(String... strings) {return getBitmap(strings[0]);}@Overrideprotected void onPostExecute(Bitmap bitmap) {callback.loadImageSuccess(urlStr, bitmap);}}.execute(urlStr);}//展示图片,没有错乱public void displayBitmap2(final String urlStr, final ImageView imageView) {//绑定url到imageviewimageView.setTag(urlStr);new AsyncTask<String, Void, Bitmap>(){@Overrideprotected Bitmap doInBackground(String... strings) {return getBitmap(strings[0]);}@Overrideprotected void onPostExecute(Bitmap bitmap) {if(imageView.getTag().equals(urlStr)) {imageView.setImageBitmap(bitmap);}else {Log.i("TEST", "错乱");}}}.execute(urlStr);}//请求一张图片,展示给ImageView//异步任务public void displayBitmap(String urlStr, final ImageView imageView) {new AsyncTask<String, Void, Bitmap>(){@Overrideprotected Bitmap doInBackground(String... strings) {return getBitmap(strings[0]);}@Overrideprotected void onPostExecute(Bitmap bitmap) {imageView.setImageBitmap(bitmap);}}.execute(urlStr);}//获取图片public Bitmap getBitmap(String urlStr) {Bitmap result = null;//从内存中要result = cache.get(url2Key(urlStr));//内存命中if(result != null) {Log.i("TEST", "内存中加载图片: " + urlStr);return result;}//从磁盘中要result = getBitmapForFile(urlStr);//文件命中if(result != null) {Log.i("TEST", "磁盘中加载图片: " + urlStr);//先存到内存缓存cache.put(url2Key(urlStr), result);return result;}//从网络中请Log.i("TEST", "网络中加载图片: " + urlStr);result = getBitmapForNetwork(urlStr);//写文件saveBitmap2File(urlStr, result);//存到内存缓存cache.put(url2Key(urlStr), result);return result;}//将url转换成key//url 做key: 太长;如果作为文件名,不允许/ ?private String url2Key(String url) {//MD5 摘要方法//MessageDigestreturn String.valueOf(url.hashCode());}//将图片存到文件private void saveBitmap2File(String urlStr, Bitmap bitmap) {//格式: png jpeg(jpg)//质量: 0 100FileOutputStream fos = null;try {fos = new FileOutputStream(new File(saveDir,url2Key(urlStr)));//图片质量压缩,   并输出到输出流bitmap.compress(Bitmap.CompressFormat.JPEG, 100, fos);} catch (FileNotFoundException e) {e.printStackTrace();}finally {if(fos != null) {try {fos.close();} catch (IOException e) {e.printStackTrace();}}}}//从文件读取图片private Bitmap getBitmapForFile(String urlStr) {/////解码文件为bitmap图片return BitmapFactory.decodeFile(new File(saveDir, url2Key(urlStr)).getAbsolutePath());}//执行一个网络请求,返回一个Bitmap//这一步做:请求图片private Bitmap getBitmapForNetwork(String urlStr) {Bitmap result = null;try {URL url = new URL(urlStr);HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();urlConnection.setRequestMethod("GET");urlConnection.setConnectTimeout(5000);urlConnection.setReadTimeout(5000);int responseCode = urlConnection.getResponseCode();if(responseCode == 200) {result = BitmapFactory.decodeStream(urlConnection.getInputStream());}} catch (java.io.IOException e) {e.printStackTrace();}return result;}///普通get请求public interface Callbak<T>{void onSuccess(T t);}///执行一个网络请求,通过回调返回结果public void getRequest(final String urlStr, final Class clazz, final Callbak callbak) {new AsyncTask<String, Void, Object>(){@Overrideprotected Object doInBackground(String... strings) {return getRequest(urlStr, clazz);}@Overrideprotected void onPostExecute(Object o) {callbak.onSuccess(o);}}.execute(urlStr);}//执行一个网络请求,返回beanpublic <T> T getRequest(String urlStr, Class clazz) {return (T) new Gson().fromJson(getRequest(urlStr), clazz);}//执行一个网络请求,返回String结果public String getRequest(String urlStr) {String result = "";try {URL url = new URL(urlStr);HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection();urlConnection.setRequestMethod("GET");urlConnection.setConnectTimeout(5000);urlConnection.setReadTimeout(5000);int responseCode = urlConnection.getResponseCode();if(responseCode == 200) {result = stream2String(urlConnection.getInputStream());}} catch (java.io.IOException e) {e.printStackTrace();}return result;}private String stream2String(InputStream is) throws IOException {StringBuilder sb = new StringBuilder();BufferedReader br = new BufferedReader(new InputStreamReader(is));for (String tmp = br.readLine(); tmp != null; tmp = br.readLine()) {sb.append(tmp);}return sb.toString();}
}

主线程MainActivity

单一性只做操作

package com.example.loadimage;import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.ListView;public class MainActivity extends AppCompatActivity {private ListView news;private MyBaseAdafter mAdapter;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);news = findViewById(R.id.news);mAdapter = new MyBaseAdafter(this);news.setAdapter(mAdapter);findViewById(R.id.left).setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {//加载数据NetUtil.getInstance(MainActivity.this).getRequest("http://api.expoon.com/AppNews/getNewsList/type/1/p/1", Bean.class, new NetUtil.Callbak<Bean>() {@Overridepublic void onSuccess(Bean o) {mAdapter.setListData(o.getData());}});}});}
}

适配器 MyBaseAdafter

package com.example.loadimage;import android.content.Context;
import android.graphics.Bitmap;
import android.util.Log;
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 MyBaseAdafter extends BaseAdapter {private Context context;private List<Bean.DataBean>mlist;public MyBaseAdafter(Context context) {this.context = context;mlist = new ArrayList<>();}
public void setListData(List<Bean.DataBean> list){this.mlist = list;notifyDataSetChanged();
}@Overridepublic int getCount() {return mlist.size();}@Overridepublic Bean.DataBean getItem(int position) {return mlist.get(position);}@Overridepublic long getItemId(int position) {return position;}@Overridepublic View getView(int position, View convertView, ViewGroup parent) {final ViewHoder viewHoder;if(convertView==null){convertView = LayoutInflater.from(context).inflate(R.layout.item,parent,false);viewHoder = new ViewHoder();viewHoder.textView1 = convertView.findViewById(R.id.textview1);viewHoder.textView2 = convertView.findViewById(R.id.textview2);viewHoder.imageView = convertView.findViewById(R.id.imageview);convertView.setTag(viewHoder);}else{viewHoder = (ViewHoder) convertView.getTag();}viewHoder.textView1.setText(mlist.get(position).getNews_title());viewHoder.textView2.setText(mlist.get(position).getNews_summary());//加载图片//错乱问题//NetUtil.getInstance().displayBitmap(getItem(position).getPic_url(), viewHoder.imageView);//NetUtil.getInstance().displayBitmap2(getItem(position).getPic_url(), viewHoder.imageView);viewHoder.imageView.setTag(getItem(position).getPic_url());NetUtil.getInstance(context).getBitmap(getItem(position).getPic_url(), new NetUtil.ImageCallback() {@Overridepublic void loadImageSuccess(String url, Bitmap bitmap) {if(viewHoder.imageView.getTag().equals(url)) {viewHoder.imageView.setImageBitmap(bitmap);}else {}}});return convertView;}class ViewHoder{private TextView textView1,textView2;private ImageView imageView;}
}

BitmapUtil

package com.example.loadimage;import android.graphics.Bitmap;
import android.graphics.BitmapFactory;public class BitmapUtil {public Bitmap scaleBitmap(int width, int height) {Bitmap result = null;return result;}
}

这篇关于interface回调获取网络数据listview展示,解决image显示错乱的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/933259

相关文章

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

Hadoop集群数据均衡之磁盘间数据均衡

生产环境,由于硬盘空间不足,往往需要增加一块硬盘。刚加载的硬盘没有数据时,可以执行磁盘数据均衡命令。(Hadoop3.x新特性) plan后面带的节点的名字必须是已经存在的,并且是需要均衡的节点。 如果节点不存在,会报如下错误: 如果节点只有一个硬盘的话,不会创建均衡计划: (1)生成均衡计划 hdfs diskbalancer -plan hadoop102 (2)执行均衡计划 hd

第10章 中断和动态时钟显示

第10章 中断和动态时钟显示 从本章开始,按照书籍的划分,第10章开始就进入保护模式(Protected Mode)部分了,感觉从这里开始难度突然就增加了。 书中介绍了为什么有中断(Interrupt)的设计,中断的几种方式:外部硬件中断、内部中断和软中断。通过中断做了一个会走的时钟和屏幕上输入字符的程序。 我自己理解中断的一些作用: 为了更好的利用处理器的性能。协同快速和慢速设备一起工作

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问