Android中從SD卡中/拍照選擇圖片並進行剪裁的方法

來源:互聯網
上載者:User

類似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的很多用法比較實用,但是太多了,需要用到的時候去查詢或者平時多看看官方文檔,很多代碼看著簡單但還是要實際自己去寫更好些,理解的更深入一些。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.