Android仿微信发表说说实现拍照、多图上传功能

本文实例为大家分享了Android仿微信发表说说、心情功能,供大家参考,具体内容如下

既能实现拍照,选图库,多图案上传的案例,目前好多App都有类似微信朋友圈的功能,能过发表说说等附带图片上传。下面的就是实现该功能的过程:大家还没有看过Android Retrofit 2.0框架上传图片解决方案这篇文章,在看今天的就很容易,接在本项目中用到了一个library:photopicker,封装了图片的选择功能,是否选相机,还有选中图片后可以查看图片的功能。

 一、 首先:将photopicker到工程中
(1)、先简单讲解一下PhotoPickerIntent的用法:

PhotoPickerIntent intent = new PhotoPickerIntent(MainActivity.this);
 intent.setSelectModel(SelectModel.MULTI); //
 intent.setShowCarema(true); // 是否显示拍照
 intent.setMaxTotal(6); // 最多选择照片数量,默认为6
 intent.setSelectedPaths(imagePaths); // 已选中的照片地址, 用于回显选中状态
 startActivityForResult(intent, REQUEST_CAMERA_CODE);

(2)、设置好之后,重写onActivityResult方法处理选中图片和预览加载适配器

@Override
 protected void onActivityResult(int requestCode, int resultCode, Intent data) {
 super.onActivityResult(requestCode, resultCode, data);
 if(resultCode == RESULT_OK) {
 switch (requestCode) {
 // 选择照片
 case REQUEST_CAMERA_CODE:
  loadAdpater(data.getStringArrayListExtra(PhotoPickerActivity.EXTRA_RESULT));
  break;
 // 预览
 case REQUEST_PREVIEW_CODE:
  loadAdpater(data.getStringArrayListExtra(PhotoPreviewActivity.EXTRA_RESULT));
  break;
 }
 }
 }

 二、重点在GridAdapter

(1)、定义一个变量 mMaxPosition,
 (2)、写一个获取最大位置的方法:用来获取item的最大位置。

 //重点在这里,当position==mMaxposition-1让"+"选择图片的默认图片显示。
 //当目前最多6中图片,则最大7时,图片影藏。
 if (position==mMaxPosition-1) {
 holder.image.setImageResource(R.mipmap.ic_launcher);
 holder.image.setVisibility(View.VISIBLE);
 if(position==6&&mMaxPosition==7){
 holder.image.setImageResource(R.mipmap.ic_launcher);
 holder.image.setVisibility(View.GONE);
 }
 } else {
 final String path=listUrls.get(position);
 Glide.with(MainActivity.this)
 .load(new File(path))
 .placeholder(R.mipmap.default_error)
 .error(R.mipmap.default_error)
 .centerCrop()
 .crossFade()
 .into(holder.image);
}

