Android实现IM多人员组合的群组头像

说明:

此头像类似微信群组头像,整个头像由组内前N位人员的头像组合而成,可用网络或本地图片进行组合,最终显示为一个头像整体,看效果图:

一、自定义整体头像的ViewGroup,计算并保存宽高(重写onMeasure):

@Override
 protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
  mWidth = getWidth(widthMeasureSpec);
  mHeight = getHeight(heightMeasureSpec);
  setMeasuredDimension(mWidth, mHeight);
 }

 private int getWidth(int measureSpec) {
  int width = MIN_WIDTH_AND_HEIGHT;
  int specMode = MeasureSpec.getMode(measureSpec);
  int specSize = MeasureSpec.getSize(measureSpec);
  if (specMode == MeasureSpec.EXACTLY) {
   width = specSize;
  } else if (specMode == MeasureSpec.AT_MOST) {
   width = Math.min(MIN_WIDTH_AND_HEIGHT, specSize);
  }
  return width;
 }

 private int getHeight(int measureSpec) {
  int height = MIN_WIDTH_AND_HEIGHT;
  int specMode = MeasureSpec.getMode(measureSpec);
  int specSize = MeasureSpec.getSize(measureSpec);
  if (specMode == MeasureSpec.EXACTLY) {
   height = specSize;
  } else if (specMode == MeasureSpec.AT_MOST) {
   height = Math.min(MIN_WIDTH_AND_HEIGHT, specSize);
  }
  return height;
 }

二、布局子头像的View(重写onLayout,对每个子头像进行布局):

@Override
 protected void onLayout(boolean changed, int l, int t, int r, int b) {
  layoutChild();
 }

 private void layoutChild() {
  if (mImgUrls == null || mImgUrls.isEmpty()) {
   return;
  }
  for (int i = 0; i < mImgSize; i++) {
   ImageView itemV = (ImageView) getChildAt(i);
   int left = 0, top = 0, right = 0, bottom = 0;
   /*
   对每个item的View计算left、top、right、bottom四个值
    */
   ...
   itemV.layout(left, top, right, bottom); //真正布局子头像位置
   showImage(itemV, mImgUrls.get(i)); //加载并显示子头像图片
  }
 }

三、加载并显示各子头像(使用Glide加载并显示每个子头像)

private void showImage(Context context, ImageView iv, String url) {
  if (TextUtils.isEmpty(url)) {
   Bitmap bmp = BitmapFactory.decodeResource(context.getResources(), R.mipmap.user_default_icon);
   iv.setImageBitmap(bmp);
   return;
  }
  Glide.with(context).load(url)
    .diskCacheStrategy(DiskCacheStrategy.ALL)
    .dontAnimate()
    .placeholder(R.mipmap.user_default_icon)
    .error(R.mipmap.user_default_icon)
    .into(iv);
 }

到此多图片组合头像已经完成,不过想要圈形的还需要进行以下步奏

四、裁剪整个群头像为圆形(重写dispatchDraw):

@Override
 protected void dispatchDraw(Canvas canvas) {
  Path path = new Path();
  path.addCircle(mWidth / 2, mHeight / 2, mWidth / 2, Path.Direction.CW);
  canvas.clipPath(path);
  canvas.drawColor(Color.TRANSPARENT);
  super.dispatchDraw(canvas);
  drawGroupView(canvas);
 }

 /**
  * 绘制各头像间隔线
  * @param canvas
  */
 private void drawGroupView(Canvas canvas) {
  /*
  计算各条线的x和y坐标值
   */
  float[] point1 = new float[2], point2 = new float[2];
  ...
  drawLine(canvas, point1, point2);
 }

 /**
  * 绘制直线
  */
 private void drawLine(Canvas canvas, float[] point1, float[] point2) {
  mPaint.reset();
  mPaint.setAntiAlias(true);
  mPaint.setStrokeWidth(mInterval);
  mPaint.setColor(Color.WHITE);
  mPaint.setStyle(Paint.Style.STROKE);
  canvas.drawLine(point1[0], point1[1], point2[0], point2[1], mPaint);
 }

五、暴露公共方法供外部调用:

/**
  * 设置图片url集合
  *
  * @param imgs 图片url集合
  */
 public void setImages(List<String> imgs) {
  if (imgs == null || imgs.isEmpty()) {
   return;
  }
  if (imgs.size() > MAX_SIZE) {
   imgs = imgs.subList(0, MAX_SIZE);
  }
  removeAllViews();
  mImgUrls = imgs;
  mImgSize = imgs.size();
  for (int i = 0; i < mImgSize; i++) {
   View v = getItemView(i);
   if (v == null) {
    return;
   }
   addView(v, generateDefaultLayoutParams());
  }
  requestLayout();
 }

 /**
  * 设置单个图片url
  *
  * @param img 图片url
  */
 public void setImageUrl(String img) {
  ArrayList imgUrls = new ArrayList<>();
  imgUrls.add(img);
  setImages(imgUrls);
 }

 /**
  * 生成一个头像布局
  */
 private ImageView getItemView(int position) {
  ...
 }

六、使用:

1.写一个布局文件放自定义群组头像控件:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#f2f2f2"
    android:orientation="vertical">

 <com.yyh.im.ui.widget.HeadView
  android:id="@+id/cv_head"
  android:layout_width="150dp"
  android:layout_height="150dp"/>

</LinearLayout>

2.代码中群组头像控件显示图片:

@BindView(R2.id.cv_head)
 public HeadView mHeadCv;

 private String[] IMG_URL_LIST = {
   "70cFv8Sh_Q1YnxGkpoWK1HF6hhy/it/u=416954025,2289731303&fm=27&gp=0.jpg",
   "70cFuXSh_Q1YnxGkpoWK1HF6hhy/it/u=704997830,3098922597&fm=27&gp=0.jpg",
   "70cFvXSh_Q1YnxGkpoWK1HF6hhy/it/u=1375449509,557259337&fm=27&gp=0.jpg",
   "70cFvnSh_Q1YnxGkpoWK1HF6hhy/it/u=2825392570,1862752263&fm=27&gp=0.jpg",
   "70cFvXSh_Q1YnxGkpoWK1HF6hhy/it/u=3252489351,440833245&fm=27&gp=0.jpg",
   "70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=3586311245,3082636880&fm=27&gp=0.jpg"
 };

 private void showImage(){
  ArrayList<String> list = new ArrayList<>();
  for (int i = 0; i < 6; i++) {
   list.add(IMG_URL_LIST[i]);
  }
  mHeadCv.setImageUrls(list);
 }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android一行代码实现圆形头像

    效果图 在开发APP中,经常要实现圆形头像,那么该如何实现呢? 要裁剪吗,要重写draw函数吗?不用,只用一行代码就可以实现 Glide实现圆形图像 Glide.with(mContext) .load(R.drawable.iv_image_header) .error(R.drawable.ic_error_default) .transform(new GlideCircleTransform(mContext)) .into(mImage); 其中load后为载入的图像,error后为出

  • Android实现用户头像更换操作

    你以为头像更换很容易?或许对于用户来讲,在微信上更换一个头像只是点击头像,选择拍照或相册,裁剪返回而已.但是对于程序员来说,要实现其实也挺吃力的(小火柴花了一个下午整理~_~). 正如用户使用那样,代码的实现也是按照操作的顺序而逐步展开.如下图: 接下来主要来讲解一下代码: 1. 弹框选择相册或拍照 比较简单的方式就是直接使用AlertDialog弹出选项供用户进行选择 public static void showImagePickDialog(final Activity activity)

  • Android根据电话号码获得联系人头像实例代码

    在日常Android手机的使用过程中,根据电话号码获得联系人头像,是经常会碰到的问题.本文即以实例形式讲述了Android根据电话号码获得联系人头像是实现代码.分享给大家供大家参考之用.具体方法如下: 首先,通过ContentProvider,可以访问Android中的联系人等数据.常用的Uri有: 联系人信息Uri:content://com.android.contacts/contacts 联系人电话Uri:content://com.android.contacts/data/phone

  • Android实现本地上传图片并设置为圆形头像

    先从本地把图片上传到服务器,然后根据URL把头像处理成圆形头像. 因为上传图片用到bmob的平台,所以要到bmob(http://www.bmob.cn)申请密钥. 效果图: 核心代码: 复制代码 代码如下: public class MainActivity extends Activity {         private ImageView iv;         private String appKey="";                //填写你的Applicatio

  • Android手机拍照或选取图库图片作为头像

    package zhangpgil.photo; import java.io.File; import android.support.v7.app.ActionBarActivity; import android.view.View; import android.widget.Button; import android.widget.ImageView; import android.widget.Toast; import android.content.Intent; import

  • Android使用CircleImageView实现圆形头像的方法

    有时我们在应用中会用到圆形头像,下面是利用CircleImageView实现圆形头像的演示,下面效果和代码,效果如图 实现起来也比较简单,先在项目中建一个circleimageview包用来存放CircleImageView类,待会直接把CircleImageView类复制到包里就可以使用了 然后,再建一个attrs.xml,其代码相当简单,定义了圆形边框宽度和颜色 <?xml version="1.0" encoding="utf-8"?> <r

  • Android实现从本地图库/相机拍照后裁剪图片并设置头像

    玩qq或者是微信的盆友都知道,这些聊天工具里都要设置头像,一般情况下大家的解决办法是从本地图库选择图片或是从相机拍照,然后根据自己的喜爱截取图片.上述过程已经实现好了,最后一步我加上了把截取好的图片在保存到本地的操作,来保存头像.为了大家需要,下面我们小编把完整的代码贴出来供大家参考. 先给大家展示效果图: 代码部分: 布局代码(其实就是两个按钮和一个ImageView来显示头像) <LinearLayout xmlns:android="http://schemas.android.co

  • Android实现个人资料页面头像背景模糊显示包(状态栏)

    最近要实现这样一个效果,然后拿出来与大家分享一下主要的几段代码,希望大家能够用到,与人方便自己方便嘛! 首先: 要实现的是浮动状态栏效果,通过在Activity的onCreate方法中调用这个方法,然后就可以让整个布局浮现在整个手机屏幕之下了,这是我觉着最简单的一种方法了. public static void alphaTask(Activity context) { context.getWindow().requestFeature(Window.FEATURE_NO_TITLE); if

  • Android实现调用系统图库与相机设置头像并保存在本地及服务器

    废话不多说了,直接给大家贴代码了,具体代码如下所述: /** * 1.实现原理:用户打开相册或相机选择相片后,相片经过压缩并设置在控件上,图片在本地sd卡存一份(如果有的话,没有则内部存储,所以还 * 需要判断用户是否挂载了sd卡),然后在服务器上存储一份该图片,当下次再次启动应用时,会默认去sd卡加载该图片,如果本地没有,再会去联网请求 * 2.使用了picasso框架以及自定义BitmapUtils工具类 * 3.记得加上相关权限 * <uses-permission android:nam

  • Android头像上传功能的实现代码(获取头像加剪切)

    因为项目中需要用到头像上传的功能,所以就下个Ddmo先来实现下. demo我是类似仿微信的,在一个GridView中展示所有的图片,其中第一个item可以去照相:获取到图片后再进行剪切. 图片的剪切是从网上找的感觉不错就用,暂时也没有测试. 获取图片可以用:https://github.com/lovetuzitong/MultiImageSelector来实现 这里的圆形图像是用https://github.com/hdodenhof/CircleImageView来实现的 Demo写的比较粗

随机推荐