回调:
是一种双向的调用模式,被调用的接口被调用时也会被调用(个人理解的是可以实现类与类之间的参数传递)。android中Button等控件的onClickListener()、AsyncTask异步任务中都使用到了回调。
实例:
下面就通过我遇到过一个例子理解 回调。
在android的Acitvity主界面中点击Button,弹出一个AlertDialog,通过AlertDialog上面的选项录入相关值,点击确定按钮时将录入的值显示到Activity的主界面中,我是通过新建一个类继承自AlertDialog来自定义对话框的,所以自定义的AlertDialog和MainActivity是两个不同的类,就想到了使用方法的回调。
1、首先新建一个Acitivty,在Acitivty的布局文件中添加一个弹出对话框的Button和用于显示录入信息的TextView,在acitivty中通过findViewById()方法实例化这些控件
<?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">
<TextView
android:id="@+id/name_txt"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
<TextView
android:id="@+id/age_txt"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
<Button
android:id="@+id/pop_alert_dialog_btn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="自定义对话框" />
</LinearLayout>
public class MainActivity extends AppCompatActivity {
Button mPopBtn;
TextView mNameTxt, mAgeTxt;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mPopBtn = (Button) findViewById(R.id.pop_alert_dialog_btn);
mNameTxt = (TextView) findViewById(R.id.name_txt);
mAgeTxt = (TextView) findViewById(R.id.age_txt);
}
}
2、自定义一个AerltDialog并创建一个对应的layout.xml文件,和上面一样实例化里面的控件
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:padding="40dp">
<TextView
android:id="@+id/name_txt"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="名字"
android:textSize="24sp" />
<EditText
android:id="@+id/name_edit_txt"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_below="@id/name_txt" />
<TextView
android:id="@+id/age_txt"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@id/name_edit_txt"
android:inputType="number"
android:text="年龄"
android:textSize="24sp" />
<EditText
android:id="@+id/age_edit_txt"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_below="@id/age_txt" />
<Button
android:id="@+id/countersign_btn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@id/age_edit_txt"
android:text="确定" />
<Button
android:id="@+id/cancel_btn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_below="@id/age_edit_txt"
android:text="取消" />
</RelativeLayout>
public class CustomAlertDialog extends AlertDialog {
EditText name;
EditText age;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.alert_dialog_layout);
name = (EditText) findViewById(R.id.name_edit_txt);
age = (EditText) findViewById(R.id.age_edit_txt);
Button countersignBtn = (Button) findViewById(R.id.countersign_btn);
Button cancelBtn = (Button) findViewById(R.id.cancel_btn);
countersignBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
dismiss();
}
});
cancelBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
dismiss();
}
});
}
}
3、通过回调,实现Activity中的TextView获取AlertDialog中的TextView的值
AlertDialog类中
public class CustomAlertDialog extends AlertDialog {
public interface Icountersign {//定义一个要回调的接口
void getData(String[] strings);//根据要实现的功能定义抽象方法
}
Icountersign mIcountersign;//声明接口
public void setIData(Icountersign icountersign) {
mIcountersign = icountersign;//设置实例化接口
}
protected CustomAlertDialog(Context context) {
super(context);
}
EditText name;
EditText age;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.alert_dialog_layout);
name = (EditText) findViewById(R.id.name_edit_txt);
age = (EditText) findViewById(R.id.age_edit_txt);
Button countersignBtn = (Button) findViewById(R.id.countersign_btn);
Button cancelBtn = (Button) findViewById(R.id.cancel_btn);
countersignBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
String[] strings = new String[]{name.getText().toString(), age.getText().toString()};
mIcountersign.getData(strings);//接口实例调用定义的方法,传递参数
dismiss();
}
});
cancelBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
dismiss();
}
});
}
}
Activity类中
public class MainActivity extends AppCompatActivity {
Button mPopBtn;
CustomAlertDialog mCustomAlertDialog;
TextView mNameTxt, mAgeTxt;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mPopBtn = (Button) findViewById(R.id.pop_alert_dialog_btn);
mNameTxt = (TextView) findViewById(R.id.name_txt);
mAgeTxt = (TextView) findViewById(R.id.age_txt);
mCustomAlertDialog = new CustomAlertDialog(this);
mPopBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
mCustomAlertDialog.show();
}
});
//设置接口实例,看起来是不是和设置控件的监听类似,按键监听的实现也是这样的
mCustomAlertDialog.setIData(new CustomAlertDialog.Icountersign() {
@Override
public void getData(String[] strings) {
//具体实现方法,这里是获取数值现实给TextView
mNameTxt.setText(strings[0]);
mAgeTxt.setText(strings[1]);
}
});
}
}
运行效果如下:
点击按钮弹出对话框,然后录入信息:
信息成功显示到activity的主界面上: