Android仿微信多图片选择,拍照等,适合快速导入到自己项目中

简介: 前段时间做项目需要用到图片选择,系统自带的intent方法选择图片已经过时了,不方便,所以就找到了一个大牛做的开源项目,拿过来修改了一下,添加了一些常用的功能,更加适合快速的集成到自己的项目中去,具体如下:类似微信从相册中选择图片或者拍照;可以控制单张或者多张选择;支持预览,并且在预览页面可以直接删除图片;选择图片后,在展示页面图片的右上角有删除按钮,点击可以直接

前段时间做项目需要用到图片选择,系统自带的intent方法选择图片已经过时了,不方便,所以就找到了一个大牛做的开源项目,拿过来修改了一下,添加了一些常用的功能,更加适合快速的集成到自己的项目中去,具体如下:

  1. 类似微信从相册中选择图片或者拍照;
  2. 可以控制单张或者多张选择;
  3. 支持预览,并且在预览页面可以直接删除图片;
  4. 选择图片后,在展示页面图片的右上角有删除按钮,点击可以直接删除;
  5. 更多属性可自行配置,适合快速集成到自己的项目中。

    直接上图片
    这里写图片描述这里写图片描述这里写图片描述这里写图片描述这里写图片描述这里写图片描述

用到的三个基本方法

/**
     * 预览
     *
     * @param position
     */
    public void previewPhoto(int position) {
        ImagePreviewActivity.startPreview(this, selectLocalMedias, selectLocalMedias, maxSelectNum, position);
    }

    /**
     * 进入相册中选择图片
     */
    public void pickerPhoto() {
        int mode = selectMode.getCheckedRadioButtonId() == R.id.mode_multiple ?
                ImageSelectorActivity.MODE_MULTIPLE : ImageSelectorActivity.MODE_SINGLE;
        boolean isShow = showCamera.getCheckedRadioButtonId() == R.id.camera_yes ? true : false;
        boolean isPreview = enablePreview.getCheckedRadioButtonId() == R.id.preview_enable ? true : false;
        boolean isCrop = enableCrop.getCheckedRadioButtonId() == R.id.crop_enable ? true : false;

        ImageSelectorActivity.start(MainActivity.this, maxSelectNum - selectedPhotos.size() + 1, spanCount, mode, isShow, isPreview, isCrop);
    }

    /**
     * 删除图片
     *
     * @param position
     */
    public void delPhoto(int position) {
        selectedPhotos.remove(position);
        selectLocalMedias.remove(position);
        if (selectedPhotos.size() < maxSelectNum) {
            // 保证最后一张是点击添加更多图片的
            selectedPhotos.add(addMoreImage);
        }
        gridAdapter.notifyDataSetChanged();
    }

以上的三个方法基本满足了需求,其中选择图片和图片预览都可以对图片进行操作,操作后的返回结果处理如下:

 @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        if (resultCode == RESULT_OK && (requestCode == ImagePreviewActivity.REQUEST_CODE_PREVIEW
                || requestCode == ImageSelectorActivity.REQUEST_CODE_PICKER)) {
            if (data != null) {

                ArrayList<String> images = (ArrayList<String>) data.getSerializableExtra(ImageSelectorActivity.REQUEST_OUTPUT);
                List<LocalMedia> localMedias = new ArrayList<>();
                for (String image : images) {
                    LocalMedia localMedia = new LocalMedia(image);
                    localMedias.add(localMedia);
                }
                Log.i("TAG", "localMedias.size = " + localMedias.size());
                if (requestCode == ImagePreviewActivity.REQUEST_CODE_PREVIEW) {
                    selectedPhotos.clear();
                    selectLocalMedias.clear();
                } else if (requestCode == ImageSelectorActivity.REQUEST_CODE_PICKER) {
                    selectedPhotos.remove(addMoreImage);
                }
                if (images != null) {
                    selectedPhotos.addAll(images);
                    selectLocalMedias.addAll(localMedias);
                }
                if (selectedPhotos.size() < maxSelectNum) {
                    // 保证最后一张是点击添加更多图片的
                    selectedPhotos.add(addMoreImage);
                }
                gridAdapter.notifyDataSetChanged();
            }
        }
    }

其中,对于选择之后图片的展示,单独写了一个adapter,里面的关键代码如下

