溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android工具類ImgUtil選擇相機和系統(tǒng)相冊的示例分析

發(fā)布時間:2021-09-10 13:52:58 來源:億速云 閱讀:107 作者:小新 欄目:移動開發(fā)

這篇文章主要為大家展示了“Android工具類ImgUtil選擇相機和系統(tǒng)相冊的示例分析”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“Android工具類ImgUtil選擇相機和系統(tǒng)相冊的示例分析”這篇文章吧。

具體內(nèi)容如下

說明:

Android選擇相機和系統(tǒng)相冊

代碼:

1、打開系統(tǒng)相機和系統(tǒng)相冊工具類

package com.gxjl.pe.gxjlpesdk.util;
 
import android.Manifest;
import android.app.Activity;
import android.app.ActivityManager;
import android.app.AlertDialog;
import android.content.Context;
import android.content.DialogInterface;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.graphics.Bitmap;
import android.net.Uri;
import android.os.Build;
import android.provider.MediaStore;
import android.support.v4.app.ActivityCompat;
import android.support.v4.content.ContextCompat;
import android.support.v4.content.FileProvider;
import android.widget.Toast;
 
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
 
/**
 * 圖片工具類
 * Created by xiaoshuai on 2018/8/17.
 */
 
public class ImgUtil {
 public static final int TAKE_PHOTO = 1;//拍照
 public static final int CHOOSE_PHOTO = 2;//選擇相冊
 public static final int REQUEST_CODE_CAMERA = 3;//相機權限請求
 public static final int REQUEST_CODE_ALBUM = 4;//相冊權限請求
 public static Uri imageUri;//相機拍照圖片保存地址
 
 /**
  * 選擇圖片,從圖庫、相機
  *
  * @param activity 上下文
  */
 public static void choicePhoto(final Activity activity) {
  //采用的是系統(tǒng)Dialog作為選擇彈框
  new AlertDialog.Builder(activity).setTitle("上傳頭像")//設置對話框標題
    .setPositiveButton("拍照", new DialogInterface.OnClickListener() {//添加確定按鈕
     @Override
     public void onClick(DialogInterface dialog, int which) {
      if (Build.VERSION.SDK_INT >= 23) {//檢查相機權限
       ArrayList<String> permissions = new ArrayList<>();
       if (activity.checkSelfPermission(Manifest.permission.CAMERA) != PackageManager.PERMISSION_GRANTED) {
        permissions.add(Manifest.permission.CAMERA);
       }
 
       if (permissions.size() == 0) {//有權限,跳轉(zhuǎn)
        //打開相機-兼容7.0
        openCamera(activity);
       } else {
        activity.requestPermissions(permissions.toArray(new String[permissions.size()]), REQUEST_CODE_CAMERA);
       }
      } else {
       //打開相機-兼容7.0
       openCamera(activity);
      }
     }
    }).
    setNegativeButton("系統(tǒng)相冊", new DialogInterface.OnClickListener() {
     @Override
     public void onClick(DialogInterface dialog, int which) {
      //如果有權限申請,請在Activity中onRequestPermissionsResult權限返回里面重新調(diào)用openAlbum()
      if (ContextCompat.checkSelfPermission(activity, Manifest.permission.WRITE_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) {
       ActivityCompat.requestPermissions(activity, new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE}, REQUEST_CODE_ALBUM);
      } else {
       openAlbum(activity);
      }
     }
    }).show();//在按鍵響應事件中顯示此對話框
 }
 
 /**
  * 打開相機
  * 兼容7.0
  *
  * @param activity
  */
 public static void openCamera(Activity activity) {
  // 創(chuàng)建File對象,用于存儲拍照后的圖片
  File outputImage = new File(activity.getExternalCacheDir(), "output_image.jpg");
  try {
   if (outputImage.exists()) {
    outputImage.delete();
   }
   outputImage.createNewFile();
  } catch (IOException e) {
   e.printStackTrace();
  }
  if (Build.VERSION.SDK_INT < 24) {
   imageUri = Uri.fromFile(outputImage);
  } else {
   //Android 7.0系統(tǒng)開始 使用本地真實的Uri路徑不安全,使用FileProvider封裝共享Uri
   //參數(shù)二:fileprovider絕對路徑 com.dyb.testcamerademo:項目包名
   imageUri = FileProvider.getUriForFile(activity, "com.mandaotech.ewallet.fileprovider", outputImage);
  }
  // 啟動相機程序
  Intent intent = new Intent("android.media.action.IMAGE_CAPTURE");
  intent.putExtra(MediaStore.EXTRA_OUTPUT, imageUri);
  activity.startActivityForResult(intent, TAKE_PHOTO);
 }
 
 /**
  * 打開圖庫
  * @param activity
  */
 public static void openAlbum(Activity activity) {
  //調(diào)用系統(tǒng)圖庫的意圖
  Intent choosePicIntent = new Intent(Intent.ACTION_PICK, null);
  choosePicIntent.setDataAndType(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, "image/*");
  activity.startActivityForResult(choosePicIntent, CHOOSE_PHOTO);
 
  //打開系統(tǒng)默認的軟件
  //Intent intent = new Intent("android.intent.action.GET_CONTENT");
  //intent.setType("image/*");
  //activity.startActivityForResult(intent, CHOOSE_PHOTO); // 打開相冊
 }
 
