欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android Glide 4.0+使用詳解

 更新時間:2018年03月15日 13:59:12   作者:yukuoyuan  
這篇文章主要介紹了Android Glide 4.0+使用詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

下載和設置

Android SDK 要求

使用最低要求 - 使用 Glide 要求 SDK 版本為 API 14 (Ice Cream Sandwich) 及以上。

編譯最低要求 - 編譯 Glide 要在 SDK 版本為 API 26 (Oreo) 及以上。

jar

你可以直接在 GitHub 下載最新的jar包

Gradle

如果使用 Gradle,可從 Maven Central 或 JCenter 中添加對 Glide 的依賴。同樣,你還需要添加 Android 支持庫的依賴。

repositories {
 mavenCentral()
 maven { url 'https://maven.google.com' }
}
dependencies {
  compile 'com.github.bumptech.glide:glide:4.1.1'
  annotationProcessor 'com.github.bumptech.glide:compiler:4.1.1'
}

Kotlin

如果你在 Kotlin 編寫的類里使用 Glide 注解,你需要引入一個 kapt 依賴,以代替常規(guī)的 annotationProcessor 依賴:

dependencies {
 kapt 'com.github.bumptech.glide:compiler:4.1.1'
}

開始使用

基本用法

加載圖片

Glide.with(fragment)
  .load(myUrl)
  .into(imageView);

取消加載圖片

Glide.with(fragment).clear(imageView);

在RecyclerView 中使用

@Override
public void onBindViewHolder(ViewHolder holder, int position) {
  String url = urls.get(position);
  Glide.with(fragment)
    .load(url)
    .into(holder.imageView);
}

加載占位圖

加載過程中的占用(Placeholder)

Glide.with(fragment)
 .load(url)
 .placeholder(R.drawable.placeholder)
 .into(view);

加載失敗后顯示的圖片(Error)

Glide.with(fragment)
 .load(url)
 .error(R.drawable.error)
 .into(view);

圖片的轉換

Glide中的大部分設置項都可以通過 RequestOptions 類和 apply() 方法來應用到程序中。 使用 request options 可以實現(xiàn)(包括但不限于):

  1. 占位圖(Placeholders)
  2. 轉換(Transformations)
  3. 緩存策略(Caching Strategies)
  4. 組件特有的設置項,例如編碼質量,或Bitmap的解碼配置等。

加載圓形圖片

 Glide.with(this)
        .load(url)
        .apply(RequestOptions.circleCropTransform())
        .into(ivTest);

加載圖片帶淡入淡出的動畫效果

 Glide.with(this)
        .load(url)
        .transition(withCrossFade())
        .into(ivTest);

等等很多的轉換效果,具體自己可以一個一個試試
緩存

Glide的默認緩存策略是AUTOMATIC,
在磁盤緩存

GlideApp.with(fragment)
 .load(url)
 .diskCacheStrategy(DiskCacheStrategy.ALL)
 .into(imageView);

僅從緩存加載圖片

GlideApp.with(fragment)
 .load(url)
 .onlyRetrieveFromCache(true)
 .into(imageView);

跳過內(nèi)存緩存

GlideApp.with(fragment)
 .load(url)
 .skipMemoryCache(true)
 .into(view);

跳過磁盤緩存

GlideApp.with(fragment)
 .load(url)
 .diskCacheStrategy(DiskCacheStrategy.NONE)
 .into(view);

跳過所有的緩存

GlideApp.with(fragment)
 .load(url)
 .diskCacheStrategy(DiskCacheStrategy.NONE)
 .skipMemoryCache(true)
 .into(view);

清理磁盤的緩存

Glide.get(applicationContext).clearDiskCache();

高級用法

加載一個圖片為高斯模糊效果

使用方法

復制代碼 代碼如下:

Glide.with(getActivity()).load("http://img1.imgtn.bdimg.com/it/u=594559231,2167829292&fm=27&gp=0.jpg").apply(RequestOptions.bitmapTransform(new GlideBlurformation(getActivity()))).into(ivTest);
  

用到的其他工具類

package com.qiezzi.clinic.chengqi.common.utils;
import android.content.Context;
import android.graphics.Bitmap;
import android.support.annotation.NonNull;
import com.bumptech.glide.load.engine.bitmap_recycle.BitmapPool;
import com.bumptech.glide.load.resource.bitmap.BitmapTransformation;
import java.security.MessageDigest;
/**
 * Created by yukuoyuan on 2017/9/29.
 */
public class GlideBlurformation extends BitmapTransformation {
  private Context context;
  public GlideBlurformation(Context context) {
    this.context = context;
  }
  @Override
  protected Bitmap transform(@NonNull BitmapPool pool, @NonNull Bitmap toTransform, int outWidth, int outHeight) {
    return BlurBitmapUtil.instance().blurBitmap(context, toTransform, 20,outWidth,outHeight);
  }
  @Override
  public void updateDiskCacheKey(MessageDigest messageDigest) {
  }
}
package com.qiezzi.clinic.chengqi.common.utils;
import android.annotation.TargetApi;
import android.content.Context;
import android.graphics.Bitmap;
import android.os.Build;
import android.renderscript.Allocation;
import android.renderscript.Element;
import android.renderscript.RenderScript;
import android.renderscript.ScriptIntrinsicBlur;
/**
 * Created by yukuoyuan on 2017/9/29.
 */
