first commit

This commit is contained in:
202310715280 FADLAN RIVALDI 2026-01-14 20:09:29 +07:00
parent 900cf99681
commit e88ada64b2
3 changed files with 50 additions and 74 deletions

120
README.md
View File

@ -1,102 +1,74 @@
# 📱 Aplikasi Absensi Akademik Berbasis Koordinat dan Foto (Mobile)## 👤 Identitas Mahasiswa # 📱 Aplikasi Absensi Akademik Berbasis Koordinat dan Foto (Mobile)
- **Nama:** Fadlan Rivaldi
- **NPM:** 202310715280
--- ## 👤 Identitas Mahasiswa
- **Nama:** Dirson Ali Wardana
- **NPM:** 202310715246---
## 📌 Deskripsi Proyek ## 📌 Deskripsi Proyek
Proyek ini merupakan **Tugas Project Akhir Mata Kuliah Pemrograman Mobile** yang bertujuan untuk membangun **aplikasi akademik berbasis mobile** dengan fokus pada **fitur absensi menggunakan data koordinat (GPS) dan pengambilan foto mahasiswa**. Proyek ini merupakan **Tugas Akhir / Project Akhir Mata Kuliah Pemrograman Mobile**. Aplikasi ini dikembangkan untuk mengelola absensi mahasiswa secara cerdas dengan validasi ganda: **Lokasi GPS (Geofencing)** dan **Verifikasi Wajah (Selfie)**.
Aplikasi ini dirancang untuk meningkatkan **validitas kehadiran mahasiswa**, dengan memastikan bahwa absensi hanya dapat dilakukan apabila mahasiswa: Aplikasi memastikan kehadiran mahasiswa valid apabila mahasiswa berada dalam radius lokasi kampus dan melakukan pengambilan foto selfie sebagai bukti kehadiran fisik yang kemudian dikirimkan ke server pemantau (n8n & Google Sheets).
1. Berada pada **lokasi yang telah ditentukan**, dan
2. Melakukan **pengambilan foto (selfie) secara langsung saat absensi**
--- ---
## 🎯 Tujuan Proyek ## 📝 Change Log (Modifikasi & Pengembangan)
- Mengimplementasikan **Location-Based Service (LBS)** pada aplikasi mobile Berdasarkan *starter project* yang disediakan, berikut adalah catatan perubahan signifikan yang telah saya implementasikan:
- Mengintegrasikan **kamera perangkat** untuk dokumentasi absensi
- Mencegah kecurangan absensi (titip absen) I. **Dropdown Mata Kuliah & Integrasi Data**: Menambahkan fitur pilihan mata kuliah dan memastikan data `namaMatkul` terkirim dengan benar ke server melalui payload JSON.
- Mengembangkan aplikasi mobile akademik berbasis Android II. **Fragment Preview (History Logic)**: Mengimplementasikan `PreviewFragment` yang merangkum seluruh data (Foto, Koordinat, Timestamp) sebelum dikirim, serta menambahkan logika penyimpanan otomatis ke `DataHolder.historyList` setelah pengiriman berhasil.
- Melatih kemampuan perancangan dan implementasi aplikasi mobile III. **Konversi Base64**: Mengimplementasikan fungsi `base64ToBitmap` dan pengiriman `foto_base64` agar foto selfie mahasiswa dapat tersimpan dan dilihat di server.
IV. **Modernisasi UI (Material Card & Progress Bar)**: Menggunakan `MaterialCardView` untuk tampilan foto preview dan menambahkan `ProgressBar` (Loading) untuk memberikan feedback visual saat proses pengiriman data ke server.
V. **Network Threading**: Menggunakan `kotlin.concurrent.thread` untuk menangani proses pengiriman data ke Webhook agar aplikasi tidak *freeze* (ANR) saat melakukan request jaringan.
--- ---
## 🚀 Fitur Utama ## 🚀 Fitur Utama
- 🔐 **Login Pengguna (Mahasiswa)** - 🔐 **Login Mahasiswa**: Autentikasi otomatis dengan data profil tetap (Hardcoded).
- 📍 **Pengambilan Koordinat Lokasi (Latitude & Longitude)** - 🎓 **Mata Kuliah Selector**: Memilih mata kuliah aktif sebelum melakukan absensi.
- 🏫 **Validasi Lokasi Absensi (Radius Area)** - 📍 **GPS Tracking**: Pengambilan koordinat Latitude dan Longitude secara presisi.
- 📸 **Pengambilan Foto Mahasiswa Saat Absensi** - 📸 **Selfie Verification**: Pratinjau foto selfie sebelum data dikirim ke server.
- 🕒 **Pencatatan Waktu Absensi** - 📄 **Real-time History**: Daftar riwayat absensi yang langsung terupdate menggunakan `RecyclerView` / `LazyColumn`.
- 📄 **Riwayat Kehadiran Mahasiswa** - 📡 **Webhook Integration**: Pengiriman data langsung ke sistem n8n Ubhara Jaya.
- ⚠️ **Notifikasi Absensi Ditolak jika Tidak Valid**
---
## 🗺️ Mekanisme Absensi Berbasis Lokasi dan Foto
1. Mahasiswa melakukan **login**
2. Memilih menu **Absensi**
3. Sistem meminta:
- Izin **akses lokasi**
- Izin **akses kamera**
4. Aplikasi mengambil:
- 📍 **Koordinat lokasi mahasiswa**
- 📸 **Foto mahasiswa secara real-time**
5. Sistem melakukan validasi:
- Lokasi berada dalam **radius absensi**
- Foto berhasil diambil
6. Jika valid → **Absensi berhasil**
7. Jika tidak valid → **Absensi ditolak**
---
## 📸 Pengambilan Foto Saat Absensi
- Foto diambil menggunakan **kamera depan (selfie)**
- Foto hanya dapat diambil **saat proses absensi**
- Foto disimpan sebagai **bukti kehadiran**
- Foto dapat digunakan untuk verifikasi manual dan dokumentasi akademik.
--- ---
## 🛠️ Teknologi yang Digunakan ## 🛠️ Teknologi yang Digunakan
- **Platform**: Android - **Bahasa**: Kotlin
- **Bahasa Pemrograman**: Kotlin - **UI Framework**: Android XML (View System) & Jetpack Compose (Interoperability).
- **Location Service**: Google Maps API / Fused Location Provider - **Network**: `HttpURLConnection` dengan format data **JSON**.
- **Camera API**: CameraX - **Kamera**: CameraX API.
- **Architecture**: MVVM / View System & Jetpack Compose - **Lokasi**: Fused Location Provider Client.
- **IDE**: Android Studio - **Data Manager**: `DataHolder` (Singleton) untuk manajemen data antar layar.
---
## 🗺️ Mekanisme Absensi
1. Mahasiswa memilih mata kuliah.
2. Aplikasi mengambil lokasi dan mahasiswa melakukan foto selfie.
3. Di halaman **Preview**, mahasiswa memvalidasi data (Nama, NPM, Lokasi, dan Foto).
4. Klik **Submit**: Data dikonversi ke JSON dan dikirim ke Webhook.
5. Jika berhasil (Response 200), data otomatis masuk ke menu **Riwayat**.
--- ---
## 🔐 Izin Aplikasi (Permissions) ## 🔐 Izin Aplikasi (Permissions)
Aplikasi memerlukan izin berikut: Aplikasi memerlukan akses berikut:
- `ACCESS_FINE_LOCATION` & `ACCESS_COARSE_LOCATION` - `android.permission.CAMERA`: Untuk mengambil foto selfie.
- `CAMERA` - `android.permission.ACCESS_FINE_LOCATION`: Untuk validasi lokasi presisi.
- `INTERNET` - `android.permission.INTERNET`: Untuk mengirim data absensi ke n8n.
--- ---
## 📂 Mockup ## ⚠️ Disclaimer & Catatan
![mockup](Mockup.png) - **PENGGUNAAN AI**: Proyek ini dikembangkan dengan bantuan **Kecerdasan Buatan (AI)** (ChatGPT/Claude) dalam proses debugging Gradle, perbaikan error `XMLStreamException`, dan penyusunan struktur pengiriman data JSON pada `PreviewFragment.kt`.
*Gambar mockup dibuat oleh AI* - **PENGEMBANGAN**: Aplikasi ini merupakan hasil modifikasi intensif dari *starter project* yang disediakan untuk memenuhi standar capaian project akhir EAS 2025/2026.
--- ---
## ⚠️ Disclaimer & Catatan Penting ## 🔗 Link Monitoring & Data
- **PENGGUNAAN AI**: Proyek ini dikembangkan dengan bantuan **Kecerdasan Buatan (AI)** dalam proses debugging, pembuatan starter project, dan penyusunan dokumentasi. - **Monitoring (ntfy)**: [ntfy.ubharajaya.ac.id/EAS](https://ntfy.ubharajaya.ac.id/EAS)
- **PENGEMBANGAN**: Proyek ini dikembangkan dari *starter project* yang disediakan dan tidak dibuat dari nol. - **Data Spreadsheet**: [Cek Data Absensi](https://docs.google.com/spreadsheets/d/1jH15MfnNgpPGuGeid0hYfY7fFUHCEFbCmg8afTyyLZs/edit?gid=0#gid=0)
- **PRIVASI KOORDINAT**: Untuk alasan keamanan/privasi, angka koordinat GPS dapat dimodifikasi sedikit agar tidak menunjukkan lokasi rumah pribadi secara presisi.
---
## 🔗 Link Pengecekan & Webhook
- **Monitoring**: [ntfy.ubharajaya.ac.id/EAS](https://ntfy.ubharajaya.ac.id/EAS)
- **Data Spreadsheet**: [Google Sheets](https://docs.google.com/spreadsheets/d/1jH15MfnNgpPGuGeid0hYfY7fFUHCEFbCmg8afTyyLZs/edit?gid=0#gid=0)
- **Webhook Production**: `https://n8n.lab.ubharajaya.ac.id/webhook/23c6993d-1792-48fb-ad1c-ffc78a3e6254` - **Webhook Production**: `https://n8n.lab.ubharajaya.ac.id/webhook/23c6993d-1792-48fb-ad1c-ffc78a3e6254`
--- ---
“⚠️ Disclaimer & Catatan Penting” *Dibuat untuk memenuhi Tugas Project Akhir Mata Kuliah Pemrograman Mobile.*
Proyek ini dikembangkan dengan bantuan Kecerdasan Buatan (AI) sebagai asisten dalam proses debugging dan dokumentasi. Seluruh implementasi, pemahaman konsep,
dan pengembangan fitur dilakukan oleh penulis secara mandiri.
*Dibuat untuk memenuhi Tugas Project Akhir EAS 2025/2026.*

View File

@ -0,0 +1,2 @@
package id.ac.ubharajaya.sistemakademik.data

View File

@ -0,0 +1,2 @@
package id.ac.ubharajaya.sistemakademik.utils