Android 在Fragment中监听返回键的做法
我只针对一种来讨论 当你的Fragment是Activity中的一个容器布局被replace或add进来的需要重写在Activity中重写onKeyDown返回键操作的方法,此方法代码@Overridepublic boolean onKeyDown(int keyCode, KeyEvent event) {if (event.getActi
·
我只针对一种来讨论
当你的Fragment是Activity中的一个容器布局被replace或add进来的
需要重写在Activity中重写
onKeyDown返回键操作的方法,
此方法代码
@Override public boolean onKeyDown(int keyCode, KeyEvent event) { if (event.getAction() == KeyEvent.ACTION_DOWN) { if (keyCode == KeyEvent.KEYCODE_BACK) { //表示按返回键 时的操作 // 监听到返回按钮点击事件 Log.e("Tag", "点击了返回键"); //后退 meFragment.exit();//这里我们调用的meFrament中的exit return true; //已处理 } } return super.onKeyDown(keyCode, event); }
在此方法中调用Fragment中自己定义的返回键的方法exit()
比如我在fragment中定义的 再按一次返回的方法。
我的Fragment是叫meFrament
就该调用此法。public void exit() { if(!isExit) { isExit = true; Toast.makeText(getActivity(), "再按一次退出程序", Toast.LENGTH_SHORT).show(); new Timer().schedule(new TimerTask() { @Override public void run() { isExit = false; } }, 2000); } else { getActivity().finish(); } }
如此就能达到在Fragment中设置返回键的监听的效果。
如果要在监听事件点击弹出一个退出对话框
那么在onkeyDwon方法中添加如下代码:
@Override public boolean onKeyDown(int keyCode, KeyEvent event) { if (keyCode == KeyEvent.KEYCODE_BACK ) { // 创建退出对话框 AlertDialog isExit = new AlertDialog.Builder(this).create(); // 设置对话框标题 isExit.setTitle("系统提示"); // 设置对话框消息 isExit.setMessage("确定要退出吗"); // 添加选择按钮并注册监听 isExit.setButton("确定", listener); isExit.setButton2("取消", listener); // 显示对话框 isExit.show(); } return false; } /**监听对话框里面的button点击事件*/ DialogInterface.OnClickListener listener = new DialogInterface.OnClickListener() { public void onClick(DialogInterface dialog, int which) { switch (which) { case AlertDialog.BUTTON_POSITIVE:// "确认"按钮退出程序 finish(); break; case AlertDialog.BUTTON_NEGATIVE:// "取消"第二个按钮取消对话框 break; default: break; } } };
Android手机常用的三个键,home键,back键及menu键。
在应用程序里我们经常会对它们经常进行一定的处理,方便用户使用。
首先我们要明确点击三个键时系统干了什么事,
如果没有进行监听处理,
点击home键时,系统默认只执行应用程序的当前显示的Activity的onStop()方法后跳出界面。
而点击back键时,系统默认执行的是应用程序当前Activity的finish()方法后跳出界面。
而点击menu键时,系统默认不进行任何处理。这里只是一个简单的应用demo,我们可以根据自己的需要设计一个更完美的退出程序对话框。
也可以在监听到返回事件后进行其他处理,等等。
更多推荐
已为社区贡献1条内容
所有评论(0)