編輯:關於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;
}
}
}
Android開發學習筆記 淺談WebView
第一種方法的步驟:1.在要Activity中實例化WebView組件:WebView webView = new WebView(this);2.調用WebView的lo
超實用的Android手勢鎖制作實例教程
今天偶遇以github上gesturelock關於手勢鎖的一個例子(有興趣的去搜索下看看),於是下載下來研究,無奈基本沒有注釋,代碼上存在一些問題(當設置gravity=
Android實戰教程 Chronometer實現倒計時
Android提供了實現按照秒計時的API,今天就是用這個API實現簡單的倒計時。來個布局: 對應活動中的代碼如下: pa
三方分享長圖、大圖
這是第一次寫博文,只是想找個地方積累一下自己覺得有用的,以後再次遇見這些問題的時候就可以更快的解決。描述一下這個問題的背景,一個日志,有文字和很多張圖片,以Recycle