Android 调用父类方法,进行子界面刷新
2013-12-09 17:47
483 查看
偶然遇到一个需求、有几个主界面需要获取消息的未读数量
由于不是所有类都调用、调用的次数又比较多,整的不上不下的
1、对于方法调用次数比较少的 推荐广播
广播的方法很方便、但是一堆的消息接收、发送很模式化
2、对于较多的方法调用 个人建议直接写共用类中
此方法通常用于数据处理、对接复杂界面处理颇感无力
3、结合父类、根据实际情况调用
今天介绍的就是通过接口调用 选择获取消息数量方法
首先介绍下主逻辑、即在子类调用父类方法、并将子类handler传入父类、进行数据返回
子类主要代码:
protected void onResume() { // TODO Auto-generated method stub if (app.jkNeedReadNum) getNoReadNum(app.userid, handler); super.onResume(); } private Handler handler = new Handler() { /* * (non-Javadoc) * * @see android.os.Handler#handleMessage(android.os.Message) */ @Override public void handleMessage(Message msg) { // TODO Auto-generated method stub switch (msg.what) { //后续修改case GET_NUM_SUCCESS:
String count = (String) msg.obj;
badge1.setText(count);
badge1.show();
badge1.invalidate();
break;
case GET_NUM_CANCLE:
badge1.setVisibility(View.GONE);
badge1.invalidate();
break;
}
}
};
父类主要代码:
// 获取未阅读数量 public void getNoReadNum(long user_id, Handler handler) { RequestParams params = new RequestParams(); params.put("user_id", user_id + ""); HttpConnection.mesNoreadSum(params, new NumAsyncHttpResponseHandler( handler)); } class NumAsyncHttpResponseHandler extends AsyncHttpResponseHandler { Handler handler; public NumAsyncHttpResponseHandler(Handler handler) { this.handler = handler; } @Override public void onStart() { // TODO Auto-generated method stub app.jkNeedReadNum = false; super.onStart(); } /* * (non-Javadoc) * * @see com.emotte.result.AsyncHttpResponseHandler#onFinish() */ @Override public void onFinish() { // TODO Auto-generated method stub app.jkNeedReadNum = true; super.onFinish(); } /* * (non-Javadoc) * * @see * com.emotte.result.AsyncHttpResponseHandler#onSuccess(java.lang.String * ) */ @Override public void onSuccess(String content) { // TODO Auto-generated method stub app.jkNeedReadNum = true; try { // JSONObject obj = new JSONObject(content); // String result = obj.optString("success"); // if (result != null || "0".equals(result)) { // String count = obj.optString("count"); // String count = "22"; System.out.println(count); if (count != null && Integer.parseInt(count) > 0) { Message m = handler.obtainMessage(); m.what = GET_NUM_SUCCESS; m.obj = count; handler.sendMessage(m); } else { Message m = handler.obtainMessage(); m.what = GET_NUM_CANCLE; handler.sendMessage(m); } // } } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } super.onSuccess(content); } /* * (non-Javadoc) * * @see * com.emotte.result.AsyncHttpResponseHandler#onFailure(java.lang.Throwable * , java.lang.String) */ @Override public void onFailure(Throwable error, String content) { // TODO Auto-generated method stub app.jkNeedReadNum = true; super.onFailure(error, content); } };
为了不重复调用、此处定义了全局变量用于判断。
DEMO下载地址:
http://www.kuaipan.cn/file/id_28743136620627165.htm?source=1
相关文章推荐
- android ListView详解
- Android SlidingMenu以及ActionBarSherlock的基础使用教程
- Android SlidingMenu以及ActionBarSherlock的基础使用教程
- Android Intent\IntentFilter 详解
- Android滑动效果入门篇———ViewFlipper实现滑动效果
- 我的android 第23天 - UriMatcher类使用介绍
- Android实现XML解析技术
- Android实现计时与倒计时的几种方法
- Android input处理机制(一)InputReader
- Android如何正确引用其它jar包
- Android系统root破解原理分析
- Android小知道积累
- android中通过拨号键打开contacts相关界面的流程分析
- Android 手势识别
- android 创建桌面快捷方式
- Android分布式编译学习(三)dmucs实现负载均衡 —— Ubuntu12.04上部署distcc分布式编译
- android TextView 垂直自动滚动字幕实现
- android TextView 垂直自动滚动字幕实现
- android的窗口机制分析------事件处理
- android.os.NetworkOnMainThreadException解决