上一次的項目中,有填寫用戶信息,需要用到類似QQ頭像選擇的一個功能,讓用戶從手機圖片或者自己拍照並圖圖像大小剪裁之後選擇,當時覺得很實用,但是自己不知道怎麼實現。最近參考同事寫的代碼並自己在網上查閱了相關信息,發現大概都是同樣的方式,自己簡單整合了一下,可以實現基本的功能,至於上傳方面還沒有深入研究。
效果圖:
下面是代碼的部分,部分是從網路上摘錄的,自己整理後當做工具類使用 配置文件:布局很簡單,一個ImageButton和一個Button,點擊都可以實現圖像選擇的功能,具體的實現根據大家在實際中用的效果而定 ————————————————————————————————————————————————— AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.cogent.piccut" android:versionCode="1" android:versionName="1.0" > <uses-sdk android:minSdkVersion="10" /> <application android:icon="@drawable/ic_launcher" android:label="@string/app_name" > <activity android:label="@string/app_name" android:name=".PicCutActivity" android:screenOrientation="portrait" > <intent-filter > <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> </application> </manifest>
————————————————————————————————————————————————— Java代碼:
package com.cogent.piccut; import java.io.File; import java.text.SimpleDateFormat; import java.util.Date; import android.app.Activity; import android.app.AlertDialog; import android.content.DialogInterface; import android.content.Intent; import android.graphics.Bitmap; import android.graphics.drawable.BitmapDrawable; import android.graphics.drawable.Drawable; import android.net.Uri; import android.os.Bundle; import android.os.Environment; import android.provider.MediaStore; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.ImageButton; public class PicCutActivity extends Activity implements OnClickListener { private ImageButton img_btn; private Button btn; private static final int PHOTO_REQUEST_TAKEPHOTO = 1;// 拍照 private static final int PHOTO_REQUEST_GALLERY = 2;// 從相冊中選擇 private static final int PHOTO_REQUEST_CUT = 3;// 結果 // 創建一個以當前時間為名稱的文件 File tempFile = new File(Environment.getExternalStorageDirectory(),getPhotoFileName()); /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); init(); } //初始化控件 private void init() { img_btn = (ImageButton) findViewById(R.id.img_btn); btn = (Button) findViewById(R.id.btn); //為ImageButton和Button添加監聽事件 img_btn.setOnClickListener(this); btn.setOnClickListener(this); } //點擊事件 @Override public void onClick(View v) { // TODO Auto-generated method stub switch (v.getId()) { case R.id.img_btn: showDialog(); break; case R.id.btn: showDialog(); break; } } //提示對話框方法 private void showDialog() { new AlertDialog.Builder(this) .setTitle("頭像設置") .setPositiveButton("拍照", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { // TODO Auto-generated method stub dialog.dismiss(); // 調用系統的拍照功能 Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); // 指定調用相機拍照後照片的儲存路徑 intent.putExtra(MediaStore.EXTRA_OUTPUT,Uri.fromFile(tempFile)); startActivityForResult(intent, PHOTO_REQUEST_TAKEPHOTO); } }) .setNegativeButton("相冊", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { // TODO Auto-generated method stub dialog.dismiss(); Intent intent = new Intent(Intent.ACTION_PICK, null); intent.setDataAndType(MediaStore.Images.Media.EXTERNAL_CONTENT_URI,"image/*"); startActivityForResult(intent, PHOTO_REQUEST_GALLERY); } }).show(); } @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { // TODO Auto-generated method stub switch (requestCode) { case PHOTO_REQUEST_TAKEPHOTO: startPhotoZoom(Uri.fromFile(tempFile), 150); break; case PHOTO_REQUEST_GALLERY: if (data != null) startPhotoZoom(data.getData(), 150); break; case PHOTO_REQUEST_CUT: if (data != null) setPicToView(data); break; } super.onActivityResult(requestCode, resultCode, data); } private void startPhotoZoom(Uri uri, int size) { Intent intent = new Intent("com.android.camera.action.CROP"); intent.setDataAndType(uri, "image/*"); // crop為true是設置在開啟的intent中設置顯示的view可以剪裁 intent.putExtra("crop", "true"); // aspectX aspectY 是寬高的比例 intent.putExtra("aspectX", 1); intent.putExtra("aspectY", 1); // outputX,outputY 是剪裁圖片的寬高 intent.putExtra("outputX", size); intent.putExtra("outputY", size); intent.putExtra("return-data", true); startActivityForResult(intent, PHOTO_REQUEST_CUT); } //將進行剪裁後的圖片顯示到UI界面上 private void setPicToView(Intent picdata) { Bundle bundle = picdata.getExtras(); if (bundle != null) { Bitmap photo = bundle.getParcelable("data"); Drawable drawable = new BitmapDrawable(photo); img_btn.setBackgroundDrawable(drawable); } } // 使用系統當前日期加以調整作為照片的名稱 private String getPhotoFileName() { Date date = new Date(System.currentTimeMillis()); SimpleDateFormat dateFormat = new SimpleDateFormat("'IMG'_yyyyMMdd_HHmmss"); return dateFormat.format(date) + ".jpg"; } }
心得總結:Androi系統內部自帶了圖片的剪裁功能,開發是只要調用即可,Intent的很多用法比較實用,但是太多了,需要用到的時候去查詢或者平時多看看官方文檔,很多代碼看著簡單但還是要實際自己去寫更好些,理解的更深入一些。