热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

Android实现图片选择器功能

这篇文章主要为大家详细介绍了Android实现图片选择器功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了Android实现图片选择器功能的具体代码,供大家参考,具体内容如下

图片选择功能用的是GitHub上的依赖库,网址

先来看下我运行的效果图如下所示:

 

该依赖库是Android平台上拍照/录像,图片/视频选择,编辑和压缩的一站式解决方案。

添加依赖,在app->build.gradle里面添加依赖

//图片/视频选择、预览、编辑与拍照
implementation 'com.github.guoxiaoxing:phoenix:1.0.15'

初始化:

public class App extends Application {
 
  @Override
  public void onCreate() {
    super.onCreate();
 
    Phoenix.config()
        .imageLoader(new ImageLoader() {
          @Override
          public void loadImage(Context mContext, ImageView imageView
                        , String imagePath, int type) {
            Glide.with(mContext)
                .load(imagePath)
                .into(imageView);
          }
        });
  }
}

开启功能:

 private void callUpSelecter(boolean isCamera, int type, int REQUEST_CODE) {
 
    if (TextUtils.isEmpty(fileID)) {
      Phoenix.with()
          .theme(PhoenixOption.THEME_RED)// 主题
          .fileType(MimeType.ofImage())//显示的文件类型图片、视频、图片和视频
          .maxPickNumber(9)// 最大选择数量
          .minPickNumber(0)// 最小选择数量
          .spanCount(4)// 每行显示个数
          .enablePreview(true)// 是否开启预览
          .enableCamera(isCamera)// 是否开启拍照
          .enableAnimation(false)// 选择界面图片点击效果
          .enableCompress(true)// 是否开启压缩
          .compressPictureFilterSize(300)//多少kb以下的图片不压缩
          .compressVideoFilterSize(2018)//多少kb以下的视频不压缩
          .thumbnailHeight(160)// 选择界面图片高度
          .thumbnailWidth(160)// 选择界面图片宽度
          .enableClickSound(false)// 是否开启点击声音
          .pickedMediaList(add_lists)// 已选图片数据
          .videoFilterTime(0)//显示多少秒以内的视频
          .mediaFilterSize(0)//显示多少kb以下的图片/视频,默认为0,表示不限制
          .start(UploadMorePicActivity.this, type, REQUEST_CODE);
    }
 
  }

获取结果:

 @Override
  protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);
    if (requestCode == 889 && resultCode == RESULT_OK) {//相册
      //返回的数据
      List result = Phoenix.result(data);
      Log.e("=====result==", result.toString());
      add_lists.clear();
      add_lists.addAll(result);
      adapter.updateItems(add_lists);
      btnOkEnable(add_lists);
 
    } else if (requestCode == 899 && resultCode == RESULT_OK) {//拍照
      List result = Phoenix.result(data);
      add_lists.addAll(result);
      adapter.updateItems(add_lists);
      btnOkEnable(add_lists);
    }
  }

recyclerView的适配基类:

/**
 * recyclerView适配器基类
 */
public abstract class BaseRecyclerAdapter extends RecyclerView.Adapter {
  public OnRecyclerViewItemClickListener mOnItemClickListener= null;
  public OnRecyclerViewItemClickListenerData listenerData;
 
  /**
   * 数据集合
   */
  protected List mItems;
  protected Context mContext;
 
  /**
   * 构造函数
   */
  public BaseRecyclerAdapter(Context context) {
    this.mCOntext= context;
    mItems = new ArrayList<>();
  }
 
  /**
   * 返回数据集
   */
  public List getList() {
    return mItems;
  }
 
  /**
   * 添加单条数据
   */
  public void addItem(T item) {
    if (item == null) return;
    mItems.add(mItems.size(), item);
    notifyItemInserted(mItems.size());
  }
 
  /**
   * 追加数据集合
   */
  public void addItems(List items) {
    if (items == null) return;
    this.mItems.addAll(items);
 
    notifyDataSetChanged();
  }
 
  public boolean containsAll(List items) {
    return mItems.containsAll(items);
  }
 
  /**
   * 更新指定行数据
   */
  public void updateItem(T tasks, int position) {
    if (tasks == null) return;
    mItems.set(position, tasks);
    notifyItemChanged(position);
  }
 
  /**
   * 更新全部数据
   */
  public void updateItems(List items) {
    if (items == null) return;
    this.mItems.clear();
    this.mItems.addAll(items);
    notifyDataSetChanged();
  }
 
