我的方式:Thread + Handle 解决子线程更新UI。
Can’t create handler inside thread that has not called Looper.prepare()
1、编写 Thread 类,实现Runnable。
在Thread 中 new Message,用 Handle.sendMessage(message)调用。
// =======密码错误 1
class errorPassThread implements Runnable {
@Override
public void run() {
Message message = new Message();
message.what = 1;
toastHandler.sendMessage(message);
}
}
// 网络错误 2
class errorNetThread implements Runnable {
@Override
public void run() {
Message message = new Message();
message.what = 2;
toastHandler.sendMessage(message);
}
}
2、new 一个 Handle 。
protected Handler toastHandler; // 子线程 提示用户信息 Toast
toastHandler = new Handler() {
@Override
public void handleMessage(Message msg) {
HintToast.Builder builder = new HintToast.Builder(mContext);
switch (msg.what) {
case 1:
builder.setMessage("密码错误:");
builder.setPositiveButton("确定", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
dialog.dismiss();
}
});
break;
case 2:
builder.setMessage("网络超时请重试");
builder.setPositiveButton("确定", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
dialog.dismiss();
}
});
break;
default:
break;
}
HintToast dialog = builder.create();
dialog.show();
super.handleMessage(msg);
}
};
3、在主线程中执行。
private Handler mainHandler;
mainHandler = new Handler(mContext.getMainLooper());
mainHandler.post(new Runnable() {
@Override
public void run() {
loadingProgressDialog.dismiss();
errorNetThread netThread = new errorNetThread();
new Thread(netThread).start();
}
});