您的位置:首页 > 产品设计 > UI/UE

[置顶] Android UI顶部导航栏模板

2016-02-17 15:35 459 查看
刚学了UI模板新东西,代码简单,很值得思考,特来分享。主要内容是顶部标题栏。

在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

创建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);

}


}

`

接下来就在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>


在其他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();

}
});


`

在其他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();
}
});`


此时就像设置点击事件一样实现不同界面下的点击事件


之后你就可以根据实际需求自己操作了,比如在一些页面隐藏右边按钮、在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下就可以直接设置监听事件实现不同点击效果。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: