2025-11-07 14:48:33 +07:00

141 lines
4.6 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# BMI Calculator (UTS Mobile Programming)
## 👨‍💻 Informasi Pengembang
- Raihan Ariq Muzakki (202310715297)
- **F5A5 Mobile Programming**
---
## 📘 Dokumentasi
- Petunjuk detail dapat dibaca di: https://docs.google.com/document/d/1iGiC0Bg3Bdcd2Maq45TYkCDUkZ5Ql51E/edit?rtpof=true
- Starter dimodifikasi dan terinspirasi dari: https://developer.android.com/codelabs/basic-android-compose-calculate-tip#0
---
## 📚 Referensi
- [kotlin.math](https://kotlinlang.org/api/core/kotlin-stdlib/kotlin.math/)
- [Calculate the Power of a Number in Kotlin](https://www.baeldung.com/kotlin/power-of-a-number)
- [Centimeters to Inches](https://www.splashlearn.com/math-vocabulary/cm-to-inches)
- [Kilograms to Pound](https://convertlive.com/id/u/mengkonversi/kilo/ke/pound)
- [Unit Testing](https://medium.com/@deonolarewaju/introduction-to-unit-testing-in-android-kotlin-4331eb2366a9)
- [Icon PNG](https://www.flaticon.com/)
---
## 📱 Deskripsi Proyek
Aplikasi BMI Calculator ini merupakan hasil proyek UTS tentang aplikasi berbasis Jetpack Compose yang berfungsi untuk menghitung Body Mass Index (BMI) menggunakan dua standar perhitungan, yaitu SI (kilogram dan sentimeter) serta USC (pound dan inch). Aplikasi ini menyediakan antarmuka yang sederhana dengan fitur input tinggi serta berat badan, pemilihan standar pengukuran melalui switch, serta tombol untuk menghitung dan menghapus data. Hasil perhitungan ditampilkan dalam format satu angka di belakang koma disertai kategori BMI yang relevan, sehingga pengguna dapat mengetahui status berat badan secara cepat dan akurat. Aplikasi ini juga memanfaatkan komponennya secara modular, termasuk fungsi perhitungan BMI, kategori BMI, dan pengaturan tata letak melalui Jetpack Compose.
---
## ✨ Fitur Utama
1. **Perhitungan BMI** dengan dua standar satuan (SI & USC).
2. **Validasi input** berdasarkan rentang nilai tinggi dan berat badan.
3. **Reset otomatis** ketika pengguna beralih standar unit.
4. **Kategori BMI** secara real-time setelah perhitungan.
5. **Antarmuka berbasis Jetpack Compose** dengan tata letak responsif.
6. **Unit Testing** untuk fungsi `calculateBMI()` dan `calculateBMICategory()`.
---
## 🗺️ Cara Menjalankan Aplikasi
### Persyaratan
- Android Studio sudah versi terbaru (Otter)
- Android SDK dan Build Tools untuk menjalankan Compose
- Perangkat Handphone (Debugging) atau Emulator Android
### Langkah Menjalankan
1. Buka Android Studio
2. Pilih Clone Repository ke
https://git.lab.ubharajaya.ac.id/202310715297-RAIHAN-ARIQ-MUZAKKI/UTS-202310715297-RaihanAriqMuzakki.git
3. Pastikan dependensi Gradle terunduh dan tersinkron
4. Pilih perangkat emulator atau perangkat fisik (Debugging) pada menu Device Manager
5. Tekan Run (Shift +F10) untuk menjalankan aplikasi
6. Aplikasi akan tampil di layar emulator atau perangkat debugging, dan siap digunakan untuk memasukkan tinggi badan, berat badan, dan Standar Perhitungan (SI Metric atau USC Units)
---
## 🧪 Dokumentasi Unit Testing
Pengujian dilakukan pada direktori:
```
app/src/test/java/calculateBMITest
```
Fungsi pengujian:
* `calculateBMITest()`
* `calculateBMICategoryTest()`
### Fokus Pengujian
1. Validasi hasil perhitungan BMI pada unit SI dan USC.
2. Akurasi kategori BMI.
3. Penanganan input tidak valid (tinggi/berat <= 0).
---
## 🔄 Changelog
Changelog disusun berdasarkan riwayat commit/push pada repository.
### v1.4 Penyempurnaan Fitur & Validasi (TERBARU)
* Penyesuaian warna pada tema terang.
* Penambahan validasi input tinggi dan berat.
* Peningkatan UI pada layout untuk konsistensi.
### v1.3 Pembaruan Tampilan & Ikon
* Perubahan ikon aplikasi.
* Optimalisasi tata letak halaman.
* Pembaruan dokumen README.
### v1.2 Integrasi Unit Testing
* Penambahan direktori dan berkas unit test.
* Pengujian ulang fungsi `calculateBMI()` dan `calculateBMICategory()`.
* Penyempurnaan logika pengkategorian BMI.
### v1.1 Penambahan Fitur Pengukuran USC
* Penyesuaian kalkulasi BMI dengan rumus USC.
* Penambahan switch untuk mengganti standar pengukuran.
* Refactor nama fungsi dan variabel.
### v1.0 Rilis Awal
* Implementasi fungsi dasar kalkulasi BMI (SI Unit).
* Struktur awal proyek Jetpack Compose.
* Penambahan komentar proyek (Nama, NPM, Kelas).
---
## 🤝 Kontribusi AI
Pengembangan aplikasi ini turut dibantu oleh:
- **Claude AI**
- **ChatGPT**
Kontribusi yang diberikan:
- Penanganan nilai *NaN → 0*
- Format desimal
- Penerapan rumus BMI sesuai standar SI & USC
- *LaunchedEffect* untuk reset input
- Simplifikasi kondisi kategori BMI
- Penyusunan Unit Testing
- Penyempurnaan layout, penambahan ikon, dan tombol aksi
- Membantu membuat Validasi Input
---