基于GridView和ActivityGroup实现的TAB分页(附源码)

分页大家都会用Android的TabHost和TabActivity的组合,今天我这里实现的是GridView和ActivityGroup实现的分页,这里需要将Activity转换成Window,然后再换成成View添加到容器中,效果如下

 

1.布局文件底部放一个GridView,然后一个LinearLayout容器在GridView之上,LinearLayout用于装载Activity的,这里布局位置错误,运行程序会抛异常,修改在下面

复制代码 代码如下:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"

xmlns:tools="http://schemas.android.com/tools"

android:layout_width="match_parent"

android:layout_height="match_parent" >

<LinearLayout

android:id="@+id/activity_group"

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:layout_above="@+id/gridView1"

android:layout_alignParentTop="true"

android:orientation="vertical" >

</LinearLayout>

<GridView

android:id="@+id/gridView1"

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:layout_alignParentBottom="true"

android:background="@drawable/navigationbardown"

android:cacheColorHint="@android:color/transparent"

android:gravity="center"

android:listSelector="@android:color/transparent"

android:verticalSpacing="0dip" >

</GridView>

</RelativeLayout>

2.接下来就是代码啦,我们需要设置GridView的列数mGridView.setNumColumns(mImageIds.length),因为他只能显示一行,然后就是设置GridView点击高亮,每张图片的高亮图片都不一样的,然后就是点击不同的item进入不同的Activity,我们先用到ActivityGroup里面的 public Window startActivity(String id, Intent intent) ,将Activity转换成Window,然后通过 public abstract View getDecorView()这个抽象方法将Window转换成View,在添加到LinearLayout容器中

复制代码 代码如下:

package com.example.tabactivity;

import android.app.ActivityGroup;

import android.content.Intent;

import android.os.Bundle;

import android.view.View;

import android.view.ViewGroup;

import android.view.ViewGroup.LayoutParams;

import android.widget.AdapterView;

import android.widget.AdapterView.OnItemClickListener;

import android.widget.BaseAdapter;

import android.widget.GridView;

import android.widget.ImageView;

import android.widget.LinearLayout;

public class TestActivity extends ActivityGroup implements OnItemClickListener {

/**

* Tab标签

*/

private GridView mGridView;

/**

* 普通图片id数组

*/

private int [] mImageIds;

/**

* 高亮图片id数组

*/

private int [] mImageLightIds;

/**

* GridView 适配器

*/

private ImageAdapter mImageAdapter;

/**

* 装载Activity的容器

*/

private LinearLayout mLinearLayout;

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_test);

mImageIds = new int[]{R.drawable.home, R.drawable.task, R.drawable.addrbook, R.drawable.longnormal};

mImageLightIds = new int[]{R.drawable.home1, R.drawable.taskhl, R.drawable.addrbook1, R.drawable.longhightlight};

mLinearLayout = (LinearLayout) findViewById(R.id.activity_group);

mGridView = (GridView) findViewById(R.id.gridView1);

//因为我们显示一行,列数等于数组的长度

mGridView.setNumColumns(mImageIds.length);

mImageAdapter = new ImageAdapter();

mGridView.setAdapter(mImageAdapter);

mGridView.setOnItemClickListener(this);

startActivity(0);

}

@Override

public void onItemClick(AdapterView<?> parent, View view, int position,

long id) {

//点击设置高亮显示

mImageAdapter.setImageLight(position);

startActivity(position);

}

/**

* 根据position跳转到不同的Activity

* @param id

*/

private void startActivity(int position){

//先清除容器里面的View

mLinearLayout.removeAllViews();

Intent intent = null;

if(position == 0){

intent = new Intent(TestActivity.this, Activity_01.class);

}else if(position == 1){

intent = new Intent(TestActivity.this, Activity_02.class);

}else if(position == 2){

intent = new Intent(TestActivity.this, Activity_03.class);

}else if(position == 3){

intent = new Intent(TestActivity.this, Activity_04.class);

}

intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);

//将Activity转换成View

View view = getLocalActivityManager().startActivity("intent", intent).getDecorView();

LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(new LinearLayout.LayoutParams(LayoutParams.FILL_PARENT,

LayoutParams.FILL_PARENT));

//将Activity转换成的View添加到容器

mLinearLayout.addView(view, layoutParams);

}

/**

* 图片适配器,没什么特别的,里面有一个设置高亮的方法比较重要

* @author mining

*

*/

private class ImageAdapter extends BaseAdapter{

private int currentItem;

/**

* 设置高亮显示

* @param currentItem

*/

public void setImageLight(int selectItem){

this.currentItem = selectItem;

notifyDataSetChanged();

}

@Override

public int getCount() {

return mImageIds.length;

}

@Override

public Object getItem(int position) {

return mImageIds[position];

}

@Override

public long getItemId(int position) {

return position;

}

@Override

public View getView(int position, View convertView, ViewGroup parent) {

if(convertView == null){

convertView = new ImageView(TestActivity.this);

}

if(position == currentItem){

convertView.setBackgroundResource(mImageLightIds[position]);

}else{

convertView.setBackgroundResource(mImageIds[position]);

}

return convertView;

}

}

}

代码都上完了,是不是很简单的赶脚,短短的100多行的代码就实现了Tab分页,上面有设置GridView高亮的方法,还不知道设置高亮的同学可以借鉴一下咯,呵呵, 写的不好,希望各位大牛指点指点!万分感谢

不好意思,上面的布局需要纠正下,位置放错了

复制代码 代码如下:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"

xmlns:tools="http://schemas.android.com/tools"

android:layout_width="match_parent"

android:layout_height="match_parent" >

<GridView

android:id="@+id/gridView1"

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:layout_alignParentBottom="true"

android:background="@drawable/navigationbardown"

android:cacheColorHint="@android:color/transparent"

android:gravity="center"

android:listSelector="@android:color/transparent"

android:verticalSpacing="0dip" >

</GridView>

<LinearLayout

android:id="@+id/activity_group"

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:layout_above="@+id/gridView1"

android:layout_alignParentTop="true"

android:orientation="vertical" >

</LinearLayout>

</RelativeLayout>

代码下载

时间: 2024-11-03 10:55:45

基于GridView和ActivityGroup实现的TAB分页(附源码)的相关文章

基于GridView和ActivityGroup实现的TAB分页(附源码)_Android

分页大家都会用Android的TabHost和TabActivity的组合,今天我这里实现的是GridView和ActivityGroup实现的分页,这里需要将Activity转换成Window,然后再换成成View添加到容器中,效果如下  1.布局文件底部放一个GridView,然后一个LinearLayout容器在GridView之上,LinearLayout用于装载Activity的,这里布局位置错误,运行程序会抛异常,修改在下面 复制代码 代码如下: <RelativeLayout xm

基于jQuery实现交互体验社会化分享代码附源码下载_jquery

先给大家展示下效果图,看看是不是亲想要的效果,如果满足您的要求请继续往下阅读. 效果展示       源码下载 基于jQuery交互体验社会化分享代码.这是一款鼠标点击分享按钮向右滑出腾讯微博,新浪微博,QQ空间,豆瓣,微信,二维码分享等分享平台. html代码: <div style="text-align:center;font:normal 14px/24px 'MicroSoft YaHei';clear:both;width:160px;margin:0 auto;"&

基于jquery实现鼠标左右拖动滑块滑动附源码下载_jquery

在没步入正文之前,先给大家贴效果图,看看是不是您想要的效果: 在线演示 源码下载 基于jQuery移动端滑块拖动设置代码.这是一款支持手机移动端的特效,可拖动滑块范围选择器,拖动滑块数值选择器. 废话不多说了,直接给大家贴代码了. html代码: <div class="demo"> <input type="hidden" class="single-slider" value="0" /> <

基于jQuery实现多层次的手风琴效果附源码_jquery

基于jQuery多层次的手风琴是一款经过美化的多级多层次手风琴特效代码.效果图如下:   在线预览    源码下载 html代码: <aside class="accordion"> <h>News</h> <div class="opened-for-codepen"> <h>News Item #</h> <div class="opened-for-codepen"

基于Jquery制作图片文字排版预览效果附源码下载_jquery

基于jQuery图文排版图片预览特效.这是一款基于jQuery+CSS3实现的鼠标点击图片弹出画廊切换特效. 效果图如下所示,怎么样感兴趣吗,感兴趣的朋友继续往下学习哦. 效果演示     源码下载 html代码: <div id="fullscreen"> <div id="fullscreen-inner"> <div id="fullscreen-inner-left" class="fullscre

一个.net分页测试源码

分页   一个.net分页测试源码作者:淘特网 出处:淘特网 注:转载请注明出处  <% @ Page Language="C#" %><% @ Import Namespace="System.Data" %><% @ Import Namespace="System.Data.SqlClient" %><Script Language="C#" Runat="Server

基于Docker的TensorFlow机器学习框架搭建和实例源码解读

概述:基于Docker的TensorFlow机器学习框架搭建和实例源码解读,TensorFlow作为最火热的机器学习框架之一,Docker是的容器,可以很好的结合起来,为机器学习或者科研人员提供便捷的机器学习开发环境,探索人工智能的奥秘,容器随开随用方便快捷.源码解析TensorFlow容器创建和示例程序运行,为热爱机器学者降低学习难度. 默认机器已经装好了Docker(Docker安装和使用可以看我另一篇博文:Ubuntu16.04安装Docker1.12+开发实例+hello world+w

PHP 一个完整的分页类(附源码)

如果是ajax调用: //$total,总数(int):$size,每页显示数量(int):$page,当前页(int),$url,链接(string):ajax,js函数名: $page = new Page(array('total'=>$total,'perpage'=>$size,'nowindex'=>$page,'url' => $url,'ajax' => 'videoGoToPage')); //变量$page_html为分页的html,参数4是分页的显示样式

基于spring+hibernate+JQuery开发之电子相册(附源码下载)_java

项目结构: 开发之电子相册(附源码下载)_java-spring hibernate源码"> 项目首页: 注册页面: 上传图片: 效果图一: 效果图二: 效果图三: ============================================================= 下面是代码部分 ============================================================= 需要用到的数据库SQL: 复制代码 代码如下: drop dat