**欢迎访问我的个人博客转发请注明出处:http://www.wensibo.top/2017/02/17/一口一口吃掉Volley(二)/ **

相信看了第一篇教程之后,你应该会对Volley有一个初步的了解了吧,那接下来就继续学习如何使用Volley进行开发吧!

配置Gradle

使用如下命令导入Volley库:

compile 'com.mcxiaoke.volley:library:1.0.19'
  • 如果你还是使用Eclipse进行开发的话,可以下载volley的jar包导入工程。

添加联网许可

在AndroidManifest.xml文件中添加联网的请求

<uses-permission android:name="android.permission.INTERNET"/>

使用StringRequest

如果你需要通过网络访问的资源属于String字符串的资源,那么使用StringRequest就最为简单了,只需按照如下步骤就行了。

① 获取一个RequestQueue

RequestQueue mQueue = Volley.newRequestQueue(this);

② 构造一个StringRequest对象

 StringRequest stringRequest=new StringRequest("http://www.wensibo.top"
, new Response.Listener<String>() {
@Override
public void onResponse(String response) {
//正常情况下的逻辑处理
String result="";
try {
result= new String(response.getBytes("ISO_8859_1"), "utf-8");
//由于访问string的时候可能会出现乱码情况,所以保险起见,可以将其转换为utf-8格式
//对于其他的自定义Requet都是同理的,均需要在重写parseNetworkResponse方法时设置编码格式,避免乱码的出现
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
Intent intent = new Intent();
intent.setClass(MainActivity.this, StringRequestActivity.class);
intent.putExtra("string_request", result);
startActivity(intent);
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
//出错的时候做的一些处理
Intent intent = new Intent();
intent.setClass(MainActivity.this, StringRequestActivity.class);
intent.putExtra("string_request", getResources().getString(R.string.error_message));
startActivity(intent);
}
}
);

由于不同的网页的编码格式不同,为了防止中文乱码情况的出现,代码中将其设置为utf-8即可得到解决。其他的Request如果要避免乱码的出现,也应该采取类似的方法进行处理。

③ 将StringRequest对象add进RequestQueue

mQueue.add(stringRequest);

看看截图

使用JsonRequest

有的时候我们不仅需要简单的String资源,还需要获取Json数据,当然Volley也帮我们提供了获取Json的接口,这个就是JsonRequest,使用JsonRequest与StringRequest类似。这里作为例子接收的是北京的天气预报的json对象,获取到的json对象直接打印出来,当然我们还可以获取里面的内容,我将会在自定义的GsonRequest中作介绍。

① 获取一个RequestQueue

RequestQueue mQueue = Volley.newRequestQueue(this);

② 构造一个JsonRequest对象

JsonObjectRequest jsonObjectRequest=new JsonObjectRequest("http://www.weather.com.cn/data/cityinfo/101010100.html"
, new Response.Listener<JSONObject>() {
@Override
public void onResponse(JSONObject response) {
Log.d("JsonObject", response.toString());
Intent intent = new Intent();
intent.setClass(MainActivity.this, JsonRequestActivity.class);
intent.putExtra("json_request", response.toString());
startActivity(intent);
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Log.e("TAG", error.getMessage(), error);
Intent intent = new Intent();
intent.setClass(MainActivity.this, JsonRequestActivity.class);
intent.putExtra("json_request", getResources().getString(R.string.error_message));
startActivity(intent);
}
});

③ 将JsonRequest对象add进RequestQueue

mQueue.add(jsonObjectRequest);

看看截图

使用ImageRequest

获取网络上的图片资源是一个很普通的需求,虽然Volley有这个功能,但是放到现在来看都已不是什么稀奇事了,而且功能比较单一,所以这里就简单介绍一下。

① 获取一个RequestQueue

RequestQueue mQueue = Volley.newRequestQueue(this);

② 构造一个ImageRequest对象

ImageRequest imageRequest=new ImageRequest("http://wensibo.top/img/avatar.jpg"
, new Response.Listener<Bitmap>() {
@Override
public void onResponse(Bitmap response) {
Log.d("SUCCESS", "成功返回ImageRequest");
iv_image_request.setImageBitmap(response);
}
}, 0, 0, Bitmap.Config.RGB_565, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Log.d("ERROR", "返回ImageRequest失败");
iv_image_request.setImageResource(R.drawable.failed_image);
}
}
);

可以看到,ImageRequest的构造函数接收六个参数,第一个参数就是图片的URL地址,这个没什么需要解释的。第二个参数是图片请求成功的回调,这里我们把返回的Bitmap参数设置到ImageView中。第三第四个参数分别用于指定允许图片最大的宽度和高度,如果指定的网络图片的宽度或高度大于这里的最大值,则会对图片进行压缩,指定成0的话就表示不管图片有多大,都不会进行压缩。第五个参数用于指定图片的颜色属性,Bitmap.Config下的几个常量都可以在这里使用,其中ARGB_8888可以展示最好的颜色属性,每个图片像素占据4个字节的大小,而RGB_565则表示每个图片像素占据2个字节大小。第六个参数是图片请求失败的回调,这里我们当请求失败时在ImageView中显示一张默认图片。

③ 将JsonRequest对象add进RequestQueue

mQueue.add(jsonObjectRequest);

**看看截图 **



使用ImageLoader

Volley在请求网络图片方面除了ImageRequest之外,还有另外一个更加高效的ImageLoader。ImageLoader用于加载网络上的图片,并且它的内部也是使用ImageRequest来实现的,不过ImageLoader明显要比ImageRequest更加高效,因为它不仅可以帮我们对图片进行缓存,还可以过滤掉重复的链接,避免重复发送请求。

由于ImageLoader已经不是继承自Request的了,所以它的用法也和我们之前学到的内容有所不同,总结起来大致可以分为以下四步:

① 获取一个RequestQueue

RequestQueue mQueue = Volley.newRequestQueue(this);

② 构造一个ImageLoader对象

ImageLoader imageLoader = new ImageLoader(mQueue, new ImageCache() {
@Override
public void putBitmap(String url, Bitmap bitmap) {
} @Override
public Bitmap getBitmap(String url) {
return null;
} );

ImageLoader的构造函数接收两个参数,第一个参数就是RequestQueue对象,第二个参数是一个ImageCache对象,这里我们先new出一个空的ImageCache的实现即可。具体的ImageCache待会讲解。

③构造一个ImageListener对象

ImageListener listener = imageLoader.getImageListener(iv_image_loader, R.drawable.failed_image, R.drawable.failed_image);

getImageListener()方法接收三个参数,第一个参数指定用于显示图片的ImageView控件,第二个参数指定加载图片的过程中显示的图片,第三个参数指定加载图片失败的情况下显示的图片。

④调用ImageLoader的get()方法加载网络上的图片

imageLoader.get("http://wensibo.top/img/avatar.jpg", listener);

最后,调用ImageLoader的get()方法来加载图片,get()方法接收两个参数,第一个参数就是图片的URL地址,第二个参数则是刚刚获取到的ImageListener对象。当然,如果你想对图片的大小进行限制,也可以使用get()方法的重载,指定图片允许的最大宽度和高度,如下所示:

imageLoader.get("http://wensibo.top/img/avatar.jpg", listener,200,200);

关于ImageCache

刚才讲到ImageLoader的构造函数的第二个参数是一个ImageCache对象,刚才介绍的ImageLoader的优点也在于此。他能起到图片缓存的作用。接下来我们就自己写一个呗!

这里我们新建一个BitmapCache并实现了ImageCache接口:

public class BitmapCache implements ImageCache{

    private LruCache<String, Bitmap> mCache;

    public BitmapCache() {
//将缓存图片的大小设置为8M
int maxSize = 8 * 1024 * 1024;
mCache = new LruCache<String, Bitmap>(maxSize){
@Override
protected int sizeOf(String key, Bitmap bitmap) {
return bitmap.getRowBytes() * bitmap.getHeight();
}
};
} @Override
public Bitmap getBitmap(String url) {
return mCache.get(url);
} @Override
public void putBitmap(String url, Bitmap bitmap) {
mCache.put(url, bitmap);
}
}

这里我们将缓存图片的大小设置为8M。接着修改创建ImageLoader实例的代码,第二个参数传入BitmapCache的实例:

ImageLoader imageLoader = new ImageLoader(mQueue, new BitmapCache());

看看效果吧!

下节课我们将一起自定义Request来满足我们的使用!come on !

一口一口吃掉Volley(二)的更多相关文章

  1. 一口一口吃掉Volley(一)

    欢迎访问我的个人博客转发请注明出处:http://www.wensibo.top/2017/02/16/一口一口吃掉Volley(一)/ 本次编写的Volley教程现在看来其实已经跟不上时代了,但是技 ...

  2. 一口一口吃掉Volley(三)

    欢迎访问我的个人博客转发请注明出处:http://www.wensibo.top/2017/02/17/一口一口吃掉Volley(三)/ 学习了一口一口吃掉Volley(二)之后,你应该已经学会了如何 ...

  3. 一口一口吃掉Volley(四)

    欢迎访问我的个人博客转发请注明出处:http://www.wensibo.top/2017/02/17/一口一口吃掉Volley(四)/ 非常感谢你能够坚持看到第四篇,同时这也是这个Volley系列教 ...

  4. 一口一口吃掉Hibernate(五)——一对多单向关联映射

    版权声明:本文为博主原创文章,未经博主允许不得转载.如需转载请声明:[转自 http://blog.csdn.net/xiaoxian8023 ] 在上一篇博客<一口一口吃掉Hibernate( ...

  5. 一口一口吃掉Hexo(二)

    如果你想得到更好的阅读效果,请访问我的个人网站 ,版权所有,未经许可不得转载! 本次系列教程的第二篇文章我会介绍如何在本地安装Hexo,请注意我使用的Windows系统,如果你是Mac或者Ubuntu ...

  6. 一口一口吃掉Hibernate(八)——Hibernate中inverse的用法

    一.Inverse是hibernate双向关系中的基本概念.inverse的真正作用就是指定由哪一方来维护之间的关联关系.当一方中指定了“inverse=false”(默认),那么那一方就有责任负责之 ...

  7. 一口一口吃掉Hexo(一)

    如果你想得到更好的阅读效果,请访问我的个人网站 ,版权所有,未经许可不得转载! 这里是我的个人博客网站,点击这里你可以到我的首页瞧瞧.我之前使用的是第三方的博客平台--博客园,点击这里可以看到我的博客 ...

  8. 一口一口吃掉Hibernate(七)——继承映射

    前几篇博文中讲到了常用的几种关联映射.其实hibernate中还有一种"省劲儿"的映射,那就是--"继承映射". 学了这么多的关系映射了,继承映射,从字面上也能 ...

  9. 一口一口吃掉Hibernate(六)——多对多关联映射

    今天来说说hibernate中的多对多关联映射,多对多关联映射涉及到单向映射和双向映射2种. 首先举个多对多关联例子:用户User和角色Role,一个用户可以属于多个角色,一个角色可以有多个用户.这就 ...

随机推荐

  1. Ubuntu Server 命令行下的默认语言改为英语en_US.UTF-8

    源文链接:http://tonychiu.blog.51cto.com/656605/393131 如果Ubuntu Server在安装过程中,选择的是中文(很多新手都会在安装时选择中文,便于上手), ...

  2. crontab使用环境变量

    两种方式: 1)直接在crontab中定义变量,如: A=123 * * * * * echo $A > /tmp/a.txt 注意在定义变量时不能使用$引用其它变量,如下面的做法错误: A=1 ...

  3. hdu 4282 枚举,非二分

    http://acm.hdu.edu.cn/showproblem.php?pid=4282 对于方程X^Z + Y^Z + XYZ = K,已知K求此方程解的个数,其中要求X<Y,Z>1 ...

  4. Scala_基本语法

    基本语法 声明值和变量 Scala有两种类型的变量: val:是不可变的(变量的引用不可变),在声明时就必须被初始化,而且初始化以后就不能再赋值: var:声明的时候需要进行初始化,初始化以还可以再对 ...

  5. poj 2886 线段树的更新+反素数

    Who Gets the Most Candies? Time Limit: 5000 MS Memory Limit: 0 KB 64-bit integer IO format: %I64d , ...

  6. Android-Java-类与对象的关系

    类class 例如:class Student {},很多人把class Student {}称为对象或实体,其实这样并不合理,应该称为描述实体/描述对象: 因为被称为对象或实体的是,new Stud ...

  7. SQL Server--疑难杂症之坑爹的Windows故障转移群集

    --============================================================== 估计是春节前最后一次写博客,也估计是本年值班最后一次踩雷,感叹下成也S ...

  8. zabbix_server 报警

    ---恢复内容开始--- 记一个zabbix报警. zabbxi版本   zabbix_server监控报警 zabbix busy unreachable poller processes  mor ...

  9. Hiho #1075: 开锁魔法III

    Problem Statement 描述 一日,崔克茜来到小马镇表演魔法. 其中有一个节目是开锁咒:舞台上有 n 个盒子,每个盒子中有一把钥匙,对于每个盒子而言有且仅有一把钥匙能打开它.初始时,崔克茜 ...

  10. Code Chef December Challenge 2018题解

    传送门 \(MAXEP\) 二分,不过二分的时候要注意把\(mid\)设成\(\left\lfloor{9l+r\over 10}\right\rfloor\),这样往右的次数不会超过\(6\)次 / ...