1、拍照
/**
* 處理拍照錄音 視頻的點擊事件
*
* @author 00
*/
class MyOnClickLitener implements OnClickListener {
@Override
public void onClick(View v) {
//申明意圖對象
Intent intent = null;
//申明文件要保存的位置
File dir = null;
switch (v.getId()) {
case R.id.id_btn_take_photo:
//初始化文件保存位置的對象
dir = new File(SDCardUtils.getRootDirectory()+ "/gdmsaec/picture/");
if (!dir.exists()) {
//如果文件夾不存在 則創建
dir.mkdirs();
}
//創建要保存的文件
photoFile = new File(dir.getAbsolutePath(), "IMG_"+ DateFormatUtils.getPVAFormatDate() + ".jpg");
// 打開系統相機
intent = new Intent();
//此句代碼 代表拍照成功之後 直接保存拍照之後的圖片到sdcad中的文件中 這樣文件的質量是最好的 最清晰的
intent.putExtra(MediaStore.EXTRA_OUTPUT,Uri.fromFile(photoFile));
//設置打開系統相機的意圖action
intent.setAction(MediaStore.ACTION_IMAGE_CAPTURE);
//打開相機
startActivityForResult(intent, Constants.OPEN_CAMERA);
break;
case R.id.id_btn_aideo:// 錄音
intent = new Intent();
//設置打開錄音的意圖action
intent.setAction(Media.RECORD_SOUND_ACTION);
startActivityForResult(intent, Constants.OPEN_AIDEO);
break;
case R.id.id_btn_video:// 視頻
//申明視頻文件需要保存的文件夾
dir = new File(SDCardUtils.getRootDirectory()+ "/gdmsaec/video/");
if (!dir.exists()) {
dir.mkdirs();
}
intent = new Intent();
//初始化視頻文件的名字
videoFile = new File(dir.getAbsoluteFile(), "VID_"+ DateFormatUtils.getPVAFormatDate() + ".3gp");
//此句代碼 標識 視頻錄製成功後 直接保存到手機sdcrad中 以上面聲明的文件名 命名
intent.putExtra(MediaStore.EXTRA_OUTPUT,Uri.fromFile(videoFile));
//設置打開視頻錄製的action
intent.setAction(MediaStore.ACTION_VIDEO_CAPTURE);
startActivityForResult(intent, Constants.OPEN_VIDEO);
break;
case R.id.id_btn_upload:
// 打開系統相冊
intent = new Intent();
//過濾 選擇的相冊是所有類型的
intent.setType("image/*");
//設置action
intent.setAction(Intent.ACTION_GET_CONTENT);
startActivityForResult(intent, Constants.OPEN_XIANGCE);
break;
}
}
}
2、拍照 視頻 錄音 成功時候的調用的方法
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
//當用戶拍照 錄音 視頻 完成之後調用此方法
//這裏說明一下 如果之前在啓動是設置 intent.putExtra(MediaStore.EXTRA_OUTPUT,Uri.fromFile(file));那麼這裏的data是獲取不到返回的值得
super.onActivityResult(requestCode, resultCode, data);
if (resultCode == Activity.RESULT_OK) {
switch (requestCode) {
case CAMERA:
cameraPopupWindow.dismiss();
alertDialog(0,"拍照成功,是否上傳至服務器?", photoFile);
break;
case VIDEO:
cameraPopupWindow.dismiss();
alertDialog(1,"錄製成功,是否上傳至服務器?", videoFile);
break;
case AUDIO://錄音文件需要特殊處理一下
Uri audioUri = data.getData();
// String aa = Util.getPath(this, audioUri);
// File fileAudio = new File(aa);
// fileAudio.delete();
try {
AssetFileDescriptor descriptor = getContentResolver().openAssetFileDescriptor(audioUri, "r");
FileInputStream fis = descriptor.createInputStream();
File path = new File(SDCardUtils.getRootDirectory()+ "/gdmsaec/aideo/");
if (!path.exists()) {
path.mkdirs();
}
audioFile = new File(path.getAbsolutePath(), "AID_"+ DateFormatUtils.getPVAFormatDate() + ".amr");
FileOutputStream fos = new FileOutputStream(audioFile);
byte[] buffer = new byte[1024];
int len = 0;
while ((len = (fis.read(buffer))) != -1) {
fos.write(buffer, 0, len);
}
fis.close();
fos.close();
} catch (Exception e) {
//ToastUtils.showToast(mainActivity, e.getMessage());
}
cameraPopupWindow.dismiss();
alertDialog(2,"錄製成功,是否上傳至服務器?", audioFile);
break;
case XIANGCE:
cameraPopupWindow.dismiss();
Uri uri = data.getData();
String path = Util.getPath(this, uri);
photoFile = new File(path);
// Bitmap bitmap = BitmapFactory.decodeFile(path);
alertDialog(3,"照片已選中,是否上傳至服務器?", photoFile);
break;
}
}
}
3、對話框提示
/**
* 彈出是否上傳文件的對話框
*
* @param str
*/
private void alertDialog(int i , String str, final File file) {
Bitmap bitmap =null;
if(i == 0){
//拍照 獲取縮略圖
bitmap = BitmapUtils.getImageThumbnail(file.getAbsolutePath(), 200, 200);
}else if(i == 1){
//獲取視頻的縮略圖
bitmap = BitmapUtils.getVideoThumbnail(file.getAbsolutePath(), 200, 200, Thumbnails.MINI_KIND);
}
DialogUtils.showDialog2(mainActivity, "溫馨提示", bitmap, str,new DialogOnClickListenner() {
@Override
public void btnConfirmClick(Dialog dialog) {
dialog.dismiss();
uploadFile(file);
}
@Override
public void btnCancelClick(Dialog dialog) {
dialog.dismiss();
}
});
}
4、獲取縮略圖的工具類
public class BitmapUtils {
/**
* 根據指定的圖像路徑和大小來獲取縮略圖 此方法有兩點好處: 1.
* 使用較小的內存空間,第一次獲取的bitmap實際上爲null,只是爲了讀取寬度和高度,
* 第二次讀取的bitmap是根據比例壓縮過的圖像,第三次讀取的bitmap是所要的縮略圖。 2.
* 縮略圖對於原圖像來講沒有拉伸,這裏使用了2.2版本的新工具ThumbnailUtils,使 用這個工具生成的圖像不會被拉伸。
*
* @param imagePath
* 圖像的路徑
* @param width
* 指定輸出圖像的寬度
* @param height
* 指定輸出圖像的高度
* @return 生成的縮略圖
*/
public static Bitmap getImageThumbnail(String imagePath, int width,
int height) {
Bitmap bitmap = null;
BitmapFactory.Options options = new BitmapFactory.Options();
options.inJustDecodeBounds = true;
// 獲取這個圖片的寬和高,注意此處的bitmap爲null
bitmap = BitmapFactory.decodeFile(imagePath, options);
options.inJustDecodeBounds = false; // 設爲 false
// 計算縮放比
int h = options.outHeight;
int w = options.outWidth;
int beWidth = w / width;
int beHeight = h / height;
int be = 1;
if (beWidth < beHeight) {
be = beWidth;
} else {
be = beHeight;
}
if (be <= 0) {
be = 1;
}
options.inSampleSize = be;
// 重新讀入圖片,讀取縮放後的bitmap,注意這次要把options.inJustDecodeBounds 設爲 false
bitmap = BitmapFactory.decodeFile(imagePath, options);
// 利用ThumbnailUtils來創建縮略圖,這裏要指定要縮放哪個Bitmap對象
bitmap = ThumbnailUtils.extractThumbnail(bitmap, width, height,
ThumbnailUtils.OPTIONS_RECYCLE_INPUT);
return bitmap;
}
/**
* 獲取視頻的縮略圖 先通過ThumbnailUtils來創建一個視頻的縮略圖,然後再利用ThumbnailUtils來生成指定大小的縮略圖。
* 如果想要的縮略圖的寬和高都小於MICRO_KIND,則類型要使用MICRO_KIND作爲kind的值,這樣會節省內存。
*
* @param videoPath
* 視頻的路徑
* @param width
* 指定輸出視頻縮略圖的寬度
* @param height
* 指定輸出視頻縮略圖的高度度
* @param kind
* 參照MediaStore.Images.Thumbnails類中的常量MINI_KIND和MICRO_KIND。
* 其中,MINI_KIND: 512 x 384,MICRO_KIND: 96 x 96
* @return 指定大小的視頻縮略圖
*/
public static Bitmap getVideoThumbnail(String videoPath, int width, int height,
int kind) {
Bitmap bitmap = null;
// 獲取視頻的縮略圖
bitmap = ThumbnailUtils.createVideoThumbnail(videoPath, kind);
System.out.println("w" + bitmap.getWidth());
System.out.println("h" + bitmap.getHeight());
bitmap = ThumbnailUtils.extractThumbnail(bitmap, width, height,
ThumbnailUtils.OPTIONS_RECYCLE_INPUT);
return bitmap;
}
}