安卓TabHost+ViewPager+RadioGroup多功能模板整理

现在安卓比较流行的布局就是类似新闻客户端和手机QQ那种的底端可选择,上面的个别页面可以滑动选择。

在测试过程中发现用安卓自带的TabHost去构建,很难得到自定义的效果。

因此采用TabHost+ViewPager+RadioGroup去构建这个效果

首先要弄清楚各自的用途和功能

(1)TabHost

由于安卓自带的TabHost貌似在有些手机版本上只能固定在底端的位置,所以我们用GadioGroup去显示界面按钮,由于构建HabHost必须定义host、tabs、content几个内容,这样我们隐藏tabs,用GadioGroup代替显示。代码如下:

<TabHost xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
   <span style="color:#ff0000;"> android:id="@android:id/tabhost" </span>
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.example.android_mode.MainActivity" >

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

        <FrameLayout
            <span style="color:#ff0000;">android:id="@android:id/tabcontent"</span>
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:layout_weight="1" >
        </FrameLayout>

        <TabWidget
            <span style="color:#ff0000;">android:id="@android:id/tabs"</span>
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            <span style="color:#000066;">android:visibility="gone"</span> >
        </TabWidget>

        <RadioGroup
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:orientation="horizontal" >

            <RadioButton
                android:id="@+id/b1"
                android:layout_width="wrap_content"
                android:layout_height="40dp"
                android:layout_weight="1"
                android:background="#00ABCD"
                android:button="@null"
                android:gravity="center"
                android:text="首页" />

            <View
                android:layout_width="2px"
                android:layout_height="fill_parent" />

            <RadioButton
                android:id="@+id/b2"
                android:layout_width="wrap_content"
                android:layout_height="40dp"
                android:layout_weight="1"
                android:background="#00ABCD"
                android:button="@null"
                android:gravity="center"
                android:text="设置" />
        </RadioGroup>
    </LinearLayout>

</TabHost>

对于主文件,由于在安卓3.0版本以下不支持TabActivity,因此我们考虑到兼容性,选用ActivityGroup。

其具体方法如下所示:

public class MyTabOwnAct extends ActivityGroup {

	RadioButton radioButton1;
	RadioButton radioButton2;
	TabHost tabHost;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		// TODO Auto-generated method stub
		super.onCreate(savedInstanceState);
		setContentView(R.layout.tabmain);
		tabHost = (TabHost) findViewById(android.R.id.tabhost);
		tabHost.setup();
		tabHost.setup(this.getLocalActivityManager());  //必须要又这个语句,如果继承TabActivity可不要
		tabHost.addTab(tabHost.newTabSpec("l1")
				.setContent(new Intent(this, Act1.class)).setIndicator("首页"));
		tabHost.addTab(tabHost.newTabSpec("l2")
				.setContent(new Intent(this, Act2.class)).setIndicator("设置"));
		radioButton1 = (RadioButton) findViewById(R.id.b1);
		radioButton2 = (RadioButton) findViewById(R.id.b2);
		radioButton1.setOnClickListener(new OnClickListener() {

			@Override
			public void onClick(View arg0) {
				// TODO Auto-generated method stub
				tabHost.setCurrentTabByTag("l1");  //显示与隐藏的标记
			}
		});
		radioButton2.setOnClickListener(new OnClickListener() {

			@Override
			public void onClick(View arg0) {
				// TODO Auto-generated method stub
				tabHost.setCurrentTabByTag("l2");
			}
		});
	}
}

到目前为止我们把底部的效果实现,即可以通过下面的按钮,改变上面的界面。

接下来我们选择上面其中的一个界面,用ViewPager实现滑动的效果。

界面布局文件如下:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <LinearLayout
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal" >

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="40dp"
            android:layout_weight="1"
            android:background="#FF0fab"
            android:gravity="center"
            android:text="页面一" />

        <View
            android:layout_width="2dp"
            android:layout_height="fill_parent" />

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="40dp"
            android:layout_weight="1"
            android:background="#da0ccb"
            android:gravity="center"
            android:text="页面二" />

        <View
            android:layout_width="2dp"
            android:layout_height="fill_parent" />

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="40dp"
            android:layout_weight="1"
            android:background="#eeffff"
            android:gravity="center"
            android:text="页面三" />
    </LinearLayout>

    <android.support.v4.view.ViewPager
        android:id="@+id/pager"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent" >
    </android.support.v4.view.ViewPager>

</LinearLayout>
</pre><span style="font-size:18px">我们要准备三个界面的布局,这里我分别命名为p1.xml,p2.xml,p3.xml,然后我们在主文件中通过得到ViewPager后关联到适配器,即可得到滑动的效果。</span><pre name="code" class="java"><span style="font-family: Arial, Helvetica, sans-serif;">public class Act1 extends Activity {</span>
	ViewPager pager;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		// TODO Auto-generated method stub
		super.onCreate(savedInstanceState);
		setContentView(R.layout.pager);
		pager = (ViewPager) findViewById(R.id.pager);

		pager.setAdapter(new MyPagerAdapter());
	}

	class MyPagerAdapter extends PagerAdapter {
		List<View> list = new ArrayList<View>();

		public MyPagerAdapter() {
			// TODO Auto-generated constructor stub
			View view1 = LayoutInflater.from(getApplicationContext()).inflate(
					R.layout.p1, null);
			View view2 = LayoutInflater.from(getApplicationContext()).inflate(
					R.layout.p2, null);
			View view3 = LayoutInflater.from(getApplicationContext()).inflate(
					R.layout.p3, null);
			list.add(view1);
			list.add(view2);
			list.add(view3);

		}

		@Override
		public Object instantiateItem(ViewGroup container, int position) {
			// TODO Auto-generated method stub
			((ViewPager) container).addView(list.get(position));
			return list.get(position);
		}

		@Override
		public void destroyItem(ViewGroup container, int position, Object object) {
			// TODO Auto-generated method stub
			// super.destroyItem(container, position, object);
			((ViewPager) container).removeView(list.get(position));///(position);// (list.get(position));
		}

		@Override
		public int getCount() {
			// TODO Auto-generated method stub
			return list.size();
		}

		@Override
		public boolean isViewFromObject(View arg0, Object arg1) {
			// TODO Auto-generated method stub
			return arg0 == arg1;
		}

	}
}

