android 环信 EaseUser,环信之Android修改圆形头像

直接进入正题吧,在demo的EaseUi里面utils包下面有个EaseUserUtils类里面有如下代码:

8fdff5e48bc95a68b3f425634335c1c3.png

然后只要在setUserAvatar这个方法里面稍作修改,可以看出用的是glide加载图片,于是我们可以写一个把图片转为圆形的类GlideCircleTransform, 代码如下:

public class GlideCircleTransform extends BitmapTransformation {

public GlideCircleTransform(Context context) {

super(context);

}

protected Bitmap transform(BitmapPool pool, Bitmap toTransform, int outWidth, int outHeight) {

return circleCrop(pool, toTransform);

}

private static Bitmap circleCrop(BitmapPool pool, Bitmap source) {

if (source == null) return null;

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

int x = (source.getWidth() - size) / 2;

int y = (source.getHeight() - size) / 2;

// TODO this could be acquired from the pool too

Bitmap squared = Bitmap.createBitmap(source, x, y, size, size);

Bitmap result = pool.get(size, size, Bitmap.Config.ARGB_8888);

if (result == null) {

result = Bitmap.createBitmap(size, size, Bitmap.Config.ARGB_8888);

}

Canvas canvas = new Canvas(result);

Paint paint = new Paint();

paint.setShader(new BitmapShader(squared, BitmapShader.TileMode.CLAMP, BitmapShader.TileMode.CLAMP));

paint.setAntiAlias(true);

float r = size / 2f;

canvas.drawCircle(r, r, r, paint);

return result;

}

@Override

public String getId() {

return getClass().getName();

}

}然后稍加修改setUserAvatar方法,代码如下:

/**

* set user avatar

* @param username

*/

public static void setUserAvatar(Context context, String username, ImageView imageView){

EaseUser user = getUserInfo(username);

if(user != null && user.getAvatar() != null){

try {

int avatarResId = Integer.parseInt(user.getAvatar());

// Glide.with(context).load(avatarResId).into(imageView);

Glide.with(context).load(avatarResId).transform(new GlideCircleTransform(context)).into(imageView);

} catch (Exception e) {

//use default avatar

// Glide.with(context).load(user.getAvatar()).diskCacheStrategy(DiskCacheStrategy.ALL).placeholder(R.drawable.ease_default_avatar).into(imageView);

Glide.with(context).load(user.getAvatar()).diskCacheStrategy(DiskCacheStrategy.ALL). placeholder(R.drawable.default_user_head_img).transform(new GlideCircleTransform(context)).into(imageView);

}

}else{

// Glide.with(context).load(R.drawable.ease_default_avatar).into(imageView);

Glide.with(context).load(R.drawable.default_user_head_img).transform(new GlideCircleTransform(context)).into(imageView);

}

}其中default_user_head_img是我项目中的默认头像,大家改为自己的即可。

到现在EaseConversationListFragment中的头像就变成圆形的了,但是EaseChatFragment还要修改easeui布局文件, 文件列表如下:

30473ba45f9511ce58e7c56b226cae84.png

我们在这些资源文件中可以用于显示头像的ImageView

4b577e64cf598a02332b07703928ebb9.png

把android:src="@drawable/ease_default_avatar"这行 删掉即可。

跑起来看看,是不是都是圆形头像了。

好了,教程结束。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值