1.前言
本文介紹兼容AndroidQ的“Bitmap插入相冊”方案买羞。
以前的發(fā)送廣播方式已失效沐兵,并且insertImage(ContentResolver cr, Bitmap source, String title, String description)也已被廢棄著蟹。
因此需要使用新的插入相冊實現(xiàn)方式杖虾。并針對AndroidQ進行版本適配流昏。
2. “Bitmap插入相冊”具體實現(xiàn):
這里有一個需要注意的地方:put(MediaStore.Images.Media.IS_PENDING, 1)冀偶。這個設(shè)置是做耗時操作時,需要獨占資源花沉。但是使用結(jié)束后柳爽,務(wù)必注意解除獨占媳握。
/**
* 保存Bitmap到相冊
*/
fun insertBitmap(
context: Context,
picBitmap: Bitmap,
picName: String,
mimeType: String
): Boolean {
val contentValues = ContentValues().apply {
this.put(MediaStore.MediaColumns.DISPLAY_NAME, picName)
this.put(MediaStore.MediaColumns.MIME_TYPE, mimeType)
val imageTime = System.currentTimeMillis()
this.put(MediaStore.MediaColumns.DATE_ADDED, imageTime / 1000)
this.put(MediaStore.MediaColumns.DATE_MODIFIED, imageTime / 1000)
// 判斷是否android10 以上
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {
// 設(shè)置相對路徑(自動創(chuàng)建文件夾)
val folder = context.resources.getString(R.string.app_name)
val relativeName =
Environment.DIRECTORY_PICTURES + File.separator + folder + File.separator
this.put(MediaStore.MediaColumns.RELATIVE_PATH, relativeName)
// 設(shè)置獨占鎖:耗時操作,獨占訪問權(quán)限磷脯,完成操作需復(fù)位
this.put(MediaStore.Images.Media.IS_PENDING, 1)
}
}
val resolver: ContentResolver = context.contentResolver
resolver.insert(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, contentValues)?.also { uri ->
try {
// First, write the actual data for our screenshot
resolver.openOutputStream(uri).use { out ->
if (!picBitmap.compress(Bitmap.CompressFormat.PNG, 100, out)) {
throw IOException("Failed to compress")
}
}
//判斷是否android10 以上
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {
// 復(fù)位(解除)獨占權(quán)限
contentValues.clear()
contentValues.put(MediaStore.Audio.Media.IS_PENDING, 0)
resolver.update(uri, contentValues, null, null)
}
} catch (e: IOException) {
// resolver.delete(uri, null)
Log.e(TAG, Log.getStackTraceString(e))
return false
}
}
return true
}
相關(guān)文檔:
參考文檔:
官方文檔地址:[https://developer.android.google.cn/training/data-storage/shared/media#add-item]