zoukankan      html  css  js  c++  java
  • Android 如何解决dialog弹出时无法捕捉Activity的back事件

    Android 如何解决dialog弹出时无法捕捉Activity的back事件

      在一些情况下,我们需要捕捉back键事件,然后在捕捉到的事件里写入我们需要进行的处理,通常可以采用下面三种办法捕捉到back事件:

      1)重写onKeyDown或者onKeyUp方法

      2)重写onBackPressed方法

      3)重写dispatchKeyEvent方法

      这三种办法有什么区别在这里不进行阐述,有兴趣的朋友可以查阅相关资料。

      然而在有dialog弹出时,想捕捉back键的事件的话,上述三种办法都无法实现。因为上述方法是重写在activity里面的,也就是说当activity是当前焦点时,它可以捕捉到相应的back键事件,而有dialog弹出时,dialog获取了当前焦点,所以activity里面的方法无法获取到back键事件,此时有两种思路:

      1)设置dialog的setOnCancelListener监听:

    selectDialog.setOnCancelListener(new OnCancelListener() {
                    
                    @Override
                    public void onCancel(DialogInterface dialog) {
                        // TODO Auto-generated method stub
                
                           // Toast.makeText(getBaseContext(), "点击了back", Toast.LENGTH_SHORT).show();
                    }
                });

      这样就可以捕捉到back键的事件了,当按下back键时,系统默认的操作会让dialog cancel掉,此时会触发OnCancelListener,然后在onCancel方法里面就可以实现自己想要实现的操作了。

      2)设置dialog的setOnKeyListener并重写dispatchKeyEvent方法

      selectDialog.setOnKeyListener(new OnKeyListener() {
                    
                    @Override
                    public boolean onKey(DialogInterface dialog, int keyCode, KeyEvent event) {
                        // TODO Auto-generated method stub
                        if(keyCode == KeyEvent.KEYCODE_BACK && event.getRepeatCount()==0)
                        {
                            dialog.dismiss();
                        }
                        return false;
                    }
                });
      public boolean dispatchKeyEvent(KeyEvent event)
        {
            
            switch(event.getKeyCode())
            {
            case KeyEvent.KEYCODE_BACK:           
                Toast.makeText(getBaseContext(), "点击了back", Toast.LENGTH_SHORT).show();
                break;
            default:
                break;
            }
            return super.dispatchKeyEvent(event);
        }

      然后在dispatchKeyEvent里面就可以实现自己想要实现的操作了。

      

  • 相关阅读:
    angular11源码探索十四[表单校验器]
    2020年终总结
    vue使用腾讯地图获取当前位置
    腾讯地图+element-ui 实现地址搜索标记功能
    腾讯地图SDK公交路线规划Demo2
    腾讯地图SDK公交路线规划Demo
    腾讯位置服务地图SDK自定义路况和字体
    腾讯地图SDK自定义地图和路况
    3D地图的定时高亮和点击事件
    vue+腾讯地图 实现坐标拾取器功能
  • 原文地址:https://www.cnblogs.com/dolphin0520/p/3414128.html
Copyright © 2011-2022 走看看