什么是Volley

很多时候,我们的APP都需要用到网络技术,使用HTTP协议来发送接收数据,谷歌推出了一个网络框架——volley,该框架适合进行数据量不大,但通信频繁的网络操作。

它的优点:

(1)默认Android2.3及以上基于HttpURLConnection,2.3以下使用基于HttpClient;

(2)符合Http 缓存语义 的缓存机制(提供了默认的磁盘和内存等缓存);

(3)请求队列的优先级排序;

(4)提供多样的取消机制;

(5)提供简便的图片加载工具(其实图片的加载才是我们最为看重的功能)

它的缺点:

不适合数据量大的传输,例如下载、视频传输等

首先获取Volley的jar包,具体方法不赘述。

https://android.googlesource.com/platform/frameworks/volley

如何使用Volley

最简单的使用方法可以归纳为:

1.创建一个请求队列→2.创建一个请求→3.将请求加到队列中

就是这么简单!

StringRequest

一个简单的例子:

MainActivity.java

package com.example.volleydemo;

import com.android.volley.RequestQueue;
import com.android.volley.Response;
import com.android.volley.Response.Listener;
import com.android.volley.VolleyError;
import com.android.volley.toolbox.StringRequest;
import com.android.volley.toolbox.Volley; import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button; public class MainActivity extends Activity { private Button bt; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); bt = (Button) findViewById(R.id.bt);
bt.setOnClickListener(new View.OnClickListener() { @Override
public void onClick(View v) {
// 定义一个请求队列
RequestQueue requestQueue = Volley.newRequestQueue(getApplicationContext()); // 定义一个字符串请求
// StringRequest的构造方法需要传入三个参数,第一个参数是我们要请求的地址,第二个参数当我们的请求响应成功时候的回调,第三个参数是当我们请求失败时候的回调
StringRequest sr = new StringRequest("http://www.baidu.com", new Listener<String>() { @Override
public void onResponse(String response) {
Log.d("TTTT", response);
}
}, new Response.ErrorListener() { @Override
public void onErrorResponse(VolleyError error) {
Log.d("TTTT", "连接出错啦!!");
}
});
// 将请求加入到队列中
requestQueue.add(sr); }
}); }
}

activity_main.xml

<RelativeLayout 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:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.example.volleydemo.MainActivity" > <Button
android:id="@+id/bt"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="click me" /> </RelativeLayout>

因为我们需要访问网络,我们还需要添加INTERNET权限,我们先不加试试,不加权限,运行的结果是:

可以看到执行了onErrorResponse中内容

我们加上权限

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

运行结果:

执行成功!Volley就是这么简单

JsonRequest

MainActivity.java

package com.example.volleydemo;

import org.json.JSONObject;

import com.android.volley.RequestQueue;
import com.android.volley.Response;
import com.android.volley.VolleyError;
import com.android.volley.toolbox.JsonObjectRequest;
import com.android.volley.toolbox.Volley; import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button; public class MainActivity extends Activity { private Button bt; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
bt = (Button) findViewById(R.id.bt);
bt.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// 定义一个请求队列
RequestQueue requestQueue = Volley.newRequestQueue(getApplicationContext());
// 定义一个jsonobject请求
// JsonObjectRequest的构造方法需要传入三个参数,第一个参数是我们要请求的地址,第二个参数是我们要传递给服务器的参数,如果没有,则为null,第三个参数当我们的请求响应成功时候的回调,第四个参数是当我们请求失败时候的回调
JsonObjectRequest jsonObjectRequest = new JsonObjectRequest(
"https://api.heweather.com/x3/weather?cityid=CN101010100&key=5d520eb089e646acb270521a7e387",
null, new Response.Listener<JSONObject>() {
public void onResponse(JSONObject response) {
Log.d("TTTT", response.toString());
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
// TODO Auto-generated method stub
}
});
// 将请求加入到队列中
requestQueue.add(jsonObjectRequest);
}
});
}
}

执行结果:成功!

ImageRequest

ImageRequest的使用方法和之前的一样,也是创建队列,创建请求,把请求加入到队列中,只不过ImageRequest的构造方法参数比较多,他们的含义分别为:

url:请求地址

listener:相应成功回调方法

maxWidth:允许图片的最大宽度,如果指定的网络图片宽度大于这里的值,则会进行压缩,如果为0则不进行压缩

maxHeight:允许图片的最大高度,如果指定的网络图片高度大于这里的值,则会进行压缩,如果为0则不进行压缩

decodeConfig:执行图片的颜色属性Bitmap.Config下的几个常量都可以在这里使用

errorListener:请求失败回调方法

MainActivity.java

package com.example.volleydemo;

import com.android.volley.RequestQueue;
import com.android.volley.Response;
import com.android.volley.VolleyError;
import com.android.volley.toolbox.ImageRequest;
import com.android.volley.toolbox.Volley;
import android.annotation.SuppressLint;
import android.app.Activity;
import android.graphics.Bitmap;
import android.graphics.drawable.BitmapDrawable;
import android.graphics.drawable.Drawable;
import android.os.Bundle;
import android.view.View;
import android.widget.Button; @SuppressLint("NewApi")
public class MainActivity extends Activity { private Button bt; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
bt = (Button) findViewById(R.id.bt);
bt.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// 定义一个请求队列
RequestQueue requestQueue = Volley.newRequestQueue(getApplicationContext());
// 定义一个ImageRequest请求
ImageRequest imageRequest = new ImageRequest(
"http://images.cnblogs.com/cnblogs_com/xs104/722323/o_pic.jpg",
new Response.Listener<Bitmap>() {
@Override
public void onResponse(Bitmap response) {
// 将请求返回的Bitmap对象转换为Drawable对象
Drawable drawable = new BitmapDrawable(response);
// 将图片设置为背景
findViewById(R.id.layout).setBackground(drawable);
}
}, 0, 0, Bitmap.Config.ARGB_8888, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) { }
});
// 将请求加入到队列中
requestQueue.add(imageRequest);
}
});
}
}

