我们先来看一下Google是如何实现一个控件的,它首先是定义一个atts.xml文件用来配置我们所需要的自定义属性,然后重写控件满足我们的要求,最后在xml中使用我们的控件。
大致过程为首先设计需要的属性-->实现一个我们的View(将定义的TopBar继承自RelativeLayout)-->引用我们的View
新建MyTopBar工程
(1) 先来创建我们需要的属性,在values目录下新建atts.xml内容为
<?xml version="1.0" encoding="utf-8"?>
<resources>
<declare-styleable name="Topbar">
<attr name="myTitle" format="string"/>
<attr name="mytitleTextSize" format="dimension"/>
<attr name="mytitleTextColor" format="color"/>
<attr name="leftText" 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>
(2) 创建一个我们自己的View,在源代码目录,新建TopBar继承自RelativeLayout
package com.davebobo.mytopbar;
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;
/**
* Created by DaveBobo on 2016/9/28.
*/
public class Topbar extends RelativeLayout{
private Button leftButton,rightButton;
private TextView tvTitile;
private String leftText;
private int leftTextColor;
private Drawable leftBackground;
private String rightText;
private int rightTextColor;
private Drawable rightBackground;
private String title;
private float titleTextSize;
private int titleTextColor;
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;
}
//将控件和属性关联
public Topbar(final Context context, AttributeSet attrs) {
super(context, attrs);
TypedArray ta = context.obtainStyledAttributes(attrs,R.styleable.Topbar);
leftText =ta.getString(R.styleable.Topbar_leftText);
leftTextColor = ta.getColor(R.styleable.Topbar_leftTextColor, 0);
leftBackground = ta.getDrawable(R.styleable.Topbar_leftBackground);
rightText =ta.getString(R.styleable.Topbar_rightText);
rightTextColor = ta.getColor(R.styleable.Topbar_rightTextColor, 0);
rightBackground = ta.getDrawable(R.styleable.Topbar_rightBackground);
title = ta.getString(R.styleable.Topbar_myTitle);
titleTextSize = ta.getDimension(R.styleable.Topbar_mytitleTextSize, 0);
titleTextColor = ta.getColor(R.styleable.Topbar_mytitleTextColor, 0);
ta.recycle();//避免浪费资源 避免由于缓存所引起的错误
//属性值获取完毕,处理我们所使用的控件
leftButton = new Button(context);
rightButton = new Button(context);
tvTitile = new TextView(context);
leftButton.setText(leftText);
leftButton.setTextColor(leftTextColor);
leftButton.setBackground(leftBackground);
rightButton.setText(rightText);
rightButton.setTextColor(rightTextColor);
rightButton.setBackground(rightBackground);
tvTitile.setText(title);
tvTitile.setTextColor(titleTextColor);
tvTitile.setTextSize(titleTextSize);
tvTitile.setGravity(Gravity.CENTER);
setBackgroundColor(0xFFF59563);//设置背景颜色
//将控件放到Layout中
leftParams = new LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
leftParams.addRule(RelativeLayout.ALIGN_PARENT_LEFT, TRUE);
addView(leftButton, leftParams);
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);
addView(tvTitile, titleParams);
leftButton.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
listener.leftClick();
}
});
rightButton.setOnClickListener(new OnClickListener() {//接口回调机制
@Override
public void onClick(View v) {
listener.rightClick();
}
});
}
public void setLeftIsvisable(boolean flag){
if (flag)
leftButton.setVisibility(View.VISIBLE);
else
leftButton.setVisibility(View.GONE);
}
}
(3) 引用自定的TopBar控件,打开layout下面的activity_main.xml修改其内容为
<?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-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:padding="5dp"
tools:context="com.davebobo.mytopbar.MainActivity">
<com.davebobo.mytopbar.Topbar
android:id="@+id/topbar"
android:layout_width="match_parent"
android:layout_height="40dp"
custom:leftText="Back"
custom:leftTextColor="#FFFFFF"
custom:leftBackground="@drawable/blue_button"
custom:rightText="More"
custom:rightTextColor="#FFFFFF"
custom:rightBackground="@drawable/blue_button"
custom:myTitle="自定义标题"
custom:mytitleTextSize="10sp"
custom:mytitleTextColor="#123412">
</com.davebobo.mytopbar.Topbar>
</RelativeLayout>
(4) 在MainActivity中获得Topbar引用并使用它
package com.davebobo.mytopbar;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Topbar topbar = (Topbar) findViewById(R.id.topbar);
topbar.setOnTopbarClickListener(new Topbar.topbarClickListener() {
@Override
public void leftClick() {
Toast.makeText(MainActivity.this, "BOBO LEFT", Toast.LENGTH_SHORT).show();
}
@Override
public void rightClick() {
Toast.makeText(MainActivity.this, "BOBO RIGHT", Toast.LENGTH_SHORT).show();
}
});
}
}
UI模板设计效果
体会、思考经典的设计模式,在编程的道路上,只有理解思想才能将其成为自己的东西。