1.Get方法獲取字符串:java
public void loadGetJson(String url) { //建立RequestQueue對象,一個activity建立一個對象便可 RequestQueue mQueue = Volley.newRequestQueue(getApplicationContext()); //建立get方法的json請求對象 StringRequest sr = new StringRequest(url, new Listener<String>() { @Override public void onResponse(String response) { Log.e("onResponse", "" + response); } }, new ErrorListener() { @Override public void onErrorResponse(VolleyError error) { Log.e("onErrorResponse", "" + error.toString()); } }); //將請求對象加入到請求隊列裏 mQueue.add(sr); }
2.指定get或者post方法獲取字符串android
(1)get方法json
RequestQueue requestQueue = Volley.newRequestQueue(this); StringRequest sRequest=new StringRequest(Request.Method.GET,CITY_CODE_URL, new Listener<String>() { @Override public void onResponse(String response) { System.out.println(response); } }, new Response.ErrorListener() { @Override public void onErrorResponse(VolleyError arg0) { System.out.println("sorry,Error"); } }); sRequest.setShouldCache(false); requestQueue.add(sRequest);
(2)post方法緩存
StringRequest中並無提供設置POST參數的方法,可是當發出POST請求的時候,Volley會嘗試調用StringRequest的父類——Request中的getParams()方法來獲取POST參數,那麼解決方法天然也就有了,咱們只須要在StringRequest的匿名類中重寫getParams()方法,在這裏設置POST參數就能夠了,代碼以下所示:網絡
StringRequest stringRequest = new StringRequest(Method.POST, url, listener, errorListener) { @Override protected Map<String, String> getParams() throws AuthFailureError { Map<String, String> map = new HashMap<String, String>(); map.put("params1", "value1"); map.put("params2", "value2"); return map; } };
完整範例以下:框架
public void loadPostLogin(String url) { RequestQueue mQueue = Volley.newRequestQueue(getApplicationContext()); StringRequest sr = new StringRequest(Request.Method.POST, url, new Listener<String>() { @Override public void onResponse(String response) { Log.e("onResponse", "" + response); } }, new ErrorListener() { @Override public void onErrorResponse(VolleyError error) { Log.e("onErrorResponse", "" + error.toString()); } }) { @Override protected Map<String, String> getParams() throws AuthFailureError { Map<String, String> map = new HashMap<String, String>(); map.put("UserName", "glblong"); map.put("PassWord", "123456"); return map; } }; mQueue.add(sr); }
3.JsonObjectRequest和JsonArrayRequest用法與StringRequest一致,方法以下:ide
第二個參數說明:佈局
Constructor which defaults to GET if jsonRequest is null, POST otherwise.post
默認狀況下設成null爲get方法,不然爲post方法。this
JsonObjectRequest jsonObjectRequest = new JsonObjectRequest(url, null, new Response.Listener<JSONObject>() { @Override public void onResponse(JSONObject response) { Log.d("TAG", response.toString()); } }, new Response.ErrorListener() { @Override public void onErrorResponse(VolleyError error) { Log.e("TAG", error.getMessage(), error); } });
4.ImageRequest用法
/** * 第三第四個參數分別用於指定容許圖片最大的寬度和高度,若是指定的網絡圖片的寬度或高度大於這裏的最大值,則會對圖片進行壓縮, * 指定成0的話就表示無論圖片有多大,都不會進行壓縮。 * * @param url * 圖片地址 * @param listener * @param maxWidth * 指定容許圖片最大的寬度 * @param maxHeight * 指定容許圖片最大的高度 * @param decodeConfig * 指定圖片的顏色屬性,Bitmap.Config下的幾個常量. * @param errorListener */ public void getImgRequest(final ImageView iv, String url) { RequestQueue queue = Volley.newRequestQueue(getApplicationContext()); ImageRequest ir = new ImageRequest(url, new Listener<Bitmap>() { public void onResponse(Bitmap response) { iv.setImageBitmap(response); }; }, 0, 0, Config.RGB_565, new ErrorListener() { @Override public void onErrorResponse(VolleyError error) { // TODO Auto-generated method stub } }); queue.add(ir); }
5. ImageLoader用法
ImageLoader比ImageRequest更加高效,由於它不只對圖片進行緩存,還能夠過濾掉重複的連接,避免重複發送請求。
//1.建立RequestQueue實例 RequestQueue queue = Volley.newRequestQueue(getApplicationContext()); //2.建立ImageLoader實例,ImageCache須要重寫才能實現緩存 ImageLoader il = new ImageLoader(queue, new ImageCache() { @Override public void putBitmap(String url, Bitmap bitmap) { // TODO Auto-generated method stub } @Override public Bitmap getBitmap(String url) { // TODO Auto-generated method stub return null; } }); //3.建立ImageListener實例,設置默認圖片和加載失敗圖片 ImageListener listener = ImageLoader.getImageListener(iv, R.drawable.img_loading, R.drawable.img_failed); //4.經過get方法加載圖片 il.get(url, listener);
使用範例代碼以下:
(1)先實現ImageCache接口
import android.graphics.Bitmap; import android.support.v4.util.LruCache; import com.android.volley.toolbox.ImageLoader.ImageCache; public class ImageLoaderCache implements ImageCache { private LruCache<String, Bitmap> mCache; public ImageLoaderCache() { int maxSize = 10 * 1024 * 1024;//設置緩存圖片的大小爲10M 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); } }
(2)使用方法以下:
public void getImgLoader(ImageView iv,String url) { RequestQueue queue = Volley.newRequestQueue(getApplicationContext()); ImageLoader il = new ImageLoader(queue, new ImageLoaderCache()); ImageListener listener = ImageLoader.getImageListener(iv, R.drawable.img_loading, R.drawable.img_failed); //加載並限定圖片寬度和高度 il.get(url, listener, 200, 300); }
6.NetworkImageView的用法
NetworkImageView在加載圖片的時候會自動獲取自身控件的寬高,而後對比網絡圖片的寬度,再決定是否須要對圖片進行壓縮。也就是說,壓縮過程是在內部徹底自動化的,並不須要咱們關心,NetworkImageView會始終呈現給咱們一張大小剛恰好的網絡圖片,不會多佔用任何一點內存。
若是不想對圖片進行壓縮的話,只須要在佈局文件中把NetworkImageView的layout_width和layout_height都設置成wrap_content就能夠了,這樣NetworkImageView就會將該圖片的原始大小展現出來,不會進行任何壓縮。
(1)佈局文件中添加NetworkImageView控件
<com.android.volley.toolbox.NetworkImageView android:id="@+id/networkImageView1" android:layout_width="120dp" android:layout_height="120dp" android:layout_centerHorizontal="true" android:layout_marginTop="60dp" android:src="@drawable/ic_launcher" />
2.代碼實現
RequestQueue queue = Volley.newRequestQueue(getApplicationContext()); ImageLoader p_w_picpathLoader = new ImageLoader(queue, new ImageLoaderCache()); NetworkImageView niv = (NetworkImageView) findViewById(R.id.networkImageView1); niv.setDefaultImageResId(R.drawable.img_loading); niv.setErrorImageResId(R.drawable.img_failed); niv.setImageUrl(url, p_w_picpathLoader);
7.取消請求
Volley提供了強大的API取消未處理或正在處理的請求。取消請求最簡單的方法是調用請求隊列cancelAll(tag)的方法,前提是你在添加請求時設置了標記。這樣就能使標籤標記的請求掛起。
給請求設置標籤:
request.setTag("My Tag");
使用ApplicationController添加使用了標籤的請求到隊列中:
ApplicationController.getInstance().addToRequestQueue(request, "My Tag");
取消全部指定標記的請求:
mRequestQueue.cancelAll("My Tag");
參考: