Pengembangan Aplikasi dengan Android Jetpack untuk Pemula

Android Jetpack merupakan sebuah inovasi dari Google yang membuat para developer Android terbantu dan cepat dalam mengembangkan sebuah Aplikasi yang berkuliatas dan tangguh dengan sekumpulan libray, tools dan panduan didalamnya.

Android Jetpack
source : https://developer.android.com

Android jetpack dapat mengelola berbagai aktifitas seperti Background Task, Navigation dan LifeCycle dari Android itu sendiri. Androi Jetpack juga didesign cocok berjalan di Kotlin yang akan membuat hemat code dengan Android KTX-nya. Banyak library dan tools panduan yang sudah disediakan Android jetpack untuk mempermudah para developer dalam mengembangkan sebuah Aplikasi Android (https://developer.android.com/jetpack/ )

Saat ini tutorial akan fokus bahas Jetpack untuk developer pemula yang mencoba memasuki Area baru pengembangan Aplikasi Android dengan Kotlin. Target tutorial ini Anda dapat ciptakan Aplikasi Android Jetpack Simple, berkenalan dengan LiveData, Observer, lifeCycle Android dan Navigation.

Sample Project Android Jetpack

SIlahkan download Android Canary 3.2 atau lebih tinggi dapat Anda unduh di https://developer.android.com/studio/preview  dan pastikan sudah melakukan instalasi yang lengkap.

  1. Buka Android Studio , Create Project dengan nama Starterjetpack
  1. Pilih Default Activity ( Activity & Fragment ViewModel)
  1. Setelah Project selesai di-create, maka langkah selanjutnya yaitu menambahkan komponen Jetpack yang kita ingin fokuskan yaitu Lifecycle ( LiveData ), Navigation.
  2. Buka File Gradle Project Anda dan sisipkan beberapa script untuk masing library jetpack.
  3. Library LifeCycle
  4. Library Navigation
  5. Sync and Run your App

Berkenalan dengan  View Model & LiveData

Baiklah, ketika komponen jetpack sudah berhasil menyatu dengan Aplikasi Startetjetpack. Bagaimana sih sebenarnya View Model & Live Data dari Android jetpack?. Jadi kalau arsitektur sebelumnya bahwa Fragment & Actvitiy bertugas untuk menyediakan & mengelola data untuk UI baik dari Database maupun webservice, sekarang tugas tersebut sudah ambil ahli oleh View Model & LiveData.

ViewModel di design berperan sebagai penyimpan data & mengelola Data UI sesuai dengan lifecycle Android, secara garis besar class ini bertugas untuk menyiapkan Data untuk UI dengan bantuan Observer. Misalkan Anda ingin menampilkan koleksi berita dari API atau dari database Anda pada Aplikasi, maka disinilah ViewModel berperan yang mungkin sebelumnya Anda assign pekerjaan ini pada Activity atau Fragment.

Sedangkan LiveData adalah kelas yang beperan untuk memberikan/update data kapan untuk di lakukan (observerable data) Observer (Pengamat) di Activity atau Fragment.

  1. Masuk ke Project yang sudah diciptakan sebelumnya
  2. Buka file MainViewModel.kt dan kita coba untuk mendaftarkan satu Live data disana sebagai data yang akan ditampilkan di welcome message Fragment default pada saat kita ciptakan proyek tadi.
  3. Sisipkan Kode berikut

Perbedaan dari LiveData dengan MutableLiveData adalah

LiveData dapat melakukan perubahan value (writable) sedangkan MutableLiveData hanya dapat baca saja (ReadOnly)

  1. Silahkan Run Aplikasi Anda

Teks di Fragment akan berganti menjadi Hello World! Sesuai dengan apa yang telah Anda  tuliskan pada ViewModel

  1. Nah, sekarang coba lakukan update pada teks hello world dengan nama “Ready to start” dengan bantuan sebuah button . Tambahkan sebuah Floating Button pada Fragment dan kita berikan click listener yang akan mengubah value data dari ViewModel dan apakah UI teks akan berubah?
  2. Tambahkan Script ini untuk Floating Point di main_fragment
  1. Set Listener dari button fab_change ini untuk merubah value HelloWorld tadi dengan script berikut.

Eitss, Import dulu package ini mempermudah kita tidak memperkenalkan fab_change

import kotlinx.android.synthetic.main. main_fragment.*

berlaku hanya untuk file kotlin

  1. Kemudian set listener dan change value helloworld dengan script ini.
fab_change.setOnClickListener{
viewModel.data.value = "Ready to start"
}
  1. . Something wrong… apa yang Anda temukan?

Karena variable data pada kelas MainViewModel adalah LiveData yang hanya ReadOnly sehingga tidak diijinkan untuk dirubah, solusi agar dapat dirubah adalah dengan definsikan variable data tersebut ke MutableLiveData dan pastinya tidak aka nada Error Kan?

  1. Silahkan Run Aplikasi and coba click floating point. Apa yang Anda temukan?
  2. Kita tidak melakukan update UI seperti cara kita sebelumnya, itu semua dilakukan oleh LiveData dengan observer yang telah kita pasanga pada Fragment Main tadi.

Berkenalan dengan Navigation dari Android Jetpack

Setelah bermain dengan ViewModel dan Live Data, sekarang mari kita lihat salah satu komponen yang ada dalam Android Jetpack yaitu Navigation. Kebetulan saat kita create project tadi, kita sudah install library untuk ini. Tools ini akan mempermudah Anda untuk menyimpelkan bagaimana implementasi Navigasi antara masing-masing destinasi pada Aplikasi Anda.

Sekarang peranan Activity pada Android jetpack merupakan entry point untuk masuk ke Aplikasi yang handle global navigation seperti Bottom Navigation, Navigation Drawer dll.

Berikut langkah-langkah untuk implementasi navigation dari Android Jetpack ini.

  1. Klik Kanan pada project dan pilih Android Resource File , berikan nama nav_graph dan tipe resource-nya adalah navigation. Akan menghasilkan struktur seperti ini.
  2. Klik Design untuk melihat Editor Navigasi.
  3. Klik Add Destination dan Pilih MainFragment, maka akan muncul disana layout main fragment
  4. Sekarang, kita akan coba untuk buat sebuah Fragment baru dengan nama AboutFragment yang nantinya ketika Teks “Ready to start” di click akan berpindah ke AboutFragment ini.
  1. Setelah FragmentAbout sudah kita ciptkan, selanjutnya kita tambahkan fragment tersebut pada nav_graph tadi, kita coba dengan penamaan seperti gambar ini.

Launcher_fragment adalah sebagai start destination pada Aplikasi.

  1. Kita lakukan update pada layout MainActivity sebelumnya dengan menyertakan satu komponen Fragment. Fragment inilah yang menjadi navigation host dari aplikasi kita, Fragment Transaction ini sudah di handle oleh Library Navigation Android Jetpack.
  1. Sekarang, kita akan set click listener pada teks “ready to start” pada launcher fragment menuju destinasi About Fragment.
  2. Oh ya, sekarang kita akan sederhanakan code pada MainAcitivity dengan script berikut
class MainActivity : AppCompatActivity() {

   override fun onCreate(savedInstanceState: Bundle?) {
       super.onCreate(savedInstanceState)
       setContentView(R.layout.main_activity)
  }

}

Yang sebelumnya dibubuhi dengan fragment transaction dihapus saja karena fragment navigation sudah di handle oleh Navigation lib.

Dengan mendefinisikan startDestination pada Nav_graph, fragment pada MainActiity kita akan otomatis jalanin MainFragment.

  1. Buka file Fragment dan set ClickListener ke Fragment About, seperti script berikut
/*Action when txt_message is click*/
message.setOnClickListener{
     view?.let { Navigation.findNavController(it).navigate(R.id.about) }
}
  1. Run Aplikasi dan Amati bagaimana Navigation bekerja.

Selamat Anda, baru saja memasuki cara baru dalam pengembangkan Aplikasi dengan Android Jetpack.

Full Project dapat Anda clone dari Github

Tagged with:

18 thoughts on “Pengembangan Aplikasi dengan Android Jetpack untuk Pemula”

  • indomethacin will increase the level or effect of valganciclovir by acidic anionic drug competition for renal tubular clearance cialis coupon Furthermore, we demonstrate that in vivo tumour growth of the NSCLC cells is also suppressed by AP 1 blockade

  • PB Pipes in Iraq At Elite Pipe Factory in Iraq, our PB pipes offer exceptional performance and durability, making them suitable for a variety of applications. Known for their resistance to high temperatures and chemicals, our PB pipes are crafted to meet the highest quality standards. As one of the best and most reliable pipe manufacturers in Iraq, Elite Pipe Factory is dedicated to providing products that excel in both performance and longevity. For more information on our PB pipes, visit elitepipeiraq.com.

  • شركة Bwer هي أحد الموردين الرئيسيين لموازين الشاحنات ذات الجسور في العراق، حيث تقدم مجموعة كاملة من الحلول لقياس حمولة المركبات بدقة. وتغطي خدماتها كل جانب من جوانب موازين الشاحنات، من تركيب وصيانة موازين الشاحنات إلى المعايرة والإصلاح. تقدم شركة Bwer موازين شاحنات تجارية وموازين شاحنات صناعية وأنظمة موازين جسور محورية، مصممة لتلبية متطلبات التطبيقات الثقيلة. تتضمن موازين الشاحنات الإلكترونية وموازين الشاحنات الرقمية من شركة Bwer تقنية متقدمة، مما يضمن قياسات دقيقة وموثوقة. تم تصميم موازين الشاحنات الثقيلة الخاصة بهم للبيئات الوعرة، مما يجعلها مناسبة للصناعات مثل الخدمات اللوجستية والزراعة والبناء. سواء كنت تبحث عن موازين شاحنات للبيع أو الإيجار أو التأجير، توفر شركة Bwer خيارات مرنة لتناسب احتياجاتك، بما في ذلك أجزاء موازين الشاحنات والملحقات والبرامج لتحسين الأداء. بصفتها شركة مصنعة موثوقة لموازين الشاحنات، تقدم شركة Bwer خدمات معايرة موازين الشاحنات المعتمدة، مما يضمن الامتثال لمعايير الصناعة. تشمل خدماتها فحص موازين الشاحنات والشهادات وخدمات الإصلاح، مما يدعم موثوقية أنظمة موازين الشاحنات الخاصة بك على المدى الطويل. بفضل فريق من الخبراء، تضمن شركة Bwer تركيب وصيانة موازين الشاحنات بسلاسة، مما يحافظ على سير عملياتك بسلاسة. لمزيد من المعلومات حول أسعار موازين الشاحنات، وتكاليف التركيب، أو لمعرفة المزيد عن مجموعة موازين الشاحنات ذات الجسور وغيرها من المنتجات، تفضل بزيارة موقع شركة Bwer على الإنترنت على bwerpipes.com

  • Hormone Ratio in Thyroglobulin Biologic Potency Half Life Days Protein Binding Levothyroxine T4 10 20 1 6 7 99 how to take priligy other s age at the time the child was born was assessed as a potential confounder but did not change the estimates

  • Bwer Company is a top supplier of weighbridge truck scales in Iraq, providing a complete range of solutions for accurate vehicle load measurement. Their services cover every aspect of truck scales, from truck scale installation and maintenance to calibration and repair. Bwer Company offers commercial truck scales, industrial truck scales, and axle weighbridge systems, tailored to meet the demands of heavy-duty applications. Bwer Company’s electronic truck scales and digital truck scales incorporate advanced technology, ensuring precise and reliable measurements. Their heavy-duty truck scales are engineered for rugged environments, making them suitable for industries such as logistics, agriculture, and construction. Whether you’re looking for truck scales for sale, rental, or lease, Bwer Company provides flexible options to match your needs, including truck scale parts, accessories, and software for enhanced performance. As trusted truck scale manufacturers, Bwer Company offers certified truck scale calibration services, ensuring compliance with industry standards. Their services include truck scale inspection, certification, and repair services, supporting the long-term reliability of your truck scale systems. With a team of experts, Bwer Company ensures seamless truck scale installation and maintenance, keeping your operations running smoothly. For more information on truck scale prices, installation costs, or to learn about their range of weighbridge truck scales and other products, visit Bwer Company’s website at bwerpipes.com.

  • It can be produced synthetically and it is also included in packaged foods cytotec online order Cysteinyl leukotriene receptors CysLT1 and CysLT2 mRNA expressions were decreased by both cyclic changes and early pregnancy, whereas 5 lipoxygenase activating protein and B leukotriene receptor mRNA expressions were not affected by early pregnancy or stages of the estrous cycle

Leave a Reply

Your email address will not be published. Required fields are marked *