本文实例为大家分享了Android实现简单顶部标题栏的具体代码,供大家参考,具体内容如下

实现功能:

1)自定义View标题栏布局;

2)灵活的可以自己传入类型,选择所需要的控件来显示隐藏

3)相对于我之前写过的一篇,免继承,可直接在布局里使用

4)直接可以在布局控件里设置属性

老规矩,上几张效果图:

\"\"

由效果图可见,这个是可以根据传入type来控制,比较灵活的

下面就来实现以下步骤,最后我会贴上源码

1.创建一个布局文件,命名,layout_ bar,来部署我们的标题栏样式,可以自定义更改,图片文件可暂时用自己的替代

<?  version=\"1.0\" encoding=\"utf-8\"?>
<android.support.constraint.ConstraintLayout  ns:android=\"http://schemas.android.com/apk/res/android\"
   ns:app=\"http://schemas.android.com/apk/res-auto\"
   ns:tools=\"http://schemas.android.com/tools\"
  android:layout_width=\"match_parent\"
  android:layout_height=\"50dp\">
 
  <ImageView
    android:id=\"@+id/iv_back\"
    android:layout_width=\"30dp\"
    android:layout_height=\"30dp\"
    android:layout_marginLeft=\"20dp\"
    android:src=\"@drawable/icon_back\"
    app:layout_constraintBottom_toBottomOf=\"parent\"
    app:layout_constraintTop_toTopOf=\"parent\" />
 
  <TextView
    android:id=\"@+id/tv_ \"
    android:layout_width=\"wrap_content\"
    android:layout_height=\"wrap_content\"
    android:text=\"标题\"
    android:textColor=\"#000\"
    android:textSize=\"16sp\"
    app:layout_constraintBottom_toBottomOf=\"parent\"
    app:layout_constraintLeft_toLeftOf=\"parent\"
    app:layout_constraintRight_toRightOf=\"parent\"
    app:layout_constraintTop_toTopOf=\"parent\" />
 
  <TextView
    android:id=\"@+id/tv_more\"
    android:layout_width=\"wrap_content\"
    android:layout_height=\"wrap_content\"
    android:text=\"更多\"
    android:textColor=\"#000\"
    android:textSize=\"16sp\"
    app:layout_constraintBottom_toBottomOf=\"parent\"
    app:layout_constraintRight_toRightOf=\"parent\"
    app:layout_constraintTop_toTopOf=\"parent\" />
 
  <ImageView
    android:id=\"@+id/iv_more\"
    android:layout_width=\"30dp\"
    android:layout_height=\"30dp\"
    android:src=\"@drawable/icon_more\"
    app:layout_constraintBottom_toBottomOf=\"parent\"
    app:layout_constraintRight_toRightOf=\"parent\"
    app:layout_constraintTop_toTopOf=\"parent\" />
 
</android.support.constraint.ConstraintLayout>

2.自定义View,继承自RelativeLayout,第3步贴上attr文件

import android.content.Context;
import android.content.res.TypedArray;
import android.util.AttributeSet;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.ImageView;
import android.widget.RelativeLayout;
import android.widget.TextView;
 
/**
 * @Author : 张
 * @Email : manitozhang@foxmail.com
 * @Date : 2018/9/19
 *
 * 一个简单的自定义标题栏
 */
 
public class Custom Bar extends RelativeLayout {
 
  private ImageView ivBack;
  private TextView tv ;
  private TextView tvMore;
  private ImageView ivMore;
 
  public Custom Bar(Context context, AttributeSet attrs) {
    super(context, attrs);
 
    initView(context,attrs);
  }
 
  //初始化视图
  private void initView(final Context context, AttributeSet attributeSet) {
    View inflate = LayoutInflater.from(context).inflate(R.layout.layout_ bar, this);
    ivBack = inflate.findViewById(R.id.iv_back);
    tv  = inflate.findViewById(R.id.tv_ );
    tvMore = inflate.findViewById(R.id.tv_more);
    ivMore = inflate.findViewById(R.id.iv_more);
 
    init(context,attributeSet);
  }
 
  //初始化资源文件
  public void init(Context context, AttributeSet attributeSet){
    TypedArray typedArray = context.obtainStyledAttributes(attributeSet, R.styleable.Custom Bar);
    String   = typedArray.getString(R.styleable.Custom Bar_ );//标题
    int leftIcon = typedArray.getResourceId(R.styleable.Custom Bar_left_icon, R.drawable.icon_back);//左边图片
    int rightIcon = typedArray.getResourceId(R.styleable.Custom Bar_right_icon, R.drawable.icon_more);//右边图片
    String rightText = typedArray.getString(R.styleable.Custom Bar_right_text);//右边文字
    int  BarType = typedArray.getInt(R.styleable.Custom Bar_ bar_type, 10);//标题栏类型,默认为10
 
    //赋值进去我们的标题栏
    tv .setText( );
    ivBack.setImageResource(leftIcon);
    tvMore.setText(rightText);
    ivMore.setImageResource(rightIcon);
 
    //可以传入type值,可自定义判断值
    if( BarType == 10){//不传入,默认为10,显示更多 文字,隐藏更多图标按钮
      ivMore.setVisibility(View.GONE);
      tvMore.setVisibility(View.VISIBLE);
    }else if( BarType == 11){//传入11,显示更多图标按钮,隐藏更多 文字
      tvMore.setVisibility(View.GONE);
      ivMore.setVisibility(View.VISIBLE);
    }
  }
 
  //左边图片点击事件
  public void setLeftIcon Listener( Listener l){
    ivBack.set Listener(l);
  }
 
  //右边图片点击事件
  public void setRightIcon Listener( Listener l){
    ivBack.set Listener(l);
  }
 
  //右边文字点击事件
  public void setRightText Listener( Listener l){
    ivBack.set Listener(l);
  }
}

3.在res下的values下创建attr文件

<?  version=\"1.0\" encoding=\"utf-8\"?>
<resources>
 
  <declare-styleable name=\"Custom Bar\">
    <attr name=\" \" format=\"string\"/>
    <attr name=\"left_icon\" format=\"reference\"/>
    <attr name=\"right_icon\" format=\"reference\"/>
    <attr name=\"right_text\" format=\"string\"/>
    <attr name=\" bar_type\" format=\"integer\"/>
  </declare-styleable>
 
</resources>

String是文字类型,references是图片类型,integer是数字类型 

4.需要用到我们的这个顶部标题栏的话,就在当前布局引入

可以根据type传入的值来改变右边显示文字还是图片,可在自定义View自定义该type值

<com. bar.Custom Bar
    android:id=\"@+id/ bar\"
    android:background=\"#DCDCDC\"
    app:right_icon=\"@drawable/icon_more\"
    app:right_text=\"更多\"
    app: bar_type=\"11\"
    app:left_icon=\"@drawable/icon_back\"
    app: =\"我是标题\"
    android:layout_width=\"match_parent\"
    android:layout_height=\"wrap_content\"></com. bar.Custom Bar>

5.可以获取它的id,来调用它的点击事件

Custom Bar  Bar = findViewById(R.id. bar);
     Bar.setLeftIcon Listener(new View. Listener() {
      @Override
      public void  (View v) {
        Toast.makeText(MainActivity.this, \"左边\", Toast.LENGTH_SHORT).show();
      }
    });

6.就这么多了,在这里贴上源码,小伙伴可以试试

Android灵活的自定义顶部标题栏

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

收藏 打印