A.  Tujuan
Dengan mengikuti perkuliahan ini mahasiswa diharapkan mampu:
1.     Membuat ListView

B.  Alat dan Bahan
1.     Personal Computer
2.    IDE Eclipse
3.    Android SDK Windows

C.  Teori Singkat
ListView adalah user interface pada Android yang menampilkan item-item dari sekumpulan daftar yang tersusun berbaris ke bawah atau ke samping dengan tampilan yang dapat scroll. ListView menampilkan item-item dari suatu Array atau List atau Query Database yang dijadikan data model sebagai item dari ListView.
Adapter adalah class yang mengatur item-item pada ListView. Adapter mengatur resource view pada setiap item dari ListView. Resource view pada ListView yang ada pada sebuah tampilan layar sebuah aplikasi memiliki jumlah resource view yang tetap sesuai dengan item yang tampak pada layar. Pada ListView dengan tampilan scroll, resourve view akan digunakan secara berulang (reusable) dengan mengatur item yang tampak dan yang tersembunyi pada ListView. Adapter juga mengatur data model dari setiap item ListView. Sebuah data model akan diatur menjadi sebuah item dari ListView. 
ListView dikatakan sederhana atau komplek ditentukan oleh kompleksitas item dari ListView tersebut. Jika masing-masing item dari ListView menampilkan sebuah kata atau kalimat saja, maka ListView tersebut sederhana. Jika masing-masing item dari ListView memiliki isi yang komplek seperti item dari sebuah status jejaring sosial dimana pada masing-masing item memiliki foto profil, nama, waktu, status dan komentar, maka ListView tersebut adalah ListView komplek. Pembuatan ListView komplek dilakukan dengan Custom ListView.

D.  Langkah Kerja
1.     Buatlah sebuah project android baru dengan nama ListViewSederhana dengan mengikuti langkah yang terlihat pada gambar.







2.    Sesuaikan source code  pada file main.xml dengan mengikuti petunjuk pada gambar berikut:



3.    Sesuaikan source code  pada file ListViewSederhanaActivity.java dengan mengikuti petunjuk pada gambar berikut:




4.    Array String[] arrName merupakan kumpulan data String yang akan ditampilkan pada ListView. Array ini dimasukkan ke dalam object dari ArrayAdapter yang bernama adapter. Adapter ini merupakan adapter sederhana yang hanya menampilkan sebuah TextView pada item ListView. Code ListView listView = (ListView) findViewById
(R.id. id_list); membuat object dari class ListView dengan menginisiasi object tersebut dengan ListView yang kita buat pada file layout.xml. Jalankan project, maka ListView tampil seperti berikut ini.


  


Membuat Custom ListView
Custom ListView merupakan ListView dengan item yang bisa kita buat sesuai selera, misalnya item yang memiliki atribut foto, nama, dan keterangan. Item yang custom seperti itu dapat dibuat dan diatur oleh class Adapter.
1.     Untuk membuat Custom ListView, kita buat terlebih dahulu layout-layoutnya. Kita membutuhkan 2 layout, yaitu layout halaman yang menampilkan ListView dan layout item untuk Adapter.
2.    Buat project baru dengan nama ListViewCustom.


3.    Layout halaman utama  kita buat dengan menyesuaikan file main.xml di dalam folder layout dengan isi seperti ini :

 


4.    Buat layout baru : Layout item untuk Adapter kita buat dengan membuat file item.xml di dalam folder layout dengan isi seperti ini :



5.    Kemudian kita siapkan gambar yang menjadi icon dari item ListView. Saya pakai gambar Android seperti ini dengan ukuran 48 x 48 px (panjang x lebar harus sama). Kita simpan gambar pada folder drawable-hdpi dengan nama icon.png.




6.    Kemudian kita buat sebuah class data model dari item ListView yang bernama class Phone. Object dari class ini akan menyimpan data-data yang akan ditampilkan pada item dari ListView. Sebuah object dari class Phone akan ditampilkan pada sebuah item dari ListView. Kita buat class yang bernama Phone.java dengan isi class sebagai berikut.

















7.    Kemudian kita buat class Adapter. Class Adapter adalah class yang akan membuat dan mengatur item-item dari ListView. Class ini mengkonversi data dari object Phone menjadi item dari ListView. Kita buat class yang bermama ListAdapter.java dengan isi class sebagai berikut :


 
8.    Kemudian sesuaikan class ListViewCustomActivity (class ini biasanya sudah dibuat otomatis pada project) sebagai class controller yang mengelola pembuatan Custom ListView. Buat class ListViewCustomActivity.java dengan isi sebagai berikut :







9.    Jalankan program, maka akan tampil seperti gambar berikut:








A.  Tujuan
Dengan mengikuti perkuliahan ini mahasiswa diharapkan mampu:
1.     Bekerja dengan TextView
2.    Bekerja dengan Button
3.    Bekerja dengan Image
4.    Bekerja dengan CheckBox
5.    Bekerja dengan RadioButton

B.  Alat dan Bahan
1.     Personal Computer
2.    IDE Eclipse
3.    Android SDK Windows


C.  Langkah Kerja
1.     Buatlah sebuah project android baru dengan aturan sebagai berikut:

-          Project Name : WidgetAndroid

-          Build Target : Android 2.2

