안 드 로 이 드 는 위 챗 을 모방 하여 사진 찍 기,다 중 이미지 업로드 기능 을 실현 한다 고 발표 했다.

본 논문 의 사례 는 여러분 에 게 안 드 로 이 드 가 위 챗 을 모방 하여 말 하고 기분 기능 을 공유 하 였 으 며,여러분 께 참고 하 시기 바 랍 니 다.구체 적 인 내용 은 다음 과 같 습 니 다.
사진 찍 기,갤러리 선택,멀 티 플 렉 스 업로드 사례 도 가능 하 며,현재 많은 앱 이 위 챗 모멘트 와 유사 한 기능 을 가지 고 있 으 며,발표 와 말 하기 등 추가 사진 을 올 릴 수 있다.다음은 이 기능 을 실현 하 는 과정 입 니 다.여러분 은 아직Android Retrofit 2.0 프레임 워 크 업로드 이미지 솔 루 션이 글 을 보지 못 했 습 니 다.오늘 의 글 을 보면 쉽 습 니 다.이 항목 에 library:photopicker 를 사용 하여 그림 의 선택 기능 을 봉 인 했 습 니 다.카 메 라 를 선택 하 시 겠 습 니까?그리고 그림 을 선택 한 후에 그림 을 볼 수 있 는 기능 도 있 습 니 다. 
 1.우선: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)설정 후 onActivity Result 방법 으로 선택 한 그림 과 미리 보기 로 딩 어댑터 를 다시 작성 합 니 다.

@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; 
 } 
 } 
 } 
 2.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); 
 } 
3.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 위 챗 개발 튜 토리 얼 집계》로 정리 되 었 으 니,여러분 의 학습 과 독 서 를 환영 합 니 다.
이상 은 본문의 전체 내용 이 므 로 여러분 의 학습 에 도움 이 되 기 를 바 랍 니 다.

좋은 웹페이지 즐겨찾기