Android, Picasso、Glide与头像

     在实际开发中,经常会需要显示用户头像,下面就具体分析下用Picasso,显示头像的实现过程。

   既然是头像,那么就必然会涉及到修改头像;如果app的功能相对来说较多,板块较杂,这个时候Picasso就有绝对的优势


 为什么不用Glide?因为一旦发生头像修改,Glide就得蛋碎了。

具体https://github.com/bumptech/glide/wiki/Caching-and-Cache-Invalidation

这是Glide官方给的描述,大概就是说:想要删除某一张特定的图片,会比较复杂,不能简单的实现。

修改头像,就是要删除特定的某一张图片,刚好。



一、集成Picasso

Eclipse:

下载jar包,放在libs文件夹里面就可以了

下载链接:http://mvnrepository.com/artifact/com.squareup.picasso/picasso

Android Studio:

在app的.gradle文件中

implementation 'com.squareup.picasso:picasso:2.5.2'

二、显示头像

显示头像的api,非常简单,只有一行代码,需要context,头像url,

以及layout里面的ImageView。如果是圆形头像,还需要传人transform。

Picasso.with(context).load(url)

.transform(new MiiPicassoCircle)

.fit().into(imageview)

三、头像改变

怎么用Picasso 实现头像修改后,及时的更新显示?

Picasso.with(context).load(url).transform().fit()

.memoryPolicy(MemoryPolicy.NO_CACHE)

.networkPolicy(NetworkPolicy.NO_CACHE)

.into(imageview)

多出:

.memoryPolicy(MemoryPolicy.NO_CACHE)

.networkPolicy(NetworkPolicy.NO_CACHE)

这2行就行了。

具体到apk里面的场景,还需要做一些细节性的限制;比如说

1、在个人信息页面,当你刚刚修改头像之后,那么需要请求一次最新的头像,之后就可以继续使用缓存.

2、对于评论列表,下拉刷新的时候,是否需要同时做头像的刷新,得看产品的需求


// 这个transformation  我们apk用了差不多1年,基本没有问题

public class MiiPicassoCircle implements Transformation {

private static final String KEY = "circleImageTransformation";

@Override

public Bitmap transform(Bitmap source) {

int minEdge = Math.min(source.getWidth(), source.getHeight());

int dx = (source.getWidth() - minEdge) / 2;

int dy = (source.getHeight() - minEdge) / 2;

Shader shader = new BitmapShader(source, Shader.TileMode.CLAMP, Shader.TileMode.CLAMP);

Matrix matrix = new Matrix();

matrix.setTranslate(-dx, -dy);

shader.setLocalMatrix(matrix);

Paint paint = new Paint(Paint.ANTI_ALIAS_FLAG);

paint.setShader(shader);

Bitmap output = null;

if (source.getConfig() == null) {

output = Bitmap.createBitmap(minEdge, minEdge, Config.ARGB_4444);

} else {

output = Bitmap.createBitmap(minEdge, minEdge, source.getConfig());

}

Canvas canvas = new Canvas(output);

canvas.drawOval(new RectF(0, 0, minEdge, minEdge), paint); source.recycle();

return output;

}

@Override

public String key() {

return KEY;

}

}



以上最适用于 头像路径不变

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,980评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,178评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,868评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,498评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,492评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,521评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,910评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,569评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,793评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,559评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,639评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,342评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,931评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,904评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,144评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,833评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,350评论 2 342

推荐阅读更多精彩内容