本文实例为大家分享了XListView实现网络加载图片,和下拉刷新的功能,供大家参考,具体内容如下
MainActivity.java
public class MainActivity extends AppCompatActivity { private XListView contents; private int page = 0; private MyBaseAdapter adapter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); contents = findViewById(R.id.contents); adapter = new MyBaseAdapter(getLayoutInflater()); contents.setAdapter(adapter); //是否开启下拉刷新 上拉加载 //contents.setPullRefreshEnable(false); contents.setPullLoadEnable(true); contents.setXListViewListener(new XListView.IXListViewListener() { @Override public void onRefresh() { page = 0; loadData(page); //加载刷新数据 } @Override public void onLoadMore() { loadData(page); } }); //一进来就去加载第一页数据 loadData(page); } private String url = "http://apis.juhe.cn/cook/query?key=3ec004200a6a2f4cf4774e480c006375&menu=%E8%A5%BF%E7%BA%A2%E6%9F%BF&rn=10&pn="; private void loadData(int page) { String requestUrlWithPageNum = url + page; //加载网络数据 new AsyncTask<String, Void, List<DataItem>>() { @Override protected List<DataItem> doInBackground(String... strings) { ResponseBean responseBean = null; try { URL url = new URL(strings[0]); HttpURLConnection urlConnection = (HttpURLConnection) url.openConnection(); urlConnection.setRequestMethod("GET"); urlConnection.setConnectTimeout(5000); urlConnection.setReadTimeout(5000); int responseCode = urlConnection.getResponseCode(); if (responseCode == 200) { String str = stream2String(urlConnection.getInputStream()); responseBean = new Gson().fromJson(str, ResponseBean.class); } else { // } return responseBean == null ? null : responseBean.getResult().getData(); } catch (MalformedURLException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } return null; } @Override protected void onPostExecute(List<DataItem> dataItems) { if (dataItems == null) { Toast.makeText(MainActivity.this, "请求数据错误", Toast.LENGTH_LONG).show(); return; } //更新数据 updateData(dataItems); loadCompleted(); } }.execute(url); } private String stream2String(InputStream is) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(is)); StringBuilder sb = new StringBuilder(); for (String tmp = br.readLine(); tmp != null; tmp = br.readLine()) { sb.append(tmp); } return sb.toString(); } private void updateData(List<DataItem> datas) { if (page == 0) { adapter.setDatas(datas); } else { adapter.addDatas(datas); } } //通过 加载 / 刷新 完成 private void loadCompleted() { //通过ListView:刷新、加载完成 page++; contents.stopLoadMore(); contents.stopRefresh(); } }
MyBaseAdapter.java
public class MyBaseAdapter extends BaseAdapter { private List<DataItem> mDatas; protected LayoutInflater mInflater; /** * 更新数据 */ public void setDatas(List<DataItem> datas) { mDatas.clear(); if (datas != null) { mDatas.addAll(datas); } notifyDataSetChanged(); } /** * 追加数据 */ public void addDatas(List<DataItem> datas) { if (datas != null) { mDatas.addAll(datas); notifyDataSetChanged(); } } public MyBaseAdapter(LayoutInflater mInflater) { this.mInflater = mInflater; mDatas = new ArrayList<>(); } @Override public int getCount() { return mDatas.size(); } @Override public DataItem getItem(int position) { return mDatas.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { BaseViewHolder viewHolder = null; if (convertView == null) { convertView = mInflater.inflate(R.layout.item, parent, false); viewHolder = new BaseViewHolder(convertView); } else { viewHolder = (BaseViewHolder) convertView.getTag(); } viewHolder.bindData(getItem(position)); return convertView; } public class BaseViewHolder { private View itemView; private ImageView icon; private TextView title; private TextView date; public BaseViewHolder(View itemView) { this.itemView = itemView; title = itemView.findViewById(R.id.title); date = itemView.findViewById(R.id.date); icon = itemView.findViewById(R.id.icon); itemView.setTag(this); } public void bindData(DataItem dataItem) { title.setText(dataItem.getTitle()); date.setText(dataItem.getId()); ImageLoader.getInstance().displayImage(dataItem.getFirstImageUrl(), icon, ImageLoaderConfigs.getDefaultDisplayImageOptions(icon.getContext())); } } } ImageLoader.java public class ImageLoaderConfigs { public static ImageLoaderConfiguration getImageLoaderConfiguration(Context context) { ImageLoaderConfiguration configuration = new ImageLoaderConfiguration.Builder(context) //内在缓存额外选项, 最大的宽度,高度 //.memoryCacheExtraOptions(480, 800) // default = device screen dimensions 内存缓存文件的最大长宽 //.diskCacheExtraOptions(480, 800, null) // 本地缓存的详细信息(缓存的最大长宽),最好不要设置这个 //线程池配置 //.taskExecutor() //.taskExecutorForCachedImages() //.threadPoolSize(3) // default 线程池内加载的数量 //.threadPriority(Thread.NORM_PRIORITY - 2) // default 设置当前线程的优先级 //任务处理优先级 Fist In Fist Out //.tasksProcessingOrder(QueueProcessingType.FIFO) // default //内存中不缓存一张图片的多个尺寸大小 //.denyCacheImageMultipleSizesInMemory() //内在缓存策略 //.memoryCache(new LruMemoryCache(2 * 1024 * 1024)) //可以通过自己的内存缓存实现 //内存缓存大小 //.memoryCacheSize(2 * 1024 * 1024) // 内存缓存的最大值 //内在缓存大小:占用百分比 .memoryCacheSizePercentage(13) // default //磁盘缓存策略 //.diskCache(new LruDiskCache()) // default 可以自定义缓存路径 //磁盘缓存大小 .diskCacheSize(50 * 1024 * 1024) // 50 Mb sd卡(本地)缓存的最大值 //.diskCacheFileCount(100) // 可以缓存的文件数量 // default为使用HASHCODE对UIL进行加密命名, 还可以用MD5(new Md5FileNameGenerator())加密 //.diskCacheFileNameGenerator(new HashCodeFileNameGenerator()) //.imageDownloader(new BaseImageDownloader(context)) // default //(new BaseImageDecoder(false)) // default //加载具体图片时的一些配置 .defaultDisplayImageOptions(DisplayImageOptions.createSimple()) // default .writeDebugLogs() // 打印debug log .build(); return configuration; } public static DisplayImageOptions getDefaultDisplayImageOptions(Context context) { DisplayImageOptions displayImageOptions = new DisplayImageOptions.Builder() //是否缓存 .cacheInMemory(true) .cacheOnDisk(true) //RGB 565 r红色占5 g绿色占6 b蓝色占5 -> 2字节 //alpha //ARGB 4444 4 4 4 4 -> 2字节 //ARGB 8888 -> 4字节 //10 * 10 用rgb565 -> 10*10*2 .bitmapConfig(Bitmap.Config.RGB_565) //加载时、加载错误时展示什么内容 .showImageOnLoading(R.mipmap.ic_launcher) .showImageOnFail(R.mipmap.ic_launcher) // .imageScaleType(ImageScaleType.EXACTLY_STRETCHED) //加载效果 //ctrl + p .displayer(new CircleBitmapDisplayer()) .build(); //ctrl + h //BitmapDisplayer; return displayImageOptions; } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍XListView实现下拉刷新和上拉加载原理解析,包括了XListView实现下拉刷新和上拉加载原理解析的使用技巧和注意事项,需要的朋友参考一下 XListview是一个非常受欢迎的下拉刷新控件,但是已经停止维护了。之前写过一篇XListview的使用介绍,用起来非常简单,这两天放假无聊,研究了下XListview的实现原理,学到了很多,今天分享给大家。 提前声明,为了让代码
本文向大家介绍Android XListView下拉刷新和上拉加载更多,包括了Android XListView下拉刷新和上拉加载更多的使用技巧和注意事项,需要的朋友参考一下 市面上有好多的类比ListView刷新数据的开源框架,如:v4包自带的SwipeRefreshLayout ,以及集ListView、GridView甚至WebView于一身的Pulltorefresh等等。前述的两个开源框
本文向大家介绍vue实现网络图片瀑布流 + 下拉刷新 + 上拉加载更多(步骤详解),包括了vue实现网络图片瀑布流 + 下拉刷新 + 上拉加载更多(步骤详解)的使用技巧和注意事项,需要的朋友参考一下 一、思路分析和效果图 用vue来实现一个瀑布流效果,加载网络图片,同时有下拉刷新和上拉加载更多功能效果。然后针对这几个效果的实现,捋下思路: 根据加载数据的顺序,依次追加标签展示效果; 选择哪种方
本文向大家介绍Android巧用XListView实现万能下拉刷新控件,包括了Android巧用XListView实现万能下拉刷新控件的使用技巧和注意事项,需要的朋友参考一下 摘要:想必大家做开发的时候都会用到下拉刷新的控件,现在各种第三方的下拉刷新控件不胜枚举。当然最NB的还是XListView。其他也有针对GridView,ScrollView,LinearLayout进行重写的下拉刷新控件。
本文向大家介绍H5基于iScroll实现下拉刷新和上拉加载更多,包括了H5基于iScroll实现下拉刷新和上拉加载更多的使用技巧和注意事项,需要的朋友参考一下 前言 前一段有个手机端的项目需要用到下拉刷新和上拉加载更多的效果,脑海里第一反映就是微博那种效果,刚开始的理解有些偏差,以为下拉也是追加数据,上拉也是追加数据,后请教同事后发现其实下拉只是刷新最新数据而已,上拉是追加数据。 使用
本文向大家介绍Android ListView实现上拉加载更多和下拉刷新功能,包括了Android ListView实现上拉加载更多和下拉刷新功能的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家介绍了Android ListView下拉刷新功能的实现方法和功能,供大家参考,具体内容如下 1、ListView优化方式 界面缓存:ViewHolder+convertView 分页加载:上拉刷新