运行结果:

Android笔记(六十二)网络框架volley的更多相关文章

  1. java之jvm学习笔记六-十二(实践写自己的安全管理器)(jar包的代码认证和签名) (实践对jar包的代码签名) (策略文件)(策略和保护域) (访问控制器) (访问控制器的栈校验机制) (jvm基本结构)

    java之jvm学习笔记六(实践写自己的安全管理器) 安全管理器SecurityManager里设计的内容实在是非常的庞大,它的核心方法就是checkPerssiom这个方法里又调用 AccessCo ...

  2. Android笔记(十二)AndroidManiFest.xml

    AndroidManiFest.xml清单文件是每个Android项目所必须的,它是整个Android应用的全局描述文件.AndroidManiFest.xml清单文件说明了该应用的名称.所使用的图标 ...

  3. 论文阅读笔记六十二:RePr: Improved Training of Convolutional Filters(CVPR2019)

    论文原址:https://arxiv.org/abs/1811.07275 摘要 一个训练好的网络模型由于其模型捕捉的特征中存在大量的重叠,可以在不过多的降低其性能的条件下进行压缩剪枝.一些skip/ ...

  4. Android笔记(七十二) Style和Theme

    我们尝尝需要使用setText.setColor.setTextSize等属性来设置控件的样式,但是每个控件都需要设置这些属性,工作量无疑是巨大的,并且后期维护起来也不方便. Style Androi ...

  5. Android笔记(六十九) 仿微信界面(一)

          综合之前的Fragment和自定义组件的知识,实现微信界面 MainActivity.java package cn.lixyz.test; import android.app.Acti ...

  6. Android笔记(六十八) Fragment总结

    Fragment的产生: 为了适应各种尺寸的屏幕,谷歌推出Fragment,可以把Fragment成Activity的一个组成部分,它拥有自己的生命周期.可以接收并处理用户的各种事件,还可以动态的增删 ...

  7. Android笔记(六十六) android中的动画——XML文件定义属性动画

    除了直接在java代码中定义动画之外,还可以使用xml文件定义动画,以便重用. 如果想要使用XML来编写动画,首先要在res目录下面新建一个animator文件夹,所有属性动画的XML文件都应该存放在 ...

  8. Android笔记(六十五) android中的动画——属性动画(propertyanimation)

    补间动画只能定义起始和结束两个帧在“透明度”.“旋转”.“倾斜”.“位移”4个方面的变化,逐帧动画也只能是播放多个图片,无法满足我们日常复杂的动画需求,所以谷歌在3.0开始,推出了属性动画(prope ...

  9. Android笔记(六十四) android中的动画——补间动画(tweened animation)

    补间动画就是只需要定义动画开始和结束的位置,动画中间的变化由系统去补齐. 补间动画由一下四种方式: 1.AplhaAnimation——透明度动画效果 2.ScaleAnimation ——缩放动画效 ...

随机推荐

  1. primer express 注册

    xp的

  2. pytorch torch.backends.cudnn设置作用

    cuDNN使用非确定性算法,并且可以使用torch.backends.cudnn.enabled = False来进行禁用 如果设置为torch.backends.cudnn.enabled =Tru ...

  3. Laya微信小游戏的开放域

    版本2.1.1.1 现在Laya的开放域比较好用了. 新建开放域项目,里面直接有个排行榜的示例. 直接发布 得到较少的文件,复制这些文件,粘贴到主项目bin/openDataContext下. (op ...

  4. [ Docker ] 基础概念

    目录- 什么是容器- 虚拟化和容器技术- docker 的基本概念 1. 什么是容器 容器英文:Container,容器是一种基础工具:泛指任何可以用于容纳其他物品的工具,可以部分或者完全封闭,被用于 ...

  5. mysql8忘记秘密-重置密码步骤

    mysql8修改密码的方式有些许不同 1.配置无密码登录 修改/etc/my.cnf文件,在mysqld模块下添加 skip-grant-tables 2.重启mysql 3.mysql -uroot ...

  6. Jenkins - 以Docker方式安装启动Jenkins

    1 - 官网信息 操作步骤:https://jenkins.io/zh/doc/book/installing/#docker Docker映像地址:https://hub.docker.com/r/ ...

  7. Java分布式定时任务

    分布式定时任务 elastic-job 可以实现任务分片 quartz 可以把任务存入数据库,实时生成任务(添加数据库添加定时任务) 文档 中文翻译 翻译2

  8. Qt编译理解(Qt 对 C++ 的扩展主要是3个方面)

    沉沉的黑夜都是白天的前奏.--郭小川 舍弃IDE或qmake.cmake等工具的束缚,通过几个例子, 一步步从标准 C++ 的编译过渡到 Qt 的编译. Qt 对 C++ 的扩展主要是3个方面: 1) ...

  9. 使用TCP的协议有哪些?使用UDP的协议有哪些?

    运行于TCP协议之上的协议: HTTP协议:超文本传输协议,用于普通浏览 HTTPS协议:安全超文本传输协议,身披SSL外衣的HTTP协议 FTP协议:文件传输协议,用于文件传输 POP3协议:邮局协 ...

  10. InfoGan笔记

    InfoGAN: Interpretable Representation Learning by Information Maximizing Generative Adversarial Nets ...