Android UI顶部导航栏模板

这篇博客分享了如何创建一个自定义的Android顶部导航栏模板。通过在values下新建atts.xml文件定义自定义属性,创建Topbar类继承RelativeLayout,并在Activity中布局UI。博主使用接口回调机制实现不同场景下的点击效果,使得导航栏能在不同页面有不同的功能。通过设置监听事件和控制按钮可见性,可以根据实际需求定制导航栏的行为。

刚学了UI模板新东西,代码简单,很值得思考,特来分享。主要内容是顶部标题栏。

  1. 在values下新建atts.xml编写自定义
<resources>

    <declare-styleable name="Topbar">
        <attr name="title" format="string" />
        <attr name="titleTextSize" format="dimension" />
        <attr name="titleTextColor" format="color" />
        <attr name="titleBackground" format="color" />
        <attr name="leftText" format="string" />
        <attr name="rightText" format="string" />
        <attr name="leftTextColor" format="color" />
        <attr name="leftBackground" format="reference|color" />
        <attr name="righttext" format="string" />
        <attr name="rightTextColor" format="color" />
        <attr name="rightBackground" format="reference|color" />
    </declare-styleable>

</resources>

declare告诉系统这是自定义控件;righttext此处t小写因为 Eclipse报错”rightText” has already been defined在这用小写了。
以上为自定义标题栏ui 内容是:左边内容 标题 右边内容。
因为颜色表达不固定 :如@color、#**等 所以指定为reference或colorr

  1. 创建Topbar.class继承RelativeLayout:初始化各个类,color为int属性,为控件赋予属性值、TypedArray找到atts.xml的控件。为控件设置属性,将定义传进来,方法与layout相似,代码如下:`package com.zkd.drawingboard;

import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.drawable.Drawable;
import android.util.AttributeSet;
import android.view.Gravity;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.RelativeLayout;
import android.widget.TextView;
import android.widget.Toast;

public class Topbar extends RelativeLayout {

private Button leftButton, rightButton;
private TextView tvTitle;

private int leftTextColor;// 颜色为int属性
private Drawable leftBackground;
private String leftText;

private int rightTextColor;
private Drawable rightBackground;
private String rightText;

private float titleTextSize;
private int titleTextColor;
private int titleBackground;
private String title;

public Topbar(Context context, AttributeSet attrs) {
    super(context, attrs);
    TypedArray ta = context.obtainStyledAttributes(attrs,
            R.styleable.Topbar);// 找到xml文件,返回TypedArray,包含了所有定义属性
    // 赋予属性值
    leftTextColor = ta.getColor(R.styleable.Topbar_leftTextColor, 0);
    leftBackground = ta.getDrawable(R.styleable.Topbar_leftBackground);
    leftText = ta.getString(R.styleable.Topbar_leftText);

    rightTextColor = ta.getColor(R.styleable.Topbar_rightTextColor, 0);
    rightBackground = ta.getDrawable(R.styleable.Topbar_rightBackground);
    rightText = ta.getString(R.styleable.Topbar_righttext);

    titleBackground=ta.getColor(R.styleable.Topbar_titleBackground, 0);
    titleTextSize = ta.getDimension(R.styleable.Topbar_titleTextSize, 0);
    titleTextColor = ta.getColor(R.styleable.Topbar_titleTextColor, 0);
    title = ta.getString(R.styleable.Topbar_title);

    ta.recycle();// 回收资源,避免缓存资源浪费

    leftButton = new Button(context);
    rightButton = new Button(context);
    tvTitle = new TextView(context);
    // 设置属性,将定义传进来
    leftButton.setTextColor(leftTextColor);
    leftButton.setBackground(leftBackground);
    leftButton.setText(leftText);

    rightButton.setTextColor(rightTextColor);
    rightButton.setBackground(rightBackground);
    rightButton.setText(rightText);

    tvTitle.setText(title);
    tvTitle.setTextColor(titleTextColor);
    tvTitle.setTextSize(titleTextSize);
    tvTitle.setGravity(Gravity.CENTER);// 居中显示
    tvTitle.setBackgroundColor(titleBackground);

    setBackgroundColor(0xFFF59563);//设置整体背景颜色
    // 放进Layout,定义属性--与xml相似
    leftParams = new LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT,
            LayoutParams.WRAP_CONTENT);
    leftParams.addRule(RelativeLayout.ALIGN_PARENT_LEFT, TRUE);// 左对齐TRUE为RelativeLayout的常量

    addView(leftButton, leftParams);// 将leftButton以params放进去

    rightParams = new LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT,
            LayoutParams.WRAP_CONTENT);
    rightParams.addRule(RelativeLayout.ALIGN_PARENT_RIGHT, TRUE);

    addView(rightButton, rightParams);

    titleParams = new LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT,
            LayoutParams.MATCH_PARENT);
    titleParams.addRule(RelativeLayout.CENTER_IN_PARENT, TRUE);// 居中,TRUE为RelativeLayout的常量

    addView(tvTitle, titleParams);

}

}

`

  1. 接下来就在Activity中布局UI,我用的Eclipse,Studio有一处代码不同。引用自定义控件一定要声明出来、xmlns:custom=”http://schemas.android.com/apk/res/com.zkd.drawingboard”–:custom不要与系统相同
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:custom="http://schemas.android.com/apk/res/com.zkd.drawingboard"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <!--
    xmlns:custom="http://schemas.android.com/apk/res-auto"   studio引用自定义控件
    -->

    <com.zkd.drawingboard.Topbar
        android:id="@+id/Topbar"
        android:layout_width="match_parent"
        android:layout_height="40dp"
        custom:leftBackground="#515151"
        custom:leftText="Back"
        custom:leftTextColor="#FFFFFF"
        custom:rightBackground="#515151"
        custom:rightText="More"
        custom:rightTextColor="#FFFFFF"
        custom:title="标题"
        custom:titleBackground="#515151"
        custom:titleTextColor="#FFFFFF"
        custom:titleTextSize="8sp" >
    </com.zkd.drawingboard.Topbar>
</RelativeLayout>
  1. 在其他class引用控件,并且实现不同场景点击效果不同,真正实现模板,运用接口回调机制实现不同情景下不同点击效果,之后就行设置监听事件一样在不同class中设置点击事件。`
    private LayoutParams leftParams, rightParams, titleParams;

    private topbarClickListener listener;

    public interface topbarClickListener {

    public void leftClick();
    
    public void rightClick();
    

    }

    public void setOnTopbarClickListener(topbarClickListener listener) {
    this.listener = listener;
    }
    // 设置点击事件
    leftButton.setOnClickListener(new OnClickListener() {

        @Override
        public void onClick(View v) {
            listener.leftClick();
        }
    });
    rightButton.setOnClickListener(new OnClickListener() {
    
        @Override
        public void onClick(View v) {
            listener.rightClick();
    
        }
    });
    

    `

  2. 在其他class中引用`//获得Topbar引用
    Topbar topbar=(Topbar) findViewById(R.id.Topbar);
    topbar.setOnTopbarClickListener(new Topbar.topbarClickListener() {

        @Override
        public void rightClick() {
            Toast.makeText(Main.this, "RIGHT", Toast.LENGTH_SHORT).show();
    
        }
    
        @Override
        public void leftClick() {
            Toast.makeText(Main.this, "LEFT", Toast.LENGTH_SHORT).show();               
        }
    });`
    

    此时就像设置点击事件一样实现不同界面下的点击事件Alt+/直接提升

  3. 之后你就可以根据实际需求自己操作了,比如在一些页面隐藏右边按钮、在Topbar.class添加代码
    // 用这个方法控制右边Button是否显示出来
    public void setRightIsvisable(boolean flag) {
    if (flag) {
    rightButton.setVisibility(View.VISIBLE);
    } else {
    rightButton.setVisibility(View.GONE);
    }
    }

在class实现 topbar.setRightIsvisable(false); //右边按钮隐藏

总结:代码简单,但是思想很重要,我们不可能学会所有方法,但是我们可以根据android系统套用,就像以上根据系统监听事件自定义监听事件,之后在不同class下就可以直接设置监听事件实现不同点击效果。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值