This repository is a demo about using Kotlin in Flutter to perform different operations and transfer the results to Flutter.
- Reading a json file with countries and their capitals and displaying the read values as a list on the Flutter side.
- Accessing the phone's gallery, having the user select an image and showing this image on the Flutter side.
- Accessing the phone's camera with permissions, having the user take a photo and showing this photo on the Flutter side.
![](https://private-user-images.githubusercontent.com/120099096/311443719-ef088960-a206-4a1e-aa78-e4f381d07fb0.png?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MzkzMzc4NzIsIm5iZiI6MTczOTMzNzU3MiwicGF0aCI6Ii8xMjAwOTkwOTYvMzExNDQzNzE5LWVmMDg4OTYwLWEyMDYtNGExZS1hYTc4LWU0ZjM4MWQwN2ZiMC5wbmc_WC1BbXotQWxnb3JpdGhtPUFXUzQtSE1BQy1TSEEyNTYmWC1BbXotQ3JlZGVudGlhbD1BS0lBVkNPRFlMU0E1M1BRSzRaQSUyRjIwMjUwMjEyJTJGdXMtZWFzdC0xJTJGczMlMkZhd3M0X3JlcXVlc3QmWC1BbXotRGF0ZT0yMDI1MDIxMlQwNTE5MzJaJlgtQW16LUV4cGlyZXM9MzAwJlgtQW16LVNpZ25hdHVyZT01YzExYjc1MDcyYWUxNWFmYjY0NTE0ZmY2MDc2NGQwMjE4ZjQ2NjVlY2ZkOGU1Zjc5MWQyN2RkZTQxODY5NGMwJlgtQW16LVNpZ25lZEhlYWRlcnM9aG9zdCJ9.p6UXQQgrj-6vT_TQtZ_SRTmg5zbMZU202EP-dRAzBeI)
![](https://private-user-images.githubusercontent.com/120099096/311443742-a1088458-eb97-4b39-8491-8333f3394e30.png?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MzkzMzc4NzIsIm5iZiI6MTczOTMzNzU3MiwicGF0aCI6Ii8xMjAwOTkwOTYvMzExNDQzNzQyLWExMDg4NDU4LWViOTctNGIzOS04NDkxLTgzMzNmMzM5NGUzMC5wbmc_WC1BbXotQWxnb3JpdGhtPUFXUzQtSE1BQy1TSEEyNTYmWC1BbXotQ3JlZGVudGlhbD1BS0lBVkNPRFlMU0E1M1BRSzRaQSUyRjIwMjUwMjEyJTJGdXMtZWFzdC0xJTJGczMlMkZhd3M0X3JlcXVlc3QmWC1BbXotRGF0ZT0yMDI1MDIxMlQwNTE5MzJaJlgtQW16LUV4cGlyZXM9MzAwJlgtQW16LVNpZ25hdHVyZT00MTBmMDNkODU5YTdiYjBlN2VkYjcxNTIzYWMxOTNjMjFiNjEzN2VkMThhYWMyMjE2MDE1YTAzZWQ4OWExZDg5JlgtQW16LVNpZ25lZEhlYWRlcnM9aG9zdCJ9.XS_L3QJpD6C6LGjekgJyNaul_9_dATqIWGWHRHlhdQo)
![](https://private-user-images.githubusercontent.com/120099096/311443760-c7098f32-9f51-4e3c-a080-5c7eeff89315.png?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MzkzMzc4NzIsIm5iZiI6MTczOTMzNzU3MiwicGF0aCI6Ii8xMjAwOTkwOTYvMzExNDQzNzYwLWM3MDk4ZjMyLTlmNTEtNGUzYy1hMDgwLTVjN2VlZmY4OTMxNS5wbmc_WC1BbXotQWxnb3JpdGhtPUFXUzQtSE1BQy1TSEEyNTYmWC1BbXotQ3JlZGVudGlhbD1BS0lBVkNPRFlMU0E1M1BRSzRaQSUyRjIwMjUwMjEyJTJGdXMtZWFzdC0xJTJGczMlMkZhd3M0X3JlcXVlc3QmWC1BbXotRGF0ZT0yMDI1MDIxMlQwNTE5MzJaJlgtQW16LUV4cGlyZXM9MzAwJlgtQW16LVNpZ25hdHVyZT0zOWY1MGM4N2VmOTE0ZGIxMWQwZWM0YjI5MDVlOWZjMjU1OGVmNzhiNDUyOTdlZDg0NTc0N2RiM2Q2YjA0MjY4JlgtQW16LVNpZ25lZEhlYWRlcnM9aG9zdCJ9.6dvCJ5-uH3VYqFcvSHBMbKtSBy-jke5hkkrsRv1aW1I)
![](https://private-user-images.githubusercontent.com/120099096/311443793-dcd053a9-9e2d-425f-bed4-e68ffe100090.png?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MzkzMzc4NzIsIm5iZiI6MTczOTMzNzU3MiwicGF0aCI6Ii8xMjAwOTkwOTYvMzExNDQzNzkzLWRjZDA1M2E5LTllMmQtNDI1Zi1iZWQ0LWU2OGZmZTEwMDA5MC5wbmc_WC1BbXotQWxnb3JpdGhtPUFXUzQtSE1BQy1TSEEyNTYmWC1BbXotQ3JlZGVudGlhbD1BS0lBVkNPRFlMU0E1M1BRSzRaQSUyRjIwMjUwMjEyJTJGdXMtZWFzdC0xJTJGczMlMkZhd3M0X3JlcXVlc3QmWC1BbXotRGF0ZT0yMDI1MDIxMlQwNTE5MzJaJlgtQW16LUV4cGlyZXM9MzAwJlgtQW16LVNpZ25hdHVyZT0xZDJiMTkzODMwZmJiYWUzZDZmNDE1Zjk1OTM4OGFlZDY5NDc1NmIxMTI5MGY3OTg2OTE3ZTg1MTAyNGNjMDI1JlgtQW16LVNpZ25lZEhlYWRlcnM9aG9zdCJ9.7jy18vjl9D_Oa_nFmMB6KSMd-XoifwbksTnaaFKhlvw)
![](https://private-user-images.githubusercontent.com/120099096/311443807-16309095-2d0a-4c73-ab81-9703aeb3c7c8.png?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MzkzMzc4NzIsIm5iZiI6MTczOTMzNzU3MiwicGF0aCI6Ii8xMjAwOTkwOTYvMzExNDQzODA3LTE2MzA5MDk1LTJkMGEtNGM3My1hYjgxLTk3MDNhZWIzYzdjOC5wbmc_WC1BbXotQWxnb3JpdGhtPUFXUzQtSE1BQy1TSEEyNTYmWC1BbXotQ3JlZGVudGlhbD1BS0lBVkNPRFlMU0E1M1BRSzRaQSUyRjIwMjUwMjEyJTJGdXMtZWFzdC0xJTJGczMlMkZhd3M0X3JlcXVlc3QmWC1BbXotRGF0ZT0yMDI1MDIxMlQwNTE5MzJaJlgtQW16LUV4cGlyZXM9MzAwJlgtQW16LVNpZ25hdHVyZT01NDE1NDQ5YjQ0M2E5OWI4M2JjZTgxNjA4MDA2ZGE4ZTdlNzkyYjAzNDE0ZWVkNTQ0MjM2Y2E4ODQ0NDE5ZjMyJlgtQW16LVNpZ25lZEhlYWRlcnM9aG9zdCJ9.t7n9bp7VoVnVFYEHTCj3TSl8Oo4NzQcHqLgAHcxUgAI)
![](https://private-user-images.githubusercontent.com/120099096/311443813-8e1d9336-dbae-476f-aa34-1c2e68734e5c.png?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MzkzMzc4NzIsIm5iZiI6MTczOTMzNzU3MiwicGF0aCI6Ii8xMjAwOTkwOTYvMzExNDQzODEzLThlMWQ5MzM2LWRiYWUtNDc2Zi1hYTM0LTFjMmU2ODczNGU1Yy5wbmc_WC1BbXotQWxnb3JpdGhtPUFXUzQtSE1BQy1TSEEyNTYmWC1BbXotQ3JlZGVudGlhbD1BS0lBVkNPRFlMU0E1M1BRSzRaQSUyRjIwMjUwMjEyJTJGdXMtZWFzdC0xJTJGczMlMkZhd3M0X3JlcXVlc3QmWC1BbXotRGF0ZT0yMDI1MDIxMlQwNTE5MzJaJlgtQW16LUV4cGlyZXM9MzAwJlgtQW16LVNpZ25hdHVyZT1lZmNjNzI5MzVjM2IzYzY2NWI2M2FmNWI2NGIwODliMzRiMjc3MGY3NWYyMjlmODJkZTk5MTEyNjc5NDgwOGEyJlgtQW16LVNpZ25lZEhlYWRlcnM9aG9zdCJ9.USsk0rBciMOpnabhLcXFfyCvYg33N5i5MEBuKfFWFBg)
![](https://private-user-images.githubusercontent.com/120099096/311443816-1c99633d-4b4f-4dc3-b55d-6ae8a27f8ae0.png?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MzkzMzc4NzIsIm5iZiI6MTczOTMzNzU3MiwicGF0aCI6Ii8xMjAwOTkwOTYvMzExNDQzODE2LTFjOTk2MzNkLTRiNGYtNGRjMy1iNTVkLTZhZThhMjdmOGFlMC5wbmc_WC1BbXotQWxnb3JpdGhtPUFXUzQtSE1BQy1TSEEyNTYmWC1BbXotQ3JlZGVudGlhbD1BS0lBVkNPRFlMU0E1M1BRSzRaQSUyRjIwMjUwMjEyJTJGdXMtZWFzdC0xJTJGczMlMkZhd3M0X3JlcXVlc3QmWC1BbXotRGF0ZT0yMDI1MDIxMlQwNTE5MzJaJlgtQW16LUV4cGlyZXM9MzAwJlgtQW16LVNpZ25hdHVyZT0zZDFkYjkxZTQwOTQ2MDUwNzNmYTFkOGI2ODAyODFlYzlmYTRiZmQ0NzBkNDI5MGE2NDMzZmFhNjcxNjU0NjMzJlgtQW16LVNpZ25lZEhlYWRlcnM9aG9zdCJ9.6oLA9LyJrs0ddC3e_LXc_ZxT87WZm2Ls9HlizuiClYs)
static const platform = MethodChannel('my_channel');
String jsonString = await platform.invokeMethod('getJsonStringOfCapitals');
var base64Result = await platform.invokeMethod('selectImageInAlbum');
var base64Result = await platform.invokeMethod('takePhoto');
class MainActivity: FlutterActivity() {
val CAMERA_REQUEST_CODE = 200
val GALLERY_REQUEST_CODE = 300
- reading the json file
if(call.method == "getJsonStringOfCapitals") {
lateinit var jsonString: String
try {
jsonString = context.assets.open("country-by-capital-city.json").bufferedReader().use { it.readText()}
result.success(jsonString)
} catch (ex: Exception) {
ex.printStackTrace()
}
}
We use result.success
to access the result on the Flutter side.
- open gallery
if(call.method == "selectImageInAlbum"){
mResult = result
val intent = Intent(Intent.ACTION_GET_CONTENT)
intent.type = "image/*"
if (intent.resolveActivity(packageManager) != null) {
startActivityForResult(intent, GALLERY_REQUEST_CODE)
}
}
- onActivityResult
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
super.onActivityResult(requestCode, resultCode, data)
if (resultCode == RESULT_OK) {
if (requestCode == GALLERY_REQUEST_CODE) {
var selectedImageUri = data?.getData()
if (selectedImageUri != null) {
val inputStream: InputStream = contentResolver.openInputStream(selectedImageUri)!!
val bytes = ByteArray(inputStream.available())
inputStream.read(bytes)
inputStream.close()
val base64Image = Base64.encodeToString(bytes, Base64.DEFAULT)
mResult.success(base64Image)
}
}
- permission control
if(call.method == "takePhoto"){
mResult = result
if (ContextCompat.checkSelfPermission(applicationContext,android.Manifest.permission.CAMERA ) == PackageManager.PERMISSION_GRANTED) {
openCamera()
} else {
ActivityCompat.requestPermissions(
this,
arrayOf(android.Manifest.permission.CAMERA),
CAMERA_REQUEST_CODE
)
}
}
- the method that opens the camera
private fun openCamera() {
val intent = Intent(MediaStore.ACTION_IMAGE_CAPTURE)
startActivityForResult(intent, CAMERA_REQUEST_CODE)
}
- permission result
override fun onRequestPermissionsResult(
requestCode: Int,
permissions: Array<out String>,
grantResults: IntArray
) {
when (requestCode) {
CAMERA_REQUEST_CODE -> {
if (grantResults.isNotEmpty() && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
// Kullanıcı kamera iznini verdi, kamera açma işlemine devam et
openCamera()
} else {
// Kullanıcı kamera iznini reddetti, hata mesajı göster veya başka bir işlem yap
mResult.error("PERMISSION_DENIED", "Kamera izni reddedildi.", null)
}
}
// Diğer izin istek kodlarını işleyebilirsiniz (gerektiğinde)
}
}
- onActivityResult
// inside of if (resultCode == RESULT_OK) {
if (requestCode == CAMERA_REQUEST_CODE ) {
val photo: Bitmap = data?.extras?.get("data") as Bitmap
val base64Image: String = convertBitmapToBase64(photo)
mResult.success(base64Image)
}