前言
最近的项目很多地方都遇到这样的要求:要求页面里面所有的EditText都是有输入才能让一个button可以被按下,就像下图那样。这个功能实现起来会在Activity占比较多重复的代码,可重用性不高。所以,我把要重复用的东西拿出来,做成了一个自定义View。
原理
实现的思路大概就是:重写Button类,传入要监听的EditText数组,为每个EditText绑定自定义的TextWatcher,然后在TextWatcher里面实现EditText是否为空的判定。然后我们就可以在被监听的EditText每次里面的内容有变化之后都会做一次是否为空的判定,从而实现功能。
下面看代码:
package scut.custombutton;
import android.content.Context;
import android.text.Editable;
import android.text.TextUtils;
import android.text.TextWatcher;
import android.util.AttributeSet;
import android.widget.Button;
import android.widget.EditText;
import java.util.ArrayList;
/**
* Created by yany on 2016/7/24.
*/
public class ButtonCheckBlank extends Button {
private ArrayList<EditText> et_list;
//需要实现下面的几个构造函数,不然有可能加载不了这个控件
public ButtonCheckBlank(Context context) {
super(context);
}
public ButtonCheckBlank(Context context, AttributeSet attrs) {
super(context, attrs);
}
public ButtonCheckBlank(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}
//在这里传入editTexts数组并为它们绑定自定义TextWatcher监听内容里面的改变
public void AddListeningEditTexts(ArrayList<EditText> editTexts){
CheckBlank_TextWatcher mCheckBlank_TextWatcher = new CheckBlank_TextWatcher(this);
et_list = editTexts;
setEnabled(false);
for (int i = 0; i < et_list.size(); i++){
et_list.get(i).addTextChangedListener(mCheckBlank_TextWatcher);
}
}
//重写TextWatcher,监听操作写在里面
private class CheckBlank_TextWatcher implements TextWatcher{
private ButtonCheckBlank mButtonCheckBlank;
public CheckBlank_TextWatcher(ButtonCheckBlank buttonCheckBlank){
mButtonCheckBlank = buttonCheckBlank;
}
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
}
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
}
@Override
public void afterTextChanged(Editable s) {
for (int i = 0; i < et_list.size(); i++){
//判断列表里面的EditText是否为空,是空就return,当所有都不是空的时候button就可以按下
if (TextUtils.isEmpty(et_list.get(i).getText())){
mButtonCheckBlank.setEnabled(false);
return;
}
}
mButtonCheckBlank.setEnabled(true);
}
}
}
在xml里使用这个控件:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="scut.custombutton.MainActivity">
<EditText
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/TextView1"
android:hint="请输入" />
<EditText
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/TextView2"
android:hint="请输入" />
<scut.custombutton.ButtonCheckBlank
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="有未输入就不给按"
android:id="@+id/btn_Check"/>
</LinearLayout>
在Activity里把要监听的TextView放进一个数组传进去:
package scut.custombutton;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.EditText;
import java.util.ArrayList;
public class MainActivity extends AppCompatActivity {
private EditText editText1,editText2;
private ButtonCheckBlank btn_check;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
editText1 = (EditText) findViewById(R.id.TextView1);
editText2 = (EditText) findViewById(R.id.TextView2);
btn_check= (ButtonCheckBlank) findViewById(R.id.btn_Check);
ArrayList<EditText> editTexts = new ArrayList<EditText>();
editTexts.add(editText1);
editTexts.add(editText2);
btn_check.AddListeningEditTexts(editTexts);
}
}
补上效果图: