java 自定义标题栏_【Android Demo】自定义Activity的标题栏(Titlebar)

缺省的情况下,通常见到Activity的标题栏(Titlebar)是这样的(红色框内):

ddcffeab5567b422f10a4a204844bce6.png

HandleContacts是Activity的标题。有时候,我们希望能改变一下这样单调的状况。比如,要在标题栏中增加一个用于美化界面的图标、增一个输入框或按钮之类的,怎样才能做到这一点呢?我们不妨来看一个实际的例子。1.首先如下创建一个Android项目

c56d2b0b4625bd5444c1b6a2b2b31c6b.png

2.将图片magnifier.png拖入该项目的res/drawable-mdpi文件夹下。magnifier.png图片的样子是这样的:

72e2f61b95209cdf85a91e9c3b081b22.png

3.在该项目的res/layout文件夹下,创建一个布局titlebar.xml,这个布局将用于定制Activity的标题栏

59123f3f2629208ca8959a140d6d3180.png

编辑titlebar.xml,使其内容如下:

xmlns:android="http://schemas.android.com/apk/res/android"

android:orientation="horizontal"

android:layout_width="fill_parent"

android:layout_height="wrap_content">

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:src="@drawable/magnifier"

android:gravity="bottom"

/>

android:layout_width="wrap_content"

android:layout_height="38dip"

android:text="@string/app_name"

android:textColor="#FFFFFFFF"

android:textSize="14dip"

android:paddingTop="1dip"

/>

android:id="@+id/searchparameter"

android:layout_width="wrap_content"

android:layout_height="38dip"

android:text="ABCDEFGHIJ"

android:textSize="14dip"

android:layout_margin="1dip"

/>

android:layout_width="wrap_content"

android:layout_height="38dip"

android:text="OK"

android:textSize="14dip"

/>

在上面的LinearLayout中,增加了以下控件:

一个ImageView,用于显示一个图标

一个TextView,用于显示应用的名称

一个EditText,用于接收输入

一个Button,用于测试

4.修改CustomizeTitlebar.java,使之如下:

public class CustomizeTitlebar extends Activity

{

@Override

public void onCreate(Bundle savedInstanceState)

{

super.onCreate(savedInstanceState);

requestWindowFeature(Window.FEATURE_CUSTOM_TITLE);

setContentView(R.layout.main);

getWindow().setFeatureInt(Window.FEATURE_CUSTOM_TITLE, R.layout.titlebar);

}

}

以上加粗的两行很重要,而且必须要严格按照上面那样的顺序出现在代码中。即:

requestWindowFeature(Window.FEATURE_CUSTOM_TITLE);必须出现在super.onCreate(savedInstanceState);之后,setContentView(R.layout.main);之前。其意思就是告诉系统,本程序要自己定义Titlebar;

getWindow().setFeatureInt(Window.FEATURE_CUSTOM_TITLE,R.layout.titlebar); 则必须出现在setContentView之后,其意思就是告诉系统,自定义的布局是R.layout.titlebar(即,我们前面编写的titlebar.xml)

到这里,不妨来运行一下,看看结果如何:

90e6ee74c8912f91fa5a5c8a1ba638c8.png

我们看到,Titlebar基本上按照我们的意思进行了改变,但也存在着一个缺陷:Titlebar太窄了,那么怎样改变Titlebar的高度呢?

5. 要改变Titlebar的高度,我们得先创建styles.xml:

5d03619bffc594c387dd1eacdc3af052.png

编辑styles.xml,使其内容如下:

38dip

上面39dip这一句,就是用来设定Titlebar的高度的。

6.在上面的基础上,我们需要修改AndroidManifest.xml中,相应Activity的属性。如下:

package="com.pat.customizetitlebar"

android:versionCode="1"

android:versionName="1.0">

android:label="@string/app_name"

android:theme="@style/titlebarstyle">

注意粗体字是新增上去的,其中的titlebar是在第5步中增加的。现在来看看运行结果:

1694b09f5f8c9ad73e57d229cc33df1f.png

可以看到结果完全符合了我们的要求。

7.我们还可以改变Titlebar的背景颜色。为此我们修改前面的styles.xml,使之如下:

#047BF0

38dip

@style/CustomizedWindowTitleBackgroundColor

注意,其中的粗体字是新增加的。

项目其他文件,均无需变动。运行结果如下:

3042bbf2bb127b81559891414616d967.png

8.最后,我们以OK按钮为例来测试Titlebar上的控件的事件响应。为此,修改CustomizeTitlebar.java,使之如下:

public class CustomizeTitlebar extends Activity implementsOnClickListener

{

private Button button;

@Override

public void onCreate(Bundle savedInstanceState)

{

super.onCreate(savedInstanceState);

requestWindowFeature(Window.FEATURE_CUSTOM_TITLE);

setContentView(R.layout.main);

getWindow().setFeatureInt(Window.FEATURE_CUSTOM_TITLE, R.layout.titlebar);

button = (Button)findViewById(R.id.button);

button.setOnClickListener(this);

}

public voidonClick(View v)

{

if(v.getId() == R.id.button)

{

Toast.makeText(this, "OK button in Titlebar clicked...", Toast.LENGTH_LONG).show();

}

}

}

粗体字部分是新增加的代码。重新运行本项目,等界面出来后,点击Titlebar上的OK按钮,将出现:

07d87a9b06bdce6b4482a88ed60b141e.png

这说明,Titlebar上自己增加上去的控件,可以很好地响应相关的事件。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值