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);