android中回掉函数用到的地方比较多,有时候我们可能需要在某一特定条件下,有可能页面已经跳转了,比如Activity A跳转到Activity B,当在B中触发某一事件时,在A中需要执行相应的动作,这个时候我们可以自定义回调函数来解决这个问题,这里我结合一个demo来说明一下,其中主要是这种思想,希望各位看完之后多提意见,不喜勿喷。
该demo的应用场景,如下:
首先有一个Activity中的代码:布局如下:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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: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="com.liyc.activity.MainActivity">
<!--这是标题-->
<TextView
android:id="@+id/tv_title"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@android:color/holo_orange_dark"
android:textColor="@android:color/white"
android:text="这是主页面"
android:textSize="25sp"
android:gravity="center"/>
<ListView
android:id="@+id/lv_list"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_below="@+id/tv_title"
/>
</RelativeLayout>
其中很简单只有一个标题,还有一个ListView,listView的item布局如下,只有一个名称和两个按钮组成:
当点击item中的第一个按钮时使用自定义的回调函数,一旦item中的按钮点击操作成功以后,在Activity中监听回调,根据操作结果来更新UI,这样所以关于UI方面的操作全部都放在了Activity中,很好的将UI更新的操作全部放在了Activity中。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="10dp"
android:orientation="vertical">
<TextView
android:id="@+id/tv_name"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="10dp"
android:layout_weight="1"
android:text="我是大明星"/>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:weightSum="2">
<Button
android:id="@+id/btn_del"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingLeft="5dp"
android:paddingRight="5dp"
android:layout_weight="1"
android:text="调用回调"/>
<Button
android:id="@+id/btn_del2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingLeft="5dp"
android:paddingRight="5dp"
android:layout_weight="1"
android:text="调用handler"/>
</LinearLayout>
</LinearLayout>
适配器中的代码如下,其中有两种方式都实现了将操作结果回传到Activity层,只有在Activity中操作UI,第一种就是使用回调,另外一种就是使用handlerpackage com.liyc.adapter;
import android.content.Context;
import android.os.Handler;
import android.os.Message;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;
import com.liyc.activity.R;
import com.liyc.domain.User;
import java.util.List;
/**
* Created by chao on 2016/3/3.
*/
public class UserAdapter extends BaseAdapter {
private List<User> list;
private Context context;
private LayoutInflater inflater;
private Handler mHandler;
public UserAdapter(Context context, Handler handler, List<User> list) {
this.context = context;
this.list = list;
inflater = LayoutInflater.from(context);
mHandler = handler;
}
@Override
public int getCount() {
if (list != null) {
return list.size();
}
return 0;
}
@Override
public Object getItem(int position) {
if (list != null) {
return list.get(position);
}
return null;
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
convertView = inflater.inflate(R.layout.list_item, null);
TextView tvName = (TextView) convertView.findViewById(R.id.tv_name);
tvName.setText(list.get(position).getName());
Button btnDel = (Button) convertView.findViewById(R.id.btn_del);
final int index = position;
btnDel.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
listener.btnonClick(view.getId(), list.get(index));
}
});
Button btnDel2 = (Button) convertView.findViewById(R.id.btn_del2);
btnDel2.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Toast.makeText(context,"点击了删除按钮",Toast.LENGTH_SHORT).show();
Message mes = mHandler.obtainMessage(1,index,0);
mes.sendToTarget();
//这里也可以采用,这里两种写法从功能上实现都可以,但是结合效率的话,采用上一种更加节省内存,效率更高
// Message mess = new Message();
// mes.what = 1;
// mHandler.sendMessage(mess);
}
});
return convertView;
}
private BtnOnClickListener listener;
public void setListener(BtnOnClickListener listener) {
this.listener = listener;
}
/**
* 删除按钮设置的回掉接口
*/
public interface BtnOnClickListener {
void btnonClick(int id, User user);
}
}
最后附上Activity代码来更新UI.
package com.liyc.activity;
import android.content.Context;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.support.v7.app.ActionBarActivity;
import android.util.Log;
import android.widget.ListView;
import android.widget.Toast;
import com.liyc.adapter.UserAdapter;
import com.liyc.domain.User;
import java.util.ArrayList;
import java.util.List;
/**
* 主要的acticity页面
*/
public class MainActivity extends ActionBarActivity implements UserAdapter.BtnOnClickListener {
private List<User> list;
private ListView listView;
private UserAdapter adapter;
private Context context;
/**
* 主线程和子线程建通讯的handler对象
*/
private Handler handler = new Handler() {
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
Log.d("meyki","arg1="+msg.arg1+",arg2 = "+msg.arg2+",what= "+msg.what);
// Toast.makeText(context,"arg1="+msg.arg1+",arg2 = "+msg.arg2+",what= "+msg.what,Toast.LENGTH_SHORT).show();
if(msg.what== 1){
Toast.makeText(context,"通过handler删除成功",Toast.LENGTH_SHORT).show();
list.remove(msg.arg1);
adapter.notifyDataSetChanged();
}
}
};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
context = this;
listView = (ListView) findViewById(R.id.lv_list);
list = new ArrayList<User>();
for (int i = 0;i<5;i++){
User user = new User("我是大明星"+(i+1),i+1);
list.add(user);
}
adapter = new UserAdapter(this,handler,list);
listView.setAdapter(adapter);
adapter.setListener(this);
}
@Override
public void btnonClick(int id, User user) {
if(id == R.id.btn_del){
list.remove(user);
Toast.makeText(context,"通过回调方式删除成功",Toast.LENGTH_SHORT).show();
adapter.notifyDataSetChanged();
}
}
}
最后附上源码下载地址,Android Studio版本:http://download.csdn.net/detail/chi474879271/9453143