Android入门之ActivityGroup+GridView实现Tab分页标签的方法

作者:shichen2014 时间:2022-11-01 05:38:33 

在Android程序中很多客户端软件和浏览器软件都喜欢用Tab分页标签来搭建界面框架。读者也许会马上想到使用TabHost 与 TabActivity的组合,其实最常用的不是它们,而是由GridView与ActivityGroup的组合。每当用户在GridView选中一项,ActivityGroup就把该项对应的Activity的Window作为View添加到ActivityGroup所指定的容器(LinearLayout)中。

先来贴出本例运行的效果图如下:

Android入门之ActivityGroup+GridView实现Tab分页标签的方法

ImageAdapter是本实例的关键之一,它继承于BaseAdapter,并加入一些自定义的方法。ImageAdapter的源码如下:


package com.ActivityGroupDemo;

import android.content.Context;
import android.graphics.drawable.ColorDrawable;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.GridView;
import android.widget.ImageView;
/**
*
* @author GV
*
*/
public class ImageAdapter extends BaseAdapter {
private Context mContext;
private ImageView[] imgItems;
private int selResId;
 public ImageAdapter(Context c,int[] picIds,int width,int height,int selResId) {
   mContext = c;
   this.selResId=selResId;
   imgItems=new ImageView[picIds.length];
   for(int i=0;i<picIds.length;i++)
   {
    imgItems[i] = new ImageView(mContext);
    imgItems[i].setLayoutParams(new GridView.LayoutParams(width, height));//设置ImageView宽高
    imgItems[i].setAdjustViewBounds(false);
    //imgItems[i].setScaleType(ImageView.ScaleType.CENTER_CROP);
    imgItems[i].setPadding(2, 2, 2, 2);
    imgItems[i].setImageResource(picIds[i]);
   }
 }
 public int getCount() {
   return imgItems.length;
 }

public Object getItem(int position) {
   return position;
 }

public long getItemId(int position) {
   return position;
 }

/**
  * 设置选中的效果
  */
 public void SetFocus(int index)
 {
   for(int i=0;i<imgItems.length;i++)
   {
     if(i!=index)
     {
      imgItems[i].setBackgroundResource(0);//恢复未选中的样式
     }
   }
   imgItems[index].setBackgroundResource(selResId);//设置选中的样式
 }

public View getView(int position, View convertView, ViewGroup parent) {
   ImageView imageView;
   if (convertView == null) {
    imageView=imgItems[position];
   } else {
     imageView = (ImageView) convertView;
   }
   return imageView;
 }
}

其中SetFocus(int)这个方法是个关键点,即实现选中的效果。例如有ABCD4个Item,其中C被选中了,那么除C以外的Item都被设置为未被选中的样式,而C则设置为选中的样式。

接下来就开始写主Activity,主Activity包含GridView控件,名为gvTopBar,有2点是需要注意一下的。

1.SetNumColumns():必须要使用setNumColumns来设置列数,因为这个GridView只有一行,即所有的Item都在同一行,Item数量即为列数。

2.setSelector(new ColorDrawable(Color.TRANSPARENT)):把系统默认选中的背景色透明化,因为我们已经在BaseAdapter中加入了SetFocus()来改变选中的样式。