  /**
   * 移除指定行数据
   */
  public void removeItem(int index) {
    mItems.remove(index);
    notifyItemRemoved(index);
    notifyItemRangeChanged((index - 1) >= 0 &#63; index - 1 : 0, mItems.size());
  }
 
  public void getView(int position, RecyclerView.ViewHolder viewHolder, int type, T item) {
  }
 
  /**
   * 返回指定行数据
   */
  public T getItem(int location) {
    if (mItems == null || mItems.isEmpty()) {
      return null;
    } else {
      return mItems.get(location);
    }
  }
 
  /**
   * 返回数据集合总数
   */
  @Override
  public int getItemCount() {
    return mItems == null &#63; 0 : mItems.size();
  }
 
  /**
   * 清除全部数据
   */
  public void clear() {
    mItems.clear();
    notifyDataSetChanged();
  }
 
  public static interface OnRecyclerViewItemClickListener {
    void onItemClick(View view, String data);
  }
 
  public void setOnItemClickListener(OnRecyclerViewItemClickListener listener) {
    this.mOnItemClickListener= listener;
  }
 
  public interface OnRecyclerViewItemClickListenerData {
    void onItemClickData(View view, T data);
  }
 
  public void setOnItemClickListenerData(OnRecyclerViewItemClickListenerData listener) {
    listenerData = listener;
  }
}

显示选择的图片的适配器:

/**
 * Created by YuShuangPing on 2018/7/16.
 */
 
public class UpLoadMorePicAdapter extends BaseRecyclerAdapter {
  /**
   * 构造函数
   *
   * @param context
   */
  public UpLoadMorePicAdapter(Context context) {
    super(context);
  }
 
  @Override
  public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
    View view= LayoutInflater.from(mContext).inflate(R.layout.item_upload_more_pic_refresh,parent,false);
    return new ViewHolder(view);
  }
 
  @Override
  public void onBindViewHolder(RecyclerView.ViewHolder holder, final int position) {
    if (holder instanceof ViewHolder){
      final ViewHolder viewHolder= (ViewHolder) holder;
      if(mItems.size()<9&&position==mItems.size()){
        Glide.with(mContext).load(R.mipmap.add_consumer).centerCrop().into(viewHolder.iv_pic);
 
      }else{
        final MediaEntity mediaEntity=mItems.get(position);
          Glide.with(mContext).load(mediaEntity.getLocalPath()).centerCrop().into(viewHolder.iv_pic);
      }
      viewHolder.iv_pic.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
          if (listenerData!=null){
            listenerData.onItemClickData(viewHolder.iv_pic,position);
          }
        }
      });
 
    }
 
  }
 
  @Override
  public int getItemCount() {
    return mItems.size()<9&#63; mItems.size()+1:9;
  }
 
  class ViewHolder extends RecyclerView.ViewHolder{
    private CustomHeightImageView iv_pic;
 
    public ViewHolder(View view) {
      super(view);
      iv_pic= (CustomHeightImageView) view.findViewById(R.id.iv_pic);
    }
  }
}

适配器布局文件:

R.layout.item_upload_more_pic_refresh

<&#63;xml version="1.0" encoding="utf-8"&#63;>

 
  

Activity中的代码:

public class UploadMorePicActivity extends AppCompatActivity
{
 private RecyclerView rl_pic;
 private UpLoadMorePicAdapter adapter;
 private List add_lists = new ArrayList<>();
 
 @Override
  protected void onCreate(@Nullable Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
 rl_pic = (RecyclerView) findViewById(R.id.rl_pic);
 adapter = new UpLoadMorePicAdapter(this);
 rl_pic.setLayoutManager(new GridLayoutManager(this, 4));
 rl_pic.setAdapter(adapter);
 adapter.updateItems(add_lists);
 adapter.setOnItemClickListenerData(new BaseRecyclerAdapter.OnRecyclerViewItemClickListenerData() {
      @Override
      public void onItemClickData(View view, Object data) {
        int position = (int) data;
        if (position >= add_lists.size()) {
          callUpSelecter(false, PhoenixOption.TYPE_PICK_MEDIA, 889);
        } else {
        }
 
      }
    });
}
private void callUpSelecter(boolean isCamera, int type, int REQUEST_CODE) {
 
    if (TextUtils.isEmpty(fileID)) {
      Phoenix.with()
          .theme(PhoenixOption.THEME_RED)// 主题
          .fileType(MimeType.ofImage())//显示的文件类型图片、视频、图片和视频
          .maxPickNumber(9)// 最大选择数量
          .minPickNumber(0)// 最小选择数量
          .spanCount(4)// 每行显示个数
          .enablePreview(true)// 是否开启预览
          .enableCamera(isCamera)// 是否开启拍照
          .enableAnimation(false)// 选择界面图片点击效果
          .enableCompress(true)// 是否开启压缩
          .compressPictureFilterSize(300)//多少kb以下的图片不压缩
          .compressVideoFilterSize(2018)//多少kb以下的视频不压缩
          .thumbnailHeight(160)// 选择界面图片高度
          .thumbnailWidth(160)// 选择界面图片宽度
          .enableClickSound(false)// 是否开启点击声音
          .pickedMediaList(add_lists)// 已选图片数据
          .videoFilterTime(0)//显示多少秒以内的视频
          .mediaFilterSize(0)//显示多少kb以下的图片/视频,默认为0,表示不限制
          .start(UploadMorePicActivity.this, type, REQUEST_CODE);
    }
 
  }
 @Override
  protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);
    if (requestCode == 889 && resultCode == RESULT_OK) {//相册
      //返回的数据
      List result = Phoenix.result(data);
      Log.e("=====result==", result.toString());
      add_lists.clear();
      add_lists.addAll(result);
      adapter.updateItems(add_lists);
      btnOkEnable(add_lists);
 
    }
 
}

