欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android無(wú)需權(quán)限調(diào)起系統(tǒng)相機(jī)

 更新時(shí)間:2023年03月22日 17:07:59   作者:5944254635000  
在進(jìn)行一些小型APP的開(kāi)發(fā),或者是對(duì)拍照界面沒(méi)有自定義要求時(shí),我們可以用調(diào)起系統(tǒng)相機(jī)的方式快速完成拍照需求

在進(jìn)行一些小型APP的開(kāi)發(fā),或者是對(duì)拍照界面沒(méi)有自定義要求時(shí),我們可以用調(diào)起系統(tǒng)相機(jī)的方式快速完成拍照需求

和不需讀寫權(quán)限進(jìn)行讀寫操作的方案一樣,都是通過(guò)Intent啟動(dòng)系統(tǒng)的activity讓用戶進(jìn)行操作,系統(tǒng)再將用戶操作的結(jié)果告訴我們,因?yàn)檫^(guò)程對(duì)APP是完全透明的,所以不會(huì)侵犯用戶隱私。

有兩種方法可以調(diào)起系統(tǒng)相機(jī)拍照獲取圖片,我們先講比較簡(jiǎn)單的一種

1、直接獲取用戶拍照結(jié)果

val launcher = registerForActivityResult(ActivityResultContracts.TakePicturePreview()) {bitmap->
    bitmap ?: return@registerForActivityResult
    vm.process(bitmap)
}

launcher.launch("image/*")

這個(gè)在舊版本的API中就等于

startActivityForResult(Intent(MediaStore.ACTION_IMAGE_CAPTURE),CODE)

等到用戶完成拍照,返回我們的activity時(shí),我們就可以得到一張經(jīng)過(guò)壓縮的bitmap。這個(gè)方法很簡(jiǎn)單,它的缺點(diǎn)就是獲得的bitmap像素太低了,如果對(duì)圖片像素有要求的話需要使用第二種方法

2、用戶拍照之后指定相機(jī)將未壓縮的圖片存放到我們指定的目錄

var uri: Uri? = null

val launcher =
  registerForActivityResult(ActivityResultContracts.TakePicture()) {
      if(it){
          uri?.let { it1 -> vm.process(it1) }
      }
  }
  
val picture = File(externalCacheDir?.path, "picture")
picture.mkdirs()
uri = FileProvider.getUriForFile(
  this,
  "${BuildConfig.APPLICATION_ID}.fileprovider",
  File(picture, "cache")
)
launcher.launch(uri)

這里我逐行進(jìn)行解釋:

  • 首先,我們需要指定拍攝的照片要存到哪,所以我們先指定圖片的存放路徑為externalCacheDir.path/picture/cache 注意這張圖片在文件系統(tǒng)中的名字就叫做cache了(沒(méi)有文件后綴)。
  • 然后我們通過(guò)FileProvider構(gòu)建一個(gè)有授權(quán)的Uri給系統(tǒng)相機(jī),相機(jī)程序拿到我們的臨時(shí)授權(quán),才有權(quán)限將文件存放到APP的私有目錄。
  • 系統(tǒng)相機(jī)拍照完成之后就會(huì)走到回調(diào),如果resultCode為RESULT_OK才說(shuō)明用戶成功拍照并保存圖片了。這樣我們就能得到一張系統(tǒng)相機(jī)拍出來(lái)的原圖的Uri,這樣我們就可以用這張圖片去處理業(yè)務(wù)了。

注意:使用方法二需要用到FileProvider,所以我們還要在AndroidManifest里聲明

<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/provider_paths" />
</provider>

@xml/provider_paths是我們授權(quán)訪問(wèn)的文件路徑,這里我寫的是

<paths xmlns:android="http://schemas.android.com/apk/res/android">
  <external-path name="external_files" path="."/>
</paths>

關(guān)于這個(gè)"path.xml",其實(shí)還有一些可以補(bǔ)充說(shuō)明的,后面有空會(huì)補(bǔ)上,這里我簡(jiǎn)單說(shuō)明一下:

因?yàn)槲覀儎?chuàng)建臨時(shí)文件的時(shí)候,文件指定的目錄是externalCacheDir?.path,對(duì)應(yīng)的path就是external-cache-path,表示我們要臨時(shí)授權(quán)的目錄是externalCacheDir,如果文件目錄指定的是其他路徑,那path節(jié)點(diǎn)也需要改成代表對(duì)應(yīng)文件夾的節(jié)點(diǎn),這樣其他應(yīng)用才能訪問(wèn)到我們APP的私有目錄

到此這篇關(guān)于Android無(wú)需權(quán)限調(diào)起系統(tǒng)相機(jī)的文章就介紹到這了,更多相關(guān)Android無(wú)需權(quán)限調(diào)起系統(tǒng)相機(jī)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論