zoukankan      html  css  js  c++  java
  • Android popupwindow 失去焦点或者点击空白区域时消失的解决方法

    先来看下Android API 的这个Methods:

    public void setOutsideTouchable (boolean touchable)

    Controls whether the pop-up will be informed of touch events outside of its window. This only makes sense for pop-ups that are touchable but not focusable, which means touches outside of the window will be delivered to the window behind. The default is false.

    If the popup is showing, calling this method will take effect only the next time the popup is shown or through a manual call to one of the update() methods.

    Parameters

    touchable true if the popup should receive outside touch events, false otherwise


    就是说,基本通过这个属性和setFocusable(true);就能实现点击别的区域让popup消失,

    也能够这样做,设置点击popup窗口自身,让其消失,通过下边的方法即root重写onTouch方法:

     //点击窗口,PopupWindow消失           
                    root.setOnTouchListener(new View.OnTouchListener() {
                        @Override
                        public boolean onTouch(View v, MotionEvent event) {
                            popup.dismiss();
                            return true;
                        }
                    });

    相同, 能够不用重写root的onTouch方法,而该重写 Activity的onTouchEvent()方法,正常情况下也能实现popup消失.


      @Override
        public boolean onTouchEvent(MotionEvent event) {  
            if (popup != null && popup.isShowing()) { 
                popup.dismiss(); 
                popup= null; 
            } 
            return super.onTouchEvent(event);
        }

    可是, 我遇到一个问题,就是上述的方法都解决不了, 是什么原因? 

    事实上,罪魁祸首就是, popup的代码顺序, 手贱先调用了 showAsDropDown()方法,在设置其它属性,导致了这样的情况.

    showAsDropDown这种方法相当于 Dialog.show()方法,  假设是先show了, 然后其它属性即使是设置了,也起不到应有的作用. 

    这一点,常常提醒别人,没想到到popup这里我犯了相同的错误.


  • 相关阅读:
    AJAX
    大前端面试一(基础)
    webpack打包vue -->简易讲解
    vue实现原理
    Spring boot 线上部署
    javascript 事件
    React native采坑路 Running 1 of 1 custom shell scripts
    PHP swoole实现redis订阅和发布
    JAVA 注解和反射
    微信公众平台获取用户地理位置之开发文档详解
  • 原文地址:https://www.cnblogs.com/clnchanpin/p/6991895.html
Copyright © 2011-2022 走看看