 /**
  * 得到byte[]
  * 這里對傳入的圖片Uri壓縮到1M以內(nèi),并轉(zhuǎn)換為byte[]后返回
  *
  * @param activity 上下文
  * @param uri  傳入圖片的Uri
  * @return byte[]
  */
 public static byte[] getImgByteFromUri(Activity activity, Uri uri) throws IOException {
  Bitmap bitmap = MediaStore.Images.Media.getBitmap(activity.getContentResolver(), uri);
  ByteArrayOutputStream out = new ByteArrayOutputStream();
  bitmap.compress(Bitmap.CompressFormat.PNG, 100, out);//100表示不壓縮,直接放到out里面
  int options = 90;//壓縮比例
  while (out.toByteArray().length / 1024 > 200) { // 循環(huán)判斷如果壓縮后圖片是否大于100kb,大于繼續(xù)壓縮
   out.reset(); // 重置baos即清空baos
   bitmap.compress(Bitmap.CompressFormat.JPEG, options, out);// 這里壓縮options%,把壓縮后的數(shù)據(jù)存放到baos中
   options -= 10;// 每次都減少10
  }
  byte[] bs = out.toByteArray();
 
  return bs;
 }
 
}

相機選擇:采用固定地址選擇大圖方式,上段代碼塊是適配7.0的,因為Android 7.0系統(tǒng)開始 使用本地真實的Uri路徑不安全,使用FileProvider封裝共享Uri。其中android:name、exported、 android:grantUriPermissions、取值固定,android:authorities取值為:“自己項目包名”.fileprovider。

2、申請權限確認

工具類中點擊申請權限,可以在Activity中檢測用戶是否同意了權限

@Override
 public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {
  switch (requestCode) {
   case REQUEST_CODE_ALBUM://相冊存儲權限
    if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
     ImgUtil.openAlbum(this);
    } else {
     UiUtil.showToast(this, "選擇圖庫需要同意權限");
    }
    break;
   case REQUEST_CODE_CAMERA://相機拍照權限
    if (grantResults[0] == PackageManager.PERMISSION_GRANTED) {//允許
     ImgUtil.openCamera(OcrHandReviewActivity.this);
    } else {//拒絕
     UiUtil.showToast(this, "只有同意相機權限,才能使用掃碼功能");
    }
    break;
   default:
  }
 }

3、相機和相冊放回

在activity中得到拍照和選擇的圖片

//相機、相冊、剪切 返回
 @Override
 public void onActivityResult(int requestCode, int resultCode, Intent data) {
 
  //正確返回
  if (resultCode == RESULT_OK) {
   switch (requestCode) {
    case ImgUtil.TAKE_PHOTO://相機返回
     Log.e("返回相機", ImgUtil.imageUri.toString());
  
  GlideApp.with(ElecIdPAActivity.this)
        .load(ImgUtil.imageUri)
        .skipMemoryCache(true)
        .diskCacheStrategy( DiskCacheStrategy.NONE )
        .into(iv_zhengmain_photo);
     break;
    case ImgUtil.CHOOSE_PHOTO://相冊返回
     try {
      if (data != null) {
       //相冊返回
       Uri uri = data.getData();
       Log.e("返回相冊", uri.toString());
  
  GlideApp.with(ElecIdPAActivity.this)
   .load(uri)
   .skipMemoryCache(true)
   .diskCacheStrategy( DiskCacheStrategy.NONE )
   .into(iv_zhengmain_photo);
      }
     } catch (Exception e) {
      e.printStackTrace();
      UiUtil.showToast(this, "圖片選擇失敗");
     }
     break;
   }
  } else {
   UiUtil.showToast(this, "圖片選擇失敗");
  }
 }

4、AndroidManifest.xml權限聲明

<!--獲取sd卡寫的權限,用于文件上傳和下載-->
 <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
 <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
 <!--允許讀取手機狀態(tài)-->
 <uses-permission android:name="android.permission.READ_PHONE_STATE"/>
 <!-- 相機權限 -->
 <uses-permission android:name="android.permission.CAMERA"/>
 <uses-permission android:name="android.permission.VIBRATE"/>
 <uses-permission android:name="android.permission.FLASHLIGHT"/>
 
<application
 
 <!--7.0相機權限-->
  <provider
   android:name="android.support.v4.content.FileProvider"
   android:authorities="com.dyb.testcamerademo.fileprovider"
   android:exported="false"
   android:grantUriPermissions="true">
   <meta-data
    android:name="android.support.FILE_PROVIDER_PATHS"
    android:resource="@xml/file_paths"/>
  </provider>

5、file_paths.xml

android:resource=“@xml/file_paths”中@xml/的文件名字可以隨便起,但一般規(guī)范化都用此名。
xml包下(在res下面新建包xml,然后在xml下面新建file_paths.xml文件)

* file_paths.xml源碼

<?xml version="1.0" encoding="utf-8"?>
<paths xmlns:android="http://schemas.android.com/apk/res/android">
 
 <!--
 name屬性的值可以隨便寫,別名
 path屬性的值表示共享的具體位置,設置空就表示將整個SD卡進行共享
  -->
 <paths>
  <external-path
   name="camera_photos"
   path=""/>
 </paths>
</paths>

以上是“Android工具類ImgUtil選擇相機和系統(tǒng)相冊的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI