自定义Tab选项卡

简介: 自定义Tab选项卡
import android.app.TabActivity;
import android.content.Intent;
import android.os.Bundle;
import android.widget.*;
import android.widget.TabHost.OnTabChangeListener;
import android.os.Build;
import android.view.View;
import java.lang.reflect.Field;
import android.view.LayoutInflater;

public class testTabActivity extends TabActivity {
  /** Called when the activity is first created. */
     @Override
     public void onCreate(Bundle savedInstanceState) {
         super.onCreate(savedInstanceState);
         int width =45;
         int height =48;
         final TabHost tabs = getTabHost();
         final TabWidget tabWidget = tabs.getTabWidget();
         Field mBottomLeftStrip;
         Field mBottomRightStrip;
         LayoutInflater.from(this).inflate(R.layout.tab_views, tabs.getTabContentView(), true);
         tabs.addTab(tabs.newTabSpec("first tab")
              .setIndicator("信息",getResources().getDrawable(R.drawable.m))
              .setContent(new Intent(testTabActivity.this,OneActivty.class))
              );
         tabs.addTab(tabs.newTabSpec("second tab")
          .setIndicator("收藏",getResources().getDrawable(R.drawable.n))
          .setContent(R.id.content));
         tabs.addTab(tabs.newTabSpec("second tab")
              .setIndicator("设置",getResources().getDrawable(R.drawable.s))
              .setContent(R.id.content));


         for (int i =0; i < tabWidget.getChildCount(); i++) {
             /**
              * 设置高度、宽度,不过宽度由于设置为fill_parent,在此对它没效果
              */
             tabWidget.getChildAt(i).getLayoutParams().height = height;
             tabWidget.getChildAt(i).getLayoutParams().width = width;
          /**
           * 设置tab中标题文字的颜色,不然默认为黑色
           */
           final TextView tv = (TextView) tabWidget.getChildAt(i).findViewById(android.R.id.title);
           tv.setTextColor(this.getResources().getColorStateList(android.R.color.white));
             /**
              * 此方法是为了去掉系统默认的色白的底角
              *
              * 在 TabWidget中mBottomLeftStrip、mBottomRightStrip
              * 都是私有变量,但是我们可以通过反射来获取
              *
              * 由于还不知道Android 2.2的接口是怎么样的,现在先加个判断好一些
              */
          if (Float.valueOf(Build.VERSION.RELEASE) <= 2.1) {
                try {
                   mBottomLeftStrip = tabWidget.getClass().getDeclaredField ("mBottomLeftStrip");
                   mBottomRightStrip = tabWidget.getClass().getDeclaredField ("mBottomRightStrip");
                   if(!mBottomLeftStrip.isAccessible()) {
                     mBottomLeftStrip.setAccessible(true);
                   }
                   if(!mBottomRightStrip.isAccessible()){
                     mBottomRightStrip.setAccessible(true);
                   }
                  mBottomLeftStrip.set(tabWidget, getResources().getDrawable (R.drawable.no));
                  mBottomRightStrip.set(tabWidget, getResources().getDrawable (R.drawable.no));
                } catch (Exception e) {
                  e.printStackTrace();
                }
          } else {
          /**
          * 不做任何处理
          */
          }
         View vvv = tabWidget.getChildAt(i);
   if(tabs.getCurrentTab()==i){
           vvv.setBackgroundDrawable(getResources().getDrawable(R.drawable.tab_button));
   }
   else {
           vvv.setBackgroundDrawable(getResources().getDrawable(R.drawable.bar));
   }
         }
         /**
          * 当点击tab选项卡的时候,更改当前的背景
          */
         tabs.setOnTabChangedListener(new OnTabChangeListener(){
    @Override
    public void onTabChanged(String tabId) {
     // TODO Auto-generated method stub
     for (int i =0; i < tabWidget.getChildCount(); i++) {
      View vvv = tabWidget.getChildAt(i);
      if(tabs.getCurrentTab()==i){
              vvv.setBackgroundDrawable(getResources().getDrawable(R.drawable.tab_button));
      }
      else {
              vvv.setBackgroundDrawable(getResources().getDrawable(R.drawable.bar));
      }
     }
    }});
     }
}
相关文章
|
7月前
|
前端开发
解决elementUI弹出框关闭后再打开el-select下拉框无法选中的问题
解决elementUI弹出框关闭后再打开el-select下拉框无法选中的问题
186 0
|
4月前
|
JavaScript 前端开发
Vue实现Element UI框架的自定义输入框或下拉框在输入时对列表选项进行过滤,以及右键列表选项弹出菜单进行删除
本文介绍了如何在Vue框架结合Element UI库实现自定义输入框或下拉框,在输入时对列表选项进行过滤,并支持右键点击列表选项弹出菜单进行删除的功能。
116 0
|
7月前
NotePad++ 使用侧边栏列表替代Tab
NotePad++ 使用侧边栏列表替代Tab
170 0
|
7月前
|
JavaScript API
Element Plus组件库中的input组件如何点击查看按钮时不可编辑,点击编辑时可编辑使用setup
Element Plus组件库中的input组件如何点击查看按钮时不可编辑,点击编辑时可编辑使用setup
165 0
|
JavaScript 前端开发
49EasyUI 窗口- 自定义带有工具条和按钮的对话框
49EasyUI 窗口- 自定义带有工具条和按钮的对话框
49 0
|
前端开发 JavaScript API
使用.LayUI实现动态选项卡Tab的强大功能
使用.LayUI实现动态选项卡Tab的强大功能
137 0
|
iOS开发 MacOS Windows
使用 Tab 键快速切换对话框按钮 | 一日一技
使用 Tab 键快速切换对话框按钮 | 一日一技
514 0
|
小程序
tab栏组件使用介绍
tab栏组件使用介绍
tab栏组件使用介绍
|
Web App开发
Bootstrap学习笔记--下拉菜单,折叠,菜单,标签,Pills
下拉菜单: 下拉菜单是比较常见的 直接看源码: .dropdown表示下拉框 按钮和下拉框都要放在dropdown类的div下 要打开下拉菜单,请使用按钮或具有属性的类.
3251 0