Android实现图片选择上传功能实例

 更新时间:2017年12月25日 11:49:33   作者:yechaoa  
这篇文章主要介绍了Android实现图片选择以及图片上传的功能,有需要的朋友跟着学习下吧。

效果图:



添加依赖:

选择图片:compile 'com.lzy.widget:imagepicker:0.5.4'

github地址:https://github.com/jeasonlzy/ImagePicker

上传文件:compile 'com.zhy:okhttputils:2.6.2'

github地址:https://github.com/hongyangAndroid/okhttputils

MainActivity.java

package com.yechaoa.uploadimage; 
import android.content.Intent; 
import android.support.v7.app.AppCompatActivity; 
import android.os.Bundle; 
import android.support.v7.widget.GridLayoutManager; 
import android.support.v7.widget.RecyclerView; 
import android.view.View; 
import android.widget.AdapterView; 
import com.lzy.imagepicker.ImagePicker; 
import com.lzy.imagepicker.bean.ImageItem; 
import com.lzy.imagepicker.ui.ImageGridActivity; 
import com.lzy.imagepicker.ui.ImagePreviewDelActivity; 
import com.lzy.imagepicker.view.CropImageView; 
import java.util.ArrayList; 
import java.util.List; 
import okhttp3.Call; 
public class MainActivity extends AppCompatActivity implements ImagePickerAdapter.OnRecyclerViewItemClickListener{ 
  public static final int IMAGE_ITEM_ADD = -1; 
  public static final int REQUEST_CODE_SELECT = 100; 
  public static final int REQUEST_CODE_PREVIEW = 101; 
  private ImagePickerAdapter adapter; 
  private ArrayList<ImageItem> selImageList; //当前选择的所有图片 
  private int maxImgCount = 8;        //允许选择图片最大数 
  private HttpUtil httpUtil; 
  @Override 
  protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 
    httpUtil = new HttpUtil(); 
    findViewById(R.id.btn).setOnClickListener(new View.OnClickListener() { 
      @Override 
      public void onClick(View v) { 
        uploadImage(selImageList); 
      } 
    }); 
    //最好放到 Application oncreate执行 
    initImagePicker(); 
    initWidget(); 
  } 
  private void initImagePicker() { 
    ImagePicker imagePicker = ImagePicker.getInstance(); 
    imagePicker.setImageLoader(new GlideImageLoader());  //设置图片加载器 
    imagePicker.setShowCamera(true);           //显示拍照按钮 
    imagePicker.setCrop(true);              //允许裁剪(单选才有效) 
    imagePicker.setSaveRectangle(true);          //是否按矩形区域保存 
    imagePicker.setSelectLimit(maxImgCount);       //选中数量限制 
    imagePicker.setMultiMode(false);           //多选 
    imagePicker.setStyle(CropImageView.Style.RECTANGLE); //裁剪框的形状 
    imagePicker.setFocusWidth(800);            //裁剪框的宽度。单位像素(圆形自动取宽高最小值) 
    imagePicker.setFocusHeight(800);           //裁剪框的高度。单位像素(圆形自动取宽高最小值) 
    imagePicker.setOutPutX(1000);             //保存文件的宽度。单位像素 
    imagePicker.setOutPutY(1000);             //保存文件的高度。单位像素 
  } 
  private void initWidget() { 
    RecyclerView recyclerView = (RecyclerView) findViewById(R.id.recyclerView); 
    selImageList = new ArrayList<>(); 
    adapter = new ImagePickerAdapter(this, selImageList, maxImgCount); 
    adapter.setOnItemClickListener(this); 
 
    recyclerView.setLayoutManager(new GridLayoutManager(this, 4)); 
    recyclerView.setHasFixedSize(true); 
    recyclerView.setAdapter(adapter); 
  } 
 
  private SelectDialog showDialog(SelectDialog.SelectDialogListener listener, List<String> names) { 
    SelectDialog dialog = new SelectDialog(this, R.style.transparentFrameWindowStyle, listener, names); 
    if (!this.isFinishing()) { 
      dialog.show(); 
    } 
    return dialog; 
  }
  @Override 
  public void onItemClick(View view, int position) { 
    switch (position) { 
      case IMAGE_ITEM_ADD: 
        List<String> names = new ArrayList<>(); 
        names.add("拍照"); 
        names.add("相册"); 
        showDialog(new SelectDialog.SelectDialogListener() { 
          @Override 
          public void onItemClick(AdapterView<?> parent, View view, int position, long id) { 
            switch (position) { 
              case 0: // 直接调起相机 
                //打开选择,本次允许选择的数量 
                ImagePicker.getInstance().setSelectLimit(maxImgCount - selImageList.size()); 
                Intent intent = new Intent(MainActivity.this, ImageGridActivity.class); 
                intent.putExtra(ImageGridActivity.EXTRAS_TAKE_PICKERS,true); // 是否是直接打开相机 
                startActivityForResult(intent, REQUEST_CODE_SELECT); 
                break; 
              case 1: 
                //打开选择,本次允许选择的数量 
                ImagePicker.getInstance().setSelectLimit(maxImgCount - selImageList.size()); 
                Intent intent1 = new Intent(MainActivity.this, ImageGridActivity.class); 
                startActivityForResult(intent1, REQUEST_CODE_SELECT); 
                break; 
              default: 
                break; 
            } 
          } 
        }, names); 
        break; 
      default: 
        //打开预览 
        Intent intentPreview = new Intent(this, ImagePreviewDelActivity.class); 
        intentPreview.putExtra(ImagePicker.EXTRA_IMAGE_ITEMS, (ArrayList<ImageItem>) adapter.getImages()); 
        intentPreview.putExtra(ImagePicker.EXTRA_SELECTED_IMAGE_POSITION, position); 
        intentPreview.putExtra(ImagePicker.EXTRA_FROM_ITEMS,true); 
        startActivityForResult(intentPreview, REQUEST_CODE_PREVIEW); 
        break; 
    } 
  } 
  @Override 
  protected void onActivityResult(int requestCode, int resultCode, Intent data) { 
    super.onActivityResult(requestCode, resultCode, data); 
    if (resultCode == ImagePicker.RESULT_CODE_ITEMS) { 
      //添加图片返回 
      if (data != null && requestCode == REQUEST_CODE_SELECT) { 
        ArrayList<ImageItem> images = (ArrayList<ImageItem>) data.getSerializableExtra(ImagePicker.EXTRA_RESULT_ITEMS); 
        if (images != null){ 
          selImageList.addAll(images); 
          adapter.setImages(selImageList); 
        } 
      } 
    } else if (resultCode == ImagePicker.RESULT_CODE_BACK) { 
      //预览图片返回 
      if (data != null && requestCode == REQUEST_CODE_PREVIEW) { 
        ArrayList<ImageItem> images = (ArrayList<ImageItem>) data.getSerializableExtra(ImagePicker.EXTRA_IMAGE_ITEMS); 
        if (images != null){ 
          selImageList.clear(); 
          selImageList.addAll(images); 
          adapter.setImages(selImageList); 
        } 
      } 
    } 
  } 
  private String url="http..."; 
 
  private void uploadImage(ArrayList<ImageItem> pathList) { 
    httpUtil.postFileRequest(url, null, pathList, new MyStringCallBack() { 
 
      @Override 
      public void onError(Call call, Exception e, int id) { 
        super.onError(call, e, id); 
      }
      @Override 
      public void onResponse(String response, int id) { 
        super.onResponse(response, id); 
        //返回图片的地址 
      } 
    }); 
  }
}

