Assalamualaiqum ☺
Di hari yang cerah ini saya akan kembali memposting tentang android. Kali ini saya akan membagikan tentang cara membuat TabHost pada aplikasi android.
Ok langsung saja.
- Buat project baru dengan nama TabHost.
- Isikan source code file activity_main.xml
<RelativeLayout xmlns:android=”http://schemas.android.com/apk/res/android”
xmlns:tools=”http://schemas.android.com/tools”
android:layout_width=”match_parent”
android:layout_height=”match_parent”
android:paddingBottom=”@dimen/activity_vertical_margin”
android:paddingLeft=”@dimen/activity_horizontal_margin”
android:paddingRight=”@dimen/activity_horizontal_margin”
android:paddingTop=”@dimen/activity_vertical_margin”
tools:context=”.MainActivity” > <TabHost
android:id=”@android:id/tabhost”
android:layout_width=”match_parent”
android:layout_height=”match_parent” >
<LinearLayout
android:layout_width=”match_parent”
android:layout_height=”match_parent”
android:orientation=”vertical” >
<TabWidget
android:id=”@android:id/tabs”
android:layout_width=”match_parent”
android:layout_height=”wrap_content” >
</TabWidget>
<FrameLayout
android:id=”@android:id/tabcontent”
android:layout_width=”match_parent”
android:layout_height=”match_parent” >
<LinearLayout
android:id=”@+id/tab1″
android:layout_width=”match_parent”
android:layout_height=”match_parent”
android:orientation=”horizontal” >
</LinearLayout>
<LinearLayout
android:id=”@+id/tab2″
android:layout_width=”match_parent”
android:layout_height=”match_parent”
android:orientation=”horizontal” >
</LinearLayout></FrameLayout>
</LinearLayout></TabHost></RelativeLayout>
Hasilnya:
- Buatlah dua buat file xml baru dengan nama activity_home.xml dan activity_about.xml.
- Source code activity_home.xml.
<?xml version=”1.0″ encoding=”utf-8″?>
<RelativeLayout xmlns:android=”http://schemas.android.com/apk/res/android”
android:layout_width=”match_parent”
android:layout_height=”match_parent”
android:orientation=”vertical” >
<TextView
android:id=”@+id/textView1″
android:layout_width=”wrap_content”
android:layout_height=”wrap_content”
android:layout_alignParentTop=”true”
android:layout_centerHorizontal=”true”
android:layout_marginTop=”143dp”
android:text=”@string/hal1″
android:textSize=”20sp” />
</RelativeLayout>
Hasilnya:
- File activity_about.xml
<?xml version=”1.0″ encoding=”utf-8″?>
<RelativeLayout xmlns:android=”http://schemas.android.com/apk/res/android”
android:layout_width=”match_parent”
android:layout_height=”match_parent”
android:orientation=”vertical” >
<TextView
android:id=”@+id/textView1″
android:layout_width=”wrap_content”
android:layout_height=”wrap_content”
android:layout_alignParentTop=”true”
android:layout_centerHorizontal=”true”
android:layout_marginTop=”171dp”
android:text=”@string/hal2″
android:textSize=”20sp” />
</RelativeLayout>
Hasilnya:
- Selanjutnya, bukalah file MainActivity.java. Salinlah source code dibawah ini, dan sesuaikan dengan project yang anda buat.
package com.putri.tabhost;
import android.os.Bundle;
import android.app.TabActivity;
import android.content.Intent;
import android.view.Menu;
import android.widget.TabHost;
@SuppressWarnings("deprecation")
public class MainActivity extends TabActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
TabHost tabhost = getTabHost();
TabHost.TabSpec spec;
Intent intent;
intent = new Intent().setClass(this, Home.class);//content pada tab yang akan kita buat
spec = tabhost.newTabSpec("home").setIndicator("Home",null).setContent(intent);//mengeset nama tab dan mengisi content pada menu tab anda.
tabhost.addTab(spec);//untuk membuat tabbaru disini bisa diatur sesuai keinginan anda
intent = new Intent().setClass(this, About.class);
spec = tabhost.newTabSpec("about").setIndicator("About",null).setContent(intent);
tabhost.addTab(spec);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
}
- Buatlah dua buah java class baru dengan nama Home.java dan About.java.
- Berikut source code file Home.java.
package com.irmarismay.tabhost;
import android.app.Activity;
import android.os.Bundle;
import android.widget.TextView;
public class Home extends Activity {
TextView textView1;
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_home);
textView1 = (TextView)findViewById(R.id.textView1);
}
}
- Source code file About.java
package com.irmarismay.tabhost;
import android.app.Activity;
import android.os.Bundle;
import android.widget.TextView;
public class About extends Activity {
TextView textView1;
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_about);
textView1 = (TextView)findViewById(R.id.textView1);
}
}
- Setelah selesai menyelesaikan program diatas, bukalah file AndroidManifest.xml, salinlah dan sesuaikan source code dibawah ini dengan project yang anda buat.
<?xml version=”1.0″ encoding=”utf-8″?>
<manifest xmlns:android=”http://schemas.android.com/apk/res/android”
package=”com.irmarismay.tabhost”
android:versionCode=”1″
android:versionName=”1.0″ >
<uses-sdk
android:minSdkVersion=”8″
android:targetSdkVersion=”17″ />
<application
android:allowBackup=”true”
android:icon=”@drawable/ic_launcher”
android:label=”@string/app_name”
android:theme=”@style/AppTheme” >
<activity
android:name=”com.irmarismay.tabhost.MainActivity”
android:label=”@string/app_name” >
<intent-filter>
<action android:name=”android.intent.action.MAIN” />
<category android:name=”android.intent.category.LAUNCHER” />
</intent-filter>
</activity>
<activity
android:name=”com.irmarismay.tabhost.Home”
android:label=”@string/app_name”>
</activity>
<activity
android:name=”com.irmarismay.tabhost.About”
android:label=”@string/app_name”>
</activity>
</application>
</manifest>
- Jalankan di emulator atau smartphone anda.
Selesai..
Gan, kan itu cuma pake 1 intent buat 2 tabhost. 1 intent itu memanggil 2 class java yaitu "home" dan "about". Apa itu ga bakal tabrakan?
BalasHapus