TabWidget类似Android中查看电话簿的界面,通过多个标签切换显示不同的内容。要实现这一效果,首先要了解TabHost ,它是一个用来存放多个Tab标签的容器。每一个Tab都可以对应自己的布局,比如,电话簿中的Tab布局就是一个List的线性布局了。

之前发表的文章中Tab图片显示似乎不起作用,在此做了些改进。

要使用TabHost ,首先需要通过getTabHost 方法来获取TabHost的对象,然后通过addTab方法来向TabHost中添加Tab。当然每个Tab在切换时都会产生一个事件,要捕捉这个事件需要设置TabActivity的事件监听器  setOnTabChangedListener。

首先我们来看布局中如何实现,如下代码所示。其中Tab对应的布局通过FrameLayout作为根布局,然后分别放置了3个TextView控件来显示每个Tab标签的内容。

 

<?xml version="1.0" encoding="utf-8"?>
<TabHost xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@android:id/tabhost"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent" >

    <RelativeLayout
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:orientation="vertical" >

        <FrameLayout
            android:id="@android:id/tabcontent"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content" >

            <TextView
                android:id="@+id/textview1"
                android:layout_width="fill_parent"
                android:layout_height="fill_parent"
                android:text="this is a tab" />

            <TextView
                android:id="@+id/textview2"
                android:layout_width="fill_parent"
                android:layout_height="fill_parent"
                android:text="this is another tab" />

            <TextView
                android:id="@+id/textview3"
                android:layout_width="fill_parent"
                android:layout_height="fill_parent"
                android:text="this is a third tab" />
        </FrameLayout>

        <TabWidget
            android:id="@android:id/tabs"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_alignParentBottom="true" >
        </TabWidget>

    </RelativeLayout>

</TabHost>

 

TabWidget的使用需要继承自TabActivity类,并实现tsetOnTabChangedListener的onTabChanged方法来监听Tab的改变,并根据Tab的·改变修改背景图片如下代码所示:

 

package com.my.tabwidget;

import java.util.ArrayList;
import java.util.List;

import android.app.TabActivity;
import android.graphics.Color;
import android.os.Bundle;
import android.view.Gravity;
import android.view.View;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TabHost;
import android.widget.TabHost.OnTabChangeListener;
import android.widget.TextView;

@SuppressWarnings("deprecation")
public class MainActivity extends TabActivity {

	//声明TabHost对象    
	    TabHost mTabHost;   
	    public List<ImageView> imageList = new ArrayList<ImageView>(); 
	    /** Called when the activity is first created. */  
	    @Override  
	    public void onCreate(Bundle savedInstanceState)   
	    {   
	        super.onCreate(savedInstanceState);   
	        setContentView(R.layout.activity_main);   
	             
	        //取得TabHost对象    
	        mTabHost = getTabHost();   
	            
	        /* 为TabHost添加标签 */  
	        //新建一个newTabSpec(newTabSpec)    
	        //设置其标签和图标(setIndicator)    
	        //设置内容(setContent)    
	        mTabHost.addTab(mTabHost.newTabSpec("tab_test1")   
	                .setIndicator(composeLayout("TAB_1", R.drawable.img1))   
	                .setContent(R.id.textview1));   
	        mTabHost.addTab(mTabHost.newTabSpec("tab_test2")   
	                .setIndicator(composeLayout("TAB_2", R.drawable.img2))   
	                .setContent(R.id.textview2));   
	        mTabHost.addTab(mTabHost.newTabSpec("tab_test3")   
	                .setIndicator(composeLayout("TAB_3", R.drawable.img3))   
	                .setContent(R.id.textview3));   
	             
	        //设置TabHost的背景颜色    
	        //mTabHost.setBackgroundColor(Color.argb(150, 22, 70, 150));   
	        //设置TabHost的背景图片资源    
	        //mTabHost.setBackgroundResource(R.drawable.image1);    
	             
	        //设置当前显示哪一个标签    
	        mTabHost.setCurrentTab(0); 
	        imageList.get(0).setImageDrawable(getResources().getDrawable(R.drawable.img01));
	             
	        //标签切换事件处理,setOnTabChangedListener    
	        mTabHost.setOnTabChangedListener(new OnTabChangeListener()   
	        {   
	            // TODO Auto-generated method stub    
	        	@Override  
	            public void onTabChanged(String tabId)   
	            {   
	        		        // 设置所有选项卡的图片为未选中图片   
	        		        imageList.get(0).setImageDrawable(getResources().getDrawable(R.drawable.img1));  
	        		        imageList.get(1).setImageDrawable(getResources().getDrawable(R.drawable.img2));  
	        		        imageList.get(2).setImageDrawable(getResources().getDrawable(R.drawable.img3));  
	        		          
	        		        if (tabId.equalsIgnoreCase("tab_test1")) {  
	        		            imageList.get(0).setImageDrawable(getResources().getDrawable(R.drawable.img01));  
	        		            // 移动底部背景图片   
	        		            //moveTopSelect(0);  
	        		        } else if (tabId.equalsIgnoreCase("tab_test2")) {  
	        		            imageList.get(1).setImageDrawable(getResources().getDrawable(R.drawable.img02));  
	        		            // 移动底部背景图片   
	        		            //moveTopSelect(1);  
	        		        } else if (tabId.equalsIgnoreCase("tab_test3")) {  
	        		            imageList.get(2).setImageDrawable(getResources().getDrawable(R.drawable.img03));  
	        		            // 移动底部背景图片   
	        		            //moveTopSelect(2);  
	        		        }  

	            }              
	        });   
	    }   
	    /** 
	     * 这个设置Tab标签本身的布局,需要TextView和ImageView不能重合 s:是文本显示的内容 i:是ImageView的图片位置 
	     */
	    public View composeLayout(String s, int i) {  
	    	        // 定义一个LinearLayout布局   
	    	        LinearLayout layout = new LinearLayout(this);  
	    	        // 设置布局垂直显示   
	    	        layout.setOrientation(LinearLayout.VERTICAL);  
	    	        ImageView iv = new ImageView(this);  
	    	        imageList.add(iv);  
	    	        iv.setImageResource(i);  
	    	        //设置图片布局
	    	        LinearLayout.LayoutParams lp = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.FILL_PARENT, 50);  
	    	        lp.setMargins(0, 0, 0, 0);  
	    	        layout.addView(iv, lp);  
	    	        // 定义TextView   
	    	        TextView tv = new TextView(this);  
	    	        tv.setGravity(Gravity.CENTER);  
	    	        tv.setSingleLine(true);  
	    	        tv.setText(s);  
	    	        tv.setTextColor(Color.BLACK);  
	    	        tv.setTextSize(10);  
	    	        //设置Text布局
	    	        layout.addView(tv, new LinearLayout.LayoutParams(LinearLayout.LayoutParams.FILL_PARENT, LinearLayout.LayoutParams.WRAP_CONTENT));  
	    	        return layout;  
	    	    }
}

 

 

效果图:

                                                  

 

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