Demo地址:https://github.com/yechaoa/UploadImage

以上就是全部内容,包含了代码,大家还有任何其他疑问可以在下方的留言讨论,感谢你对脚本之家的支持。

相关文章

  • Android学习之本地广播使用方法详解

    Android学习之本地广播使用方法详解

    这篇文章主要为大家详细介绍了Android学习之本地广播使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • so加载Linker跟NameSpace机制详解

    so加载Linker跟NameSpace机制详解

    这篇文章主要为大家介绍了so加载Linker跟NameSpace机制详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-01-01
  • Android下拉列表spinner的实例代码

    Android下拉列表spinner的实例代码

    这篇文章主要为大家详细介绍了Android下拉列表spinner的实例代码。感兴趣的小伙伴们可以参考一下
    2016-05-05
  • Android自定义viewgroup快速滑动(4)

    Android自定义viewgroup快速滑动(4)

    这篇文章主要为大家详细介绍了Android自定义viewgroup快速滑动的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-12-12
  • Android中使用AsyncTask实现文件下载以及进度更新提示

    Android中使用AsyncTask实现文件下载以及进度更新提示

    AsyncTask,它使创建需要与用户界面交互的长时间运行的任务变得更简单,本篇文章主要介绍了Android中使用AsyncTask实现文件下载以及进度更新提示,有兴趣的可以了解一下。
    2016-12-12
  • Android、iOS和Windows Phone中的推送技术详解

    Android、iOS和Windows Phone中的推送技术详解

    这篇文章主要介绍了Android、iOS和Windows Phone中的推送技术详解,推送技术的实现通常会使用服务端向客户端推送消息的方式,也就是说客户端通过用户名、Key等ID注册到服务端后,在服务端就可以将消息向所有活动的客户端发送,需要的朋友可以参考下
    2015-01-01
  • Android开发之DOM解析xml文件的方法

    Android开发之DOM解析xml文件的方法

    这篇文章主要介绍了Android开发之DOM解析xml文件的方法,涉及Android中DOM工厂对象的创建,文档的获取及节点的遍历技巧,需要的朋友可以参考下
    2015-12-12
  • 安卓(Android)动态创建多个按钮并添加监听事件

    安卓(Android)动态创建多个按钮并添加监听事件

    本文主要介绍Android动态创建多个按钮并给每个按键添加监听事件,在做Android项目会经常遇到的,希望对需要用到的同学有所帮助
    2016-07-07
  • 使用User Agent分辨出Android设备类型的安全做法

    使用User Agent分辨出Android设备类型的安全做法

    这篇文章主要介绍了使用User Agent分辨出Android设备类型的安全做法,本文得出的结论是当你依据检测UA来判断Android手机设备,请同时检查android和mobile两个字符串,需要的朋友可以参考下
    2015-01-01
  • Android AMS启动App进程原理分析

    Android AMS启动App进程原理分析

    这篇文章主要介绍了Android AMS启动App进程原理,系统fork函数是如何创建进程,文中有详细的代码示例,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2023-05-05

最新评论