Android框架Volley之:利用Imageloader和NetWorkImageView載入圖片

来源:https://www.cnblogs.com/geeksongs/archive/2019/05/16/10875275.html
-Advertisement-
Play Games

首先我們在項目中導入這個框架: 在AndroidManifest文件當中添加網路許可權: 下麵是我們的首頁佈局:在這個佈局當中我們將Volley框架的所有功能都做成了一個按鈕,按下按鈕之後就會在“顯示結果”下麵顯示結果,顯示結果下麵使用了一個ScrollView,併在ScrollView下麵嵌套了一個 ...


首先我們在項目中導入這個框架:

implementation 'com.mcxiaoke.volley:library:1.0.19'

在AndroidManifest文件當中添加網路許可權:

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

下麵是我們的首頁佈局:
在這個佈局當中我們將Volley框架的所有功能都做成了一個按鈕,按下按鈕之後就會在“顯示結果”下麵顯示結果,顯示結果下麵使用了一個ScrollView,併在ScrollView下麵嵌套了一個Textview和Imageview,用於把我們載入成功之後的圖片和文字進行顯示。

下麵是首頁佈局的代碼:

 
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity">
<Button
    android:id="@+id/get"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:text="Get請求"/>
    <Button
        android:id="@+id/post"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="Post請求"/>
    <Button
        android:id="@+id/json"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="請求JSON"/>
    <Button
        android:id="@+id/ImageRquest"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="ImageRquest載入圖片"/>
    <Button
        android:id="@+id/ImageLoader"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="ImageLoader載入圖片"/>
    <Button
        android:id="@+id/NetWorkImageView"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="NetWorkImageView載入圖片"/>
    <TextView
        android:text="顯示結果"
        android:textSize="20sp"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
    <ImageView
        android:visibility="gone"
        android:id="@+id/iv_volley"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
    <com.android.volley.toolbox.NetworkImageView
        android:id="@+id/NetWork"
        android:visibility="gone"
        android:layout_width="200dp"
        android:layout_height="200dp" />
   <ScrollView
       android:layout_width="match_parent"
       android:layout_height="match_parent">
       <TextView
           android:id="@+id/tv_volley_result"
           android:layout_width="match_parent"
           android:layout_height="match_parent" />



   </ScrollView>
</LinearLayout>
 

圖片緩存類BitmapCache.java代碼:

import android.graphics.Bitmap;
import android.support.v4.util.LruCache;

import com.android.volley.toolbox.ImageLoader;

public class BitmapCache implements ImageLoader.ImageCache {

    private LruCache<String, Bitmap> mCache;

    public BitmapCache() {
        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);
    }


}

 

主活動業務邏輯實現代碼:

import android.graphics.Bitmap;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.TextView;

import com.android.volley.AuthFailureError;
import com.android.volley.Request;
import com.android.volley.RequestQueue;
import com.android.volley.Response;
import com.android.volley.VolleyError;
import com.android.volley.toolbox.ImageLoader;
import com.android.volley.toolbox.ImageRequest;
import com.android.volley.toolbox.JsonArrayRequest;
import com.android.volley.toolbox.JsonObjectRequest;
import com.android.volley.toolbox.NetworkImageView;
import com.android.volley.toolbox.StringRequest;
import com.android.volley.toolbox.Volley;

import org.json.JSONObject;

import java.util.HashMap;
import java.util.Map;

public class MainActivity extends AppCompatActivity {
    private Button get;
    private Button post;
    private Button json;
    private Button imagerequest;
    private  Button imageload;
    private  Button netWorkImageView;

