import android.Manifest import android.app.Activity import android.content.Intent import android.content.pm.PackageManager import android.graphics.Bitmap import android.graphics.BitmapFactory import android.os.Bundle import android.provider.MediaStore import android.widget.Button import android.widget.EditText import android.widget.ImageView import android.widget.Toast import androidx.appcompat.app.AppCompatActivity import androidx.core.app.ActivityCompat import androidx.core.content.ContextCompat import com.github.barteksc.pdfviewer.PDFView import com.itextpdf.text.Document import com.itextpdf.text.Paragraph import com.itextpdf.text.pdf.PdfWriter import java.io.ByteArrayOutputStream import java.io.FileOutputStream import java.text.SimpleDateFormat import java.util.* class MainActivity : AppCompatActivity() { private lateinit var imageView: ImageView private lateinit var placeEditText: EditText private lateinit var nameEditText: EditText private lateinit var descriptionEditText: EditText private lateinit var captureButton: Button private lateinit var submitButton: Button private val REQUEST_IMAGE_CAPTURE = 1 private val PERMISSION_REQUEST_CODE = 200 override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) imageView = findViewById(R.id.imageView) placeEditText = findViewById(R.id.placeEditText) nameEditText = findViewById(R.id.nameEditText) descriptionEditText = findViewById(R.id.descriptionEditText) captureButton = findViewById(R.id.captureButton) submitButton = findViewById(R.id.submitButton) captureButton.setOnClickListener { if (checkPermission()) { dispatchTakePictureIntent() } else { requestPermission() } } submitButton.setOnClickListener { saveEvent() } } private fun checkPermission(): Boolean { return (ContextCompat.checkSelfPermission( this, Manifest.permission.CAMERA ) == PackageManager.PERMISSION_GRANTED) } private fun requestPermission() { ActivityCompat.requestPermissions( this, arrayOf(Manifest.permission.CAMERA), PERMISSION_REQUEST_CODE ) } override fun onRequestPermissionsResult( requestCode: Int, permissions: Array<String>, grantResults: IntArray ) { super.onRequestPermissionsResult(requestCode, permissions, grantResults) if (requestCode == PERMISSION_REQUEST_CODE) { if (grantResults.isNotEmpty() && grantResults[0] == PackageManager.PERMISSION_GRANTED) { dispatchTakePictureIntent() } else { Toast.makeText(this, "Permission Denied", Toast.LENGTH_SHORT).show() } } } private fun dispatchTakePictureIntent() { val takePictureIntent = Intent(MediaStore.ACTION_IMAGE_CAPTURE) startActivityForResult(takePictureIntent, REQUEST_IMAGE_CAPTURE) } override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) { super.onActivityResult(requestCode, resultCode, data) if (requestCode == REQUEST_IMAGE_CAPTURE && resultCode == Activity.RESULT_OK) { val imageBitmap = data?.extras?.get("data") as Bitmap imageView.setImageBitmap(imageBitmap) } } private fun saveEvent() { val place = placeEditText.text.toString() val name = nameEditText.text.toString() val description = descriptionEditText.text.toString() // Get current date and time val sdf = SimpleDateFormat("yyyy-MM-dd HH:mm:ss", Locale.getDefault()) val currentDateAndTime: String = sdf.format(Date()) // Create PDF val document = Document() val pdfFileName = "incident_report_$currentDateAndTime.pdf" val filePath = "${filesDir}/$pdfFileName" PdfWriter.getInstance(document, FileOutputStream(filePath)) document.open() document.add(Paragraph("Incident Report")) document.add(Paragraph("Date and Time: $currentDateAndTime")) document.add(Paragraph("Place: $place")) document.add(Paragraph("Name: $name")) document.add(Paragraph("Description: $description")) // Add image to PDF if available if (imageView.drawable != null) { val stream = ByteArrayOutputStream() (imageView.drawable).toBitmap().compress(Bitmap.CompressFormat.PNG, 100, stream) val image = com.itextpdf.text.Image.getInstance(stream.toByteArray()) document.add(image) } document.close() Toast.makeText(this, "Event saved successfully", Toast.LENGTH_SHORT).show() } }
Write, Run & Share Kotlin code online using OneCompiler’s Kotlin online compiler for free. It’s a modern and fast online playground for Kotlin, supporting the latest version and ideal for learning, experimenting, and sharing code instantly.
Kotlin is a statically typed, modern programming language developed by JetBrains. It runs on the JVM and is fully interoperable with Java. Kotlin is concise, expressive, and safe, and it’s officially supported by Google for Android app development.
The following is a simple Kotlin program that prints a greeting:
fun main() {
println("Hello, OneCompiler!")
}
OneCompiler’s Kotlin editor supports stdin. You can provide input using the I/O tab. Here's a sample program that reads a line of input and prints a greeting:
fun main() {
print("Enter your name: ")
val name = readLine()
println("Hello, $name")
}
val name: String = "OneCompiler" // Immutable
var age: Int = 25 // Mutable
Kotlin supports type inference, so explicit types are optional:
val city = "Hyderabad"
var count = 10
val score = 85
if (score >= 50) {
println("Pass")
} else {
println("Fail")
}
for (i in 1..5) {
println(i)
}
var i = 1
while (i <= 5) {
println(i)
i++
}
var j = 1
do {
println(j)
j++
} while (j <= 5)
fun add(a: Int, b: Int): Int {
return a + b
}
fun greet(name: String) = "Hello, $name"
val items = listOf("apple", "banana", "cherry")
for (item in items) {
println(item)
}
This guide provides a quick reference to Kotlin programming syntax and features. Start coding in Kotlin using OneCompiler’s Kotlin online compiler today!