@Override
    public void onBindViewHolder(GridAdapter.ViewHolder holder, final int position) {
        if (images.get(position).equals("addMoreImage")) {
            // 添加更多图片
            holder.imageView.setImageResource(R.drawable.btn_addphoto);
            holder.imageViewDel.setVisibility(View.GONE);
            holder.imageView.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View view) {
                    // 非常棒的写法
                    if (mContext instanceof MainActivity) {
                        ((MainActivity) mContext).pickerPhoto();
                    }
                }
            });
        } else {
            // 点击图片
            Glide.with(mContext)
                    .load(new File(images.get(position)))
                    .centerCrop()
                    .into(holder.imageView);
            holder.imageViewDel.setVisibility(View.VISIBLE);
            holder.imageViewDel.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    // 非常棒的写法
                    if (mContext instanceof MainActivity) {
                        ((MainActivity) mContext).delPhoto(position);
                    }
                }
            });
            holder.imageView.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View view) {
                    // 非常棒的写法
                    if (mContext instanceof MainActivity) {
                        ((MainActivity) mContext).previewPhoto(position);
                    }
                }
            });
        }
    }

这里因为要增加一个点击添加更多图片的功能,所以额外的增加了一个addMoreImage的图片路径,在具体使用的时候,需要特别留意。
备注:
个人感觉微信的图片选择有一个地方做的不太人性化,就是如果选择了两张图片,再次点击选择图片按钮的时候,没有把已经选择的这两张图片传递到图片选择页面,导致会出现重复选择的问题,试了一下,没有修复成功,有兴趣的小伙伴可以fork一下,推送给我。
欢迎大家交流沟通,下面是github地址: https://github.com/BrillantZhao/photoPicker

相关文章
|
11天前
|
人工智能 自然语言处理
使用企业微信或公众号自动回复图片消息
AppFlow支持企业微信和公众号接收图片消息,并提供两种回复方式。方式一:直接回复图片消息,用户发送图片后立即收到回复,但无法继续追问。方式二:先保存图片,待用户发送文字后再一并处理并回复。配置步骤包括选择模板、配置鉴权信息、设置执行动作参数及发布连接流。详细操作可参考相关文档。
使用企业微信或公众号自动回复图片消息
|
5月前
|
存储 缓存 编解码
Android经典面试题之图片Bitmap怎么做优化
本文介绍了图片相关的内存优化方法,包括分辨率适配、图片压缩与缓存。文中详细讲解了如何根据不同分辨率放置图片资源,避免图片拉伸变形;并通过示例代码展示了使用`BitmapFactory.Options`进行图片压缩的具体步骤。此外,还介绍了Glide等第三方库如何利用LRU算法实现高效图片缓存。
86 20
Android经典面试题之图片Bitmap怎么做优化
|
4月前
|
移动开发 小程序 数据可视化
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
基于npm CLI脚手架的uniapp项目创建、运行与打包全攻略(微信小程序、H5、APP全覆盖)
520 3
|
4月前
|
小程序 JavaScript API
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
这篇文章介绍了如何在uni-app和微信小程序中实现将图片保存到用户手机相册的功能。
1621 0
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
|
4月前
|
算法 小程序 Java
java制作海报三:获取微信二维码详情,并改变大小,合成到海报(另一张图片)上
这篇文章介绍了如何使用Java获取微信小程序的二维码,并将其调整大小后合成到海报(另一张图片)上。
73 0
|
4月前
|
JavaScript
vue尚品汇商城项目-day06【43.微信支付业务】
vue尚品汇商城项目-day06【43.微信支付业务】
44 0
|
6月前
|
小程序 前端开发
|
6月前
|
小程序 前端开发
微信小程序商城,微信小程序微店 【毕业设计参考项目】
文章推荐了一个微信小程序商城项目作为毕业设计参考,该项目在Github上获得18.2k星,提供了详细的使用教程和前端页面实现,适合学习微信小程序开发和作为毕业设计项目。
微信小程序商城,微信小程序微店 【毕业设计参考项目】
|
6月前
|
数据处理 开发工具 数据安全/隐私保护
Android平台RTMP推送|轻量级RTSP服务|GB28181接入之文字、png图片水印的精进之路
本文探讨了Android平台上推流模块中添加文字与PNG水印的技术演进。自2015年起,为了满足应急指挥及安防领域的需求,逐步发展出三代水印技术:第一代为静态文字与图像水印;第二代实现了动态更新水印内容的能力,例如实时位置与时间信息;至第三代,则优化了数据传输效率,直接使用Bitmap对象传递水印数据至JNI层,减少了内存拷贝次数。这些迭代不仅提升了用户体验和技术效率,也体现了开发者追求极致与不断创新的精神。
|
6月前
|
小程序
关于我花了一个星期学习微信小程序开发、并且成功开发出一个商城项目系统的心得体会
这篇文章是作者关于学习微信小程序开发并在一周内成功开发出一个商城项目系统的心得体会,分享了学习基础知识、实战项目开发的过程,以及小程序开发的易上手性和开发周期的简短。
关于我花了一个星期学习微信小程序开发、并且成功开发出一个商城项目系统的心得体会

热门文章

最新文章