public class BlurBitmapUtil {
  private static BlurBitmapUtil sInstance;
  private BlurBitmapUtil() {
  }
  public static BlurBitmapUtil instance() {
    if (sInstance == null) {
      synchronized (BlurBitmapUtil.class) {
        if (sInstance == null) {
          sInstance = new BlurBitmapUtil();
        }
      }
    }
    return sInstance;
  }
  /**
   * @param context  上下文對象
   * @param image   需要模糊的圖片
   * @param outWidth 輸入出的寬度
   * @param outHeight 輸出的高度
   * @return 模糊處理后的Bitmap
   */
  @TargetApi(Build.VERSION_CODES.JELLY_BEAN_MR1)
  public Bitmap blurBitmap(Context context, Bitmap image, float blurRadius, int outWidth, int outHeight) {
    // 將縮小后的圖片做為預渲染的圖片
    Bitmap inputBitmap = Bitmap.createScaledBitmap(image, outWidth, outHeight, false);
    // 創(chuàng)建一張渲染后的輸出圖片
    Bitmap outputBitmap = Bitmap.createBitmap(inputBitmap);
    // 創(chuàng)建RenderScript內(nèi)核對象
    RenderScript rs = RenderScript.create(context);
    // 創(chuàng)建一個模糊效果的RenderScript的工具對象
    ScriptIntrinsicBlur blurScript = ScriptIntrinsicBlur.create(rs, Element.U8_4(rs));
    // 由于RenderScript并沒有使用VM來分配內(nèi)存,所以需要使用Allocation類來創(chuàng)建和分配內(nèi)存空間
    // 創(chuàng)建Allocation對象的時候其實內(nèi)存是空的,需要使用copyTo()將數(shù)據(jù)填充進去
    Allocation tmpIn = Allocation.createFromBitmap(rs, inputBitmap);
    Allocation tmpOut = Allocation.createFromBitmap(rs, outputBitmap);
    // 設置渲染的模糊程度, 25f是最大模糊度
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN_MR1) {
      blurScript.setRadius(blurRadius);
    }
    // 設置blurScript對象的輸入內(nèi)存
    blurScript.setInput(tmpIn);
    // 將輸出數(shù)據(jù)保存到輸出內(nèi)存中
    blurScript.forEach(tmpOut);
    // 將數(shù)據(jù)填充到Allocation中
    tmpOut.copyTo(outputBitmap);
    return outputBitmap;
  }
}

具體其他效果就自己寫吧,其實原理很簡單,就是通過繼承BitmapTransformation接口,然后在里邊把bitmap處理為自己想要的效果.沒有什么過于復雜的過程.

參考資料 : Glide官方文檔

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • android push推送相關基本問答總結

    android push推送相關基本問答總結

    現(xiàn)在網(wǎng)上一大堆的關于推送方面的實現(xiàn)原理:1.通過pull(拉),也就是通過客戶端主動定時輪詢服務器請求數(shù)據(jù)。2.通過push(推),服務器通過一個長連接主動推送消息到客戶端。這兩個方式都可以實現(xiàn)推送功能。pull這個方式?jīng)]什么問題好理解。
    2015-05-05
  • Android中自定義View實現(xiàn)圓環(huán)等待及相關的音量調節(jié)效果

    Android中自定義View實現(xiàn)圓環(huán)等待及相關的音量調節(jié)效果

    這篇文章主要介紹了Android中自定義View實現(xiàn)圓環(huán)等待及相關的音量調節(jié)效果,邏輯非常簡單,或許繪圖方面更加繁瑣XD 需要的朋友可以參考下
    2016-04-04
  • Android5.0新控件實例詳解

    Android5.0新控件實例詳解

    谷歌在推出Android5.0的同時推出了一些新控件,Android5.0中最常用的新控件有下面5種。具體哪五種大家通過本文學習下
    2018-02-02
  • Android 重力傳感器在游戲開發(fā)中的應用

    Android 重力傳感器在游戲開發(fā)中的應用

    本文主要介紹Android 重力傳感器,這里整理了詳細的資料,并且詳細的說明重力傳感器的使用方法,有興趣的小伙伴可以參考下
    2016-08-08
  • Android實現(xiàn)自動文本框提示功能

    Android實現(xiàn)自動文本框提示功能

    這篇文章主要為大家詳細介紹了Android實現(xiàn)自動文本框提示功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • Android MQTT與WebSocket協(xié)議詳細講解

    Android MQTT與WebSocket協(xié)議詳細講解

    MQTT(消息隊列遙測傳輸)是ISO 標準(ISO/IEC PRF 20922)下基于發(fā)布/訂閱范式的消息協(xié)議。它工作在TCP/IP協(xié)議族上,是為硬件性能低下的遠程設備以及網(wǎng)絡狀況糟糕的情況下而設計的發(fā)布/訂閱型消息協(xié)議
    2022-11-11
  • Flutter多選按鈕組件Checkbox使用方法詳解

    Flutter多選按鈕組件Checkbox使用方法詳解

    這篇文章主要為大家詳細介紹了Flutter多選按鈕組件Checkbox使用方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • android開發(fā)教程之view組件添加邊框示例

    android開發(fā)教程之view組件添加邊框示例

    這篇文章主要介紹了android開發(fā)中給view組件添加邊框的示例,需要的朋友可以參考下
    2014-02-02
  • Android開發(fā)中簡單設置啟動界面的方法

    Android開發(fā)中簡單設置啟動界面的方法

    這篇文章主要介紹了Android開發(fā)中簡單設置啟動界面的方法,涉及Android界面布局、加載、跳轉等相關操作技巧,需要的朋友可以參考下
    2018-01-01
  • android BottomSheetDialog新控件解析實現(xiàn)知乎評論列表效果(實例代碼)

    android BottomSheetDialog新控件解析實現(xiàn)知乎評論列表效果(實例代碼)

    BottomSheetDialog是一個自定義的從底部滑入的對話框,這篇文章主要介紹了android BottomSheetDialog新控件解析實現(xiàn)知乎評論列表效果,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04

最新評論