Android中通過訪問本地相冊或者相機設置用戶頭像實例
目前幾乎所有的APP在用戶注冊時都會有設置頭像的需求,大致分為三種情況:
(1)通過獲取本地相冊的圖片,經(jīng)過裁剪后作為頭像。
(2)通過啟動手機相機,現(xiàn)拍圖片然后裁剪作為頭像。
(3)在APP中添加一些自帶的頭像資源,供用戶選擇(不夠人性化,目前很少使用)。
這次我們簡單介紹下通過獲取本地相冊以及相機拍攝的方法設置頭像,實現(xiàn)思路如下:
(1)通過startActivityForResult方法,分別傳遞調(diào)用系統(tǒng)相冊的Intent和調(diào)用相機拍照的Intent來做選擇
(2)調(diào)用Android系統(tǒng)中自帶的圖片剪裁,實現(xiàn)圖片的剪裁并在onActivityResult方法中獲取數(shù)據(jù)。
本次演示效果如下(分別為從本地相冊獲取以及從相機拍攝獲取頭像):
簡單布局文件這里不再做贅述,本次試驗使用隱式intent調(diào)用相機以及本地相冊,未在配置清單上添加權限,依然可以調(diào)用。
java實現(xiàn)代碼如下:
import android.content.Intent; import android.graphics.Bitmap; import android.net.Uri; import android.os.Bundle; import android.os.Environment; import android.provider.MediaStore; import android.support.v7.app.AppCompatActivity; import android.view.View; import android.widget.Button; import android.widget.ImageView; import android.widget.Toast; import java.io.File; public class MainActivity extends AppCompatActivity implements View.OnClickListener { private Button buttonLocal, buttonCamera; private ImageView imageView; //相機拍攝的頭像文件(本次演示存放在SD卡根目錄下) private static final File USER_ICON = new File(Environment.getExternalStorageDirectory(), "user_icon.jpg"); //請求識別碼(分別為本地相冊、相機、圖片裁剪) private static final int CODE_PHOTO_REQUEST = 1; private static final int CODE_CAMERA_REQUEST = 2; private static final int CODE_PHOTO_CLIP = 3; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); buttonLocal = (Button) findViewById(R.id.buttonLocal); buttonCamera = (Button) findViewById(R.id.buttonCamera); imageView = (ImageView) findViewById(R.id.imageView); buttonLocal.setOnClickListener(this); buttonCamera.setOnClickListener(this); } //設置點擊事件 @Override public void onClick(View view) { switch (view.getId()) { case R.id.buttonLocal: //調(diào)用獲取本地圖片的方法 getPicFromLocal(); break; case R.id.buttonCamera: //調(diào)用相機拍照的方法 getPicFromCamera(); break; default: break; } } /** * 從本機相冊獲取圖片 */ private void getPicFromLocal() { Intent intent = new Intent(); // 獲取本地相冊方法一 intent.setAction(Intent.ACTION_GET_CONTENT); intent.setType("image/*"); //獲取本地相冊方法二 // intent.setAction(Intent.ACTION_PICK); // intent.setDataAndType(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, // "image/*"); startActivityForResult(intent, CODE_PHOTO_REQUEST); } /** * 通過相機拍攝獲取圖片, * 并存入設置的路徑中 */ private void getPicFromCamera() { Intent intent = new Intent(); intent.setAction(MediaStore.ACTION_IMAGE_CAPTURE); // 下面這句指定調(diào)用相機拍照后的照片存儲的路徑 intent.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(USER_ICON)); startActivityForResult(intent, CODE_CAMERA_REQUEST); } /** * 圖片裁剪 * * @param uri */ private void photoClip(Uri uri) { // 調(diào)用系統(tǒng)中自帶的圖片剪裁 Intent intent = new Intent(); intent.setAction("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 是裁剪圖片寬高 *這里僅僅是頭像展示,不建議將值設置過高 * 否則超過binder機制的緩存大小的1M限制 * 報TransactionTooLargeException */ intent.putExtra("outputX", 150); intent.putExtra("outputY", 150); intent.putExtra("return-data", true); startActivityForResult(intent, CODE_PHOTO_CLIP); } /** * 提取保存裁剪之后的圖片數(shù)據(jù),并設置頭像部分的View */ private void setImageToHeadView(Intent intent) { Bundle extras = intent.getExtras(); if (extras != null) { Bitmap photo = extras.getParcelable("data"); imageView.setImageBitmap(photo); } } @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { // 用戶沒有進行有效的設置操作,返回 if (resultCode == RESULT_CANCELED) { Toast.makeText(MainActivity.this, "取消", Toast.LENGTH_LONG).show(); return; } switch (requestCode) { case CODE_CAMERA_REQUEST: if (USER_ICON.exists()) { photoClip(Uri.fromFile(USER_ICON)); } break; case CODE_PHOTO_REQUEST: if (data != null) { photoClip(data.getData()); } break; case CODE_PHOTO_CLIP: if (data != null) { setImageToHeadView(data); } break; } super.onActivityResult(requestCode, resultCode, data); } }
這里要注意的是在裁剪圖片時,長和寬不要設置太大,否則超過binder機制的緩存大小的限制(受手機配置影響).報TransactionTooLargeException,在代碼中已經(jīng)做了詳細標注,請各位看官在實現(xiàn)的時候萬萬注意。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Android RecyclerView的Item自定義動畫及DefaultItemAnimator源碼分析
這篇文章主要介紹了Android RecyclerView的Item自定義動畫及DefaultItemAnimator源碼,感興趣的小伙伴們可以參考一下2016-07-07Android 照片選擇區(qū)域功能實現(xiàn)示例
這篇文章主要介紹了Android 照片選擇區(qū)域功能實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-04-04Android啟動頁優(yōu)化之實現(xiàn)應用秒開
現(xiàn)在很多應用都會在進入主界面之前,添加一個啟動頁,然后加入幾秒鐘的廣告,我覺得這個不能算是 “真正意義上的 “ 啟動頁,應該叫廣告頁。2021-05-05Android如何實現(xiàn)一個DocumentProvider示例詳解
這篇文章主要為大家介紹了Android如何實現(xiàn)一個DocumentProvider示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12Android學習教程之下拉刷新實現(xiàn)代碼(11)
這篇文章主要為大家詳細介紹了Android學習教程之下拉刷新實現(xiàn)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-11-11Android 圖片切換器(dp、sp、px) 的單位轉(zhuǎn)換器
這篇文章主要介紹了Android 圖片切換器(dp、sp、px) 的單位轉(zhuǎn)換器的相關資料,需要的朋友可以參考下2017-03-03