1.布局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="@android:id/tabhost"> <RelativeLayout android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <TextView android:id="@+id/bottomtip" android:layout_width="match_parent" android:layout_height="50dp" android:text="@string/funPageBtn2" android:gravity="center_horizontal|center_vertical" android:layout_alignParentTop="true" android:textColor="@android:color/white" android:background="@android:color/black" /> <FrameLayout android:id="@android:id/tabcontent" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_above="@android:id/tabs" android:layout_below="@+id/bottomtip" /> <TabWidget android:id="@android:id/tabs" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignParentBottom="true" android:background="@android:color/black" /> </RelativeLayout> </TabHost>
布局效果理解:
2.Activity类实现
package com.test.appdemo1.actlearn; import com.test.appdemo1.R; import android.app.TabActivity; import android.content.Intent; import android.os.Bundle; import android.widget.TabHost; import android.widget.TabHost.TabSpec; @SuppressWarnings("deprecation") public class TabOptTopAct extends TabActivity { private TabHost tabHost; protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.tabtoplayout); initTab(); } private void initTab() { tabHost = getTabHost(); TabSpec tabSpec = null; Intent intent = new Intent(this,MainActivity.class); //第一个 tabSpec = tabHost.newTabSpec("tab1") .setIndicator("首页",getResources().getDrawable(R.drawable.home)) .setContent(intent); tabHost.addTab(tabSpec); //第二个 intent = new Intent(this,NextActivity.class); tabSpec = tabHost.newTabSpec("tab2") .setIndicator("邮件",getResources().getDrawable(R.drawable.mail)) .setContent(intent); tabHost.addTab(tabSpec); //第三个 intent = new Intent(this,ServiceActDemo.class); tabSpec = tabHost.newTabSpec("tab3") .setIndicator("音乐",getResources().getDrawable(R.drawable.music)) .setContent(intent); tabHost.addTab(tabSpec); //第四个 intent = new Intent(this,FrameLearnLayoutAct.class); tabSpec = tabHost.newTabSpec("tab4") .setIndicator("计算",getResources().getDrawable(R.drawable.calc)) .setContent(intent); tabHost.addTab(tabSpec); tabHost.setCurrentTab(1); } public void onBackPressed() { super.onBackPressed(); finish(); } }
最后说明:如果想把选项卡放到顶部只需修改布局文件中RelativeLayout里面的三个元素的位置
若有问题请大家指正.
程序运行效果如上图片所示.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· SQL Server 2025 AI相关能力初探
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库