鱼C论坛

 找回密码
 立即注册
查看: 2217|回复: 1

[原创]android学习之TabHost

[复制链接]
发表于 2014-11-23 14:39:04 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
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;
        }
}
QQ截图20141123140823.png




tabhost_test.zip

1.19 MB, 下载次数: 0

源码

评分

参与人数 1荣誉 +5 鱼币 +5 贡献 +3 收起 理由
拈花小仙 + 5 + 5 + 3 感谢楼主无私奉献!

查看全部评分

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2015-1-9 13:17:20 | 显示全部楼层
菜鸟表示看不懂。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-15 16:30

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表