Android仿微信朋友圈添加图片的实例代码

作者:陪你唠嗑 时间:2021-06-26 13:19:05 

* 惯,先上图,着急用的朋友,直接带走Demo,先拿来用吧,毕竟老板催的紧,先把工作完成了,再看也来得及,是吧!

Android仿微信朋友圈添加图片的实例代码

在项目中这种添加图片上传的效果应该是非常常见的,后面有个添加的按钮应该让有些童鞋不知道咋办了吧,其实没那么复杂,通过GridView就可以实现了

先说明一下,这里主要是讲添加图片的效果,至于图片选择器用的是第三方库photopicker,6.0权限用的是第三方库EasyPermission

1、首先这是用GridView实现的


<?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="#fff"
 android:orientation="vertical">

<!--展示上传的图片-->
 <GridView
   android:id="@+id/gridView"
   android:layout_width="match_parent"
   android:layout_height="wrap_content"
   android:layout_margin="15dp"
   android:columnWidth="60dp"
   android:horizontalSpacing="10dp"
   android:numColumns="auto_fit"
   android:verticalSpacing="10dp" />

</LinearLayout>

Adapter


package com.dearxy.wxcircleaddpic;

import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;

import com.bumptech.glide.Glide;

import java.util.List;

/**
* 展示上传的图片的GridView的适配器
* 作者: 周旭 on 2017/6/21/0021.
*/

public class GridViewAdapter extends android.widget.BaseAdapter {

private Context mContext;
 private List<String> mList;
 private LayoutInflater inflater;

public GridViewAdapter(Context mContext, List<String> mList) {
   this.mContext = mContext;
   this.mList = mList;
   inflater = LayoutInflater.from(mContext);
 }

@Override
 public int getCount() {
   //return mList.size() + 1;//因为最后多了一个添加图片的ImageView
   int count = mList == null ? 1 : mList.size() + 1;
   if (count > MainConstant.MAX_SELECT_PIC_NUM) {
     return mList.size();
   } else {
     return count;
   }
 }

@Override
 public Object getItem(int position) {
   return mList.get(position);
 }

@Override
 public long getItemId(int position) {
   return position;
 }

@Override
 public View getView(int position, View convertView, ViewGroup parent) {
   convertView = inflater.inflate(R.layout.grid_item, parent,false);
   ImageView iv = (ImageView) convertView.findViewById(R.id.pic_iv);
   if (position < mList.size()) {
    //代表+号之前的需要正常显示图片
     String picUrl = mList.get(position); //图片路径
     Glide.with(mContext).load(picUrl).into(iv);
   } else {
     iv.setImageResource(R.mipmap.zj);//最后一个显示加号图片
   }
   return convertView;
 }
}

MainActivity

这里只贴出了拿到相册返回的图片的路径后的处理


//初始化展示上传图片的GridView
 private void initGridView() {
   mPicList = new ArrayList<>();
   mGridViewAdapter = new GridViewAdapter(mContext, mPicList);
   gridView.setAdapter(mGridViewAdapter);
   gridView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
     @Override
     public void onItemClick(AdapterView<?> parent, View view,
                 int position, long id) {
       if (position == parent.getChildCount() - 1) {
         //添加凭证图片
         checkPhotoPermission();
       } else {
         //查看大图
         Intent intent = new Intent(mContext, PlusImageActivity.class);
         //图片的路径
         intent.putExtra(MainConstant.PIC_PATH, mPicList.get(position));
         intent.putExtra(MainConstant.POSITION, position);
         startActivityForResult(intent, MainConstant.REQUEST_CODE_MAIN);
       }
     }
   });
 }

// 处理返回照片地址
 private void refreshAdapter(final ArrayList<String> paths) {
   for (int i = 0; i < paths.size(); i++) {
     Log.i(TAG, "path:---->" + paths.get(i));
     proofPicCount++;
     if (proofPicCount <= MainConstant.MAX_SELECT_PIC_NUM) {
       //添加图片到GridView
       mPicList.add(paths.get(i));
     }
   }
   mGridViewAdapter.notifyDataSetChanged();
 }

github地址:https://github.com/zhouxu88/WXCircleAddPic

总结:其实原理就是把数据的size+1,做为添加按钮的放置,然后判断下有9张图就不显示添加按钮,并且size也不+1,就这样,一个带添加按钮的GridView就好了~希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

来源:http://www.jianshu.com/p/b5b5eac5c64c?utm_source=tuicool&utm_medium=referral

标签:Android,添加,图片
0
投稿

猜你喜欢

  • C#实现文件分割和合并的示例详解

    2023-05-24 21:04:03
  • Java中的这些骚操作你不能不知道!!!

    2022-07-08 12:28:14
  • 十种JAVA排序算法实例

    2022-11-11 00:19:54
  • Java链表数据结构及其简单使用方法解析

    2022-11-20 23:42:53
  • Spring使用redis遇到的问题及解决方案

    2023-07-28 08:47:02
  • WPF+Canvas实现平滑笔迹的示例代码

    2021-10-06 06:35:13
  • android使用PullToRefresh实现下拉刷新和上拉加载

    2023-08-06 11:06:58
  • C#实现DataTable转TXT、CSV文件

    2022-08-09 06:50:09
  • 详解java动态代理模式

    2023-03-29 13:39:29
  • C#程序提示“正由另一进程使用,因此该进程无法访问该文件”的解决办法

    2022-06-27 04:34:11
  • Unity3D实现简易五子棋源码

    2021-08-15 15:57:04
  • java中Scanner类的简单用法分享

    2023-04-16 04:24:50
  • Android开发实现的简单五子棋游戏示例

    2022-10-26 04:47:59
  • eclipse 联想功能设置技巧

    2023-03-18 04:11:39
  • C#实现微信红包功能

    2023-11-30 02:49:51
  • Android 判断日期是否在一年以内的算法实例

    2023-03-22 06:04:13
  • spring boot启动加载数据原理分析

    2021-06-16 07:56:15
  • Android 自定义ListView实现QQ空间界面(说说内包含图片、视频、点赞、评论、转发功能)

    2022-08-12 20:52:44
  • java两种单例模式用法分析

    2023-10-06 03:51:34
  • eclipse报错 eclipse启动报错解决方法

    2023-04-28 08:43:49
  • asp之家 软件编程 m.aspxhome.com