摘要:前言想必很多人都用過,為了建立網(wǎng)絡編程的知識體系,是必須要講的知識點,所以我這里有必要再次介紹一下的使用。簡介在年大會上推出了一個新的網(wǎng)絡通信框架。在使用前請下載庫并放在目錄下并到工程中。
前言
Volley想必很多人都用過,為了建立網(wǎng)絡編程的知識體系,Volley是必須要講的知識點,所以我這里有必要再次介紹一下Volley的使用。
1.Volley簡介在2013年Google I/O大會上推出了一個新的網(wǎng)絡通信框架Volley。Volley既可以訪問網(wǎng)絡取得數(shù)據(jù),也可以加載圖片,并且在性能方面也進行了大幅度的調(diào)整,它的設計目標就是非常適合去進行數(shù)據(jù)量不大,但通信頻繁的網(wǎng)絡操作,而對于大數(shù)據(jù)量的網(wǎng)絡操作,比如說下載文件等,Volley的表現(xiàn)就會非常糟糕。在使用Volley前請下載Volley庫并放在libs目錄下并add到工程中。 下載Volley請點擊這
2.Volley網(wǎng)絡請求隊列Volley請求網(wǎng)絡都是基于請求隊列的,開發(fā)者只要把請求放在請求隊列中就可以了,請求隊列會依次進行請求,一般情況下,一個應用程序如果網(wǎng)絡請求沒有特別頻繁則完全可以只有一個請求隊列(對應Application),如果非常多或其他情況,則可以是一個Activity對應一個網(wǎng)絡請求隊列,這就要看具體情況了,首先創(chuàng)建隊列:
RequestQueue mQueue = Volley.newRequestQueue(getApplicationContext());3.StringRequest的用法
StringRequest返回的數(shù)據(jù)是String類型的,我們查看下StringRequest的源碼:
public class StringRequest extends Request{ private final Listener mListener; public StringRequest(int method, String url, Listener listener, ErrorListener errorListener) { super(method, url, errorListener); this.mListener = listener; } public StringRequest(String url, Listener listener, ErrorListener errorListener) { this(0, url, listener, errorListener); } ...省略 }
有兩個構(gòu)造函數(shù),其中第一個比第二個多了一個請求的方法,如果采用第二個則默認是GET請求。好了,我們試著用GET方法來請求百度:
//創(chuàng)建請求隊列 RequestQueue mQueue = Volley.newRequestQueue(getApplicationContext()); StringRequest mStringRequest = new StringRequest(Request.Method.GET, "http://www.baidu.com", new Response.Listener() { @Override public void onResponse(String response) { Log.i("wangshu", response); } }, new Response.ErrorListener() { @Override public void onErrorResponse(VolleyError error) { Log.e("wangshu", error.getMessage(), error); } }); //將請求添加在請求隊列中 mQueue.add(mStringRequest);
當然別忘了添加網(wǎng)絡訪問權(quán)限:
請求結(jié)果不用說是百度界面的html文件:
4.JsonRequest的用法和StringRequest類似,我們直接上代碼:
RequestQueue mQueue = Volley.newRequestQueue(getApplicationContext()); JsonObjectRequest mJsonObjectRequest = new JsonObjectRequest(Request.Method.POST,"http://api.1-blog.com/biz/bizserver/article/list.do", new Response.Listener() { @Override public void onResponse(JSONObject response) { Log.d("wangshu", response.toString()); } }, new Response.ErrorListener() { @Override public void onErrorResponse(VolleyError error) { Log.e("wangshu", error.getMessage(), error); } } ); mQueue.add(mJsonObjectRequest);
運行程序返回的是一堆新聞的Json數(shù)據(jù):
為了解析這些Json數(shù)據(jù),我們用Gson來解析Json數(shù)據(jù)。點擊這里下載Gson將jar包放在libs目錄下并add進工程中。我們開始寫article類用于存儲數(shù)據(jù):
public class Article { private String desc; private String status; private Listdetail = new ArrayList (); public List getDetail() { return detail; } public void setDetail(List detail) { this.detail = detail; } public String getDesc() { return desc; } public void setDesc(String desc) { this.desc = desc; } public String getStatus() { return status; } public void setStatus(String status) { this.status = status; } public class detail { private String title; private String article_url; private String my_abstract; private String article_type; public String getTitle() { return title; } public void setTitle(String title) { this.title = title; } public String getArticle_url() { return article_url; } public void setArticle_url(String article_url) { this.article_url = article_url; } public String getMy_abstract() { return my_abstract; } public void setMy_abstract(String my_abstract) { this.my_abstract = my_abstract; } public String getArticle_type() { return article_type; } public void setArticle_type(String article_type) { this.article_type = article_type; } } }
最后我們改寫JsonRequest的請求回調(diào):
RequestQueue mQueue = Volley.newRequestQueue(getApplicationContext()); JsonObjectRequest mJsonObjectRequest = new JsonObjectRequest(Request.Method.POST,"http://api.1-blog.com/biz/bizserver/article/list.do", new Response.Listener() { @Override public void onResponse(JSONObject response) { Article mArticle=new Gson().fromJson(response.toString(), Article.class); List mList=mArticle.getDetail(); String title=mList.get(0).getTitle(); Log.d("wangshu", title); } }, new Response.ErrorListener() { @Override public void onErrorResponse(VolleyError error) { Log.e("wangshu", error.getMessage(), error); } } ); mQueue.add(mJsonObjectRequest);
來看看打印結(jié)果:
5.使用ImageRequest加載圖片ImageRequest已經(jīng)是過時的方法了,和前面兩種的用法類似:
RequestQueue mQueue = Volley.newRequestQueue(getApplicationContext()); ImageRequest imageRequest = new ImageRequest( "http://img.my.csdn.net/uploads/201603/26/1458988468_5804.jpg", new Response.Listener() { @Override public void onResponse(Bitmap response) { iv_image.setImageBitmap(response); } }, 0, 0, Bitmap.Config.RGB_565, new Response.ErrorListener() { @Override public void onErrorResponse(VolleyError error) { iv_image.setImageResource(R.drawable.ico_default); } }); mQueue.add(imageRequest);
查看ImageRequest的源碼發(fā)現(xiàn)它可以設置你想要的圖片的最大寬度和高度,在加載圖片時如果圖片超過期望的最大寬度和高度則會進行壓縮:
public ImageRequest(String url, Listener6.使用ImageLoader加載圖片listener, int maxWidth, int maxHeight, ScaleType scaleType, Config decodeConfig, ErrorListener errorListener) { super(0, url, errorListener); this.setRetryPolicy(new DefaultRetryPolicy(1000, 2, 2.0F)); this.mListener = listener; this.mDecodeConfig = decodeConfig; this.mMaxWidth = maxWidth; this.mMaxHeight = maxHeight; this.mScaleType = scaleType; }
ImageLoader的內(nèi)部使用ImageRequest來實現(xiàn),它的構(gòu)造器可以傳入一個ImageCache緩存形參,實現(xiàn)了圖片緩存的功能,同時還可以過濾重復鏈接,避免重復發(fā)送請求。
RequestQueue mQueue = Volley.newRequestQueue(getApplicationContext()); ImageLoader imageLoader = new ImageLoader(mQueue, new BitmapCache()); ImageLoader.ImageListener listener = ImageLoader.getImageListener(iv_image,R.drawable.ico_default, R.drawable.ico_default); imageLoader.get("http://img.my.csdn.net/uploads/201603/26/1458988468_5804.jpg", listener);
與ImageRequest實現(xiàn)效果不同的是,ImageLoader加載圖片會先顯示默認的圖片,等待圖片加載完成才會顯示在ImageView上。
當然ImageLoader也提供了設置最大寬度和高度的方法:
public ImageLoader.ImageContainer get(String requestUrl, ImageLoader.ImageListener imageListener, int maxWidth, int maxHeight) { return this.get(requestUrl, imageListener, maxWidth, maxHeight, ScaleType.CENTER_INSIDE); }7.使用NetworkImageView加載圖片
NetworkImageView是一個自定義控件,繼承自ImageView,封裝了請求網(wǎng)絡加載圖片的功能。
先在布局中引用:
代碼中調(diào)用,和ImageLoader用法類似:
iv_image = (ImageView) this.findViewById(R.id.iv_image); RequestQueue mQueue = Volley.newRequestQueue(getApplicationContext()); ImageLoader imageLoader = new ImageLoader(mQueue, new BitmapCache()); nv_image.setDefaultImageResId(R.drawable.ico_default); nv_image.setErrorImageResId(R.drawable.ico_default); nv_image.setImageUrl("http://img.my.csdn.net/uploads/201603/26/1458988468_5804.jpg", imageLoader);
NetworkImageView并沒有提供設置最大寬度和高度的方法,根據(jù)我們設置控件的寬和高結(jié)合網(wǎng)絡圖片的寬和高內(nèi)部會自動去實現(xiàn)壓縮,如果我們不想要壓縮可以設置NetworkImageView控件的寬和高都為wrap_content。
github源碼下載
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/70591.html
摘要:需要注意的是回調(diào)并不是在線程。也可以通過來同時取消多個請求。在開始創(chuàng)建的時候配置好,在請求網(wǎng)絡的時候用將請求的結(jié)果回調(diào)給線程。最后調(diào)用這個的方法請求成功使用起來簡單多了,而且請求結(jié)果回調(diào)是在線程的。 前言 講完了Volley,我們接下來看看目前比較火的網(wǎng)絡框架OkHttp, 它處理了很多網(wǎng)絡疑難雜癥:會從很多常用的連接問題中自動恢復。如果您的服務器配置了多個IP地址,當?shù)谝粋€IP連接失...
閱讀 871·2021-10-11 10:59
閱讀 2806·2019-08-30 15:43
閱讀 2136·2019-08-30 11:08
閱讀 1657·2019-08-29 15:20
閱讀 1016·2019-08-29 13:53
閱讀 493·2019-08-26 13:24
閱讀 1644·2019-08-26 13:24
閱讀 2828·2019-08-26 12:08