Android 相機 拍照 後 無法 返回 照片 問題 – 人生 碎碎念 – Medio

原本 使用 以下 código 都 還 可以 正常

val intent = Intent(MediaStore.ACTION_IMAGE_CAPTURE)
startActivityForResult(intent, REQUEST_IMAGE_CAPTURE)

升級 手機 系統 Android Q 最新 版 後 卻 無法 正常 取 的 Uri , 只會 得到 一張 縮圖

然後 也 有 發現 拍照 後 相簿 不會 出現 照片

翻看 一 推 文件 和 測試 之後 , 得到 結論

  1. cameraX 和 camera2 是 自 訂 相機 用
  2. 只能 使用 內部 空間 來 存放 檔案 (自己 測試 結果 , 外部 照片 都 失敗)

測試 成功 是 參照 google 以下 網址 的 作法

有 變更 的 部分 為 FileProvider 的 設定

val photoURI: Uri = FileProvider.getUriForFile(
this,
"com.example.android.fileprovider",
it
)

下方 這 一個 設定 要 變更 成 自己 專案 Identificación

com.example.android.fileprovider

AndroidManifest.xml 的 autoridad 設定 也要 變更

<provider
android:name="androidx.core.content.FileProvider"
android:authorities="${applicationId}.fileprovider"
android:exported="false"
android:grantUriPermissions="true">
<meta-data
android:name="android.support.FILE_PROVIDER_PATHS"
android:resource="@xml/file_paths"></meta-data>
</provider>

然後 會 需要 在 res / xml 下 建立 file_paths , 輸入 使用 以下 內容

<?xml version="1.0" encoding="utf-8"?>
<paths xmlns:android="http://schemas.android.com/apk/res/android">
<external-files-path name="my_images" path="Android/data/com.example.package.name/files/Pictures" />
</paths>

重點 來 了 , 官方 範例 的 Ruta 不 知道 怎麼 回事 , 測試 都 不會 成功

所以 只好 依照 網路 上 的 解法 變更 成 自 訂 路徑

/uploadPostPhotoTmp

另外 在 將 creatImageFile 改寫

lateinit var currentPhotoPath: String

@Throws(IOException::class)
private fun createImageFile(): File {
// Create an image file name
val timeStamp: String = SimpleDateFormat("yyyyMMdd_HHmmss").format(Date())
val storageDir: File = getExternalFilesDir(Environment.DIRECTORY_PICTURES)
return File.createTempFile(
"JPEG_${timeStamp}_", /* prefix */
".jpg", /* suffix */
storageDir /* directory */
).apply {
// Save a file: path for use with ACTION_VIEW intents
currentPhotoPath = absolutePath
}
}

改寫 內容 為 變更 路徑 為 uploadPostPhotoTmp

val path = getExternalFilesDir(null).toString() + "/uploadPostPhotoTmp"

val storageDir: File? = File(path)

總算 可以 在 專案 內部 放置 拍照 後 的 結果 了

最終 currentPhotoPath 裡面 就 可以 拿到 ImagePath , 開心 收工

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *