android自定义标题栏

用自定义控件的方法创建上面的标题栏,顺便重温一下自定义控件的步骤。

下面说一下整个过程:

1.在layout下添加标题栏布局文件来设置标题栏样式

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="50dp" 
    android:background="#58AB21"  
    >
    <ImageButton 
        android:id="@+id/bar_menu_left"
        android:layout_width="20dp"
        android:layout_height="20dp"
        android:layout_centerVertical="true"
        android:layout_alignParentLeft="true"
        android:layout_marginLeft="10dp"
        android:src="@drawable/action_bar_home_light"
        />
    <TextView 
        android:id="@+id/bar_title"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textColor="@android:color/white"
        android:text="添加标题"
        android:textSize="8sp"
        android:layout_toRightOf="@id/bar_menu_left"
        android:layout_centerVertical="true"
        android:layout_marginLeft="30dp"
        />
    <ImageButton 
        android:id="@+id/bar_menu_right1"
        android:layout_width="50dp"
        android:layout_height="50dp"
        android:layout_centerVertical="true"
        android:layout_alignParentRight="true"
        android:src="@drawable/action_bar_more_light"
        android:background="@drawable/bar_menu_button" />
     <ImageButton  
        android:id="@+id/bar_menu_right2"
        android:layout_width="50dp"
        android:layout_height="50dp"
        android:src="@drawable/action_bar_add_light"
        android:layout_centerVertical="true"
        android:layout_toLeftOf="@id/bar_menu_right1"
        android:layout_marginRight="0dp"
        android:background="@drawable/bar_menu_button" />

    <ImageButton
        android:id="@+id/bar_menu_right3"
        android:layout_width="50dp"
        android:layout_height="50dp"
        android:layout_alignParentTop="true"
        android:layout_toLeftOf="@+id/bar_menu_right2"
        android:background="@drawable/bar_menu_button"
        android:src="@drawable/action_bar_attach_light" />

</RelativeLayout>
2.在values文件夹下建立attrs.xml文件
<?xml version="1.0" encoding="utf-8"?>
<resources>
    <declare-styleable name="MyActionBar">
        <attr name="buttonLeftIcon" format="reference"/>
        <attr name="buttonRight1Icon" format="reference"/>
        <attr name="buttonRight2Icon" format="reference"/>
        <attr name="buttonRight3Icon" format="reference"/>
        <attr name="titleText" format="string"/>
        <attr name="titleTextSize" format="dimension"/>  
        <attr name="titleTextColor" format="color|reference"/>  
    </declare-styleable>
</resources>
这个文件主要用来定义自定义控件的属性和格式,格式有 reference,float,color,dimension,boolean,string,enum,integer,fraction,flag。

<declare-styleable>标签下的name属性一般程自定义控件的名字。
3.写一个自定义控件类

package com.isaac.tools;

import com.isaac.myactionbar.R;

import android.content.Context;
import android.content.res.TypedArray;
import android.util.AttributeSet;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.ImageButton;
import android.widget.RelativeLayout;
import android.widget.TextView;

public class MyActionBar extends RelativeLayout{
	
	private ImageButton buttonLeft;
	private ImageButton buttonRight1;
	private ImageButton buttonRight2;
	private ImageButton buttonRight3;
	private TextView titleView;
	

