android学习笔记---66_自定义标签页

2013/7/17
66_自定义标签页
技术qq交流群:JavaDream:251572072
教程下载,在线交流:创梦IT社区: www.credream.com
smdl2tmp1.asec
8.用TabHost实现标签页与自定义标签页
--------------------------------------
a.首先了解标签页
  ------------------------------------
  |        |        |        |       |--->这个部分叫TabWigdet  
  |        |        |        |       |    用来放标签的,每一个格格
  |----------------------------------|    放一个标签          
  |                                  |
  |                                  |
  |                                  |-->这个部分叫FrameLayout,是一个
  |                                  |   用来显示每个标签页的内容的窗口
  |                                  |
  |                                  |
  |                                  |  
  |-----------------------------------
  以上整个的合起来叫做:TabHost
b.TabHost是标签页的集合,TabSpec代表标签页.得到TabHost对象后,可以调用addTab方法
  添加多个TabSpec标签页对象
----------------------------------
TabHost tabHost=(TabHost)this.findViewById(R.id.tabHost);
tabHost.setup();//查找获取ID为 android:id/tabs的TabWidget用于标签导航,
FrameLayout用于放置所有标签页面:
TabSpec  tabSpec1 = tabHost.newTabSpec("tab1");//创建标签,并指定标识
tabSpec1.setlndicator("首页",)
-----------------------------------------------------------------------------------
2.下面是自定义标签页实例的所有源码:
  a.新建android工程:tabhost
  b./tabhost/src/com/credream/tabhost/TabhostActivity.java
    package com.credream.tabhost;
import android.app.Activity;
import android.os.Bundle;
import android.os.Debug;
import android.view.Gravity;
import android.view.View;
import android.view.ViewGroup;
import android.widget.LinearLayout;
import android.widget.TabHost;
import android.widget.TabHost.TabSpec;
import android.widget.TextView;
/**
*
* @author xiaofeng 欢迎加入creDream创梦IT社区: www.credream.com
* creDream创梦QQ技术交流群:251572072
* 欢迎进入进行技术交流,或教程下载
*/
public class TabhostActivity extends Activity {
TabHost tabHost;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
      
        Debug.startMethodTracing("itcast");
//找到TabHost的标签集合
        tabHost = (TabHost) this.findViewById(R.id.tabhost);
        tabHost.setup();//这一句在源代码中,会根据findviewbyId()找到
        //对应的TabWidget,还需要根据findViewById()找到这个TabWidget下面对应的标签页的
        //内容.也就是FrameLayout这个显示控件.
        /*这里的第一个findviewbyId(),这个Id是系统指定的固定的id,可以查看api文档得到
         * 进入文档G:\android\android-sdk-windows\docs\reference\packages.html点击
         * Reference-->然后在左侧找到android-->点击然后选择:R.id-->找到tabs点击-->
         * public static final int tabs
         * Since: API Level 1
         * Constant Value: 16908307 (0x01020013)
         * 这里可以看到tabs代表的值,但是为了可读性好,还是给在布局文件main.xml中给
         * TagWidget控件,用这种方式定义id:
         * android:id="@android:id/tabs"这里@代表 访问R文件,这里代表访问的是android包中的R文件中的id
         * 这个类中的tabs
         * android是个包,R文件的类就在这个包中定义的,id是R类中的一个内部类,
         * FrameLayout控件的id代表的是:
         * android:id="@android:id/tabs"
         * */
        //TabSpec这个是标签页对象.
        TabSpec tabSpec = tabHost.newTabSpec("page1");//新建一个标签页对象.
        //tabSpec.setIndicator("首页", getResources().getDrawable(R.drawable.i1));
       //第一个参数指定标签名字,第二个,指定图片资源,汉子显示在图片的下面.
        tabSpec.setIndicator(createTabView("首页"));//设置这个标签页的标题
        //createTabView("首页")这里这个时候就可以替换成自己的API,也就那个切换标签页的显示内容页对应的view对象
        tabSpec.setContent(R.id.page1);//指定标签页的内容页.
        tabHost.addTab(tabSpec);//把这个标签页,添加到标签对象tabHost中.
       
        tabSpec = tabHost.newTabSpec("page2");
       // tabSpec.setIndicator("第二页", getResources().getDrawable(R.drawable.i2));
        tabSpec.setIndicator(createTabView("第二页"));
        tabSpec.setContent(R.id.page2);
        tabHost.addTab(tabSpec);
       
        tabSpec = tabHost.newTabSpec("page3");
        //tabSpec.setIndicator("第三页", getResources().getDrawable(R.drawable.i7));
        tabSpec.setIndicator(createTabView("第三页"));
        tabSpec.setContent(R.id.page3);
        tabHost.addTab(tabSpec);
        // 这里可以设置,哪个标签页为默认的第一个页面.
        tabHost.setCurrentTab(0);
    }
   
