赞
踩
最近项目需要在fragment 中实现系统的按键监听,网上很多都是通过对ListView 进行监听,但是这种依赖focus的效果不是很好。
这里总结下自己的实现方式。
- @Override
- protected View initView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
- //.............
- View view = View.inflate(UIUtils.getContext(), R.layout.homefragment, null);
- ButterKnife.bind(this, view);
- //监听back必须设置的
- view.setFocusable(true);
- view.setFocusableInTouchMode(true);
- //然后在写这个监听器
- view.setOnKeyListener(backlistener);
- return view;
- }
-
- private View.OnKeyListener backlistener = new View.OnKeyListener() {
- @Override
- public boolean onKey(View view, int i, KeyEvent keyEvent) {
- if (keyEvent.getAction() == KeyEvent.ACTION_DOWN) {
- //这边判断,如果是back的按键被点击了 就自己拦截实现掉
- if (i == KeyEvent.KEYCODE_BACK) {
- Toast.makeText(UIUtils.getContext(), "BACK拦截", Toast.LENGTH_SHORT).show();
- return true;//表示处理了
- }
- }
- return false;
- }
- };

或者是:
- public class phonerecorder extends Fragment {
- View listview;
- public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
- listview = (View) inflater.inflate(R.layout.phonerecorder, null);
- mListView = (ListView) listview.findViewById(R.id.listView);
- init();
- mListView.setOnItemClickListener(clickitemlistener);
- listview.setFocusable(true);//这个和下面的这个命令必须要设置了,才能监听back事件。
- listview.setFocusableInTouchMode(true);
- listview.setOnKeyListener(backlistener);
- return listview;
- }
-
- private View.OnKeyListener backlistener = new View.OnKeyListener() {
- @Override
- public boolean onKey(View view, int i, KeyEvent keyEvent) {
- if (keyEvent.getAction() == KeyEvent.ACTION_DOWN) {
- if (i == KeyEvent.KEYCODE_BACK) { //表示按返回键 时的操作
- if (!rootpatch.equals(currentfilepach) && currentfilepach != null) {
- File file = new File(currentfilepach);
- openDir2(file.getParent().toString());
- currentfilepach = file.getParent().toString();
- return true;
- } //后退
- return false; //已处理
- }
- }
- return false;
- }
- };
- }

上面两种方式,都需要寻求focus,通过对指定的View 进行onKeyListener。不失为一种方式,但个人觉得这种方式总是有点牵强。下面来分享下自己的实现:
- import android.view.KeyEvent;
-
- public interface FragmentOnKeyListener {
- boolean onKeyDown(int keyCode, KeyEvent event);
- }
对应的fragment 需要implements FragmentOnkeyListener,这一步很关键。
然后实现该onKeyDown:
- @Override
- public boolean onKeyDown(int keyCode, KeyEvent event) {
- LogUtils.LOGD(TAG, "==== onKeyDown");
- if (mMode == SafeboxFilesPreference.MODE_EDIT) {
- switchToMode(SafeboxFilesPreference.MODE_NORMAL);
- return true;
- }
- return false;
- }
这里可以对不同的keyevent 进行不同的处理。
- @Override
- public boolean onKeyDown(int keyCode, KeyEvent event) {
- if (keyCode == KeyEvent.KEYCODE_BACK) {
- Fragment fragment = getShowingFragment();
- if (fragment != null && fragment instanceof FragmentOnKeyListener
- && ((FragmentOnKeyListener) fragment).onKeyDown(keyCode, event)) {
- return true;
- }
- }
- return super.onKeyDown(keyCode, event);
- }
在Activity 中如何拿到Fragment 这个比较简单了,根据不同的实现方式,肯定可以拿到这个Fragment。
最终会调用到fragment 已经实现的onKeyDown。
由于项目需要这里只需要监听BACK,所以,在Activity 中就进行了拦截,如果按键比较多,可以放到Fragment中。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。