package com.ActivityGroupDemo;
import android.app.Activity;
import android.app.ActivityGroup;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.graphics.Color;
import android.graphics.drawable.ColorDrawable;
import android.os.Bundle;
import android.util.Log;
import android.view.Gravity;
import android.view.View;
import android.view.Window;
import android.view.ViewGroup.LayoutParams;
import android.widget.AdapterView;
import android.widget.GridView;
import android.widget.LinearLayout;
import android.widget.Toast;
import android.widget.AdapterView.OnItemClickListener;
/**
*
* @author GV
*
*/
public class ActivityGroupDemo extends ActivityGroup {

private GridView gvTopBar;
private ImageAdapter topImgAdapter;
public LinearLayout container;// 装载sub Activity的容器

/** 顶部按钮图片 **/
int[] topbar_image_array = { R.drawable.topbar_home,
 R.drawable.topbar_user, R.drawable.topbar_shoppingcart,
 R.drawable.topbar_note };
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
gvTopBar = (GridView) this.findViewById(R.id.gvTopBar);
gvTopBar.setNumColumns(topbar_image_array.length);// 设置每行列数
gvTopBar.setSelector(new ColorDrawable(Color.TRANSPARENT));// 选中的时候为透明色
gvTopBar.setGravity(Gravity.CENTER);// 位置居中
gvTopBar.setVerticalSpacing(0);// 垂直间隔
int width = this.getWindowManager().getDefaultDisplay().getWidth()
 / topbar_image_array.length;
topImgAdapter = new ImageAdapter(this, topbar_image_array, width, 48,
 R.drawable.topbar_itemselector);
gvTopBar.setAdapter(topImgAdapter);// 设置菜单Adapter
gvTopBar.setOnItemClickListener(new ItemClickEvent());// 项目点击事件
container = (LinearLayout) findViewById(R.id.Container);
SwitchActivity(0);//默认打开第0页
}
class ItemClickEvent implements OnItemClickListener {

public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,
 long arg3) {
 SwitchActivity(arg2);
}
}
/**
* 根据ID打开指定的Activity
* @param id GridView选中项的序号
*/
void SwitchActivity(int id)
{
topImgAdapter.SetFocus(id);//选中项获得高亮
container.removeAllViews();//必须先清除容器中所有的View
Intent intent =null;
if (id == 0 || id == 2) {
 intent = new Intent(ActivityGroupDemo.this, ActivityA.class);
} else if (id == 1 || id == 3) {
 intent = new Intent(ActivityGroupDemo.this, ActivityB.class);
}
intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
//Activity 转为 View
Window subActivity = getLocalActivityManager().startActivity(
 "subActivity", intent);
//容器添加View
container.addView(subActivity.getDecorView(),
 LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT);
}
}
标签:Android,ActivityGroup,GridView,Tab
0
投稿

猜你喜欢

  • 深入解析C#设计模式编程中对建造者模式的运用

    2023-02-22 08:19:35
  • Java初学者问题图解(动力节点Java学院整理)

    2023-10-15 18:06:11
  • 结合mybatis-plus实现简单不需要写sql的多表查询

    2021-06-25 12:54:22
  • Android集成zxing扫码框架功能

    2021-09-27 02:37:17
  • idea输入sout无法自动补全System.out.println()的问题

    2023-11-28 21:34:03
  • Android开发入门环境快速搭建实战教程

    2022-06-17 15:59:41
  • Android学习之AppWidget笔记分享

    2022-04-10 21:25:46
  • 详解Android短信的发送和广播接收实现短信的监听

    2022-08-14 16:55:23
  • feign GET请求不支持对象传参的坑及解决

    2023-07-29 18:10:25
  • Android ListView仿微信聊天界面

    2023-10-15 04:59:46
  • Spring ApplicationListener源码解析

    2021-08-10 08:11:12
  • SpringMVC域对象共享数据示例详解

    2023-03-10 22:21:21
  • 使用eclipse创建java项目的方法

    2022-10-15 04:41:00
  • springboot maven 项目打包jar 最后名称自定义的教程

    2021-08-12 00:01:11
  • SpringMVC教程之文件上传与下载详解

    2022-12-21 03:49:09
  • SpringBoot 项目瘦身maven/gradle详解

    2021-10-26 04:39:12
  • Android蓝牙服务启动流程分析探索

    2023-12-20 17:45:35
  • java实现飞机游戏代码

    2022-01-08 06:48:34
  • 详解Java中restTemplate的使用

    2023-06-19 23:20:29
  • Android编程实现自定义手势的方法详解

    2023-09-14 16:02:36
  • asp之家 软件编程 m.aspxhome.com