青玄 发表于 2014-11-23 14:39:04

[原创]android学习之TabHost

1.布局文件的配置:
<LinearLayout 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:orientation="vertical"
    tools:context=".MainActivity" >
        <TabHost
          android:layout_width="fill_parent"
          android:layout_height="fill_parent"
          android:id="@android:id/tabhost"
          >
          <RelativeLayout
             android:layout_width="fill_parent"
             android:layout_height="fill_parent"
                >
                <TabWidget
                android:layout_width="fill_parent"
                android:layout_height="60dip"
                android:id="@android:id/tabs"
                android:background="#ffccdd"
                    ></TabWidget>
                
                <FrameLayout
                    android:layout_width="fill_parent"
                    android:layout_height="fill_parent"
                    android:layout_marginBottom="60dp"
                    android:id="@android:id/tabcontent"
                    ></FrameLayout>
          </RelativeLayout>
        </TabHost>
   
</LinearLayout>

2.选项的配置:item.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
           android:gravity="center"
           android:orientation="vertical"
    >
    <ImageView
      android:id="@+id/iv_opt_item"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:src="@drawable/tab1"
      />
    <TextView
      android:id="@+id/tv_opt_name"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="缓存清理"
      android:textColor="#99000000"
      android:textSize="12sp"
      />

</LinearLayout>

3.部分activity布局的配置:activity_m1.xml
<LinearLayout 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:gravity="center"
   
    >
   <TextView
      android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="缓存清理"
       ></TextView>

</LinearLayout>
4.部分activity布局的载入:M1.java
package com.cb.tabhost;

import com.example.tabhost_test.R;

import android.app.Activity;
import android.os.Bundle;

public class M1 extends Activity {
       
        @Override
        protected void onCreate(Bundle savedInstanceState) {
                // TODO Auto-generated method stub
                super.onCreate(savedInstanceState);
                setContentView(R.layout.activity_m1);
        }

}

5.主程序功能的实现: MainActivity.java

package com.example.tabhost_test;

import com.cb.tabhost.M1;
import com.cb.tabhost.M2;
import com.cb.tabhost.M3;

import android.os.Bundle;
import android.app.Activity;
import android.app.TabActivity;
import android.content.Intent;
import android.view.Menu;
import android.view.View;
import android.widget.ImageView;
import android.widget.TabHost;
import android.widget.TabHost.TabSpec;
import android.widget.TextView;

public class MainActivity extends TabActivity {

        @Override
        protected void onCreate(Bundle savedInstanceState) {
                super.onCreate(savedInstanceState);
                setContentView(R.layout.activity_main);
               
                TabHost myTabHost = getTabHost();
               
                TabSpec tab1 = myTabHost.newTabSpec("缓存清理");
                tab1.setIndicator(getIndicatorView("缓存清理", R.drawable.tab1));
                tab1.setContent(new Intent(this, M1.class));
               
                TabSpec tab2 = myTabHost.newTabSpec("sdcard清理");
                tab2.setIndicator(getIndicatorView("sdcard清理", R.drawable.tab2));
                tab2.setContent(new Intent(this, M2.class));
               
                TabSpec tab3 = myTabHost.newTabSpec("开机加速");
                tab3.setIndicator(getIndicatorView("开机加速", R.drawable.tab3));   
                tab3.setContent(new Intent(this, M3.class));   //这个是底下要显示的界面
                //将各项加入到tabHost里面
                myTabHost.addTab(tab1);   
                myTabHost.addTab(tab2);
                myTabHost.addTab(tab3);
                myTabHost.setCurrentTab(0);   //设置当前默认的显示位置是第一位
        }

        //这个返回的是一个转化后的布局文件
        public View getIndicatorView(String name, int id)
        {
                View view = View.inflate(this, R.layout.item, null);
                TextView tv = (TextView) view.findViewById(R.id.tv_opt_name);
                ImageView iv = (ImageView) view.findViewById(R.id.iv_opt_item);
               
                tv.setText(name);
                iv.setImageResource(id);
                return view;
        }
}






暂借 发表于 2015-1-9 13:17:20

{:5_107:}菜鸟表示看不懂。
页: [1]
查看完整版本: [原创]android学习之TabHost