Android - Tata Letak UI

Blok bangunan dasar untuk antarmuka pengguna adalah a Viewobjek yang dibuat dari kelas View dan menempati area persegi panjang di layar dan bertanggung jawab untuk menggambar dan menangani acara. View adalah kelas dasar untuk widget, yang digunakan untuk membuat komponen UI interaktif seperti tombol, bidang teks, dll.

Itu ViewGroup adalah subclass dari View dan menyediakan wadah tak terlihat yang menampung Views lain atau ViewGroups lain dan menentukan properti tata letaknya.

Pada tingkat ketiga kita memiliki tata letak berbeda yang merupakan subkelas dari kelas ViewGroup dan tata letak tipikal mendefinisikan struktur visual untuk antarmuka pengguna Android dan dapat dibuat baik pada saat menjalankan menggunakan View/ViewGroup objek atau Anda bisa mendeklarasikan layout Anda menggunakan file XML sederhana main_layout.xml yang terletak di folder res / layout proyek Anda.

Parameter tata letak

Tutorial ini lebih lanjut tentang membuat GUI Anda berdasarkan tata letak yang ditentukan dalam file XML. Tata letak dapat berisi semua jenis widget seperti tombol, label, kotak teks, dan sebagainya. Berikut adalah contoh sederhana file XML yang memiliki LinearLayout -

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
   android:layout_width="fill_parent"
   android:layout_height="fill_parent"
   android:orientation="vertical" >
   
   <TextView android:id="@+id/text"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="This is a TextView" />
      
   <Button android:id="@+id/button"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="This is a Button" />
      
   <!-- More GUI components go here  -->
   
</LinearLayout>

Setelah tata letak Anda dibuat, Anda bisa memuat sumber daya tata letak dari kode aplikasi Anda, dalam implementasi callback Activity.onCreate () seperti yang ditunjukkan di bawah ini -

public void onCreate(Bundle savedInstanceState) {
   super.onCreate(savedInstanceState);
   setContentView(R.layout.activity_main);
}

Jenis Tata Letak Android

Ada sejumlah Tata Letak yang disediakan oleh Android yang akan Anda gunakan di hampir semua aplikasi Android untuk memberikan tampilan, tampilan, dan nuansa yang berbeda.

Sr Tidak Tata Letak & Deskripsi
1 Tata Letak Linear

LinearLayout adalah grup tampilan yang meratakan semua anak dalam satu arah, secara vertikal atau horizontal.

2 Tata Letak Relatif

RelativeLayout adalah grup tampilan yang menampilkan tampilan anak dalam posisi relatif.

3 Tata Letak Tabel

TableLayout adalah tampilan yang mengelompokkan tampilan ke dalam baris dan kolom.

4 Tata Letak Mutlak

AbsoluteLayout memungkinkan Anda menentukan lokasi persis turunannya.

5 Tata Letak Bingkai

FrameLayout adalah placeholder di layar yang bisa Anda gunakan untuk menampilkan tampilan tunggal.

6 Tampilan Daftar

ListView adalah grup tampilan yang menampilkan daftar item yang dapat digulir.

7 Tampilan bergaris

GridView adalah ViewGroup yang menampilkan item dalam kisi dua dimensi yang dapat digulir.

Atribut Tata Letak

Setiap tata letak memiliki sekumpulan atribut yang menentukan properti visual dari tata letak itu. Ada beberapa atribut umum di antara semua tata letak dan ada atribut lain yang khusus untuk tata letak itu. Berikut adalah atribut umum dan akan diterapkan ke semua tata letak:

Sr Tidak Atribut & Deskripsi
1

android:id

Ini adalah ID yang secara unik mengidentifikasi tampilan.

2

android:layout_width

Ini adalah lebar tata letak.

3

android:layout_height

Ini adalah ketinggian tata letak

4

android:layout_marginTop

Ini adalah ruang ekstra di sisi atas tata letak.

5

android:layout_marginBottom

Ini adalah ruang ekstra di sisi bawah tata letak.

6

android:layout_marginLeft

Ini adalah ruang ekstra di sisi kiri tata letak.

7

android:layout_marginRight

Ini adalah ruang ekstra di sisi kanan tata letak.

8

android:layout_gravity

Ini menentukan bagaimana View anak diposisikan.

9

android:layout_weight

Ini menentukan berapa banyak ruang ekstra dalam layout yang harus dialokasikan ke View.

10

android:layout_x

Ini menentukan koordinat x dari tata letak.