	public MyActionBar(Context context, AttributeSet attrs) {
		super(context, attrs);
		LayoutInflater.from(context).inflate(R.layout.layout_my_actionbar, this);
		buttonLeft=(ImageButton)findViewById(R.id.bar_menu_left);
		buttonRight1=(ImageButton)findViewById(R.id.bar_menu_right1);
		buttonRight2=(ImageButton)findViewById(R.id.bar_menu_right2);
		buttonRight3=(ImageButton)findViewById(R.id.bar_menu_right3);
		titleView=(TextView)findViewById(R.id.bar_title);
		
		 //获得自定义属性并赋值  
        TypedArray typedArray = context.obtainStyledAttributes(attrs, R.styleable.MyActionBar);   
        int btnLeftIcon = typedArray.getResourceId(R.styleable.MyActionBar_buttonLeftIcon,0x58AB21);  
        int btnRight1Icon = typedArray.getResourceId(R.styleable.MyActionBar_buttonRight1Icon, 0x58AB21);  
        int btnRight2Icon = typedArray.getResourceId(R.styleable.MyActionBar_buttonRight2Icon, 0x58AB21); 
        int btnRight3Icon = typedArray.getResourceId(R.styleable.MyActionBar_buttonRight3Icon, 0x58AB21); 
        String titleText = typedArray.getString(R.styleable.MyActionBar_titleText);  
        float titleTextSize = typedArray.getDimension(R.styleable.MyActionBar_titleTextSize, 0);  
        int titleTextColor = typedArray.getColor(R.styleable.MyActionBar_titleTextColor, android.R.color.white);  
        typedArray.recycle();//释放资源  
        
        buttonLeft.setImageResource(btnLeftIcon);
        buttonRight1.setImageResource(btnRight1Icon);
        buttonRight2.setImageResource(btnRight2Icon);
        buttonRight3.setImageResource(btnRight3Icon);
        titleView.setText(titleText);
        titleView.setTextSize(titleTextSize);
        titleView.setTextColor(titleTextColor);
		
	}
	

	
	public ImageButton getButtonLeft() {
		return buttonLeft;
	}
	public void setButtonLeft(ImageButton buttonLeft) {
		this.buttonLeft = buttonLeft;
	}
	public ImageButton getButtonRight1() {
		return buttonRight1;
	}
	public void setButtonRight1(ImageButton buttonRight1) {
		this.buttonRight1 = buttonRight1;
	}
	public ImageButton getButtonRight2() {
		return buttonRight2;
	}
	public void setButtonRight2(ImageButton buttonRight2) {
		this.buttonRight2 = buttonRight2;
	}
	public ImageButton getButtonRight3() {
		return buttonRight3;
	}
	public void setButtonRight3(ImageButton buttonRight3) {
		this.buttonRight3 = buttonRight3;
	}
	public TextView getTitleView() {
		return titleView;
	}
	public void setTitleView(TextView titleView) {
		this.titleView = titleView;
	}
	
	
}
这个自定义控件类要继承View类,根据实际情况,这里继承RelativeLayout类。通过TypeArray给自定义属性赋值。到这里,一个自定义标题栏就已经完成了,下面讲怎么把它添加到Activity中。

首先去掉系统自带的标题栏,这里只要将AndroidManifest.xml中application标签下的Theme主题设置成不带标题栏的风格即可。比如 android:theme="@android:style/Theme.Holo.Light.NoActionBar"。然后再布局文件中添加自定义的控件

<com.isaac.tools.MyActionBar
     android:id="@+id/testActionBar"
     android:layout_width="match_parent"
     android:layout_height="50dp"
     isaac:titleText="测试标题"
     isaac:titleTextSize="8sp"
     isaac:titleTextColor="@android:color/white"
     isaac:buttonLeftIcon="@drawable/action_bar_home_light"
     isaac:buttonRight1Icon="@drawable/action_bar_more_light"
	 isaac:buttonRight2Icon="@drawable/action_bar_add_light"
     isaac:buttonRight3Icon="@drawable/action_bar_attach_light"
     
        >

    </com.isaac.tools.MyActionBar>
 这里要注意,为了得到自定义的属性,要在xml文件的根布局下添加命名空间xmlns:isaac="http://schemas.android.com/apk/res/com.isaac.myactionbar"

接下来就可以在Activity中得到自定义控件

package com.isaac.tools;

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

import com.isaac.myactionbar.R;

public class MainActivity extends Activity {
	
	MyActionBar mActionBar;
	
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		// TODO Auto-generated method stub
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		mActionBar=(MyActionBar)findViewById(R.id.testActionBar);
		ImageButton imageButton=mActionBar.getButtonRight1();
		imageButton.setOnClickListener(new OnClickListener() {
			
			@Override
			public void onClick(View v) {
				// TODO Auto-generated method stub
				Toast.makeText(MainActivity.this, "test", Toast.LENGTH_SHORT).show();
			}
		});
		
		
		
	}

}






  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值