效果显示图:

时间: 2024-10-26 18:22:48

安卓TabHost+ViewPager+RadioGroup多功能模板整理的相关文章

安卓蓝牙实现即时通讯功能

安卓蓝牙实现即时通讯功能 本demo是<Android智能穿戴设备开发指南>书中的一块内容,实现了两台手机基于蓝牙进行即时通讯的功能. demo演示如下: 结构图 主要代码 MainActivity:启动服务器和客户端界面 @Override public void onClick(View arg0) { switch (arg0.getId()) { case R.id.startServerBtn: //打开服务器 Intent serverIntent = new Intent(Mai

手机客户端接口开发文档模板整理

这是个人整理的手机开发文档模板,方便自己以后编写文档. 大体内容如下,详细在个人csdn中下载: 移动端转发短信上传温湿度信息 移动端负责后台接收温湿度传感器通过短信发来的温湿度和经纬度信息,移动端后台接收后上传web服务器,当然传感器也可通过wifi直接上传web服务器.返回小写true或者false. 请求URL: http://192.168.1.101:8080/RFID/addTransTemperature.action?phoneNumber=123&temperature=12.

安卓实现记住密码登陆功能

在安卓程序中,我们经常会使用到很多登陆的功能,会看到很多记住密码的地方.这里,我给大家写一个简单的记住密码的功能.注意,这里是简单的记住密码功能,仅用于练习学习用哦.这个程序主要是给学习安卓的朋友作为一个入门程序来学习.用到的知识点主要就是JAVA的IO流知识.所以,如果对IO流知识不熟悉的朋友们,一定要好好回去复习一下IO的知识.IO流的知识对于我们以后的开发有着十分重要的地位.这里顺便给点建议,学习安卓其实到头来,难得还是JAVA.如果前期JAVA学的好,其实安卓学起来是还是比较得心应手的.

安卓屏幕助手下载及功能介绍

软件目的 随着安卓应用开发的普及,手机项目演示时很不方便.安卓屏幕助手旨在解决此问题 软件简介 通过安卓屏幕助手,手机USB连接上电脑后,在电脑屏幕上同步显示手机的屏幕画面. 功能列表 实时同步显示手机屏幕,支持横屏竖屏切换. 实时记录屏幕影像保存为视频. 截取当前屏幕保存为图片. 软件截图 注意事项 软件正常使用前提:电脑安装了豌豆荚等助手软件,并开启.通过USB连接手机 其他说明:由于ADB接口的限制,传输效果达不到实时. 文件下载 安卓屏幕助手.zip

安卓---Tabhost实现页面局部刷新

TabHost的实现分为两种,一个是不继承TabActivity,一个是继承自TabActivity:当然了选用继承自TabActivity的话就相对容易一些,下面来看看分别是怎样来实现的吧. 我只写继承TabActivity,文章末尾会给一个比较牛逼的链接,本人也是照着他的做的 首先准备几个跳转的页面,布局文件里面的东西大家自己添加,没必要按照我的布局来, main2.xml <?xml version="1.0" encoding="utf-8"?>

saltstack state.sls常用功能模板编写

saltstack常用功能模块编写 一.简介 Master - 控制中心,salt命令运行和资源状态管理端 Minions - 需要管理的客户端机器,会主动去连接Master端,并从Master端得到资源状态信息,同步资源管理信息 States - 配置管理的指令集 Modules- 包含命令行下运行的指令,和在配置文件里面使用的指令模块可以的函数可以在命令行下运行 Grains - minion端的变量,静态 pillar - minion端的变量,动态,可自定义 highstate - 给m

『嗨威说』常见的C++函数模板整理(一)

开学两天,身上的职责直接变为两个班班长,三个小组组长,哇这事情估计够我忙活了,想躲都躲不掉啊,看来我还是真招人推荐各种管理职务啊,以后要是有人推荐我当经理啊领导啊该多好哈哈哈哈.记得今天奶奶生日,很开心地给奶奶打了一通电话,这怕是我第一次给奶奶电话送生日祝福了哈哈哈,是啊,很想珍惜身边的人,但很多时候却一心想提高自己地能力而忽视了身边人,就这四年,就这四年好好提升自己,毕业出来一定要好好陪陪家里祖辈亲戚们. 今天有点特殊,我整理了一下学到这么久编程以来的一些模板和技巧,虽然还没整理完,就作为(一

sed常用模板整理

sed可以按照指令或脚本编辑文本的linux工具,文本处理功能非常强大,本文总结一些工作中常用的sed模板,方便大家使用 替换 1. 替换文件中所有的 aaa 到 bbb sed -i 's/aaa/bbb/g' /path/to/file 2. 找到文件的修改日期 stat deploy | sed -n '/^Modify.*/p' # 找到 stat deploy | sed -n '/^Modify.*/p' | grep -Eo "....-..-.. ..:..:.." #

【POJ 3241】曼哈顿最小生成树(模板整理)

关于 曼哈顿最小生成树 的证明见:http://www.2cto.com/kf/201505/399861.html 模板: #include<cmath> #include<cstdio> #include<cstring> #include<algorithm> using namespace std; const int MAXN = 100010; const int INF = 0x3f3f3f3f; struct Point{ int x,y,i