<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"> <TextView
android:layout_width="match_parent"
android:layout_height="60dp"
android:background="@android:color/holo_blue_light"
android:gravity="center"
android:text="ImagleLoager_Gridview"
android:textColor="@android:color/white"
android:textSize="25sp" /> <android.support.v4.view.ViewPager
android:id="@+id/viewPage"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
/> </LinearLayout>
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="60dp"
android:layout_height="60dp"
android:orientation="vertical">
<ImageView
android:src="@drawable/ic_launcher"
android:id="@+id/image"
android:layout_width="50dp"
android:layout_height="50dp" />
<ProgressBar
android:id="@+id/loading"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@android:color/holo_blue_light" /> </LinearLayout>
package application.weiyuan.com.listviewimageloader;

/**
* Created by Administrator on 2017/7/26.
*/
public class Contants { public static String[] imageUrls = new String[] {"http://h.hiphotos.baidu.com/image/w%3D230/sign=6e399656d343ad4ba62e41c3b2035a89/a08b87d6277f9e2fb00276fb1d30e924b899f30a.jpg"
,"http://h.hiphotos.baidu.com/image/w%3D230/sign=2c133914cdfc1e17fdbf8b327a91f67c/a8ec8a13632762d098b92abda2ec08fa513dc629.jpg"
,"http://g.hiphotos.baidu.com/image/w%3D230/sign=776ceec6c1cec3fd8b3ea076e689d4b6/faedab64034f78f0394889f97b310a55b3191c7c.jpg"
,"http://a.hiphotos.baidu.com/image/w%3D230/sign=a97edd106259252da3171a07049a032c/7dd98d1001e9390151b8b23479ec54e736d19605.jpg"
,"http://c.hiphotos.baidu.com/image/w%3D230/sign=5889f92579f40ad115e4c0e0672d1151/1b4c510fd9f9d72a32abde00d62a2834359bbbe4.jpg"
,"http://imgt8.bdstatic.com/it/u=2,926638203&fm=25&gp=0.jpg"
,"http://imgt8.bdstatic.com/it/u=2,926635772&fm=25&gp=0.jpg"
,"http://imgt9.bdstatic.com/it/u=2,926635207&fm=25&gp=0.jpg"
,"http://imgt8.bdstatic.com/it/u=2,926635826&fm=25&gp=0.jpg"
,"http://imgt7.bdstatic.com/it/u=2,767513653&fm=25&gp=0.jpg"
,"http://imgt9.bdstatic.com/it/u=2,861946843&fm=25&gp=0.jpg"
,"http://imgt7.bdstatic.com/it/u=2,956835248&fm=25&gp=0.jpg"
,"http://f.hiphotos.baidu.com/image/w%3D230/sign=1d32d901b9a1cd1105b675238913c8b0/d01373f082025aaf41e143faf8edab64034f1a2b.jpg"
,"http://imgt6.bdstatic.com/it/u=2,926633844&fm=25&gp=0.jpg"
,"http://imgt6.bdstatic.com/it/u=2,975762047&fm=25&gp=0.jpg"
,"http://imgt7.bdstatic.com/it/u=2,851741187&fm=25&gp=0.jpg"
,"http://imgt9.bdstatic.com/it/u=2,851680066&fm=25&gp=0.jpg"
,"http://imgt6.bdstatic.com/it/u=2,851165675&fm=25&gp=0.jpg"
,"http://imgt8.bdstatic.com/it/u=2,771262254&fm=25&gp=0.jpg"
,"http://imgt8.bdstatic.com/it/u=2,829083522&fm=25&gp=0.jpg"}; }
package application.weiyuan.com.listviewimageloader;

import android.app.Activity;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.ViewParent;
import android.widget.GridView;
import android.widget.ListView; public class MainActivity extends Activity { private ViewPager viewPage;
private ViewPagerAdapter listViewAdapter; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
initData();
} private void initView() {
viewPage = (ViewPager) findViewById(R.id.viewPage);
} private void initData() {
// 创建适配器
listViewAdapter = new ViewPagerAdapter(MainActivity.this);
// 添加适配器到listview中
viewPage.setAdapter(listViewAdapter);
} }
package application.weiyuan.com.listviewimageloader;

import android.app.Application;

import com.nostra13.universalimageloader.cache.disc.naming.Md5FileNameGenerator;
import com.nostra13.universalimageloader.core.ImageLoader;
import com.nostra13.universalimageloader.core.ImageLoaderConfiguration;
import com.nostra13.universalimageloader.core.assist.QueueProcessingType; /**
* Created by Administrator on 2017/7/26.
*/
public class MyApplication extends Application { @Override
public void onCreate() {
super.onCreate();
// 初始化参数
ImageLoaderConfiguration config = new ImageLoaderConfiguration.Builder(this)
.threadPriority(Thread.NORM_PRIORITY - 2) // 线程优先级
.denyCacheImageMultipleSizesInMemory() // 当同一个Uri获取不同大小的图片,缓存到内存时,只缓存一个。默认会缓存多个不同的大小的相同图片
.discCacheFileNameGenerator(new Md5FileNameGenerator()) // 将保存的时候的URI名称用MD5
.tasksProcessingOrder(QueueProcessingType.LIFO) // 设置图片下载和显示的工作队列排序
.writeDebugLogs() // 打印debug log
.build();
ImageLoader.getInstance().init(config); }
}
package application.weiyuan.com.listviewimageloader;

