`
iaiai
  • 浏览: 2180150 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Android TabSwitcher自定义控件

 
阅读更多
先来看下效果:


main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
	android:orientation="vertical" android:layout_width="fill_parent"
	android:layout_height="fill_parent" android:background="#ffffff">
	<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
		android:id="@+id/tab" android:orientation="vertical"
		android:layout_width="fill_parent" android:layout_height="wrap_content"
		android:background="#ffffff">
	</LinearLayout>
</LinearLayout>


TabSwitcher.java
package com.iaiai.activity;

import android.content.Context;
import android.graphics.Color;
import android.view.Gravity;
import android.view.View;
import android.widget.LinearLayout;
import android.widget.TextView;

/**
 * 
 * <p>
 * Title: TabSwitcher.java
 * </p>
 * <p>
 * E-Mail: 176291935@qq.com
 * </p>
 * <p>
 * QQ: 176291935
 * </p>
 * <p>
 * Http: iaiai.iteye.com
 * </p>
 * <p>
 * Create time: 2011-8-11
 * </p>
 * 
 * @author 丸子
 * @version 0.0.1
 */
public class TabSwitcher extends LinearLayout {

	private Context context;
	private String[] texts;
	private int selectedPosition = 0;
	private int oldPosition = selectedPosition;
	private int[] background = { R.drawable.tabswitcher_short,
			Color.TRANSPARENT };
	private TextView[] tvs;

	public TabSwitcher(Context context, String[] texts) {
		super(context);
		this.texts = texts;
		this.context = context;
		setOrientation(HORIZONTAL);
		LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(
				LinearLayout.LayoutParams.FILL_PARENT,
				LinearLayout.LayoutParams.WRAP_CONTENT);
		setLayoutParams(params);
		setBackgroundResource(R.drawable.tabswitcher_long);
	}

	@Override
	protected void onFinishInflate() {
		// TODO Auto-generated method stub
		super.onFinishInflate();
		tvs = new TextView[texts.length];
		LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(
				LinearLayout.LayoutParams.FILL_PARENT,
				LinearLayout.LayoutParams.WRAP_CONTENT);
		params.weight = 1;
		params.gravity = Gravity.CENTER_VERTICAL;
		for (int i = 0; i < texts.length; i++) {
			TextView child = new TextView(context);
			child.setTag(i);
			child.setTextSize(16);
			child.setTextColor(Color.BLACK);
			child.setGravity(Gravity.CENTER);

			tvs[i] = child;
			child.setOnClickListener(listener);
			this.addView(child, params);
		}
	}

	OnClickListener listener = new OnClickListener() {

		@Override
		public void onClick(View v) {
			selectedPosition = (Integer) v.getTag();
			if (selectedPosition != oldPosition) {
				tvs[oldPosition].setBackgroundColor(background[1]);
				oldPosition = selectedPosition;
				((TextView) v).setBackgroundResource(background[0]);
				if (onItemClickLisener != null) {
					onItemClickLisener.onItemClickLisener(v, selectedPosition);
				}
			}
		}

	};

	@Override
	protected void onSizeChanged(int w, int h, int oldw, int oldh) {
		super.onSizeChanged(w, h, oldw, oldh);
		oldPosition = selectedPosition;
		for (int i = 0; i < texts.length; i++) {
			tvs[i].setText(texts[i]);
			if (selectedPosition == i) {
				tvs[i].setBackgroundResource(background[0]);
			} else {
				tvs[i].setBackgroundColor(background[1]);
			}
		}
	}

	private OnItemClickLisener onItemClickLisener;

	public void setOnItemClickLisener(OnItemClickLisener onItemClickLisener) {
		this.onItemClickLisener = onItemClickLisener;
	}

	public interface OnItemClickLisener {
		void onItemClickLisener(View view, int position);
	}

	public void setTexts(String[] texts) {
		this.texts = texts;
	}

	public void setSelectedPosition(int selectedPosition) {
		this.selectedPosition = selectedPosition;
	}

}


IaiaiActivity.java
package com.iaiai.activity;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.LinearLayout;
import android.widget.Toast;

import com.iaiai.activity.TabSwitcher.OnItemClickLisener;

/**
 * 
 * <p>
 * Title: IaiaiActivity.java
 * </p>
 * <p>
 * E-Mail: 176291935@qq.com
 * </p>
 * <p>
 * QQ: 176291935
 * </p>
 * <p>
 * Http: iaiai.iteye.com
 * </p>
 * <p>
 * Create time: 2011-8-11
 * </p>
 * 
 * @author 丸子
 * @version 0.0.1
 */
public class IaiaiActivity extends Activity {

	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		TabSwitcher tabSwitcher = new TabSwitcher(this, new String[] { "1",
				"2", "3", "4" });
		tabSwitcher.setSelectedPosition(1);
		tabSwitcher.setOnItemClickLisener(onItemClickLisener);
		tabSwitcher.onFinishInflate();
		
		LinearLayout linearLayout = (LinearLayout) findViewById(R.id.tab);
		linearLayout.addView(tabSwitcher, new LinearLayout.LayoutParams(
				LinearLayout.LayoutParams.FILL_PARENT,
				LinearLayout.LayoutParams.WRAP_CONTENT));
	}

	OnItemClickLisener onItemClickLisener = new OnItemClickLisener() {
		@Override
		public void onItemClickLisener(View view, int position) {
			// TODO Auto-generated method stub
			//
			switch (position) {
			case 0:
			case 1:
			case 2:
				Toast.makeText(IaiaiActivity.this,
						"position clicked:" + position, Toast.LENGTH_SHORT)
						.show();
				break;
			default:
				break;
			}
		}

	};
}


tabswitcher_long.9.png:

tabswitcher_short.9.png:
  • 大小: 9.8 KB
  • 大小: 1.7 KB
  • 大小: 5.1 KB
分享到:
评论

相关推荐

    TabSwitcher自定义控件(不带滑动效果)

    《TabSwitcher自定义控件:打造不带滑动效果的UI组件》 在Android应用开发中,界面设计和用户体验是至关重要的因素。一个优秀的应用不仅需要功能强大,还需要有一个直观且美观的用户界面。TabSwitcher控件是实现多...

    TabSwitcher自定义控件(带滑动效果)

    【标题】"TabSwitcher自定义控件(带滑动效果)"揭示了本文将要讨论的是一个特定的Android开发中的自定义用户界面组件。TabSwitcher控件通常用于在多个选项卡之间切换,而且这个控件增加了滑动交互,使得用户体验更加...

    TabSwitcher自定义控件(带拖动&滑动效果)

    在实际项目中,"TabSwitcher"控件的源码是一个很好的学习资源,可以帮助我们了解Android手势检测、动画实现以及自定义控件设计等方面的知识。你可以通过提供的博客链接(https://gundumw100.iteye.com/blog/1140930...

    Android定制RadioButton样式三种实现方法

    在Android开发中,自定义UI元素是提升应用用户体验的重要手段之一。RadioButton作为常用的控件,其默认样式可能无法满足所有设计需求。本文将详细介绍三种方法来定制RadioButton的样式,包括使用XML文件、在Java代码...

    Android系统浏览器源码+UML分析图

    本资源提供了Android系统浏览器的源码以及对应的UML(Unified Modeling Language)分析图,这对于理解浏览器的工作原理、优化性能、自定义功能或开发自己的浏览器应用都有着极大的帮助。 一、Android系统浏览器源码...

    AndroidTabSwither:一个简单好用的Android Tab实现

    在Android应用开发中,设计用户友好的界面是至关重要的,其中Tab切换是常见的导航模式,让用户能在多个相关视图间轻松切换。`AndroidTabSwither`是一个专为Android平台设计的简单易用的Tab实现库,它允许开发者创建...

    Radio Button

    Radio Button在Android开发中是一种常见的UI控件,用于在多个选项中进行单选。它通常包含一个小圆点,表示当前选中的状态。本篇将详细讲解如何通过三种方法定制Android的RadioButton样式。 1. **使用XML文件进行...

    TabSwitcher-crx插件

    TabSwitcher尝试通过让您##如何使用来解决此问题。安装后,按`CTRL + SHIFT + K'或`CMD + SHIFT + K'以显示选项卡切换器。您可以按Enter或使用鼠标键导航到选项卡。您可以在任何标签上按分号(即“;”键)关闭该标签...

    tabswitcher-crx插件

    语言:English tl;博士还记得textmate的命令t? Chrome是相同的。 警告:必须在Chrome的扩展中手动设置快捷方式...... tl;博士还记得textmate的命令t? Chrome是相同的。 警告:必须在Chrome的扩展设置中手动设置快捷...

    sitepoint-tabswitcher

    标签切换器 使用ember.js构建的选项卡切换器小部件,用于显示ember组件的工作方式。 先决条件 您需要在计算机上正确安装以下物品。 (带有NPM) 安装 git clone 此存储库 切换到新目录 npm install ...

    Tab Switcher-crx插件

    语言:English 快速过滤和切换窗口和选项卡 使用选项卡切换器,您可以仅使用键盘快速切换到其他打开的选项卡,包括按部分名称或URL匹配过滤选项卡。...隐私政策请在http://flowapps.co/tabswitcher/privacypoli

    标签切换器「Tab Switcher」-crx插件

    快速控制,过滤和切换标签 ...请在https://github.com/kallepersson/tabswitcher中查看源代码。如何更改键盘快捷键以显示Tab切换器? –很简单,您可以在扩展设置页面底部更改键盘快捷键! 支持语言:English

    提前制表符:Web浏览器扩展,可帮助您按标题和URL快速查找打开的制表符

    在实际使用中,用户可能需要安装并启用这个扩展,然后在浏览器的某个指定位置(如地址栏旁或自定义快捷键)启动搜索功能。对于经常需要处理大量标签页的用户,例如研究人员、内容创作者或是多任务处理者来说,"提前...

Global site tag (gtag.js) - Google Analytics