Volley

Volley

前言:volley的ImageLoader方法获取的图片,将会结合LruCache实现图片缓存,缓存的数据将会自动在程序被后台杀死的时候清除,原因显而易见。

ImageLoader不但有缓存,还有本地存储,即:DishCache ,也是volley自行实现的,我们不用去存,也不用去取,当使用ImageLoader时,这一切volley都会自行完成,

即:volley会先缓存,然后在本地存,然后会取缓存,没有就取本地,没有就网络再获取。(可能顺序有出入,如想细致了解,请看volley源码)
 
缓存是存储在LruCache<String, Bitmap> mCacheMap = new LruCache<String, Bitmap>  这样的一个map中
本地存储位置,一般为:data/data/包名/cache/volley   目录下


网络请求String类型,get与post方法

复制代码
public class MainActivity extends Activity {
    RequestQueue mQueue;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mQueue = Volley.newRequestQueue(this);
        getVolley();
        postVolley();
    }
   //get方法 private void getVolley() {
        StringRequest stringRequest = new StringRequest("http://www.baidu.com",
                new Response.Listener<String>() {

                    @Override
                    public void onResponse(String arg0) {
                        System.out.println("##########  " + arg0);
                    }
                }, new Response.ErrorListener() {

                    @Override
                    public void onErrorResponse(VolleyError arg0) {
                        System.out.println("$$$$$$$$$$  " + arg0);
                    }
                });
        mQueue.add(stringRequest);
    }
  

  //post方法
private void postVolley() { StringRequest request = new StringRequest(Method.POST, "http://www.baidu.com", new Response.Listener<String>() { @Override public void onResponse(String arg0) { System.out.println("@@@@@@@@@@@@ " + arg0); } }, new Response.ErrorListener() { @Override public void onErrorResponse(VolleyError arg0) { System.out.println("%%%%%%%%%%% " + arg0); } }) { @Override protected Map<String, String> getParams() throws AuthFailureError { Map<String, String> map = new HashMap<String, String>(); map.put("Key1", "value1"); map.put("Key2", "value2"); return map; } }; mQueue.add(request); } }
复制代码

post方法,有的同学复写不了getParams()方法,是因为需要实现一个匿名内部类。

写法:

//post方法

   private void postVolley() {
      StringRequest request = new StringRequest(method, url, listener, errorListener){
  此时,在此处@Override就可以看到Request<String>了,然后点开选择getParams()方法就可以了。

  Volley_第1张图片
   };
}

 

网络请求Json数据

复制代码
public class MainActivity extends Activity {
    RequestQueue mQueue;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mQueue = Volley.newRequestQueue(this);
        jsonVolley();
    }
        
    private void jsonVolley() {
        JsonObjectRequest jb = new JsonObjectRequest("http://pipes.yahooapis.com/pipes/pipe.run?_id=giWz8Vc33BG6rQEQo_NLYQ&_render=json", null, new Response.Listener<JSONObject>() {

            @Override
            public void onResponse(JSONObject arg0) {
                System.out.println("##########  " + arg0);
            }
        }, new Response.ErrorListener() {

            @Override
            public void onErrorResponse(VolleyError arg0) {
                System.out.println("$$$$$$$$$$  " + arg0);
            }
        });
        mQueue.add(jb);
    }
}
复制代码

 

volley网络获取json源码:http://download.csdn.net/detail/bx276626237/8903127


从获取图片开始,我们RequestQueue放入Application,因为一个程序中通常只需要一个RequestQueue实例。

复制代码
public class ApplicationTest extends Application {
    private static ApplicationTest instance;
    private RequestQueue mQueue;

    public static ApplicationTest getInstance() {
        if (instance == null) {
            instance = new ApplicationTest();
        }
        return instance;
    }

    @Override
    public void onCreate() {
        super.onCreate();
        instance = this;
        setmQueue(Volley.newRequestQueue(this));
    }

    public RequestQueue getmQueue() {
        return mQueue;
    }

    public void setmQueue(RequestQueue mQueue) {
        this.mQueue = mQueue;
    }
}
复制代码

 

 

ImageRequest获取网络图片