-          Package Name : widget.android.ku
-          Create Activity : WidgetAndroidActivity
-          Min SDK Version : 8

2.    Klik finish, maka dapat dilihat project yang telah dibuat pada bagian package explorer.


3.    Buka main.xml di folder layout. Pada awalnya, tampilan main.xml terlihat seperti gambar berikut:


4.    Hapus TextView yang sudah ada sehingga main.xml menjadi sbb:


5.    Melalui Graphical Layout, tambahkan view-view sebagai berikut:

6.    Atur property semua view sbb:












7.    main.xml akan berubah menjadi sbb:


  





































8.    Coba jalankan aplikasi, akan didapatkan tampilan sbb:


Akan tampak bahwa, ukuran layar secara vertical tidak cukup untuk menampilkan seluruh obyek view yang ada. Solusinya adalah dengan menambahkan Scroll untuk menggulung layar kearah vertical.

9.    Tambahkan ScrollView dengan menambahkan kode berikut ini pada main.xml. (sorce code yang diubah hanya yang berada dalam lingkaran merah saja. Yang lain tetap.



10. Sesuaikan kode program pada WidgetAndroidActivity seperti yang terlihat pada gambar berikut:ini, sehingga jika di klik OK, maka akan memunculkan identitas ke Form.




11.  Jalankan program maka akan tampil:

12. Ketika diklik tombol OK, maka data akan terisi dengan sendirinya.

D.  TUGAS
Buatlah program Android yang menampilkan Widget seperti yang terlihat pada gambar berikut:
Main.txt
<?xml version="1.0" encoding="utf-8"?>
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/scrollView1"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">


<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/textNamaDepan"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Nama Depan" android:typeface="monospace" android:textSize="24dp" android:textStyle="bold"/>

    <EditText
        android:id="@+id/editNamaDepan"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:ems="10" android:typeface="monospace" android:textSize="24dp">

        <requestFocus />
    </EditText>

    <TextView
        android:id="@+id/textNamaBlkg"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Nama Belakang" android:typeface="monospace" android:textSize="24dp" android:textStyle="bold"/>

    <EditText
        android:id="@+id/editNamaBlkg"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:ems="10" android:typeface="monospace" android:textSize="24dp"/>

    <TextView
        android:id="@+id/textNoTlpn"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Nomor Telpon" android:typeface="monospace" android:textSize="24dp" android:textStyle="bold"/>

    <EditText
        android:id="@+id/editNoTlpn"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:ems="10" android:typeface="monospace" android:textSize="24dp"/>

    <TextView
        android:id="@+id/textNegara"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Kewarganegaraan" android:typeface="monospace" android:textSize="24dp" android:textStyle="bold"/>

    <RadioGroup
        android:id="@+id/radioGroup1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" >

        <RadioButton
            android:id="@+id/radioWni"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:checked="true"
            android:text="WNI" />

        <RadioButton
            android:id="@+id/radioWna"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="WNA" />
    </RadioGroup>

    <TextView
        android:id="@+id/textViewBakat"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Bakat" android:typeface="monospace" android:textSize="24dp" android:textStyle="bold"/>

    <CheckBox
        android:id="@+id/checkBernyanyi"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Bernyanyi" />

    <CheckBox
        android:id="@+id/checkMenari"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Menari" />

    <CheckBox
        android:id="@+id/checkAltmsk"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Memainkan Alat Musik" />

    <Button
        android:id="@+id/btnTampil"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Tampil" />

</LinearLayout>
</ScrollView>

activity
package WidgetTugas.Aril;

import android.app.Activity;
import android.os.Bundle;
import android.text.style.LineHeightSpan.WithDensity;
import android.view.View;
import android.widget.Button;
import android.widget.CheckBox;
import android.widget.EditText;
import android.widget.RadioButton;

public class WidgetTugasArilActivity extends Activity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
       
        final EditText editNamaDepan = (EditText) findViewById(R.id.editNamaDepan);
        final EditText editNamaBlkg = (EditText)
        findViewById(R.id.editNamaBlkg);
        final EditText editNoTlpn = (EditText)
        findViewById(R.id.editNoTlpn);
        final RadioButton radioWni = (RadioButton)
        findViewById(R.id.radioWni);
        final RadioButton radioWna = (RadioButton)
        findViewById(R.id.radioWna);
        final CheckBox checkBernyanyi = (CheckBox)
        findViewById(R.id.checkBernyanyi);
        final CheckBox checkMenari = (CheckBox)
        findViewById(R.id.checkMenari);
        final CheckBox checkAltmsk = (CheckBox)
        findViewById(R.id.checkAltmsk);
       
        Button btnTampil = (Button) findViewById(R.id.btnTampil);
        btnTampil.setOnClickListener(new View.OnClickListener() {
                            
                             public void onClick(View arg0) {
                                      // TODO Auto-generated method stub
                             editNamaDepan.setText("Syahril");
                             editNamaBlkg.setText("Ramadhani");
                             editNoTlpn.setText("085217237186");
                             radioWni.setChecked(true);
                             checkBernyanyi.setChecked(true);
                             }
                   });
    }
}



Jika Tombol Tampil diklik, maka akan tampil data seperti yanguatlah program Android yang menampilkan Widget seperti yang terlihat terpada gambar berikut: