关闭 x
IT技术网
    技 采 号
    ITJS.cn - 技术改变世界
    • 实用工具
    • 菜鸟教程
    IT采购网 中国存储网 科技号 CIO智库

    IT技术网

    IT采购网
    • 首页
    • 行业资讯
    • 系统运维
      • 操作系统
        • Windows
        • Linux
        • Mac OS
      • 数据库
        • MySQL
        • Oracle
        • SQL Server
      • 网站建设
    • 人工智能
    • 半导体芯片
    • 笔记本电脑
    • 智能手机
    • 智能汽车
    • 编程语言
    IT技术网 - ITJS.CN
    首页 » 安卓开发 »Android UI控件系列:Tab Layout(选项卡布局)

    Android UI控件系列:Tab Layout(选项卡布局)

    2014-11-29 00:00:00 出处:51CTO
    分享

    为了创建一个选项卡的UI,你需要使用一个TabHost和一个TabWidget,TabHost必须是布局文件的根节点,它包含了为了显示选项卡的TabWidget和一个用于显示选项内容的FrameLayout

    你可以用一或两种方法实现你的选项卡内容:在用一个Activity中用选项卡来在视图之间切换,或者用用选项卡来改变所有的分离的Activity。你根据你的需求来使用你想在程序中的方法,但是假如每个选项卡提供一个独特的用户Activity,那么为每个选项卡实现独立的Activity是有意义的,所有你最好在你的离散群里管理应用程序,要好过使用大量的应用程序和布局文件。

    在这个例子中,你可以创建一个为每个单独的Activity创建选项卡来创建一个选项卡UI

    1、开始一个新的工程,叫做HelloTabWidget

    2、第一,创建三个独立的Activity程序在你的工程中:ArtistsActivity,AlbumsActivity,和SongsActivity,他们每个代表一个单独的选项卡,现在用TextView来没每个程序显示一个简单的信息,比如:

    package org.hualang.tabwidget;
    
    import android.app.Activity;
    import android.os.Bundle;
    import android.widget.TextView;
    
    public class AlbumsActivity extends Activity {
            public void onCreate(Bundle savedInstanceState)
            {
                    super.onCreate(savedInstanceState);
                     TextView textview = new TextView(this);
                     textview.setText("This is the Albums tab");        
                    setContentView(textview);
            }
    }
    package org.hualang.tabwidget;
    
    import android.app.Activity;
    import android.os.Bundle;
    import android.widget.TextView;
    
    public class SongsActivity extends Activity {
            public void onCreate(Bundle savedInstanceState)
            {
                    super.onCreate(savedInstanceState);
                     TextView textview = new TextView(this);
                     textview.setText("This is the Songs tab"); 
                    setContentView(textview);
            }
    
    }
    package org.hualang.tabwidget;
    
    import android.app.Activity;
    import android.os.Bundle;
    import android.widget.TextView;
    
    public class ArtistsActivity extends Activity {
        /** Called when the activity is first created. */
        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
                     TextView textview = new TextView(this);
                     textview.setText("This is the Artists tab"); 
            setContentView(textview);
        }
    }

    注意这个例子中不需要布局文件,只需要创建一个TextView,并且为文本赋值即可。重复创建三个类似的Activity,并且要在AndroidManifest.xml文件中注册,否则报错

    3、你需要为每个选项卡设置一个icon,每个icon,你可以有两个版本,一个是当选项卡被选中的时候,另一个是当选项卡未被选中的时候。一般设计来说,建议当被选中的时候用灰色,的那个未被选中的时候用白色,比如


    你可以拷贝这两张图片来做实验用

    现在创建一个状态图片列表来制定每个选项卡不同状态的时候所指定的图片
    ①把图排尿保存在res/drawable/目录下
    ②在res/drawable/目录下创建一个名为ic_tab_artists.xml文件,并且插入如下信息

    < xml version="1.0" encoding="utf-8" >
    <selector xmlns:android="http://schemas.android.com/apk/res/android">
    <!-- When selected,use grey -->
            <item android:drawable="@drawable/ic_tab_artists_grey"
                    android:state_selected="true"/>
            <!-- When not selected ,use white -->
            <item android:drawable="@drawable/ic_tab_artists_white"/>
    </selector>

    上面这个文件,当选项卡的状态改变的时候,选项卡就会自动的在两种已经定义的图片之间切换

    4、打开res/layout/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"
            android:padding="5dp">
            <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"
                android:padding="5dp" />
        </LinearLayout>
    </TabHost>

    这个布局文件将显示选项卡兵器提供每个Activity之间的导航

    TabHost要求一个TabWidget和一个FrameLayout布局,为了使TabWidget和FrameLayout的位置处于垂直方向,需要一个LinearLayout,FrameLayout是每个选项卡内容的地方,之所以那里的内容是空的是因为在TahHost中将自动为每个Activity嵌入

    注意,TabWidget和FrameLayout元素的ID标签和tabcontent元素,这些名称必须使用,因为TahHost检索他们的引用,它恰好期望的是这些名字

    6、编写HelloTabWidget。继承TabWidget

    package org.hualang.tabwidget;
    
    import android.app.TabActivity;
    import android.content.Intent;
    import android.content.res.Resources;
    import android.os.Bundle;
    import android.widget.TabHost;
    
    public class HelloTabWidget extends TabActivity  {
            public void onCreate(Bundle savedInstanceState) {
                super.onCreate(savedInstanceState);
                setContentView(R.layout.main);
    
                Resources res = getResources(); // Resource object to get Drawables
                TabHost tabHost = getTabHost();  // The activity TabHost
                TabHost.TabSpec spec;  // Resusable TabSpec for each tab
                Intent intent;  // Reusable Intent for each tab
    
                // Create an Intent to launch an Activity for the tab (to be reused)
                intent = new Intent().setClass(this, ArtistsActivity.class);
    
                // Initialize a TabSpec for each tab and add it to the TabHost
                spec = tabHost.newTabSpec("artists").setIndicator("Artists",
                                  res.getDrawable(R.drawable.ic_tab_drawable))
                              .setContent(intent);
                tabHost.addTab(spec);
    
                // Do the same for the other tabs
                intent = new Intent().setClass(this, AlbumsActivity.class);
                spec = tabHost.newTabSpec("albums").setIndicator("Albums",
                                  res.getDrawable(R.drawable.ic_tab_drawable))
                              .setContent(intent);
                tabHost.addTab(spec);
    
                intent = new Intent().setClass(this, SongsActivity.class);
                spec = tabHost.newTabSpec("songs").setIndicator("Songs",
                                  res.getDrawable(R.drawable.ic_tab_drawable))
                              .setContent(intent);
                tabHost.addTab(spec);
    
                tabHost.setCurrentTab(2);
            }
    
    }

    运行结果:

    上一篇返回首页 下一篇

    声明: 此文观点不代表本站立场;转载务必保留本文链接;版权疑问请联系我们。

    别人在看

    电脑屏幕不小心竖起来了?别慌,快捷键搞定

    Destoon 模板存放规则及语法参考

    Destoon系统常量与变量

    Destoon系统目录文件结构说明

    Destoon 系统安装指南

    Destoon会员公司主页模板风格添加方法

    Destoon 二次开发入门

    Microsoft 将于 2026 年 10 月终止对 Windows 11 SE 的支持

    Windows 11 存储感知如何设置?了解Windows 11 存储感知开启的好处

    Windows 11 24H2 更新灾难:系统升级了,SSD固态盘不见了...

    IT头条

    Synology 更新 ActiveProtect Manager 1.1 以增强企业网络弹性和合规性

    00:43

    新的 Rubrik Agent Cloud 加速了可信的企业 AI 代理部署

    00:34

    宇树科技 G1人形机器人,拉动一辆重达1.4吨的汽车

    00:21

    Cloudera 调查发现,96% 的企业已将 AI 集成到核心业务流程中,这表明 AI 已从竞争优势转变为强制性实践

    02:05

    投资者反对马斯克 1 万亿美元薪酬方案,要求重组特斯拉董事会

    01:18

    技术热点

    大型网站的 HTTPS 实践(三):基于协议和配置的优化

    ubuntu下右键菜单添加新建word、excel文档等快捷方式

    Sublime Text 简明教程

    用户定义SQL Server函数的描述

    怎么在windows 7开始菜单中添加下载选项?

    SQL Server 2016将有哪些功能改进?

      友情链接:
    • IT采购网
    • 科技号
    • 中国存储网
    • 存储网
    • 半导体联盟
    • 医疗软件网
    • 软件中国
    • ITbrand
    • 采购中国
    • CIO智库
    • 考研题库
    • 法务网
    • AI工具网
    • 电子芯片网
    • 安全库
    • 隐私保护
    • 版权申明
    • 联系我们
    IT技术网 版权所有 © 2020-2025,京ICP备14047533号-20,Power by OK设计网

    在上方输入关键词后,回车键 开始搜索。Esc键 取消该搜索窗口。