Picasso图片加载器简单封装

简介: Picasso是一款当下好用并且流行的图片加载器,在这里分享一下我的简单封装,小巧玲珑、方便使用。废话不多讲直接上代码。首先Picasso在github上面的显示地址:https://github.com/square/picasso然后根据当下的依赖版本,添加依赖在你的Module的build.gradle内部。

Picasso是一款当下好用并且流行的图片加载器,在这里分享一下我的简单封装,小巧玲珑、方便使用。废话不多讲直接上代码。

首先Picasso在github上面的显示地址:https://github.com/square/picasso

然后根据当下的依赖版本,添加依赖在你的Module的build.gradle内部。

   compile 'com.squareup.picasso:picasso:2.5.2'

接下来就是简单的封装使用。

import android.content.Context;
import android.graphics.Bitmap;
import android.text.TextUtils;
import android.view.View;
import android.widget.ImageView;

import com.squareup.picasso.Picasso;
import com.squareup.picasso.Transformation;

/**
 * 图片加载工具
 * Created by 韩小呆 on 2017/12/10.
 */

public class PicassoUtils {
    /**
     * 默认加载图片
     */
    public static void loadImageView(Context context, String url, ImageView imageView) {

        Picasso.with(context).load(url).into(imageView);
    }

    /**
     * 从res文件内部加载图片
     */
    public static void loadImageViewFromRes(Context context, int resourceId, ImageView imageView) {
        Picasso.with(context).load(resourceId).into(imageView);
    }

    /**
     * 网上加载指定图片大小的图片
     */
    public static void loadImageViewSize(Context context, String url, int width, int height, ImageView imageView) {
        Picasso.with(context).load(url).resize(width, height).centerCrop().into(imageView);
    }
  /**
     *res文件内部加载指定大小图片
     */
    public static void loadImageViewSizeForRes(Context context, int id, int width, int height, ImageView imageView) {
        Picasso.with(context).load(id).resize(width, height).centerCrop().into(imageView);
    }

    /**
     * 1、加载中图片,加载错误图片,加载正确图片并且设置
     * 2、当没有图片时,因此imageView
     */
    public static void loadImageViewHolder(Context context, String url, int loadingImage, int loadingErrorImage, ImageView imageView) {
        if (url != null && !TextUtils.isEmpty(url)) {
            Picasso.with(context).load(url).placeholder(loadingImage).error(loadingErrorImage).into(imageView);
        } else {
            imageView.setVisibility(View.GONE);
        }

    }

    public static void loadImageViewHolderSize(Context context, String url, int width, int height, int loadingImage, int loadingErrorImage, ImageView imageView) {
        if (url != null && !TextUtils.isEmpty(url)) {
            Picasso.with(context).load(url).resize(width, height).centerCrop().placeholder(loadingImage).error(loadingErrorImage).into(imageView);
        } else {
            imageView.setVisibility(View.GONE);
        }

    }


    /**
     * 裁剪图片
     */
    public static void loadImageViewCrop(Context context, String url, ImageView imageView) {
        Picasso.with(context).load(url).transform(new CropSquareTransformation()).into(imageView);
    }

    /**
     * 按比例裁剪图片
     */
    public static class CropSquareTransformation implements Transformation {
        @Override
        public Bitmap transform(Bitmap source) {
            int size = Math.min(source.getWidth(), source.getHeight());
            int x = (source.getWidth() - size) / 2;
            int y = (source.getHeight() - size) / 2;
            Bitmap result = Bitmap.createBitmap(source, x, y, size, size);
            if (result != source) {
                source.recycle();
            }
            return result;
        }

        @Override
        public String key() {
            return "crop";
        }
    }
}

最后就是,你可以在你的类内部进行调用了,简单方便,一步到位。

相关文章
|
消息中间件 存储 安全
类是如何加载的?
类是如何加载的?
99 0
|
移动开发 前端开发 UED
前端加载之懒加载
懒加载就是延时加载,也被称为按需加载。
430 0
|
JavaScript UED
Day24 - 图片懒加载的原理
Day24 - 图片懒加载的原理
109 0
|
缓存 Android开发
Anroid笔记:Android图片加载框架Glide用法
Anroid笔记:Android图片加载框架Glide用法
169 0
|
JavaScript UED 缓存
图片预加载和懒加载的实现方法
图片预加载,即图片提前加载,可以保证图片快速、无缝的发布,用户需要查看时可直接从本地缓存中渲染,适用于图片占据很大比例的网站。 一、懒加载 将图片src赋值为一张默认的图片,当用户滚动到可视区域的时候,再去加载真正的图片; 代码实现: html代码 js代码 vue中实现懒加载 对于图片过多的页面,为了加速页面加载速度,所以很多时候我们需要将页面内未出现在可视区域内的图片先不做加载, 等到滚动到可视区域后再去加载。
2125 0
|
移动开发 JavaScript 前端开发
Picasso图片加载器简单封装
Picasso是一款当下好用并且流行的图片加载器,在这里分享一下我的简单封装,小巧玲珑、方便使用。废话不多讲直接上代码。 首先Picasso在github上面的显示地址:https://github.com/square/picasso 然后根据当下的依赖版本,添加依赖在你的Module的build.gradle内部。
808 0
|
Android开发
探索Glide对Gif图片资源的获取、解析过程
先预祝大家汤圆节快乐!很久没写博客了。今天我们来探索一下Glide是如何支持Gif图片加载的。 本篇博客的目的 了解代码分析的基本思路与方法 了解Glide是如何对Gif图片进行支持的 探索背景 为什么会有这么一个想法呢,一来一直对Glide是知其名而不知其所以然,二来还主要是工作中需要对它研究研究,以便更好的支持工作内容。
1485 0