Glide4 设置默认图片和错误图片,即设置占位图

一,设置占位图: 

 RequestOptions options = new RequestOptions()
                .placeholder(R.drawable.img_default)//图片加载出来前,显示的图片
                .fallback( R.drawable.img_blank) //url为空的时候,显示的图片
                .error(drawable.img_load_failure);//图片加载失败后,显示的图片

Glide.with(this)
                .load(URL) //图片地址
                .apply(options)
                .into(ImagView); 

其他相关知识:

二,Glide4设置图片圆角

2.1,第一种方式:

RequestOptions options = new RequestOptions().
error(R.drawable.img_load_failure).
bitmapTransform(new RoundedCorners(30));//图片圆角为30

Glide.with(this)
                .load(URL) //图片地址
                .apply(options)
                .into(ImagView);

2.2,第二种方式:

RequestOptions requestOptions = new RequestOptions();
requestOptions.placeholder(R.drawable.ic_launcher_background);
requestOptions.circleCropTransform();
requestOptions.transforms( new RoundedCorners(30));

Glide.with(this)
                .load(URL) //图片地址
                .apply(options)
                .into(ImagView);

2.3,第三种方式:

 RequestOptions options = new RequestOptions() 
                .centerCrop() 
                .transform(new RoundTransform(this,30)); 
Glide.with(this)
                .load(URL) //图片地址
                .apply(options)
                .into(ImagView);
public class RoundTransform extends BitmapTransformation { 
    private static float radius = 0f; 
    public RoundTransform(Context context) { 
        this(context, 4); 
    } 
   
    public RoundTransform(Context context, int dp) { 
        super(context); 
        this.radius = Resources.getSystem().getDisplayMetrics().density * dp; 
    } 
   
    @Override 
    protected Bitmap transform(BitmapPool pool, Bitmap toTransform, int outWidth, int outHeight) { 
        Bitmap bitmap = TransformationUtils.centerCrop(pool, toTransform, outWidth, outHeight); 
        return roundCrop(pool, bitmap); 
    } 
   
    private static Bitmap roundCrop(BitmapPool pool, Bitmap source) { 
        if (source == null) return null; 
        Bitmap result = pool.get(source.getWidth(), source.getHeight(), Bitmap.Config.ARGB_8888); 
        if (result == null) { 
            result = Bitmap.createBitmap(source.getWidth(), source.getHeight(), Bitmap.Config.ARGB_8888); 
        } 
   
        Canvas canvas = new Canvas(result); 
        Paint paint = new Paint(); 
        paint.setShader(new BitmapShader(source, BitmapShader.TileMode.CLAMP, BitmapShader.TileMode.CLAMP)); 
        paint.setAntiAlias(true); 
        RectF rectF = new RectF(0f, 0f, source.getWidth(), source.getHeight()); 
        canvas.drawRoundRect(rectF, radius, radius, paint); 
        return result; 
    } 
   
    public String getId() { 
        return getClass().getName() + Math.round(radius); 
    } 
   
    @Override 
    public void updateDiskCacheKey(MessageDigest messageDigest) { 
   
    } 
   
} 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Ang_qq_252390816

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值