国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Android > 正文

Android實現IM多人員組合的群組頭像

2019-10-21 21:36:25
字體:
來源:轉載
供稿:網友

說明:

此頭像類似微信群組頭像,整個頭像由組內前N位人員的頭像組合而成,可用網絡或本地圖片進行組合,最終顯示為一個頭像整體,看效果圖:

Android,IM,群組頭像

一、自定義整體頭像的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); }

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到Android開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 枣强县| 宁德市| 北京市| 平罗县| 启东市| 全州县| 平遥县| 安乡县| 容城县| 大城县| 麻栗坡县| 马边| 西乌珠穆沁旗| 饶平县| 五台县| 陆丰市| 汉源县| 新巴尔虎左旗| 达日县| 全南县| 额济纳旗| 漠河县| 公主岭市| 牙克石市| 正蓝旗| 洛隆县| 扶沟县| 图片| 奉新县| 舞钢市| 泸溪县| 乌拉特后旗| 崇义县| 西乌珠穆沁旗| 青州市| 宁都县| 武山县| 上高县| 左贡县| 普格县| 马龙县|