    private ImageView iv;
    private NetworkImageView network;
    private TextView tv_volley_result;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        initview();
        initListener();

    }
    public void initview()//把需要初始化的控制項的邏輯都寫在這裡是一個很好的編程範式
    {

        get=findViewById(R.id.get);
        post=findViewById(R.id.post);
        json=findViewById(R.id.json);
        imagerequest=findViewById(R.id.ImageRquest);
        imageload=findViewById(R.id.ImageLoader);
        netWorkImageView=findViewById(R.id.NetWorkImageView);
        iv=findViewById(R.id.iv_volley);
        network=findViewById(R.id.NetWork);
        tv_volley_result=findViewById(R.id.tv_volley_result);



    }
    public void initListener()
    {
        get.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                //創建一個請求隊列
                RequestQueue requestQueue=Volley.newRequestQueue(MainActivity.this);
                //創建一個請求
                String url="http://gank.io/api/xiandu/category/wow";
                StringRequest stringRequest=new StringRequest(url, new Response.Listener<String>() {
                   //正確接受數據之後的回調
                    @Override
                    public void onResponse(String response) {
                    tv_volley_result.setText(response);
                    }
                }, new Response.ErrorListener() {//發生異常之後的監聽回調
                    @Override
                    public void onErrorResponse(VolleyError error) {
                        tv_volley_result.setText("載入錯誤"+error);
                    }
                });
                //將創建的請求添加到請求隊列當中
                requestQueue.add(stringRequest);
            }
        });


        post.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                // 1 創建一個請求隊列
                RequestQueue requestQueue = Volley.newRequestQueue(MainActivity.this);

                // 2 創建一個post請求
                String url = "http://api.m.mtime.cn/PageSubArea/TrailerList.api";
                StringRequest stringRequest = new StringRequest(Request.Method.POST, url, new Response.Listener<String>() {
                    @Override
                    public void onResponse(String s) {
                        tv_volley_result.setText(s);
                    }
                }, new Response.ErrorListener() {
                    @Override
                    public void onErrorResponse(VolleyError volleyError) {
                        tv_volley_result.setText("請求失敗" + volleyError);
                    }
                }) {
                    @Override
                    protected Map<String, String> getParams() throws AuthFailureError {

                        Map<String, String> map = new HashMap<String, String>();
//                        map.put("value1","param1");

                        return map;
                    }
                };

                // 3 將post請求添加到隊列中
                requestQueue.add(stringRequest);




            }
        });

        json.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
// 1 創建一個請求隊列
                RequestQueue requestQueue = Volley.newRequestQueue(MainActivity.this);

                // 2 創建一個請求
                String url = "http://gank.io/api/xiandu/category/wow";
                //JsonArrayRequest jsonObjectRequest2=......
                JsonObjectRequest jsonObjectRequest = new JsonObjectRequest(url, null, new Response.Listener<JSONObject>() {
                    @Override
                    public void onResponse(JSONObject jsonObject) {
                        tv_volley_result.setText(jsonObject.toString());
                    }
                }, new Response.ErrorListener() {
                    @Override
                    public void onErrorResponse(VolleyError volleyError) {
                        tv_volley_result.setText("請求失敗" + volleyError);
                    }
                });

                // 3 將創建的請求添加到請求隊列中
                requestQueue.add(jsonObjectRequest);

//這一步完成之後就可以使用我們的json解析了

            }
        });

        imagerequest.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                // 1 創建一個請求隊列
                RequestQueue requestQueue = Volley.newRequestQueue(MainActivity.this);

                // 2 創建一個圖片的請求
                String url = "http://img5.mtime.cn/mg/2016/10/11/160347.30270341.jpg";
                ImageRequest imageRequest = new ImageRequest(url, new Response.Listener<Bitmap>() {
                    @Override
                    public void onResponse(Bitmap bitmap) {
                        // 正確接收到圖片
                        iv.setVisibility(View.VISIBLE);//將圖片設置為可見
                        iv.setImageBitmap(bitmap);//將接受到的圖片Bitmap對象傳入到我們的imageview當中
                    }
                }, 0, 0, Bitmap.Config.RGB_565, new Response.ErrorListener() {
                    //前面兩個0,0的參數表示的是我們載入圖片最大寬度和高度,後面的Bitmap.Config.RGB_565表示圖片的質量
                    @Override
                    public void onErrorResponse(VolleyError volleyError) {
                        iv.setImageResource(R.drawable.test);
                    }
                });

                // 3 將請求添加到請求隊列中
                requestQueue.add(imageRequest);

            }
        });


        imageload.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                RequestQueue requestQueue = Volley.newRequestQueue(MainActivity.this);


                ImageLoader imageLoader = new ImageLoader(requestQueue, new ImageLoader.ImageCache() {
                   @Override
                   public Bitmap getBitmap(String s) {
                      return null;
                   }

                   @Override
                  public void putBitmap(String s, Bitmap bitmap) {

                  }
               });


                // 載入圖片
                String url = "http://img5.mtime.cn/mg/2016/10/11/160347.30270341.jpg";
                iv.setVisibility(View.VISIBLE);
                ImageLoader.ImageListener imageListener = imageLoader.getImageListener(iv, R.drawable.test, R.drawable.test);
                //上述代碼後面兩個參數分別表示的是預設的圖片和載入失敗之後的圖片
                imageLoader.get(url, imageListener);
            }
        });

        netWorkImageView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {

                // 讓控制項顯示
                network.setVisibility(View.VISIBLE);

                // 創建一個請求隊列
                RequestQueue requestQueue = Volley.newRequestQueue(MainActivity.this);

                // 創建一個Imageloader
                ImageLoader imageLoader = new ImageLoader(requestQueue, new BitmapCache());

                // 預設圖片和異常圖片設置
                network.setDefaultImageResId(R.drawable.test);
                network.setErrorImageResId(R.drawable.test);

                // 載入圖片
                String url = "http://img5.mtime.cn/mg/2016/10/11/160347.30270341.jpg";
                network.setImageUrl(url, imageLoader);


            }
        });

    }
}

得解。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • JSON 可謂風靡互聯網,在數據交換使用上,其優勢特別明顯,其結構簡潔、可讀易讀、形式靈活。很多 API 介面的數據都採用 JSON 來表示。 PostgreSQL 對 JSON 提供了良好的支持。具體的相關函數可參考: "JSON類型和函數" 從使用的角度而言,個人覺得常見的應用場景為: 1. 讀 ...
  • 當然首先要裝好Oracle 11g 然後還要有sqlplus,這個在Oracle11g的時候應該都會配上的 進入正題,如果oracle/plsql沒scott賬戶,如何創建 先找到Oracle安裝目錄下的soctt.sql 我的是在: E:\app\91959\product\11.2.0\dbho ...
  • (1)連接資料庫時報錯 錯誤原因是和轉義字元有關。連接字元串使用的URL格式,所以其中的密碼中的% 需要轉義。 知識擴展: 連接mongo使用URI有特殊字元 '@' 或者":"或者‘%’, 連接會報錯,需要進行轉義。 解決方法: 把 @ 換成 %40 把 : 換成 %3A 把 % 換成 %25 ( ...
  • 1. 現象與問題 ORDER BY排序後,用LIMIT取前幾條,發現返回的結果集的順序與預期的不一樣 下麵是我遇到的問題: 可以看到,帶LIMIT與不帶LIMIT的結果與我預期的不一樣,而且“很不可思議”,真是百思不得其解 後來百度了一下,如果order by的列有相同的值時,mysql會隨機選取這 ...
  • 問題的提出 在項目中,有些表的記錄增長非常快,記錄數過大時會使得查詢變得困難,導致整個資料庫處理性能下降。此時,我們會考慮按一定的規則進行分表存儲。 常用的分表方式是按時間周期,如每月一張,每天一張等。當每月或每天首條記錄到達時,根據表結構創建該周期為尾碼的表進行存儲。 相關考慮 這其中主要考慮兩個 ...
  • 一、MySQL5.7的卸載 1.1yum方式查看yum是否安裝過mysql cd yum list installed mysql* 如或顯示了列表,說明系統中有MySQL 如上顯示,我已經安裝了mysql,共有4項 1.2yum卸載mysql 將列表中出現的名字全部卸載掉 yum remove m ...
  • 小程式開發框架的目標是通過儘可能簡單、高效的方式讓開發者可以在微信中開發具有原生 APP 體驗的服務。 ...
  • 1、向目標Activity傳遞數據: 2、在目標Activity中取出數據 目標Activity銷毀時,可以回傳數據給上一個Activity: 1、啟動目標Activity,並設置一個請求碼標識當前Activity 2、在目標Activity中回傳數據 回傳時會把請求碼、結果碼、Intent數據封裝 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...