Android实现自定义标题栏的方法

前端技术 2023/09/05 Android

本文要讲自己定义一个标题栏,能加事件。然后可以移值到不同的手机上,基本上不用改什么,调用也很简单
在layout文件夹下,新建一个XML。名字叫做layout_title_bar.xml然后来看看布局:

<?xml version=\"1.0\" encoding=\"utf-8\"?> 
<RelativeLayout xmlns:android=\"http://schemas.android.com/apk/res/android\" 
  android:layout_width=\"fill_parent\" 
  android:layout_height=\"45.0dip\" 
  android:background=\"@drawable/bg_title_bar\" 
  android:gravity=\"top\" > 
 
  <ImageView 
    android:id=\"@+id/title_bar_menu_btn\" 
    android:layout_width=\"wrap_content\" 
    android:layout_height=\"wrap_content\" 
    android:layout_centerVertical=\"true\" 
    android:layout_marginLeft=\"3.0dip\" 
    android:layout_marginRight=\"3.0dip\" 
    android:layout_marginTop=\"3.0dip\" 
    android:gravity=\"center\" 
    android:src=\"@drawable/ic_top_bar_category\" /> 
 
  <ImageView 
    android:layout_width=\"wrap_content\" 
    android:layout_height=\"fill_parent\" 
    android:layout_toRightOf=\"@id/title_bar_menu_btn\" 
    android:background=\"@drawable/ic_top_divider\" /> 
 
  <TextView 
    android:id=\"@+id/title_bar_name\" 
    android:layout_width=\"wrap_content\" 
    android:layout_height=\"wrap_content\" 
    android:layout_centerInParent=\"true\" 
    android:ellipsize=\"end\" 
    android:gravity=\"center\" 
    android:paddingLeft=\"75.0dip\" 
    android:paddingRight=\"75.0dip\" 
    android:singleLine=\"true\" 
    android:text=\"Java学习宝典\" 
    android:textColor=\"#ffffff\" 
    android:textSize=\"22sp\" /> 
 
</RelativeLayout> 

看下效果:

接下要就是要用了,在要用到的地方:我这里是activity_main.xml文件中:
加上一句:  <include layout=\"@layout/layout_title_bar\" />这样就行了,
然后我们要给标题栏上的按钮添加事件,这个更加简单了:
在MainActivity.java(对应activity_main.xml)中,onCreate函数中添加:事件可以自己改,我这里是让它控制左右滑动的功能。

ImageView menuImg = (ImageView) findViewById(R.id.title_bar_menu_btn); 
    menuImg.setOnClickListener(new View.OnClickListener() { 
 
      @Override 
      public void onClick(View arg0) { 
        if (!menuIsShow) 
          showMenu(); 
        else { 
          hideMenu(); 
        } 
 
      } 
 
    }); 

这样就可以了:
我们来看看效果

这就是效果了,很简单吧,想用直接把上面的布局复制过去就OK了!

本文地址:https://www.stayed.cn/item/12888

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。