編輯:關於Android編程
【Android設置頭像,手機拍照或從本地相冊選取圖片作為頭像】
像微信、QQ、微博等社交類的APP,通常都有設置頭像的功能,設置頭像通常有兩種方式:
1,讓用戶通過選擇本地相冊之類的圖片庫中已有的圖像,裁剪後作為頭像。
2,讓用戶啟動手機的相機拍照,拍完照片後裁剪,然後作為頭像。
我現在寫一個簡單的完整代碼例子,說明如何在Android中實現上述兩個頭像設置功能。
MainActivity.java文件:
package zhangpgil.photo; import java.io.File; import android.support.v7.app.ActionBarActivity; import android.view.View; import android.widget.Button; import android.widget.ImageView; import android.widget.Toast; import android.content.Intent; import android.graphics.Bitmap; import android.net.Uri; import android.os.Bundle; import android.os.Environment; import android.provider.MediaStore; public class MainActivity extends ActionBarActivity { /* 頭像文件 */ private static final String IMAGE_FILE_NAME = temp_head_image.jpg; /* 請求識別碼 */ private static final int CODE_GALLERY_REQUEST = 0xa0; private static final int CODE_CAMERA_REQUEST = 0xa1; private static final int CODE_RESULT_REQUEST = 0xa2; // 裁剪後圖片的寬(X)和高(Y),480 X 480的正方形。 private static int output_X = 480; private static int output_Y = 480; private ImageView headImage = null; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); headImage = (ImageView) findViewById(R.id.imageView); Button buttonLocal = (Button) findViewById(R.id.buttonLocal); buttonLocal.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { choseHeadImageFromGallery(); } }); Button buttonCamera = (Button) findViewById(R.id.buttonCamera); buttonCamera.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { choseHeadImageFromCameraCapture(); } }); } // 從本地相冊選取圖片作為頭像 private void choseHeadImageFromGallery() { Intent intentFromGallery = new Intent(); // 設置文件類型 intentFromGallery.setType(image/*); intentFromGallery.setAction(Intent.ACTION_GET_CONTENT); startActivityForResult(intentFromGallery, CODE_GALLERY_REQUEST); } // 啟動手機相機拍攝照片作為頭像 private void choseHeadImageFromCameraCapture() { Intent intentFromCapture = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); // 判斷存儲卡是否可用,存儲照片文件 if (hasSdcard()) { intentFromCapture.putExtra(MediaStore.EXTRA_OUTPUT, Uri .fromFile(new File(Environment .getExternalStorageDirectory(), IMAGE_FILE_NAME))); } startActivityForResult(intentFromCapture, CODE_CAMERA_REQUEST); } @Override protected void onActivityResult(int requestCode, int resultCode, Intent intent) { // 用戶沒有進行有效的設置操作,返回 if (resultCode == RESULT_CANCELED) { Toast.makeText(getApplication(), 取消, Toast.LENGTH_LONG).show(); return; } switch (requestCode) { case CODE_GALLERY_REQUEST: cropRawPhoto(intent.getData()); break; case CODE_CAMERA_REQUEST: if (hasSdcard()) { File tempFile = new File( Environment.getExternalStorageDirectory(), IMAGE_FILE_NAME); cropRawPhoto(Uri.fromFile(tempFile)); } else { Toast.makeText(getApplication(), 沒有SDCard!, Toast.LENGTH_LONG) .show(); } break; case CODE_RESULT_REQUEST: if (intent != null) { setImageToHeadView(intent); } break; } super.onActivityResult(requestCode, resultCode, intent); } /** * 裁剪原始的圖片 */ public void cropRawPhoto(Uri uri) { Intent intent = new Intent(com.android.camera.action.CROP); intent.setDataAndType(uri, image/*); // 設置裁剪 intent.putExtra(crop, true); // aspectX , aspectY :寬高的比例 intent.putExtra(aspectX, 1); intent.putExtra(aspectY, 1); // outputX , outputY : 裁剪圖片寬高 intent.putExtra(outputX, output_X); intent.putExtra(outputY, output_Y); intent.putExtra(return-data, true); startActivityForResult(intent, CODE_RESULT_REQUEST); } /** * 提取保存裁剪之後的圖片數據,並設置頭像部分的View */ private void setImageToHeadView(Intent intent) { Bundle extras = intent.getExtras(); if (extras != null) { Bitmap photo = extras.getParcelable(data); headImage.setImageBitmap(photo); } } /** * 檢查設備是否存在SDCard的工具方法 */ public static boolean hasSdcard() { String state = Environment.getExternalStorageState(); if (state.equals(Environment.MEDIA_MOUNTED)) { // 有存儲的SDCard return true; } else { return false; } } }
第一種方法的步驟:1.在要Activity中實例化WebView組件:WebView webView = new WebView(this);2.調用WebView的lo
今天偶遇以github上gesturelock關於手勢鎖的一個例子(有興趣的去搜索下看看),於是下載下來研究,無奈基本沒有注釋,代碼上存在一些問題(當設置gravity=
Android提供了實現按照秒計時的API,今天就是用這個API實現簡單的倒計時。來個布局: 對應活動中的代碼如下: pa
這是第一次寫博文,只是想找個地方積累一下自己覺得有用的,以後再次遇見這些問題的時候就可以更快的解決。描述一下這個問題的背景,一個日志,有文字和很多張圖片,以Recycle