11

android:layout_y

Ini menentukan koordinat y dari tata letak.

12

android:layout_width

Ini adalah lebar tata letak.

13

android:paddingLeft

Ini adalah padding kiri yang diisi untuk tata letak.

14

android:paddingRight

Ini adalah padding yang tepat untuk tata letak.

15

android:paddingTop

Ini adalah padding atas yang diisi untuk tata letak.

16

android:paddingBottom

Ini adalah padding bawah yang diisi untuk tata letak.

Di sini lebar dan tinggi adalah dimensi dari tata letak / tampilan yang dapat ditentukan dalam hal dp (Piksel yang tidak bergantung kepadatan), sp (Piksel yang tidak bergantung Skala), pt (Titik yang berukuran 1/72 inci), px ( Piksel), mm (Milimeter) dan terakhir dalam (inci).

Anda dapat menentukan lebar dan tinggi dengan ukuran yang tepat tetapi lebih sering, Anda akan menggunakan salah satu konstanta ini untuk mengatur lebar atau tinggi -

  • android:layout_width=wrap_content memberi tahu tampilan Anda untuk menyesuaikannya dengan dimensi yang dibutuhkan oleh kontennya.

  • android:layout_width=fill_parent memberi tahu tampilan Anda untuk menjadi sebesar tampilan induknya.

Atribut gravitasi memainkan peran penting dalam memposisikan objek tampilan dan dapat mengambil satu atau lebih (dipisahkan oleh '|') dari nilai konstan berikut.

Konstan Nilai Deskripsi
puncak 0x30 Dorong objek ke atas wadahnya, jangan mengubah ukurannya.
bawah 0x50 Dorong objek ke bagian bawah wadahnya, jangan mengubah ukurannya.
kiri 0x03 Dorong objek ke kiri wadahnya, jangan ubah ukurannya.
Baik 0x05 Dorong objek ke kanan penampungnya, jangan ubah ukurannya.
center_vertical 0x10 Tempatkan objek di tengah vertikal wadahnya, jangan ubah ukurannya.
fill_vertical 0x70 Perbanyak ukuran vertikal objek jika diperlukan agar benar-benar memenuhi wadahnya.
center_horizontal 0x01 Tempatkan objek di tengah horizontal wadahnya, jangan mengubah ukurannya.
fill_horizontal 0x07 Perbanyak ukuran horizontal objek jika diperlukan agar benar-benar memenuhi wadahnya.
pusat 0x11 Tempatkan objek di tengah wadahnya pada sumbu vertikal dan horizontal, tidak mengubah ukurannya.
mengisi 0x77 Perbanyak ukuran horizontal dan vertikal objek jika diperlukan agar benar-benar memenuhi wadahnya.
clip_vertical 0x80 Opsi tambahan yang dapat diatur agar tepi atas dan / atau bawah anak terpotong ke batas wadahnya. Klip akan didasarkan pada gravitasi vertikal: gravitasi atas akan memotong tepi bawah, gravitasi bawah akan memotong tepi atas, dan tidak juga memotong kedua tepi.
clip_horizontal 0x08 Opsi tambahan yang dapat diatur agar tepi kiri dan / atau kanan anak terpotong hingga batas wadahnya. Klip akan didasarkan pada gravitasi horizontal: gravitasi kiri akan memotong tepi kanan, gravitasi kanan akan memotong tepi kiri, dan tidak juga memotong kedua tepi.
Mulailah 0x00800003 Dorong objek ke awal penampungnya, jangan mengubah ukurannya.
akhir 0x00800005 Dorong objek ke ujung penampungnya, jangan ubah ukurannya.

Lihat Identifikasi

Objek tampilan mungkin memiliki ID unik yang ditetapkan padanya yang akan mengidentifikasi Tampilan secara unik di dalam pohon. Sintaks untuk ID, di dalam tag XML adalah -

android:id="@+id/my_button"

Berikut adalah uraian singkat tentang tanda @ dan + -

  • Simbol at (@) di awal string menunjukkan bahwa pengurai XML harus mengurai dan memperluas string ID lainnya dan mengidentifikasinya sebagai sumber daya ID.

  • Simbol plus (+) berarti ini adalah nama sumber daya baru yang harus dibuat dan ditambahkan ke sumber daya kita. Untuk membuat instance dari objek tampilan dan menangkapnya dari tata letak, gunakan yang berikut ini -

Button myButton = (Button) findViewById(R.id.my_button);