Android 判断View是否被遮挡

android开发中,我经常会遇到View是否被覆盖的问题,那么,要如何来判断一个View是否被遮挡呢?

原理,通过view的四个顶点坐标,判断view之间是否有重叠的区域,以此来判断view是否被遮挡,但是情况覆盖不全面,需要根据具体情况调整判断策略

public boolean isViewCovered(final View view){
         View currentView = view;

         Rect currentViewRect = new Rect();
         boolean partVisible =currentView.getGlobalVisibleRect(currentViewRect);
         boolean totalHeightVisible = (currentViewRect.bottom - currentViewRect.top) >=view.getMeasuredHeight();
         boolean totalWidthVisible = (currentViewRect.right - currentViewRect.left) >= view.getMeasuredWidth();
         boolean totalViewVisible = partVisible && totalHeightVisible && totalWidthVisible;
         if (!totalViewVisible)//if any part of the view is clipped by any of its parents,return true
                 return true;

         while (currentView.getParent() instanceof ViewGroup) {
                 ViewGroup currentParent = (ViewGroup) currentView.getParent();
                 if (currentParent.getVisibility() != View.VISIBLE)//if the parent of view is not visible,return true
                         return true;

                 int start = indexOfViewInParent(currentView, currentParent);
                 for (int i = start + 1; i < currentParent.getChildCount(); i++) {
                         Rect viewRect = new Rect();
                         view.getGlobalVisibleRect(viewRect);
                         View otherView = currentParent.getChildAt(i);
                         Rect otherViewRect = new Rect();
                         otherView.getGlobalVisibleRect(otherViewRect);
                         if (Rect.intersects(viewRect, otherViewRect))//if view intersects its older brother(covered),return true
                                 return true;
                 }
                 currentView = currentParent;
         }
         return false;
 }


 private int indexOfViewInParent(View view, ViewGroup parent){
         int index;
         for (index = 0; index < parent.getChildCount(); index++) {
                 if (parent.getChildAt(index) == view)
                         break;
         }
         return index;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值