复制代码
public class ImgActivity extends Activity {
    ApplicationTest app;
    RequestQueue mQ;
    ImageView iv;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mQ = app.getInstance().getmQueue();
        iv = (ImageView) findViewById(R.id.img);
        imgVolley();
    }

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

                    @Override
                    public void onResponse(Bitmap arg0) {
                        iv.setImageBitmap(arg0);

                    }
                }, 0, 0, Config.RGB_565, new Response.ErrorListener() {

                    @Override
                    public void onErrorResponse(VolleyError arg0) {
                        iv.setImageResource(R.drawable.ic_launcher);
                    }
                });
        mQ.add(img);
    }

}
复制代码

 

ImageLoader的用法

如果你觉得ImageRequest已经非常好用了,那我只能说你太容易满足了 ^_^。实际上,Volley在请求网络图片方面可以做到的还远远不止这些,而ImageLoader就是一个很好的例子。ImageLoader也可以用于加载网络上的图片,并且它的内部也是使用ImageRequest来实现的,不过ImageLoader明显要比ImageRequest更加高效,因为它不仅可以帮我们对图片进行缓存,还可以过滤掉重复的链接,避免重复发送请求。

复制代码
public class ImgActivity extends Activity {
    ApplicationTest app;
    RequestQueue mQ;
    ImageView iv;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mQ = app.getInstance().getmQueue();
        iv = (ImageView) findViewById(R.id.img);

        loaderImgVolley();
    }

    private void loaderImgVolley() {
        ImageLoader imgLoader = new ImageLoader(mQ, new ImageCache() {
            
            @Override
            public void putBitmap(String arg0, Bitmap arg1) {
                // 如果不缓存,可以空着
                
            }
            
            @Override
            public Bitmap getBitmap(String arg0) {
                // TODO Auto-generated method stub
                return null;
            }
        });
        
        ImageListener listener = ImageLoader.getImageListener(iv, R.drawable.app_icon, R.drawable.ic_launcher);
        imgLoader.get("http://img.my.csdn.net/uploads/201404/13/1397393290_5765.jpeg", listener);  
    }
}
复制代码

 

虽然现在我们已经掌握了ImageLoader的用法,但是刚才介绍的ImageLoader的优点却还没有使用到。为什么呢?因为这里创建的ImageCache对象是一个空的实现,完全没能起到图片缓存的作用。其实写一个ImageCache也非常简单,但是如果想要写一个性能非常好的ImageCache,最好就要借助Android提供的LruCache功能.

复制代码
public class ImgActivity extends Activity {
    ApplicationTest app;
    RequestQueue mQ;
    ImageView iv;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mQ = app.getInstance().getmQueue();
        iv = (ImageView) findViewById(R.id.img);

        loaderImgVolley();
    }

    /**
     *图片缓存需要做成单例,全局共享
     */
    private static class LruImageCache implements ImageCache
    {
        private LruImageCache(){}
        
        private static LruImageCache instance = new LruImageCache();
        
        public static final LruImageCache getInstance()
        {
            return instance;
        }
        private static final String TAG = "LruImageCache";
        private final int maxSize = (int) (Runtime.getRuntime().maxMemory()/8);
        private LruCache<String,Bitmap> mCacheMap = new LruCache<String,Bitmap>(maxSize)
        {
            protected int sizeOf(String key, Bitmap value)
            {
                return value.getRowBytes()*value.getHeight();
            }
        };
        
        @Override
        public Bitmap getBitmap(String url)
        {
            Bitmap bitmap = mCacheMap.get(url);
            Log.i(TAG, "url = "+url);
            return bitmap;
        }
        @Override
        public void putBitmap(String url, Bitmap bitmap)
        {
            Log.i(TAG, "put url = "+url+",cache:"+bitmap);
            mCacheMap.put(url, bitmap);
        }
        
    }
    private void loaderImgVolley() {
        
        ImageLoader imgLoader = new ImageLoader(mQ, new LruImageCache());
        ImageListener listener = ImageLoader.getImageListener(iv, R.drawable.app_icon, R.drawable.ic_launcher);
        imgLoader.get("http://img.my.csdn.net/uploads/201404/13/1397393290_5765.jpeg", listener);  
    }
}
复制代码

 

你可能感兴趣的:(Volley)