(3)、关于图片的显示:

 private class GridAdapter extends BaseAdapter{
 private ArrayList<String> listUrls;
 private int mMaxPosition;
 private LayoutInflater inflater;
 public GridAdapter(ArrayList<String> listUrls) {
 this.listUrls = listUrls;
 inflater = LayoutInflater.from(MainActivity.this);
 }
 public int getCount() {
 mMaxPosition = listUrls.size()+1;
 return mMaxPosition;
 }
 public int getMaxPosition(){
 return mMaxPosition;
 }
 @Override
 public String getItem(int position) {
 return listUrls.get(position);
 } 

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

 @Override
 public View getView(int position, View convertView, ViewGroup parent) {
 ViewHolder holder = null;
 if (convertView == null) {
 holder = new ViewHolder();
 convertView = inflater.inflate(R.layout.item_image, parent,false);
 holder.image = (ImageView) convertView.findViewById(R.id.imageView);
 convertView.setTag(holder);
 } else {
 holder = (ViewHolder)convertView.getTag();
 }
 Log.d("", "position:"+position+" mMaxPosition:"+mMaxPosition);
 //重点在这里,当position==mMaxposition-1让"+"选择图片的默认图片显示。
 //当目前最多6中图片,则最大7时,图片影藏。
 if (position==mMaxPosition-1) {
// holder.image.setTag("default");
 holder.image.setImageResource(R.mipmap.ic_launcher);
 holder.image.setVisibility(View.VISIBLE);
 if(position==6&&mMaxPosition==7){
  holder.image.setImageResource(R.mipmap.ic_launcher);
  holder.image.setVisibility(View.GONE);
 }
 } else {
 final String path=listUrls.get(position);
 Glide.with(MainActivity.this)
  .load(new File(path))
  .placeholder(R.mipmap.default_error)
  .error(R.mipmap.default_error)
  .centerCrop()
  .crossFade()
  .into(holder.image);
 }

三、GridView中Item的点击事件

gridView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
 @Override
 public void onItemClick(AdapterView<?> parent, View view, int position, long id) { 

  if (position == gridAdapter.getMaxPosition() - 1) {
  PhotoPickerIntent intent = new PhotoPickerIntent(MainActivity.this);
  intent.setSelectModel(SelectModel.MULTI);
  intent.setShowCarema(true); // 是否显示拍照
  intent.setMaxTotal(6); // 最多选择照片数量,默认为9
  intent.setSelectedPaths(imagePaths); // 已选中的照片地址, 用于回显选中状态
  startActivityForResult(intent, REQUEST_CAMERA_CODE);
  }else{
  PhotoPreviewIntent intent = new PhotoPreviewIntent(MainActivity.this);
  intent.setCurrentItem(position);
  intent.setPhotoPaths(imagePaths);
  startActivityForResult(intent, REQUEST_PREVIEW_CODE);
  }
 }
 });

整体源码:

package com.lidong.photopickersample; 

import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.EditText;
import android.widget.GridView;
import android.widget.ImageView;
import com.bumptech.glide.Glide;
import com.lidong.photopicker.ImageCaptureManager;
import com.lidong.photopicker.PhotoPickerActivity;
import com.lidong.photopicker.PhotoPreviewActivity;
import com.lidong.photopicker.SelectModel;
import com.lidong.photopicker.intent.PhotoPickerIntent;
import com.lidong.photopicker.intent.PhotoPreviewIntent;
import org.json.JSONArray;
import java.io.File;
import java.util.ArrayList; 

/**
 * @
 * @author lidong
 * @date 2016-02-29
 */
public class MainActivity extends AppCompatActivity { 

