• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >Android > 类似微信朋友圈,点击+号图片,可以加图片,信朋友圈

类似微信朋友圈,点击+号图片,可以加图片,信朋友圈

作者:网友 字体:[增加 减小] 来源:互联网 时间:2017-05-26

网友通过本文主要向大家介绍了微信朋友圈,微信朋友圈广告加盟,微信朋友圈推送广告,微信朋友圈广告位,微信朋友圈广告等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

类似微信朋友圈,点击+号图片,可以加图片,信朋友圈


xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginTop="40dp"
android:orientation="vertical" >

<com.sw.demo.widget.NinePhotoView
    android:id="@+id/photoview"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    app:ninephoto_hspace="10dp"
    app:ninephoto_vspace="10dp"
    app:rainbowbar_color="@android:color/holo_blue_bright" >

</com.sw.demo.widget.NinePhotoView>

NinePhotoView.java

public class NinePhotoView extends ViewGroup {

public static final int MAX_PHOTO_NUMBER = 9;

private int[] constImageIds = { R.drawable.girl_0, R.drawable.girl_1,
      R.drawable.girl_2, R.drawable.girl_3, R.drawable.girl_4,
      R.drawable.girl_5, R.drawable.girl_6, R.drawable.girl_7,
      R.drawable.girl_8 };

// horizontal space among children views
int hSpace = Utils.dpToPx(10, getResources());
// vertical space among children views
int vSpace = Utils.dpToPx(10, getResources());

// every child view width and height.
int childWidth = 0;
int childHeight = 0;

// store images res id
ArrayList<integer> mImageResArrayList = new ArrayList<integer>(9);
private View addPhotoView;

public NinePhotoView(Context context) {
  super(context);
}

public NinePhotoView(Context context, AttributeSet attrs) {
  this(context, attrs, 0);
}

public NinePhotoView(Context context, AttributeSet attrs, int defStyle) {
  super(context, attrs, defStyle);

  TypedArray t = context.obtainStyledAttributes(attrs,
          R.styleable.NinePhotoView, 0, 0);
  hSpace = t.getDimensionPixelSize(
          R.styleable.NinePhotoView_ninephoto_hspace, hSpace);
  vSpace = t.getDimensionPixelSize(
          R.styleable.NinePhotoView_ninephoto_vspace, vSpace);
  t.recycle();

  addPhotoView = new View(context);
  addView(addPhotoView);
  mImageResArrayList.add(new integer());
}

Measure

@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
  int rw = MeasureSpec.getSize(widthMeasureSpec);
  int rh = MeasureSpec.getSize(heightMeasureSpec);

  childWidth = (rw - 2 * hSpace) / 3;
  childHeight = childWidth;

  int childCount = this.getChildCount();
  for (int i = 0; i < childCount; i++) {
      View child = this.getChildAt(i);
      //this.measureChild(child, widthMeasureSpec, heightMeasureSpec);

      LayoutParams lParams = (LayoutParams) child.getLayoutParams();
      lParams.left = (i % 3) * (childWidth + hSpace);
      lParams.top = (i / 3) * (childWidth + vSpace);
  }

  int vw = rw;
  int vh = rh;
  if (childCount < 3) {
      vw = childCount * (childWidth + hSpace);
  }
  vh = ((childCount + 3) / 3) * (childWidth + vSpace);
  setMeasuredDimension(vw, vh);
}

  我们的子View三个一排,而且都是正方形,所以我们上面通过循环很好去得到所有子View的位置,注意我们上面把子View的左上角坐标存储到我们自定义的LayoutParams 的left和top二个字段中,Layout阶段会使用,最后我们算得整个ViewGroup的宽高,调用setMeasuredDimension设置。  

 

Layout

@Override
protected void onLayout(boolean arg0, int arg1, int arg2, int arg3, int arg4) {
  int childCount = this.getChildCount();
  for (int i = 0; i < childCount; i++) {
      View child = this.getChildAt(i);
      LayoutParams lParams = (LayoutParams) child.getLayoutParams();
      child.layout(lParams.left, lParams.top, lParams.left + childWidth,
              lParams.top + childHeight);

      if (i == mImageResArrayList.size() - 1 && mImageResArrayList.size() != MAX_PHOTO_NUMBER) {
          child.setBackgroundResource(R.drawable.add_photo);
          child.setOnClickListener(new View.OnClickListener() {

              @Override
              public void onClick(View arg0) {
                  addPhotoBtnClick();
              }
          });
      }else {
          child.setBackgroundResource(constImageIds[i]);
          child.setOnClickListener(null);
      }
  }
}

public void addPhoto() {
  if (mImageResArrayList.size() < MAX_PHOTO_NUMBER) {
      View newChild = new View(getContext());
      addView(newChild);
      mImageResArrayList.add(new integer());
      requestLayout();
      invalidate();
  }
}

public void addPhotoBtnClick() {
  final CharSequence[] items = { "Take Photo", "Photo from gallery" };

  AlertDialog.Builder builder = new AlertDialog.Builder(getContext());
  builder.setItems(items, new DialogInterface.OnClickListener() {

      @Override
      public void onClick(DialogInterface arg0, int arg1) {
          addPhoto();
      }

  });
  builder.show();
}

  最核心的就是调用layout方法,根据我们measure阶段获得的LayoutParams中的left和top字段,也很好对每个子View进行位置排列。然后判断在图片未达到最大值9张时,默认最后一张是+号图片,然后设置点击事件,弹出对话框供用户选择操作。

 

Draw
不需要重写,使用ViewGroup默认实现即可。

 

 

  

 

 

NiewPhotoView.gif
   

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 类似微信朋友圈,点击+号图片,可以加图片,信朋友圈

相关文章

  • 2017-05-26GsonFormat插件从配置到使用,gsonformat插件配置
  • 2017-05-26Android中BroadcastReceiver的两种注册方式(静态和动态)详解,broadcastreceiver
  • 2017-05-26活动的生命周期(三):实例上机课,生命周期上机
  • 2017-05-26Android之使用Bundle进行IPC,androidbundleipc
  • 2017-05-26Linux之使用NTP服务管理/同步服务器时间
  • 2017-05-26Android线程优先级设置方法技巧,android线程优先级
  • 2017-05-26Android开发重点难点1:RelativeLayout(相对布局)详解,
  • 2017-05-222.6.1 PopupWindow(悬浮框)的基本使用
  • 2017-05-26Android 应用程序集成Google 登录,androidgoogle
  • 2017-05-26搭建邮件服务器postfix 步骤(转)

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 违章查询源码分享,违章查询源码
    • android:Activity启动模式之singleTop
    • Volley的基本使用,Volley使用
    • android --多线程下载过程分析
    • 2.6.4 DrawerLayout(官方侧滑菜单)的简单使用
    • 硅谷商城第二版5--个人中心模块,硅谷商城第二版5--
    • 8.1.1 Android中的13种Drawable小结 Part 1
    • Android中View的事件分发机制——Android开发艺术探索笔记
    • 测试经验总结之--测试员的角色
    • Kotlin中变量不同于Java: var 对val(KAD 02),kotlinkad

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有