Professional Documents
Culture Documents
Agus Haryanto
agus.superwriter@gmail.com
http://agusharyanto.net
Belajar Android studio kali ini akan menarik karena kita akan membuat aplikasi
CRUD Data Mahasiswa dimana nantinya disini kita akan belajar tentang cara
insert, update, delete, select data ke suatu table database sqlite. Disini kita
juga sudah menggunakan beberapa komponen material design seperti
coordinator layout, toolbar, floating action button, RecyclerView dan
CardView.
Sekarang mari kita mulai pembuatannya.
1. Buka Android Studio lalu buat project baru, isi project name dengan
CRUD Data Mahasiswa dan domain name dengan agusharyanto.net
kemudian klik next 2 kali
2. Sampai pada pada jendela add an activity to mobile pilih Blank Activity
lalu klik next sampai finish.
3. Sekarang kita edit script gradle(Module:app)nya lalu ketikan kode berikut.
apply plugin: 'com.android.application'
android {
compileSdkVersion 23
buildToolsVersion "23.0.2"
defaultConfig {
applicationId
"net.agusharyanto.cruddatamahasiswa"
minSdkVersion 15
targetSdkVersion 23
versionCode 1
versionName "1.0"
}
buildTypes {
release {
minifyEnabled false
proguardFiles
getDefaultProguardFile('proguard-android.txt'),
'proguard-rules.pro'
}
}
}
dependencies {
compile fileTree(dir: 'libs', include:
['*.jar'])
testCompile 'junit:junit:4.12'
compile 'com.android.support:appcompatv7:23.1.0'
compile 'com.android.support:design:23.1.0'
compile 'com.android.support:cardview-v7:23.1.0'
compile 'com.android.support:recyclerviewv7:23.1.0'
}
3. Untuk Data Mahasiswa kita perlu buat modelnya. Untuk itu buat class baru
dengan nama Mahasiswa lalu ketikan kode berikut
package net.agusharyanto.cruddatamahasiswa;
import java.io.Serializable;
/**
* Created by agus on 12/1/15.
*/
public class Mahasiswa implements Serializable{
private String id="";
private String nim="";
private String nama="";
private String jurusan="";
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getNim() {
return nim;
}
public void setNim(String nim) {
this.nim = nim;
}
public String getNama() {
return nama;
}
public void setNama(String nama) {
this.nama = nama;
}
public String getJurusan() {
return jurusan;
}
public void setJurusan(String jurusan) {
this.jurusan = jurusan;
}
@Override
public String toString() {
return "Mahasiswa{" +
"id='" + id + '\'' +
", nim='" + nim + '\'' +
", nama='" + nama + '\'' +
", jurusan='" + jurusan + '\'' +
'}';
}
}
4. Sekarang kita urus pembuatan databasenya, buat class baru dengan nama
DatabaseHelper lalu ketikan kode berikut
package net.agusharyanto.cruddatamahasiswa;
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import java.util.ArrayList;
/**
* Created by agus on 12/1/15.
*/
public class DatabaseHelper extends
SQLiteOpenHelper{
private final static String DATABASE_NAME
="dbmahasiswa";
private final static int DATABASE_VERSION = 1;
ContentValues();
contentValues2.put(FIELD_NIMS,"201510003");
contentValues2.put(FIELD_NAMA,"Muhid");
contentValues2.put(FIELD_JURUSAN, "TI");
db.insert(MAHASISWA_TABLE,null,contentValues2);
}
public ArrayList<Mahasiswa>
getDataMahasiswa(SQLiteDatabase db){
ArrayList<Mahasiswa> mahasiswaArrayList =
new ArrayList<Mahasiswa>();
String[] allColumns = {FIELD_ID, FIELD_NIMS,
FIELD_NAMA, FIELD_JURUSAN};
Cursor cursor =
db.query(MAHASISWA_TABLE,allColumns,null,null,null,n
ull,null);
cursor.moveToFirst();
while (!cursor.isAfterLast()) {
Mahasiswa mahasiswa =
cursorToMahasiswa(cursor);
mahasiswaArrayList.add(mahasiswa);
cursor.moveToNext();
}
return mahasiswaArrayList;
}
public long updateMahasiswa(Mahasiswa mahasiswa,
SQLiteDatabase db) {
ContentValues initialValues = new
ContentValues();
initialValues.put(FIELD_NIMS,
mahasiswa.getNim());
initialValues.put(FIELD_NAMA,
mahasiswa.getNama());
initialValues.put(FIELD_JURUSAN,
mahasiswa.getJurusan());
long rowaffect =db.update(MAHASISWA_TABLE,
initialValues, FIELD_ID + "=" + mahasiswa.getId(),
null);
return rowaffect;
}
gin"
android:paddingTop="@dimen/activity_vertical_margin"
app:layout_behavior="@string/appbar_scrolling_view_b
ehavior"
tools:context="net.agusharyanto.cruddatamahasiswa.Ma
inActivity"
tools:showIn="@layout/activity_main">
<android.support.v7.widget.RecyclerView
android:id="@+id/my_recycler_view"
android:scrollbars="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
</RelativeLayout>
android:layout_width="100dp"
android:layout_height="wrap_content"
android:text="@string/nim"
android:id="@+id/textViewRowNim" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/nama"
android:id="@+id/textViewRowNama"
android:layout_alignParentTop="true"
android:layout_toRightOf="@+id/textViewRowNim"
android:layout_toEndOf="@+id/textViewRowNim" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/jurusan"
android:id="@+id/textViewRowJurusan"
android:layout_alignParentTop="true"
android:layout_alignParentRight="true"
android:layout_alignParentEnd="true"
/>
</RelativeLayout>
</android.support.v7.widget.CardView>
</LinearLayout>
8. Kembali source java buat Activity baru pilih blank activity lalu beri nama
MahasiswaActivity
9. pada directory res/layout edit activity_mahasiswa.xml lalu ketikan kode
berikut
<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
xmlns:android="http://schemas.android.com/apk/res/an
droid"
xmlns:app="http://schemas.android.com/apk/resauto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
tools:context="net.agusharyanto.cruddatamahasiswa.Ma
hasiswaActivity">
<android.support.design.widget.AppBarLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:theme="@style/AppTheme.AppBarOverlay">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?
attr/actionBarSize"
android:background="?attr/colorPrimary"
app:popupTheme="@style/AppTheme.PopupOverlay" />
</android.support.design.widget.AppBarLayout>
<include layout="@layout/content_mahasiswa" />
<android.support.design.widget.FloatingActionButton
android:id="@+id/fab"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="bottom|end"
android:layout_margin="@dimen/fab_margin"
android:src="@android:drawable/ic_menu_save"
/>
</android.support.design.widget.CoordinatorLayout>
xmlns:app="http://schemas.android.com/apk/resauto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_marg
in"
android:paddingLeft="@dimen/activity_horizontal_marg
in"
android:paddingRight="@dimen/activity_horizontal_mar
gin"
android:paddingTop="@dimen/activity_vertical_margin"
android:orientation="vertical"
app:layout_behavior="@string/appbar_scrolling_view_b
ehavior"
tools:context="net.agusharyanto.cruddatamahasiswa.Ma
hasiswaActivity"
tools:showIn="@layout/activity_mahasiswa">
<android.support.design.widget.TextInputLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp">
<EditText
android:id="@+id/editTextNim"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="@string/nim"/>
</android.support.design.widget.TextInputLayout>
<android.support.design.widget.TextInputLayout
android:layout_width="match_parent"
android:layout_height="wrap_content">
<EditText
android:id="@+id/editTextNama"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="@string/nama"/>
</android.support.design.widget.TextInputLayout>
<android.support.design.widget.TextInputLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="8dp">
<EditText
android:id="@+id/editTextJurusan"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="@string/jurusan"/>
</android.support.design.widget.TextInputLayout>
</LinearLayout>
app:showAsAction="always" />
</menu>
11. Sekarang kita beralih ke bagian javanya. Buat class baru dengan nama
MahasiswaAdapter.java lalu ketikan kode berikut.
package net.agusharyanto.cruddatamahasiswa;
import android.support.v7.widget.CardView;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;
import java.util.List;
/**
* Created by agus on 12/4/15.
*/
public class MahasiswaAdapter extends
RecyclerView.Adapter<MahasiswaAdapter.MahasiswaViewH
older> {
List<Mahasiswa> mahasiswas;
MahasiswaAdapter(List<Mahasiswa> mahasiswas) {
this.mahasiswas = mahasiswas;
}
@Override
public MahasiswaViewHolder
onCreateViewHolder(ViewGroup viewGroup, int i) {
View v =
LayoutInflater.from(viewGroup.getContext()).inflate(
R.layout.row_mahasiswa, viewGroup, false);
MahasiswaViewHolder mahasiswaViewHolder =
new MahasiswaViewHolder(v);
return mahasiswaViewHolder;
}
@Override
public void onBindViewHolder(MahasiswaViewHolder
mahasiswaViewHolder, int i) {
mahasiswaViewHolder.mahasiswaName.setText(mahasiswas.
get(i).getNama());
mahasiswaViewHolder.mahasiswaJurusan.setText(mahasis
was.get(i).getJurusan());
mahasiswaViewHolder.mahasiswaNim.setText(mahasiswas.
get(i).getNim());
}
@Override
public int getItemCount() {
return mahasiswas.size();
}
public Mahasiswa getItem(int position) {
return mahasiswas.get(position);
}
@Override
public void
onAttachedToRecyclerView(RecyclerView recyclerView)
{
super.onAttachedToRecyclerView(recyclerView);
}
public static class MahasiswaViewHolder extends
RecyclerView.ViewHolder {
CardView cv;
TextView mahasiswaName;
TextView mahasiswaJurusan;
TextView mahasiswaNim;
MahasiswaViewHolder(View itemView) {
super(itemView);
cv = (CardView)
itemView.findViewById(R.id.cv);
mahasiswaName = (TextView)
itemView.findViewById(R.id.textViewRowNama);
mahasiswaJurusan = (TextView)
itemView.findViewById(R.id.textViewRowJurusan);
mahasiswaNim = (TextView)
itemView.findViewById(R.id.textViewRowNim);
}
}
13. Buat class baru dengan nama RecyclerItemListener.java lalu ketikan kode
berikut
package net.agusharyanto.cruddatamahasiswa;
import android.content.Context;
import android.support.v7.widget.RecyclerView;
import android.view.GestureDetector;
import android.view.MotionEvent;
import android.view.View;
/**
* Created by agus on 12/4/15.
*/
public class RecyclerItemClickListener implements
RecyclerView.OnItemTouchListener {
private OnItemClickListener mListener;
public interface OnItemClickListener {
public void onItemClick(View view, int
position);
}
GestureDetector mGestureDetector;
public RecyclerItemClickListener(Context
context, OnItemClickListener listener) {
mListener = listener;
mGestureDetector = new
GestureDetector(context, new
GestureDetector.SimpleOnGestureListener() {
@Override public boolean
onSingleTapUp(MotionEvent e) {
return true;
}
});
}
@Override
public boolean
onInterceptTouchEvent(RecyclerView view, MotionEvent
e) {
View childView =
view.findChildViewUnder(e.getX(), e.getY());
if (childView != null && mListener != null
&& mGestureDetector.onTouchEvent(e)) {
mListener.onItemClick(childView,
view.getChildPosition(childView));
return true;
}
return false;
}
@Override public void onTouchEvent(RecyclerView
view, MotionEvent motionEvent) { }
@Override
public void
onRequestDisallowInterceptTouchEvent(boolean b) {
}
}
mLayoutManager;
private Context context = MainActivity.this;
private DatabaseHelper databaseHelper;
private SQLiteDatabase db;
private static final int REQUEST_CODE_ADD =1;
private static final int REQUEST_CODE_EDIT =2;
@Override
protected void onCreate(Bundle
savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Toolbar toolbar = (Toolbar)
findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
FloatingActionButton fab =
(FloatingActionButton) findViewById(R.id.fab);
fab.setOnClickListener(new
View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new
Intent(MainActivity.this, MahasiswaActivity.class);
// intent.putExtra("action",
REQUEST_CODE_ADD);
startActivityForResult(intent,
REQUEST_CODE_ADD);
}
});
initializeData();
mRecyclerView = (RecyclerView)
findViewById(R.id.my_recycler_view);
// use this setting to improve performance
if you know that changes
// in content do not change the layout size
of the RecyclerView
mRecyclerView.setHasFixedSize(true);
// use a linear layout manager
mLayoutManager = new
LinearLayoutManager(this);
mRecyclerView.setLayoutManager(mLayoutManager);
// specify an adapter (see also next
example)
gambarDatakeRecyclerView();
}
private void gambarDatakeRecyclerView(){
rvAdapter = new
MahasiswaAdapter(mahasiswaList);
mRecyclerView.setAdapter(rvAdapter);
mRecyclerView.addOnItemTouchListener(
new
RecyclerItemClickListener(context, new
RecyclerItemClickListener.OnItemClickListener() {
@Override
public void onItemClick(View
view, int position) {
Mahasiswa mahasiswa =
rvAdapter.getItem(position);
//Toast.makeText(context,
"Name :" + mahasiswa.getNama(),
Toast.LENGTH_SHORT).show();
// selectedPosition =
position;
Intent intent = new
Intent(MainActivity.this, MahasiswaActivity.class);
intent.putExtra("mahasiswa",
mahasiswa);
startActivityForResult(intent, REQUEST_CODE_EDIT);
}
})
);
}
private List<Mahasiswa> mahasiswaList;
// This method creates an ArrayList that has
three Fruit objects
private void initializeData(){
databaseHelper = new
DatabaseHelper(context);
db = databaseHelper.getWritableDatabase();
mahasiswaList =
databaseHelper.getDataMahasiswa(db);
}
@Override
protected void onActivityResult(int requestCode,
int resultCode, Intent data) {
super.onActivityResult(requestCode,
resultCode, data);
switch (requestCode) {
case REQUEST_CODE_ADD: {
if (resultCode == RESULT_OK && null !
= data) {
if
(data.getStringExtra("refreshflag").equals("1")) {
mahasiswaList =
databaseHelper.getDataMahasiswa(db);
gambarDatakeRecyclerView();
}
}
break;
}
case REQUEST_CODE_EDIT: {
if (resultCode == RESULT_OK && null !
= data) {
if
(data.getStringExtra("refreshflag").equals("1")) {
mahasiswaList =
databaseHelper.getDataMahasiswa(db);
gambarDatakeRecyclerView();
}
}
break;
}
}
}
@Override
public void onDestroy(){
db.close();
databaseHelper.close();
super.onDestroy();
}
}
findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
FloatingActionButton fab =
(FloatingActionButton) findViewById(R.id.fab);
fab.setOnClickListener(new
View.OnClickListener() {
@Override
public void onClick(View view) {
saveData();
}
});
getSupportActionBar().setDisplayHomeAsUpEnabled(true)
;
databaseHelper = new
DatabaseHelper(MahasiswaActivity.this);
db= databaseHelper.getWritableDatabase();
mahasiswa = new Mahasiswa();
initUI();
//initEvent();
Intent intent = getIntent();
if (intent.hasExtra("mahasiswa")) {
mahasiswa = (Mahasiswa)
intent.getSerializableExtra("mahasiswa");
Log.d(TAG, "Mahasiswa : " +
mahasiswa.toString());
setData(mahasiswa);
action_flag = "edit";
editTextNIM.setEnabled(false);
}else{
mahasiswa = new Mahasiswa();
}
}
private void setData(Mahasiswa mahasiswa) {
editTextNIM.setText(mahasiswa.getNim());
editTextNama.setText(mahasiswa.getNama());
editTextJurusan.setText(mahasiswa.getJurusan());
}
private void initUI() {
editTextNIM = (EditText)
findViewById(R.id.editTextNim);
editTextNama = (EditText)
findViewById(R.id.editTextNama);
editTextJurusan = (EditText)
findViewById(R.id.editTextJurusan);
}
private void initEvent() {
buttonSave.setOnClickListener(new
View.OnClickListener() {
@Override
public void onClick(View v) {
saveData();
}
});
buttonHapus.setOnClickListener(new
View.OnClickListener() {
@Override
public void onClick(View v) {
hapusData();
}
});
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the
action bar if it is present.
getMenuInflater().inflate(R.menu.menu_mahasiswa,
menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem
item) {
// Handle action bar item clicks here. The
action bar will
// automatically handle clicks on the
Home/Up button, so long
// as you specify a parent activity in
AndroidManifest.xml.
int id = item.getItemId();
//noinspection SimplifiableIfStatement
if (id == R.id.action_save) {
saveData();
return true;
}else if (id == R.id.action_delete) {
hapusData();
return true;
}
return super.onOptionsItemSelected(item);
}
private void saveData() {
String nama =
editTextNama.getText().toString();
String nim =
editTextNIM.getText().toString();
String jurusan =
editTextJurusan.getText().toString();
mahasiswa.setNim(nim);
mahasiswa.setNama(nama);
mahasiswa.setJurusan(jurusan);
long rowaffect=0;
if (action_flag.equals("add")) {
rowaffect =
databaseHelper.insertMahasiswa(mahasiswa, db);
}else if (action_flag.equals("edit")){
rowaffect =
databaseHelper.updateMahasiswa(mahasiswa, db);
}
if (rowaffect > 0){
Toast.makeText(getBaseContext(), "Save
Data Sukses", Toast.LENGTH_SHORT).show();
refreshFlag="1";
finish();
}else{
Toast.makeText(getBaseContext(), "Save
Data Gagal", Toast.LENGTH_SHORT).show();
}
}
16. Jika semua sudah selesai dibuat maka struktur projectnya akan terlihat
seperti dibawah ini.