 private static final int REQUEST_CAMERA_CODE = 10;
 private static final int REQUEST_PREVIEW_CODE = 20;
 private ArrayList<String> imagePaths = new ArrayList<>();
 private ImageCaptureManager captureManager; // 相机拍照处理类
 private GridView gridView;
 private int columnWidth;
 private GridAdapter gridAdapter;
 private Button mButton;
 private String depp;
 private EditText textView; 

 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 gridView = (GridView) findViewById(R.id.gridView);
 mButton = (Button) findViewById(R.id.button);
 textView= (EditText)findViewById(R.id.et_context);
 int cols = getResources().getDisplayMetrics().widthPixels / getResources().getDisplayMetrics().densityDpi;
 cols = cols < 3 ? 3 : cols;
 gridView.setNumColumns(cols);
 // preview
 gridView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
 @Override
 public void onItemClick(AdapterView<?> parent, View view, int position, long id) { 

 if (position == gridAdapter.getMaxPosition() - 1) {
 PhotoPickerIntent intent = new PhotoPickerIntent(MainActivity.this);
 intent.setSelectModel(SelectModel.MULTI);
 intent.setShowCarema(true); // 是否显示拍照
 intent.setMaxTotal(6); // 最多选择照片数量,默认为9
 intent.setSelectedPaths(imagePaths); // 已选中的照片地址, 用于回显选中状态
 startActivityForResult(intent, REQUEST_CAMERA_CODE);
 }else{
 PhotoPreviewIntent intent = new PhotoPreviewIntent(MainActivity.this);
 intent.setCurrentItem(position);
 intent.setPhotoPaths(imagePaths);
 startActivityForResult(intent, REQUEST_PREVIEW_CODE);
 }
 }
 });
 gridAdapter = new GridAdapter(imagePaths);
 gridView.setAdapter(gridAdapter); 

 mButton.setOnClickListener(new View.OnClickListener() {
 @Override
 public void onClick(View v) {
 depp =textView.getText().toString().trim()!=null?textView.getText().toString().trim():"woowoeo";
 new Thread(){
 @Override
 public void run() {
 super.run();
 FileUploadManager.upload(imagePaths,depp);
 }
 }.start();
 }
 });
 } 

 @Override
 protected void onActivityResult(int requestCode, int resultCode, Intent data) {
 super.onActivityResult(requestCode, resultCode, data);
 if(resultCode == RESULT_OK) {
 switch (requestCode) {
 // 选择照片
 case REQUEST_CAMERA_CODE:
 loadAdpater(data.getStringArrayListExtra(PhotoPickerActivity.EXTRA_RESULT));
 break;
 // 预览
 case REQUEST_PREVIEW_CODE:
 loadAdpater(data.getStringArrayListExtra(PhotoPreviewActivity.EXTRA_RESULT));
 break;
 }
 }
 } 

 private void loadAdpater(ArrayList<String> paths){
 if(imagePaths == null){
 imagePaths = new ArrayList<>();
 }
 imagePaths.clear();
 imagePaths.addAll(paths);
 try{
 JSONArray obj = new JSONArray(imagePaths);
 Log.e("--", obj.toString());
 }catch (Exception e){
 e.printStackTrace();
 }
 gridAdapter.notifyDataSetChanged();
 } 

 private class GridAdapter extends BaseAdapter{
 private ArrayList<String> listUrls;
 private int mMaxPosition;
 private LayoutInflater inflater;
 public GridAdapter(ArrayList<String> listUrls) {
 this.listUrls = listUrls;
 inflater = LayoutInflater.from(MainActivity.this);
 } 

 public int getCount() {
 if (listUrls.size() == 9) {
 mMaxPosition = listUrls.size()+1;
 } else {
 mMaxPosition = listUrls.size()+1;
 }
 return mMaxPosition;
 }
 public int getMaxPosition(){
 return mMaxPosition;
 }
 @Override
 public String getItem(int position) {
 return listUrls.get(position);
 } 

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

 @Override
 public View getView(int position, View convertView, ViewGroup parent) {
 ViewHolder holder = null;
 if (convertView == null) {
 holder = new ViewHolder(); 

 convertView = inflater.inflate(R.layout.item_image, parent,false);
 holder.image = (ImageView) convertView.findViewById(R.id.imageView);
 convertView.setTag(holder);
 } else {
 holder = (ViewHolder)convertView.getTag();
 }
 Log.d("", "position:"+position+" mMaxPosition:"+mMaxPosition); 

 if (position==mMaxPosition-1) {
// holder.image.setTag("default");
 holder.image.setImageResource(R.mipmap.ic_launcher);
 holder.image.setVisibility(View.VISIBLE);
 if(position==6&&mMaxPosition==7){
 holder.image.setImageResource(R.mipmap.ic_launcher);
 holder.image.setVisibility(View.GONE);
 }
 } else {
 final String path=listUrls.get(position);
 Glide.with(MainActivity.this)
 .load(new File(path))
 .placeholder(R.mipmap.default_error)
 .error(R.mipmap.default_error)
 .centerCrop()
 .crossFade()
 .into(holder.image);
 } 

 return convertView;
 }
 public class ViewHolder {
 public ImageView image;
 }
 }
}

上传的类:FileUploadManager.java

package com.lidong.photopickersample;
import android.util.Log;
import com.squareup.okhttp.MediaType;
import com.squareup.okhttp.RequestBody;
import java.io.File;
import java.util.ArrayList;
import retrofit.Call;
import retrofit.Callback;
import retrofit.GsonConverterFactory;
import retrofit.Response;
import retrofit.Retrofit;
import retrofit.http.Multipart;
import retrofit.http.POST;
import retrofit.http.Part; 

/**
 * Created by lidong on 2016/2/29
 */
public class FileUploadManager { 

 private static final String ENDPOINT = "http://192.168.1.122:8080"; 

 public interface FileUploadService {
 /**
 * 上传一张图片
 * @param description
 * @param imgs
 * @return
 */
 @Multipart
 @POST("/upload")
 Call<String> uploadImage(@Part("fileName") String description,
  @Part("file\"; filename=\"image.png\"") RequestBody imgs); 

 /**
 * 上传6张图片
 * @param description
 * @param imgs1
 * @param imgs2
 * @param imgs3
 * @param imgs4
 * @param imgs5
 * @param imgs6
 * @return
 */
 @Multipart
 @POST("/upload")
 Call<String> uploadImage(@Part("description") String description,
  @Part("file\"; filename=\"image.png\"") RequestBody imgs1,
  @Part("file\"; filename=\"image.png\"") RequestBody imgs2,
  @Part("file\"; filename=\"image.png\"") RequestBody imgs3,
  @Part("file\"; filename=\"image.png\"") RequestBody imgs4,
  @Part("file\"; filename=\"image.png\"") RequestBody imgs5,
  @Part("file\"; filename=\"image.png\"") RequestBody imgs6);
 } 

 private static final Retrofit sRetrofit = new Retrofit .Builder()
 .baseUrl(ENDPOINT)
 .addConverterFactory(GsonConverterFactory.create())
// .addCallAdapterFactory(RxJavaCallAdapterFactory.create()) // 使用RxJava作为回调适配器
 .build(); 

 private static final FileUploadService apiManager = sRetrofit.create(FileUploadService.class); 

 /**
 * 发说说
 * @param paths
 * @param desp
 */
 public static void upload(ArrayList<String> paths,String desp){
 RequestBody[] requestBody= new RequestBody[6];
 if (paths.size()>0) {
 for (int i=0;i<paths.size();i++) {
 requestBody[i] =
 RequestBody.create(MediaType.parse("multipart/form-data"), new File(paths.get(i)));
 }
 }
 Call<String> call = apiManager.uploadImage( desp,requestBody[0],requestBody[1],requestBody[2],requestBody[3],requestBody[4],requestBody[5]);
 call.enqueue(new Callback<String>() {
 @Override
 public void onResponse(Response<String> response, Retrofit retrofit) {
 Log.v("Upload", response.message());
 Log.v("Upload", "success");
 } 

 @Override
 public void onFailure(Throwable t) {
 Log.e("Upload", t.toString());
 }
 }); 

 }
}

效果:

关于Android上传功能的更多内容请点击专题:Android上传操作汇总进行学习。

本文已被整理到了《Android微信开发教程汇总》,欢迎大家学习阅读。

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

时间: 2016-02-29

Android Retrofit 2.0框架上传图片解决方案

本文为大家分享了 Android Retrofit 2.0框架上传图片解决方案,具体内容如下 1.单张图片的上传 /** * 上传一张图片 * @param description * @param imgs * @return */ @Multipart @POST("/upload") Call<String> uploadImage(@Part("fileName") String description, @Part("file\&qu

Android实现上传文件功能的方法

本文所述为一个Android上传文件的源代码,每一步实现过程都备有详尽的注释,思路比较清楚,学习了本例所述上传文件代码之后,你可以应对其它格式文件的上传.实例中主要实现上传文件至Server的方法,允许Input.Output,不使用Cache,使Androiod上传文件变得轻松. 主要功能代码如下: package com.test; import java.io.DataOutputStream; import java.io.FileInputStream; import java.io.

android 上传文件到服务器代码实例

android对于上传文件,还是很简单的,和java里面的上传都是一样的,基本上都是熟悉操作输出流和输入流!还有一个特别重要的就是需要一些content-type这些参数的配置!  如果这些都弄好了,上传就很简单了!   下面是我写的一个上传的工具类: 复制代码 代码如下: package com.spring.sky.image.upload.network; import java.io.DataOutputStream;import java.io.File;import java.io.

android文件上传示例分享(android图片上传)

主要思路是调用系统文件管理器或者其他媒体采集资源来获取要上传的文件,然后将文件的上传进度实时展示到进度条中. 主Activity 复制代码 代码如下: package com.guotop.elearn.activity.app.yunpan.activity; import java.io.File;import java.io.FileNotFoundException;import java.io.IOException; import android.app.Activity;impor

android 拍照和上传的实现代码

复制代码 代码如下: import java.io.ByteArrayOutputStream;   import java.io.File;   import android.app.Activity;   import android.content.Intent;   import android.graphics.Bitmap;   import android.net.Uri;   import android.os.Bundle;   import android.os.Enviro

android 捕获系统异常并上传日志具体实现

在做项目时,经常会把错误利用异常抛出去,这样在开发时就可以通过手机抛出的异常排查错误.但是当程序开发完毕,版本稳定,需要上线时,为了避免抛出异常影响用户感受,可以用UncaughtExceptionHandler捕获全局异常,对异常做出处理.比如我们可以获取到抛出异常的时间.手机的硬件信息.错误的堆栈信息,然后将获取到的所有的信息发送到服务器中,也可以发送到指定的邮件中,以便及时修改bug. 示例: 自定义异常类实现UncaughtExceptionHandler接口,当某个页面出现异常就会调用

Android实现本地上传图片并设置为圆形头像

先从本地把图片上传到服务器,然后根据URL把头像处理成圆形头像. 因为上传图片用到bmob的平台,所以要到bmob(http://www.bmob.cn)申请密钥. 效果图: 核心代码: 复制代码 代码如下: public class MainActivity extends Activity {         private ImageView iv;         private String appKey="";                //填写你的Applicatio

SimpleCommand实现上传文件或视频功能(四)

上传文件的核心功能主要是在UploadCommand.java中实现 使用步骤: 1 创建UploadCommand的构建类Builder UploadCommand.Builder builder = new UploadCommand.Builder(); 2 通过构建类设置UploadCommand的各种属性 builder.domain("上传地址的域名") .path("上传接口") .contentType("请求头文件的Content-typ

Android中发送Http请求(包括文件上传、servlet接收)的实例代码

复制代码 代码如下: /*** 通过http协议提交数据到服务端,实现表单提交功能,包括上传文件* @param actionUrl 上传路径 * @param params 请求参数 key为参数名,value为参数值 * @param file 上传文件 */public static void postMultiParams(String actionUrl, Map<String, String> params, FormBean[] files) {try {PostMethod p

Android使用post方式上传图片到服务器的方法

本文实例讲述了Android使用post方式上传图片到服务器的方法.分享给大家供大家参考,具体如下: /** * 上传文件到服务器类 * * @author tom */ public class UploadUtil { private static final String TAG = "uploadFile"; private static final int TIME_OUT = 10 * 1000; // 超时时间 private static final String CH

Android开发中调用系统相册上传图片到服务器OPPO等部分手机上出现短暂的显示桌面问题的解决方法

要原因是主体样式设置的问题:这里把appTheme设置一个style即可: <item name="android:windowBackground">@color/white</item> <!--下面这个属性很重要,有时候会出现某些机型在调用系统相册的时候,短暂的出现手机桌面现象--> <item name="android:windowIsTranslucent">false</item> <i

Android 通过Base64上传图片到服务器实现实例

Android 通过Base64上传图片到服务器 之前做上传图片是采用HttpServlet上传,不过用了一下Base64上传图片后,感觉比HttpServlet方便很多,大家也可以跟着尝试一下. 前台图片处理:(传Bitmap对象即可) /** * 通过Base32将Bitmap转换成Base64字符串 * @param bit * @return */ public String Bitmap2StrByBase64(Bitmap bit){ ByteArrayOutputStream bo

Android采取BroadcastReceiver方式自动获取验证码

Android 自动获取验证码的两种方式分别是BroadcastReceiver及ContentObserver,两种方式都需要进行注册.取消注册两个步骤 记得添加权限,本文先介绍其中一种. <uses-permission android:name="android.permission.RECEIVE_SMS"/> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORA

Android上传文件到服务器的方法

本文实例为大家分享了Android端实现文件上传的具体代码,供大家参考,具体内容如下 1).新建一个Android项目命名为androidUpload,目录结构如下: 2).新建FormFile类,用来封装文件信息 package com.ljq.utils; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.InputStream;

Android实现上传文件到服务器实例详解

本实例实现每隔5秒上传一次,通过服务器端获取手机上传过来的文件信息并做相应处理:采用Android+Struts2技术. 一.Android端实现文件上传 1).新建一个Android项目命名为androidUpload,目录结构如下: 2).新建FormFile类,用来封装文件信息 package com.ljq.utils; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundExce

在Android设备上搭建Web服务器的方法

一般而言,Android 应用在请求数据时都是以 Get 或 Post 等方式向远程服务器发起请求,那你有没有想过其实我们也可以在 Android 设备上搭建一个小型 Web 服务器,并且实现常规的下载图片.下载文件.提交表单等功能呢? 下面要介绍的就是如何在 Android 设备上搭建一个 Web 服务器,这个 Web 服务器的功能有如下几点: 接受客户端文件上传.下载文件 动态 Http API,像 Java 的 Servlet 一样写接口 部署静态网站,例如纯Html,支持 JS.CSS.

Android使用ftp方式实现文件上传和下载

近期在工作上一直再维护平台OTA在线升级项目,其中关于这个升级文件主要是存放于ftp服务器上的,然后客户端通过走ftp协议方式下载至本地Android机进行一个系统升级操作.那么今天将对ftp实现文件上传和下载进行一个使用总结,关于ftp这方面的理论知识如果不是太了解的各位道友,那么请移步HTTP和FTP的区别的一些理论知识 作个具体的了解或者查阅相关资料.那么先看看个人工作项目这个OTA升级效果图吧.如下: 下面是具体的接口实现: 那么相关ftp的操作,已经被封装到ota.ftp这个包下,各位

使用Post方式提交数据到Tomcat服务器的方法

我在上一篇文章中介绍了 使用Get方式提交数据到Tomcat服务器,这篇将介绍使用Post方式提交数据到服务器,由于Post的方式和Get方式创建Web工程是一模一样的,只用几个地方的代码不同所以,我就直接介绍不同的地方,第一个不同点是,提交方式不同,所以修改LoginServlet.Java中的代码 package com.fyt.org; import java.io.IOException; import java.io.OutputStream; import java.io.Print

使用Get方式提交数据到Tomcat服务器的方法

这篇文章将介绍向服务器发送数据,并且服务器将数据的处理结果返回给客户端,这次先介绍使用Get方式向服务器发送数据,下篇将介绍使用Post方式向服务器发送数据,需要的朋友参考下吧! 实现方式分为以下几步: 第一步:使用MyEclipse创建一个Web project,项目命名为WebProject->在src文件夹中新建一个包名为com.fyt.org的包 ->在包中新建一个Servlet,Servlet命名为LoginServlet,并在LoginServlet.Java中添加下面的代码 pa