1、通过intent打开gallery
val galleryIntent = Intent(Intent.ACTION_PICK,MediaStore.Images.Media.EXTERNAL_CONTENT_URI)
startActivityForResult(galleryIntent, GALLERY)
2、接收返回的数据
if(resultCode == Activity.RESULT_OK){
if(requestCode == GALLERY){
data?.data?.let {
val selectedPhotoUri = data.data
mBinding.ivDishImage.setImageURI(selectedPhotoUri)
mBinding.ivAddDishImage.setImageDrawable(ContextCompat.getDrawable(this,R.drawable.ic_vector_edit))
}
}
}
3、没有选择任何图片之前的界面:
从gallery选择图片:
选择图片:
选择图片之后显示在界面:
注:
activity的代码:
package com.example.mykotlin1
import android.Manifest
import android.app.Activity
import android.app.AlertDialog
import android.app.Dialog
import android.content.ActivityNotFoundException
import android.content.Intent
import android.graphics.Bitmap
import android.net.Uri
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.provider.MediaStore
import android.provider.Settings
import android.util.Log
import android.view.View
import android.widget.Toast
import androidx.core.content.ContextCompat
import com.example.mykotlin1.databinding.ActivityAddUpdateDishBinding
import com.example.mykotlin1.databinding.DialogCustomImageSelectionBinding
import com.karumi.dexter.Dexter
import com.karumi.dexter.MultiplePermissionsReport
import com.karumi.dexter.PermissionToken
import com.karumi.dexter.listener.PermissionDeniedResponse
import com.karumi.dexter.listener.PermissionGrantedResponse
import com.karumi.dexter.listener.PermissionRequest
import com.karumi.dexter.listener.multi.MultiplePermissionsListener
import com.karumi.dexter.listener.single.PermissionListener
class AddUpdateDishActivity : AppCompatActivity(), View.OnClickListener {
private lateinit var mBinding : ActivityAddUpdateDishBinding
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
mBinding = ActivityAddUpdateDishBinding.inflate(layoutInflater)
setContentView(mBinding.root)
mBinding.ivAddDishImage.setOnClickListener(this)
mBinding.svContainer.setHorizontalFadingEdgeEnabled(false)
//setupActionBar()
}
private fun setupActionBar(){
val toobar = mBinding.toolbarAddDishActivity
// Log.i("AddUpdateDishActivity",toobar.isEmpty()+"")
setSupportActionBar(mBinding.toolbarAddDishActivity)
supportActionBar?.setDisplayHomeAsUpEnabled(true)
mBinding.toolbarAddDishActivity.setNavigationOnClickListener {
onBackPressed()
}
}
override fun onClick(v: View?) {
when(v!!.id){
R.id.iv_add_dish_image ->{
customImageSelectionDialog()
return;
}
}
}
private fun customImageSelectionDialog(){
val dialog = Dialog(this);
val binding : DialogCustomImageSelectionBinding = DialogCustomImageSelectionBinding.inflate(layoutInflater)
dialog.setContentView(binding.root)
binding.tvCamera.setOnClickListener {
Dexter.withContext(this).withPermissions(
Manifest.permission.READ_EXTERNAL_STORAGE,
//Manifest.permission.WRITE_EXTERNAL_STORAGE,
Manifest.permission.CAMERA
).withListener(object : MultiplePermissionsListener {
override fun onPermissionsChecked(report : MultiplePermissionsReport?) {
report?.let {
if(report!!.areAllPermissionsGranted()){
val intent = Intent(MediaStore.ACTION_IMAGE_CAPTURE)
startActivityForResult(intent,CAMERA)
}
}
}
override fun onPermissionRationaleShouldBeShown(
permissions: MutableList<PermissionRequest>?,
token: PermissionToken?
) {
showRationalDialogForPermissions()
}
}).onSameThread().check()
dialog.dismiss()
}
binding.tvGallery.setOnClickListener {
Dexter.withContext(this@AddUpdateDishActivity)
.withPermission(
Manifest.permission.READ_EXTERNAL_STORAGE,
).withListener(object : PermissionListener {
override fun onPermissionGranted(p0: PermissionGrantedResponse?) {
val galleryIntent = Intent(Intent.ACTION_PICK,MediaStore.Images.Media.EXTERNAL_CONTENT_URI)
startActivityForResult(galleryIntent, GALLERY)
}
override fun onPermissionDenied(p0: PermissionDeniedResponse?) {
Toast.makeText(this@AddUpdateDishActivity,"You have denied to storage permission to select image",Toast.LENGTH_SHORT).show()
}
override fun onPermissionRationaleShouldBeShown(
p0: PermissionRequest?,
p1: PermissionToken?
) {
showRationalDialogForPermissions()
}
}).onSameThread().check()
dialog.dismiss()
}
dialog.show()
}
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
super.onActivityResult(requestCode, resultCode, data)
if(resultCode == Activity.RESULT_OK){
if(requestCode == CAMERA){
data?.extras?.let {
val thumbnail : Bitmap = data.extras!!.get("data") as Bitmap
mBinding.ivDishImage.setImageBitmap(thumbnail)
mBinding.ivAddDishImage.setImageDrawable(ContextCompat.getDrawable(this,R.drawable.ic_vector_edit))
}
}
if(requestCode == GALLERY){
data?.data?.let {
val selectedPhotoUri = data.data
mBinding.ivDishImage.setImageURI(selectedPhotoUri)
//mBinding.ivAddDishImage.setImageDrawable(ContextCompat.getDrawable(this,R.drawable.ic_vector_edit))
}
}
}else if( resultCode == Activity.RESULT_CANCELED){
Log.e("cancelled","User canceled selection")
}
}
private fun showRationalDialogForPermissions(){
AlertDialog.Builder(this).setMessage("It looks like you have turned off permissions " +
"required for this feature.It can be enabled under Application Settings")
.setPositiveButton("GO TO SETTINGS")
{_,_ ->
try{
val intent = Intent(Settings.ACTION_APPLICATION_DETAILS_SETTINGS)
val uri = Uri.fromParts("package",packageName,null)
intent.data = uri
startActivity(intent)
}catch (e : ActivityNotFoundException){
e.printStackTrace()
}
}.setNegativeButton("Cancel"){dialog,_->
dialog.dismiss()
}.show()
}
companion object{
private const val CAMERA = 1
private const val GALLERY = 2
}
}