一口一口吃掉Volley(二)
**欢迎访问我的个人博客转发请注明出处: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(二)的更多相关文章
- 一口一口吃掉Volley(一)
欢迎访问我的个人博客转发请注明出处:http://www.wensibo.top/2017/02/16/一口一口吃掉Volley(一)/ 本次编写的Volley教程现在看来其实已经跟不上时代了,但是技 ...
- 一口一口吃掉Volley(三)
欢迎访问我的个人博客转发请注明出处:http://www.wensibo.top/2017/02/17/一口一口吃掉Volley(三)/ 学习了一口一口吃掉Volley(二)之后,你应该已经学会了如何 ...
- 一口一口吃掉Volley(四)
欢迎访问我的个人博客转发请注明出处:http://www.wensibo.top/2017/02/17/一口一口吃掉Volley(四)/ 非常感谢你能够坚持看到第四篇,同时这也是这个Volley系列教 ...
- 一口一口吃掉Hibernate(五)——一对多单向关联映射
版权声明:本文为博主原创文章,未经博主允许不得转载.如需转载请声明:[转自 http://blog.csdn.net/xiaoxian8023 ] 在上一篇博客<一口一口吃掉Hibernate( ...
- 一口一口吃掉Hexo(二)
如果你想得到更好的阅读效果,请访问我的个人网站 ,版权所有,未经许可不得转载! 本次系列教程的第二篇文章我会介绍如何在本地安装Hexo,请注意我使用的Windows系统,如果你是Mac或者Ubuntu ...
- 一口一口吃掉Hibernate(八)——Hibernate中inverse的用法
一.Inverse是hibernate双向关系中的基本概念.inverse的真正作用就是指定由哪一方来维护之间的关联关系.当一方中指定了“inverse=false”(默认),那么那一方就有责任负责之 ...
- 一口一口吃掉Hexo(一)
如果你想得到更好的阅读效果,请访问我的个人网站 ,版权所有,未经许可不得转载! 这里是我的个人博客网站,点击这里你可以到我的首页瞧瞧.我之前使用的是第三方的博客平台--博客园,点击这里可以看到我的博客 ...
- 一口一口吃掉Hibernate(七)——继承映射
前几篇博文中讲到了常用的几种关联映射.其实hibernate中还有一种"省劲儿"的映射,那就是--"继承映射". 学了这么多的关系映射了,继承映射,从字面上也能 ...
- 一口一口吃掉Hibernate(六)——多对多关联映射
今天来说说hibernate中的多对多关联映射,多对多关联映射涉及到单向映射和双向映射2种. 首先举个多对多关联例子:用户User和角色Role,一个用户可以属于多个角色,一个角色可以有多个用户.这就 ...
随机推荐
- [置顶] AngularJS实战之路由ui-sref-active使用
当我们使用angularjs的路由时,时常会出现一个需求,当选中菜单时把当前菜单的样式设置为选中状态(多数就是改变颜色) 接下来就看看Angular-UI-Router里的指令ui-sref-acti ...
- kafka参数
转载地址http://debugo.com/kafka-params/ ############################# System ########################### ...
- Hdu4135 Co-prime 2017-06-27 16:03 25人阅读 评论(0) 收藏
Co-prime Time Limit : 2000/1000ms (Java/Other) Memory Limit : 32768/32768K (Java/Other) Total Subm ...
- 14:super关键字
本小节知识点: 1.super基本概念 2.super的作用 1.super基本概念 super是个编译器的指令符号,只是告诉编译器在执行的时候,去调谁的方法. self是一个隐私参数; self r ...
- 两个jsp文件运行后弹出对话框 下载文件问题
这个问题是两个jsp字符编码不一致的问题 如图所示 划线部分是要特别注意的地方 出错往往是这里 有时是“;”后面有无空格 如果login.jsp有 那么loginCheck.jsp也必须要有而且是同样 ...
- nodes 验证码
一个常见的需求. 知乎上得讨论:http://www.zhihu.com/question/32156977 node-canvas 在mac上安装有问题,可能是我没有sudo 使用了ccap:挺不错 ...
- shell 命令 -- 漂亮的资源查看命令 htop
htop 相较top,htop更加直接和美观.
- AngularJS 指令中的require
require参数可以被设置为字符串或数组,字符串代表另外一个指令的名字.require会将控制器注入到其值所指定的指令中,并作为当前指令的链接函数的第四个参数.字符串或数组元素的值是会在当前指令的作 ...
- AngularJS 路由 resolve属性
当路由切换的时候,被路由的页面中的元素(标签)就会立马显示出来,同时,数据会被准备好并呈现出来.但是注意,数据和元素并不是同步的,在没有任何设置的情况下,AngularJS默认先呈现出元素,而后再呈现 ...
- hdu 1012 素数判定
这道题~以前判定prime是一个个去试着整除再去存储,上次弄过欧拉函数那题目之后就知道了,这样会更快捷: prime[] = prime[] = ; ; i <maxn; i++) { if(! ...