@Override
protected void onDestroy() {
  Debug.stopMethodTracing();
  super.onDestroy();
}
//这里可以做一个自定义标签页,返回一个view,tabSpec.setIndicator(createTabView("第二页"))
//因为这里可以传一个view进去.
private View createTabView(String name) {
  //通过下面的这句可以得到自定义的标签页的view对象.
  //View tabView = getLayoutInflater().inflate(R.layout.tab, null);
  //TextView textView =tabView.findViewById(R.id.name);//找到textview控件
  //textView.setText(name);显示这个名称.
  //return tabView
 
 
  LinearLayout linearLayout = new LinearLayout(this);
  linearLayout.setOrientation(LinearLayout.VERTICAL);
  linearLayout.setBackgroundColor(0xFFFFFF);
 
  TextView textView = new TextView(this);
  textView.setText(name);
  textView.setBackgroundResource(R.drawable.tab_bg);
  textView.setTextColor(0xFFFFFF);
  textView.setTextSize(18.0f);
  textView.setGravity(Gravity.CENTER);
  ViewGroup.LayoutParams params = new ViewGroup.LayoutParams(
    ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT);
  linearLayout.addView(textView, params);
 
  return linearLayout;
}
}
-----------------------------------------------------
c.在drawable文件夹中放入项目需要的两张图片,用来做标签页的背景图:
  /tabhost/res/drawable/bg_normal.9.png
  /tabhost/res/drawable/bg_selected.9.png
----------------------------------------------
d.写标签页的切换效果的/tabhost/res/drawable/tab_bg.xml文件,这里用到状态列表图片
  <?xml version="1.0" encoding="utf-8"?>
< selector xmlns:android=" http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true" android:drawable="@drawable/bg_selected" />
    <!-- 当用户按下Textview的时候显示这张图片 -->
    <!-- pressed -->
    <!-- 当用户选择TextView的时候显示这张图片 -->
<item android:state_selected="true" android:drawable="@drawable/bg_selected" />
    <!-- 其他状态显示的是这张图片 -->
    <item android:drawable="@drawable/bg_normal" /> <!-- default -->
< /selector>
------------------------------------------------------------------------------
e.放上用来做为标签页的图标文件
  /tabhost/res/drawable-hdpi/i1.png
  /tabhost/res/drawable-hdpi/i2.png
  /tabhost/res/drawable-hdpi/i7.png
  /tabhost/res/drawable-hdpi/icon.png
--------------------------------------------
f.项目的布局文件:
  /tabhost/res/layout/main.xml
  <?xml version="1.0" encoding="utf-8"?>
< TabHost xmlns:android=" http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:id="@+id/tabhost"
    >
    <!-- tabhost用来存放标签对象
    1.在标签页中,每一页和这一页的内容,是垂直摆放的所以这里用到了线性布局
    -->
<LinearLayout
android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android rientation="vertical"
>
<!-- 这里开始存放每个标签TabWidget ,这个标签可以存放所有的标签TabWidget-->
  <TabWidget
  android:layout_width="fill_parent"
     android:layout_height="wrap_content"
     android:id="@android:id/tabs"
  />
  <!-- android:id="@android:id/tabs"这个是在系统文件中定义的,是写死的 -->
  <!-- 因为每个标签页相当于浮动的,所以这里每个标签页的内容用到了帧布局 -->
  <FrameLayout
  android:layout_width="fill_parent"
     android:layout_height="fill_parent"
     android:id="@android:id/tabcontent"
  >
  <!-- 这里放的是第一个标签的内容 -->
   <LinearLayout
   android:layout_width="fill_parent"
      android:layout_height="fill_parent"
      android:id="@+id/page1"
   >
   <!-- 第一个的标签页显示的内容 -->
      <TextView
      android:layout_width="fill_parent"
       android:layout_height="wrap_content"
       android:text="这是第一个标签页"
      />
   </LinearLayout>
  <!-- 第二个的标签页显示的内容 -->
     <LinearLayout
   android:layout_width="fill_parent"
      android:layout_height="fill_parent"
      android:id="@+id/page2"
   >
      <TextView
      android:layout_width="fill_parent"
       android:layout_height="wrap_content"
       android:text="这是第二个标签页"
      />
   </LinearLayout>
   <!-- 第三个的标签页显示的内容 -->
      <LinearLayout
   android:layout_width="fill_parent"
      android:layout_height="fill_parent"
      android:id="@+id/page3"
   >
      <TextView
      android:layout_width="fill_parent"
       android:layout_height="wrap_content"
       android:text="这是第三个标签页"
      />
   </LinearLayout>
  </FrameLayout>
</LinearLayout>
< /TabHost>
------------------------------------------------------------------------------
g./tabhost/res/layout/tab.xml这里是标签页内容定义文件,可以在activity中进行调用
  <?xml version="1.0" encoding="utf-8"?>
< LinearLayout
  xmlns:android=" http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android rientation="vertical"
  android:background="#FFFFFF"
  >
< !-- 这里要求当用户按住textview的时候,显示一张图片,当textview被
选择的时候显示一张图片,当其他状态的时候,也显示一张图片
android:background="@drawable/tab_bg"
//给这个TextView应用这个状态列表图像.
-->
    <TextView
  android:background="@drawable/tab_bg"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:gravity="center"
  android:textSize="18sp"
  android:textColor="#FFFFFF"
  android:layout_marginRight="1dp"
  android:id="@+id/name"
  />
   <!--
   android:background="@drawable/tab_bg"
   //这里用到了状态列表图形,这里需要随着标签页的切换来改变图形
   //这里的状态列表图形定义,可以参考api:
   //打开Dev Guide这个标签->然后在左侧选择->
   //Framework Topics -Application Resources->
   //Resource Types->Drawable->State List->然后拷贝例子代码到tab_bg.xml中
   android:layout_marginRight="1dp"定义了标签页之间的间隔颜色
  
    android:gravity="center"指定内容要居中对齐 -->
< /LinearLayout>

你可能感兴趣的:(android学习笔记---66_自定义标签页)