Android Glide图片加载库

glide 的 github地址:glide
glide 中文文档说明:地址

Glide

Glide.with(MainActivity.this)

传入 Activity 或 Fragment 实例,在里面进行显示

.load(faceUrl)

加载的资源,可以本地的资源,也可以是网络的资源

.placeholder(R.mipmap.pic_1000)

占位符是当请求正在执行时被展示的 Drawable 。
当请求成功完成时,占位符会被请求到的资源替换。
如果被请求的资源是从内存中加载出来的,那么占位符可能根本不会被显示。
如果请求失败并且没有设置 error Drawable ,则占位符将被持续展示。
类似地,如果请求的url/model为 null ,并且 error Drawable 和 fallback 都没有设置,那么占位符也会继续显示。

.error(new ColorDrawable(Color.RED))

错误符,在请求永久性失败时展示。
error Drawable 同样也在请求的url/model为 null ,且并没有设置 fallback Drawable 时展示。

.fallback(new ColorDrawable(Color.BLUE))

后备回调符,在请求的url/model为 null 时展示。
设计 fallback Drawable 的主要目的是允许用户指示 null 是否为可接受的正常情况。
例如,一个 null 的个人资料 url 可能暗示这个用户没有设置头像,因此应该使用默认头像。然而,null 也可能表明这个元数据根本就是不合法的,或者取不到。 默认情况下Glide将 null 作为错误处理,所以可以接受 null 的应用应当显式地设置一个 fallback Drawable 。

.apply(RequestOptions.bitmapTransform(new CircleCrop()))

设置圆形、圆角等效果

.into(imageView);

显示到对应的 ImageView 中

示例使用

添加依赖

mytest1\build.gradle

implementation 'com.github.bumptech.glide:glide:4.11.0'
annotationProcessor 'com.github.bumptech.glide:compiler:4.11.0'

权限

mytest1\src\main\AndroidManifest.xml

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

xml布局

mytest1\src\main\res\layout\activity_main.xml

<?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"
    tools:context=".MainActivity"
    android:orientation="vertical"
    >
    <Button
        android:id="@+id/change_bt"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="change"
        />
    <ImageView
        android:id="@+id/test_iv"
        android:layout_width="200dp"
        android:layout_height="200dp"
        android:background="@color/purple_200"
        />
</LinearLayout>

MainActivity

mytest1\src\main\java\com\example\mytest1\MainActivity.java

import androidx.appcompat.app.AppCompatActivity;
import android.graphics.Color;
import android.graphics.drawable.ColorDrawable;
import android.os.Bundle;
import android.view.View;
import android.widget.ImageView;
import com.bumptech.glide.Glide;
import com.bumptech.glide.load.resource.bitmap.CircleCrop;
import com.bumptech.glide.request.RequestOptions;
import java.util.Random;

public class MainActivity extends AppCompatActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        ImageView imageView = findViewById(R.id.test_iv);

        findViewById(R.id.change_bt).setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                // 加载本地的资源
//                Glide.with(MainActivity.this).load(R.mipmap.pic_1000).into(imageView);

                // 加载公网的资源
                String faceUrl = String.format("https://picsum.photos/id/%d/200/200",
                        new Random().nextInt(1000));
                Glide.with(MainActivity.this)
                        .load(faceUrl)
                        .placeholder(R.mipmap.pic_1000)  // 占位符
                        .error(new ColorDrawable(Color.RED))  // 错误符
                        .fallback(new ColorDrawable(Color.BLUE))  // 后备回调符
                        .apply(RequestOptions.bitmapTransform(new CircleCrop())) // 圆形
//                        .apply(RequestOptions.bitmapTransform(new RoundedCorners(200))) // 圆角
                        .into(imageView);
            }
        });
    }
}

效果

在这里插入图片描述

代码

Glide示例代码: 地址

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值