android自定义的actionbar

今天利用画图实现了一个android自定义的actionbar,在加上系统的viewpager+fragment实现的可以滑动切换的效果。代码如下:

首先编写三个fragment的代码,FragmentOne.java的代码如下:

public class FragmentOne extends Fragment {
	
	@Override
	public View onCreateView(LayoutInflater inflater, ViewGroup container,
			Bundle savedInstanceState) {
		return inflater.inflate(R.layout.one,container,false);
	}
	
}

FragmentTwo.java和FragmentThree.java和FragmentOne.java大同小异。这里就不列举出来了。

接下来是自定义的MyTabView.java

import java.util.List;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.text.TextPaint;
import android.util.AttributeSet;
import android.util.DisplayMetrics;
import android.util.Log;
import android.view.MotionEvent;
import android.view.View;
import android.view.WindowManager;

public class MyTabView extends View {

	private List<String>list;//用于存放tab上的文字
	private float textWidth;//文字的宽度
	private Paint paint;
	private int tabBackColor = Color.parseColor("#ff76786b");//tab项的背景色
	private int textColor = Color.parseColor("#ffef6881"); //字体的颜色
	private int vertalLineColor = Color.parseColor("#ffffff"); //竖智分割线的颜色
	private int horizinalLineColor = Color.parseColor("#86ff35");//滑动下划线的颜色

	private float pressX;
	private float pressY;

	private float height;//该控件的高度
	private float width;//高控件的宽度

	private float tabLength;//单个tab的宽度

	private float horizinalLineX = 0.0f;//用于控制水平下划线的位置
	
	private boolean isMoving = false;
	//	float  tabHeight = 0.0f; 
	
	 private  int index = 0;//当前被选中的项

	public MyTabView(Context context, AttributeSet attrs) {
		super(context, attrs);
		//获得屏幕的宽度
		WindowManager windowManager = (WindowManager) context.getSystemService(context.WINDOW_SERVICE);
		DisplayMetrics outMetrics = new DisplayMetrics();
		windowManager.getDefaultDisplay().getMetrics(outMetrics);
		//		tabHeight = outMetrics.heightPixels / 10;
		paint = new Paint();

	}


	/**
	 * 根据文本和字体大小获得文本的宽度
	 * @param text
	 * @param textSize
	 * @return
	 */
	public float getTextWidth(String text,float textSize) {

		TextPaint textPaint = new TextPaint();
		textPaint.setTextSize(textSize);
		return textPaint.measureText(text);
	}

	@Override
	protected void onDraw(Canvas canvas) {
		// TODO Auto-generated method stub
		super.onDraw(canvas);

		width = getWidth();//获得控件的宽度
		height = getHeight();//获得控件的高度

		tabLength = width/list.size();//动态分割宽度

		/**
		 * 绘出当前的tab和文字以及下划线
		 */
		for (int i = 0; i < list.size(); i++) {
			paint.setColor(tabBackColor);
			textWidth = getTextWidth(list.get(i),18.f);
			//绘制单个tab
			canvas.drawRect(i*tabLength,0,(i+1)*tabLength,height, paint);
			/**
			 * 绘制竖直分割线
			 */
			if (i >= 1 && i < list.size()) {
				paint.setColor(vertalLineColor);
				paint.setStrokeWidth(2);
				canvas.drawLine(i*tabLength,2.0f,i*tabLength,tabLength-3.0f,paint);
			}
			//绘制tab文本
			paint.setColor(textColor);
			canvas.drawText(list.get(i),i*tabLength+(tabLength-getPaddingLeft()-getPaddingRight()-textWidth)/2,height/2, paint);
			//绘制tab地步水平滑动条
			paint.setColor(horizinalLineColor);
			paint.setStrokeWidth(15);
			canvas.drawLine(horizinalLineX,height,horizinalLineX+tabLength,height, paint);
		}

	}

	@Override
	public boolean onTouchEvent(MotionEvent event) {
		// TODO Auto-generated method stub
		int action = event.getAction();
		switch (action) {
		case MotionEvent.ACTION_DOWN:
			
			if (!isMoving) {//如果不是滑动的情况
				pressX = event.getX();
				pressY = event.getY();
				index = checkLegal(pressX,pressY);
//				horizinalLineX = index * tabLength;
				MainActivity.pager.setCurrentItem(index);
				invalidate();
			}

			break;
		case MotionEvent.ACTION_MOVE:
			isMoving = true;
			pressX = event.getX();
			pressY = event.getY();
			horizinalLineX = pressX - tabLength;
			if (horizinalLineX <= 0) {
				horizinalLineX = 0;
			}
			if (horizinalLineX + tabLength >= width) {
				horizinalLineX = width - tabLength;
			}
			invalidate();//重画
			
			break;
		case MotionEvent.ACTION_UP:
			isMoving = false;
			pressX = event.getX();
			index = (int) ( pressX / tabLength);
			Log.d("test","当前项"+index);
			if (horizinalLineX > index * tabLength + tabLength/2) {//是否已经滑动超过一半
				horizinalLineX = tabLength * (index+1);
			}else{
				
				horizinalLineX = tabLength * index;
			}
			MainActivity.pager.setCurrentItem(index);
			invalidate();
			
			break;
		default:
			break;
		}

		return true;
	}


	/**
	 * 用于结合viewpager滑动绘制
	 * @param pos
	 */
	public void onPagerDraw(int pos) {
		horizinalLineX = tabLength * pos;
		invalidate();
	}
	
	public int checkLegal(float x,float y) {
		int index = (int)x / (int)tabLength;
		return index;
	}

	public List<String> getList() {
		return list;
	}

	public void setList(List<String> list) {
		this.list = list;
	}

	public int getIndex() {
		return index;
	}
	public void setIndex(int index) {
		this.index = index;
	}

}
MainActivity.java如下:

import java.util.ArrayList;
import java.util.List;

import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.util.Log;
import android.view.View;
import android.view.ViewGroup;

public class MainActivity extends FragmentActivity implements OnPageChangeListener{
	List<Fragment>listfrFragments ;
	
	static int fragmentIndex = 0;
	static ViewPager pager = null;
	MyTabView myTabView;
	
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		myTabView = (MyTabView) findViewById(R.id.tabid);
		List<String>list = new ArrayList<String>();
		list.add("title");
		list.add("content");
		list.add("friends");
		myTabView.setList(list);
		
		listfrFragments = new ArrayList<Fragment>();
		listfrFragments.add(new FragmentOne());
		listfrFragments.add(new FragmentTwo());
		listfrFragments.add(new FragmentThree());
		
		pager = (ViewPager) findViewById(R.id.viewpagerid);
		FragmentManager manager = getSupportFragmentManager();
		pager.setAdapter(new FramentApter(manager));
		pager.setOnPageChangeListener(this);
		
	}


	class FramentApter extends FragmentPagerAdapter {
		public FramentApter(FragmentManager fm) {
			super(fm);
		}
		@Override
		public int getCount() {
			return listfrFragments.size();
		}
		@Override
		public Fragment getItem(int arg0) {
			return listfrFragments.get(arg0);
		}
		
		@Override
		public void destroyItem(ViewGroup container, int position, Object object) {
			super.destroyItem(container, position, object);
		}
		
		@Override
		public Object instantiateItem(ViewGroup container, int position) {
			return super.instantiateItem(container, position);
		}
	}

	@Override
	public void onPageScrollStateChanged(int position) {
//		System.out.println(position);
//		Log.d("test",position+"---onPageScrollStateChanged");
	}

	@Override
	public void onPageScrolled(int position, float arg1, int arg2) {
//		Log.d("test","比例"+arg1);
//		Log.d("test",arg2+"");
	}

	@Override
	public void onPageSelected(int position) {
		myTabView.onPagerDraw(position);//当viewpager选择新的选项时候重新绘制自定义tab的水平条
	}
	
}
activity_main.xml如下:

<LinearLayout 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"
    android:orientation="vertical"
    tools:context=".MainActivity" >

    <com.example.androidselftab.MyTabView
        android:id="@+id/tabid"
        android:layout_width="match_parent"
        android:layout_height="40dp" />

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

    </android.support.v4.view.ViewPager>

</LinearLayout>

源码连接 http://download.csdn.net/detail/mockingbirds/8185319


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值