好的,是时候偿还了。
所以你在清单上有你的权限。
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-feature android:name="android.hardware.camera" android:required="true" />
<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
而且您还有提供者元数据。
<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>
一个遗漏的细节是(android:authorities applicationId),您需要添加自己的应用程序包名称。
因此,在我们在manifest中提到的
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="Pictures" />
</paths>
我们已经完成了复制粘贴的第一部分。现在在我们上面的活动
onCreate(savedInstanceState: Bundle?)
中定义这些美丽的内容。
val REQUEST_IMAGE_CAPTURE = 1
lateinit var currentPhotoPath: String
var cameraIntent = Intent(MediaStore.ACTION_IMAGE_CAPTURE)
您可能想查看原始资源,但通常会缺少细节,Android开发人员:
link
另一个缺失的细节是
packageName + ".fileprovider"
,如果您已经有方法,请注意需要提供自己的包名称。
private fun dispatchTakePictureIntent() {
Intent(MediaStore.ACTION_IMAGE_CAPTURE).also { takePictureIntent ->
takePictureIntent.resolveActivity(packageManager)?.also {
val photoFile: File? = try {
createImageFile()
} catch (ex: IOException) {
ex.message
null
}
photoFile?.also {
val photoURI: Uri = FileProvider.getUriForFile(
this,
packageName + ".fileprovider",
it
)
takePictureIntent.putExtra(MediaStore.EXTRA_OUTPUT, photoURI)
startActivityForResult(takePictureIntent, REQUEST_IMAGE_CAPTURE)
}
}
}
}
createImageFile
函数
@Throws(IOException::class)
private fun createImageFile(): File {
val timeStamp: String = SimpleDateFormat("yyyyMMdd_HHmmss").format(Date())
val storageDir: File = this!!.getExternalFilesDir(Environment.DIRECTORY_PICTURES)!!
return File.createTempFile(
"JPEG_${timeStamp}_",
".jpg",
storageDir
).apply {
currentPhotoPath = absolutePath
}
}
测试。
使用onClick事件调用您的dispatchTakePictureIntent()
方法,确保权限已被允许。
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (resultCode == Activity.RESULT_OK && requestCode == REQUEST_IMAGE_CAPTURE) {
var mBitmap_org = MediaStore.Images.Media.getBitmap(
this.getContentResolver(),
Uri.fromFile(File(currentPhotoPath))
);
}
}
请勿检查数据,我们将通过imagePath获取数据。如果您正在检查
Uri.parse(currentPhotoPath)
,请确保它是
Uri.fromFile(File(currentPhotoPath))
。
现在您已经拥有了位图,可以花费其他几个小时/天来调整大小、解码和保存。
还有一种保存tokken图片的方法,也许您可以帮我看看应该把它放在哪里,如果我需要将tokken图片保存在相册中。
private fun galleryAddPic() {
Intent(Intent.ACTION_MEDIA_SCANNER_SCAN_FILE).also { mediaScanIntent ->
val f = File(currentPhotoPath)
mediaScanIntent.data = Uri.fromFile(f)
sendBroadcast(mediaScanIntent)
}
}
intent.putExtra(MediaStore.EXTRA_OUTPUT, mImageUri);
,请参考 http://developer.android.com/reference/android/provider/MediaStore.html#ACTION_IMAGE_CAPTURE 以获得关于此行为的难以捉摸的文档说明。 - CheezmeisterEnvironment.getExternalStorageDirectory()+"/.temp/"
。 - Barmaley