import android.content.Context;
import android.graphics.Bitmap;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.ProgressBar;
import android.widget.Toast; import com.nostra13.universalimageloader.core.DisplayImageOptions;
import com.nostra13.universalimageloader.core.ImageLoader;
import com.nostra13.universalimageloader.core.assist.FailReason;
import com.nostra13.universalimageloader.core.assist.ImageScaleType;
import com.nostra13.universalimageloader.core.display.FadeInBitmapDisplayer;
import com.nostra13.universalimageloader.core.listener.SimpleImageLoadingListener; /**
* Created by Administrator on 2017/7/27.
*/
public class ViewPagerAdapter extends PagerAdapter{ private final DisplayImageOptions options;
private final ImageLoader imageLoader;
private final Context mContext; public ViewPagerAdapter(Context context){
// 获取上下文
mContext = context; // 获取ImageLoader实例
imageLoader = ImageLoader.getInstance(); // 配置图片加载参数
options = new DisplayImageOptions.Builder()
.showImageForEmptyUri(R.drawable.ic_launcher) // 设置图片Uri为空或是错误的时候显示的图片
.showImageOnFail(R.drawable.ic_launcher) // 设置图片加载或解码过程中发生错误显示的图片
.resetViewBeforeLoading(true) // 设置图片在下载前是否重置,复位
.cacheOnDisc(true) // 设置下载的图片是否缓存在SD卡中
.imageScaleType(ImageScaleType.EXACTLY) // 设置图片以如何的编码方式显示
.bitmapConfig(Bitmap.Config.RGB_565) // 设置图片的解码类型
.displayer(new FadeInBitmapDisplayer(300)) // 设置图片渐变显示
.build(); } @Override
public int getCount() {
return Contants.imageUrls.length;
} @Override
public boolean isViewFromObject(View view, Object object) {
return view.equals(object);
} @Override
public void destroyItem(ViewGroup container, int position, Object object) {
// super.destroyItem(container, position, object);
((ViewPager) container).removeView((View) object);
} @Override
public Object instantiateItem(ViewGroup container, int position) {
View imageLayout = View.inflate(mContext, R.layout.listview_item, null); ImageView imageView = (ImageView) imageLayout.findViewById(R.id.image);
final ProgressBar spinner = (ProgressBar) imageLayout.findViewById(R.id.loading); // 加载图片
imageLoader.displayImage(Contants.imageUrls[position], imageView, options, new SimpleImageLoadingListener() {
@Override
public void onLoadingStarted(String imageUri, View view) {
// 显示加载进度条
spinner.setVisibility(View.VISIBLE);
} @Override
public void onLoadingFailed(String imageUri, View view, FailReason failReason) {
String message = null; // 获取图片失败类型
switch (failReason.getType()) {
case IO_ERROR: // 文件I/O错误
message = "Input/Output error";
break; case DECODING_ERROR: // 解码错误
message = "Image can't be decoded";
break; case NETWORK_DENIED: // 网络延迟
message = "Downloads are denied";
break; case OUT_OF_MEMORY: // 内存不足
message = "Out Of Memory error";
break; case UNKNOWN: // 原因不明
message = "Unknown error";
break;
} Toast.makeText(mContext, message, Toast.LENGTH_SHORT).show(); // 隐藏加载进度条
spinner.setVisibility(View.GONE);
} @Override
public void onLoadingComplete(String imageUri, View view, Bitmap loadedImage) {
// 隐藏加载进度条
spinner.setVisibility(View.GONE); // 不显示圆形进度条
}
}); ((ViewPager) container).addView(imageLayout, 0); // 将图片增加到ViewPager return imageLayout;
} }
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="application.weiyuan.com.listviewimageloader">
<uses-permission android:name="android.permission.INTERNET"></uses-permission>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission> <application
android:name=".MyApplication"
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application> </manifest>

ImageLoader在ViewPage中的使用的更多相关文章

  1. ImageLoader在Gridview中的使用

    原理和ImageLoader在Listview中的使用一样,只有下面的几点变化 主页面的布局 <?xml version="1.0" encoding="utf-8 ...

  2. ImageLoader在Listview中的使用

    图片加载框架之ImageLoader 1_特点 1)多线程下载图片,图片可以来源于网络,文件系统,项目文件夹assets中以及drawable中等 2)支持随意的配置ImageLoader,例如线程池 ...

  3. 解决ViewPage中嵌套有ListView或者滑动手势等造成滑动的冲突

    public class ViewPagerCompat extends ViewPager { //mViewTouchMode表示ViewPager是否全权控制滑动事件,默认为false,即不控制 ...

  4. MVC中自定义ViewPage和WebViewPage

    ViewPage和WebViewPage的作用就是将Controller中数据返回给页面,一个是针对aspx一个相对cshtml的.代码如下: public abstract class WebVie ...

  5. 在Asp.net MVC 3 web应用程序中,我们会用到ViewData与ViewBag,对比一下:

    Asp.net MVC中的ViewData与ViewBag ViewData ViewBag 它是Key/Value字典集合 它是dynamic类型对像 从Asp.net MVC 1 就有了 ASP. ...

  6. ASP.NET MVC中viewData、viewBag和templateData的区别

    在MVC3开始,视图数据可以通过ViewBag属性访问,在MVC2中则是使用ViewData.MVC3中保留了ViewData的使用.ViewBag是动态类型(dynamic),ViewData是一个 ...

  7. viewpage滑动查看图片并再有缩略图预览

    首先看下效果图, 主要功能分为3大块 一是滑动查看,通过viewpage来实现,方法见 http://www.cnblogs.com/lovemo1314/p/6109312.html 二.点击放大 ...

  8. 从源代码分析Universal-Image-Loader中的线程池

    一般来讲一个网络访问就需要App创建一个线程来执行,但是这也导致了当网络访问比较多的情况下,线程的数目可能积聚增多,虽然Android系统理论上说可以创建无数个线程,但是某一时间段,线程数的急剧增加可 ...

  9. ImageLoader实现图片异步加载

    ImageLoader是一个广泛使用的图片库,在向网络请求图片时,使用imageView和smartView常会产生outofmemory错误,这时ImageLoader可以起到很大的作用,主要有如下 ...

随机推荐

  1. 缓冲区(Buffer)的数据存取

    缓冲区(Buffer) 1. 缓冲区(Buffer):一个用于特定基本数据类 型的容器. 由 java.nio 包定义的,所有缓冲区 都是 Buffer 抽象类的子类.2. Java NIO 中的 B ...

  2. Rocket - util - MaskGen

    https://mp.weixin.qq.com/s/_aJqf1cFJDK5RVRBhxTWOw   介绍MaskGen的实现.   ​​   1. 基本介绍   给定总线宽度beatBytes,根 ...

  3. 高性能可扩展mysql 笔记(三)Hash分区、RANGE分区、LIST分区

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) 一.MySQL分区表操作 1.定义:数据库表分区是数据库基本设计规范之一,分区表在物理上表现为多个文件, ...

  4. Java实现 LeetCode 747 至少是其他数字两倍的最大数(暴力)

    747. 至少是其他数字两倍的最大数 在一个给定的数组nums中,总是存在一个最大元素 . 查找数组中的最大元素是否至少是数组中每个其他数字的两倍. 如果是,则返回最大元素的索引,否则返回-1. 示例 ...

  5. Java实现 LeetCode 542 01 矩阵(暴力大法,正反便利)

    542. 01 矩阵 给定一个由 0 和 1 组成的矩阵,找出每个元素到最近的 0 的距离. 两个相邻元素间的距离为 1 . 示例 1: 输入: 0 0 0 0 1 0 0 0 0 输出: 0 0 0 ...

  6. Java实现 LeetCode 424 替换后的最长重复字符

    424. 替换后的最长重复字符 给你一个仅由大写英文字母组成的字符串,你可以将任意位置上的字符替换成另外的字符,总共可最多替换 k 次.在执行上述操作后,找到包含重复字母的最长子串的长度. 注意: 字 ...

  7. Java实现 蓝桥杯VIP 算法训练 判断字符位置

    判定字符位置 时间限制: 1Sec 内存限制: 128MB 提交: 487 解决: 251 题目描述 返回给定字符串s中元音字母的首次出现位置.英语元音字母只有'a'.'e'.'i'.'o'.'u'五 ...

  8. java实现祖冲之割圆法

    祖冲之割圆法 南北朝时,我国数学家祖冲之首先把圆周率值 计算到小数点后六位,比欧洲早了1100年!他采 用的是称为"割圆法"的算法,实际上已经蕴含 着现代微积分的思想. 如图[1. ...

  9. Java实现串的简单处理

    串的处理 在实际的开发工作中,对字符串的处理是最常见的编程任务.本题目即是要求程序对用户输入的串进行处理.具体规则如下: 把每个单词的首字母变为大写. 把数字与字母之间用下划线字符(_)分开,使得更清 ...

  10. STL关联容器

    这里简单学习一下STL关联容器,主要是map.multimap.set.multiset以及unordered_map.前四个底层实现都是利用红黑树实现的,查找算法时间复杂度为\(O(log(n))\ ...