zoukankan      html  css  js  c++  java
  • 玩转Android TabWidget(切换卡)

    Tab选项卡类似与电话本的界面,通过多个标签切换不同的内容,要实现这个效果,首先要知道TabHost,它是一个用来存放多个Tab标签的容器,每一个Tab都可以对应自己的布局,比如,电话本中的Tab布局就是一个线性布局
    要使用TabHost,首先要通过getTabHost方法获取TabHost的对象,然后通过addTab方法来向TabHost中添加Tab,当然每个Tab在切换时都会产生一个事件,要捕捉这个事件,需要设置TabActivity的事件监听setOnTabChangedListener
    下面是个小例子:
    TabTest.java   
      
    view plaincopy to clipboardprint?   
    package org.hualang.tab;     
    import android.app.Activity;     
    import android.app.TabActivity;     
    import android.graphics.Color;     
    import android.os.Bundle;     
    import android.widget.TabHost;     
    import android.widget.Toast;     
    import android.widget.TabHost.OnTabChangeListener;     
    public class TabTest extends TabActivity {     
        /** Called when the activity is first created. */     
        TabHost tabhost;     
        @Override     
        public void onCreate(Bundle savedInstanceState) {     
            super.onCreate(savedInstanceState);     
            setContentView(R.layout.main);     
            //取得TabHost对象     
            tabhost = getTabHost();     
            //为TabHost添加标签     
            //新建一个newTabSpec(newTabSpec)     
            //设置其标签和图标(setIndicator)     
            //设置内容(setContent)     
            tabhost.addTab(tabhost.newTabSpec("tab1")     
                    .setIndicator("TAB 1",getResources().getDrawable(R.drawable.img1))     
                    .setContent(R.id.text1));     
            tabhost.addTab(tabhost.newTabSpec("tab2")     
                    .setIndicator("TAB 2",getResources().getDrawable(R.drawable.img2))     
                    .setContent(R.id.text2));     
            tabhost.addTab(tabhost.newTabSpec("tab3")     
                    .setIndicator("TAB 3",getResources().getDrawable(R.drawable.img3))     
                    .setContent(R.id.text3));     
            //设置TabHost的背景颜色     
            //tabhost.setBackgroundColor(Color.argb(150,22,70,150));     
            //设置TabHost的背景图片资源     
            tabhost.setBackgroundResource(R.drawable.bg0);     
            //设置当前显示哪个标签     
            tabhost.setCurrentTab(0);     
            //标签切换事件处理,setOnTabChangedListener     
            tabhost.setOnTabChangedListener(new OnTabChangeListener()     
            {     
                public void onTabChanged(String tabId)     
                {     
                    Toast toast=Toast.makeText(getApplicationContext(), "现在是"+tabId+"标签", Toast.LENGTH_SHORT);     
                    toast.show();     
                }     
            });     
                 
        }     
    }     
    main.xml
    <?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">     
        <LinearLayout     
            android:orientation="vertical"     
            android:layout_width="fill_parent"     
            android:layout_height="fill_parent">     
            <TabWidget     
                android:id="@android:id/tabs"     
                android:layout_width="fill_parent"     
                android:layout_height="wrap_content" />     
            <FrameLayout     
                android:id="@android:id/tabcontent"     
                android:layout_width="fill_parent"     
                android:layout_height="fill_parent">     
                <TextView      
                    android:id="@+id/text1"     
                    android:layout_width="fill_parent"     
                    android:layout_height="fill_parent"      
                    android:text="选项卡1" />     
                <TextView      
                    android:id="@+id/text2"     
                    android:layout_width="fill_parent"     
                    android:layout_height="fill_parent"      
                    android:text="选项卡2" />     
                <TextView      
                    android:id="@+id/text3"     
                    android:layout_width="fill_parent"     
                    android:layout_height="fill_parent"      
                    android:text="选项卡3" />     
            </FrameLayout>     
        </LinearLayout>     
    </TabHost>    
  • 相关阅读:
    [转] 64位Oracle 11g R2的客户端连接时报ORA-01019错误
    [转]Oracle11g链接提示未“在本地计算机注册“OraOLEDB.Oracle”解决方法
    [转]通过Net Manager 配置Oracle 11g本地监听服务(listener service)
    [转]jQuery Mobile动态刷新页面样式
    [转]SSIS
    [转]在SSIS中,使用“包配置”时的常见错误与解析
    使用JMH做Java微基准测试
    秒杀系统解决方案
    cookie机制和session机制
    app如何节省流量
  • 原文地址:https://www.cnblogs.com/top5/p/2415941.html
Copyright © 2011-2022 走看看