自定义ImageView:

public class CustomHeightImageView extends android.support.v7.widget.AppCompatImageView {
  float scale = 0;
 
  public CustomHeightImageView(Context context) {
    super(context);
  }
 
  public CustomHeightImageView(Context context, float scale) {
    super(context);
    this.scale = scale;
  }
 
  public CustomHeightImageView(Context context, AttributeSet attrs) {
    super(context, attrs);
    TypedArray a = getContext().obtainStyledAttributes(attrs, R.styleable.CustomHeightRelativeLayout);
    scale = a.getFloat(R.styleable.CustomHeightRelativeLayout_scale, -1f);
//    float scale = a.
  }
 
 
  @Override
  protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
    if (scale == -1) {
      super.onMeasure(widthMeasureSpec, heightMeasureSpec);
    } else {
      super.onMeasure(widthMeasureSpec, MeasureSpec.makeMeasureSpec(
          (int) (MeasureSpec.getSize(widthMeasureSpec) * (scale)),
          MeasureSpec.getMode(widthMeasureSpec)));
    }
 
  }
}

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


推荐阅读
  • Android LED 数字字体的应用与实现
    本文介绍了一种适用于 Android 应用的 LED 数字字体(digital font),并详细描述了其在 UI 设计中的应用场景及其实现方法。这种字体常用于视频、广告倒计时等场景,能够增强视觉效果。 ... [详细]
  • RecyclerView初步学习(一)
    RecyclerView初步学习(一)ReCyclerView提供了一种插件式的编程模式,除了提供ViewHolder缓存模式,还可以自定义动画,分割符,布局样式,相比于传统的ListVi ... [详细]
  • Android 九宫格布局详解及实现:人人网应用示例
    本文深入探讨了人人网Android应用中独特的九宫格布局设计,解析其背后的GridView实现原理,并提供详细的代码示例。这种布局方式不仅美观大方,而且在现代Android应用中较为少见,值得开发者借鉴。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 解决微信电脑版无法刷朋友圈问题:使用安卓远程投屏方案
    在工作期间想要浏览微信和朋友圈却不太方便?虽然微信电脑版目前不支持直接刷朋友圈,但通过远程投屏技术,可以轻松实现在电脑上操作安卓设备的功能。 ... [详细]
  • 本文详细介绍了 Java 中 org.apache.xmlbeans.SchemaType 类的 getBaseEnumType() 方法,提供了多个代码示例,并解释了其在不同场景下的使用方法。 ... [详细]
  • 本文深入探讨了 com.example.android.sunshine.data.TestUtilities 中 validateThenCloseCursor() 方法的使用方法及其代码示例,旨在帮助开发者更好地理解和应用该方法。 ... [详细]
  • 从零开始构建完整手机站:Vue CLI 3 实战指南(第一部分)
    本系列教程将引导您使用 Vue CLI 3 构建一个功能齐全的移动应用。我们将深入探讨项目中涉及的每一个知识点,并确保这些内容与实际工作中的需求紧密结合。 ... [详细]
  • 本报告涵盖了个人博客账号和码云账号的注册过程,以及对网络工程专业学习的反思与展望。通过回顾初入大学时的专业选择,分析当前的专业知识和技能水平,并对未来的职业规划进行了详细讨论。 ... [详细]
  • 本文详细介绍了 com.facebook.drawee.view.SimpleDraweeView 中的 setScaleType 方法,提供了多个实际代码示例,并解释了其在不同场景下的应用。 ... [详细]
  • libsodium 1.0.15 发布:引入重大不兼容更新
    最新发布的 libsodium 1.0.15 版本带来了若干不兼容的变更,其中包括默认密码散列算法的更改和其他重要调整。 ... [详细]
  • 本文详细记录了在银河麒麟操作系统和龙芯架构上使用 Qt 5.15.2 进行项目打包时遇到的问题及解决方案,特别关注于 linuxdeployqt 工具的应用。 ... [详细]
  • VSCode与Gitee集成:项目提交的高效实践
    本文介绍如何利用VSCode内置的Git工具将项目提交到Gitee,简化Git命令的使用,提升代码管理效率。同时分享一些常见的踩坑经验和解决方案。 ... [详细]
  • 本文详细介绍了如何在ECharts中使用线性渐变色,通过echarts.graphic.LinearGradient方法实现。文章不仅提供了完整的代码示例,还解释了各个参数的具体含义及其应用场景。 ... [详细]
author-avatar
笃志单车小博_801
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有