当前位置: 首页 > news >正文

做旅行义工网站蚁拉新奖励的app排行

做旅行义工网站蚁,拉新奖励的app排行,成都有做公司网站的公司吗,平台推广引流一、问题原因 昨天,突然一个问题丢在了我的头上,用户反馈说某某界面下拉刷新不好使啊,怎么回事。二话不说直接运行项目,经过测试,发现果然不好使。一看代码提交日期好家伙2020年,百思不得其解,…

一、问题原因

昨天,突然一个问题丢在了我的头上,用户反馈说某某界面下拉刷新不好使啊,怎么回事。二话不说直接运行项目,经过测试,发现果然不好使。一看代码提交日期好家伙2020年,百思不得其解,为啥20年的下拉刷新不好使,到现在才反馈。

还是看问题原因吧。
看了下下拉刷新框架是PullToRefreshView(好像没有用过这个框架),经过测试发现下拉手势怎么都不能回调到刷新回调,
只能断点调试了。
有几个方向可以试探下。

  • ViewPager拦截我们的触摸事件了,导致触摸事件没有下发到我们的listView中
  • 没有正确注册刷新回调接口
  • ListView本身没有处理好下拉事件

以上都是几个猜想方向,我们一一验证。
我们就直接注册ListView触摸事件回调,就可以验证上述猜想。经过验证发现,以上猜想都错了。那么问题是出在哪呢。
跟着代码一步一步走下去就能发现原因了。

二、问题分析

经过调试,最终定位到PullToRefreshBase这个类中。在这个类的onInterceptTouchEvent方法中找到了处理手势的逻辑。

public final boolean onInterceptTouchEvent(MotionEvent event) {if (!isPullToRefreshEnabled()) {return false;}final int action = event.getAction();if (action == MotionEvent.ACTION_CANCEL || action == MotionEvent.ACTION_UP) {mIsBeingDragged = false;return false;}if (action != MotionEvent.ACTION_DOWN && mIsBeingDragged) {return true;}switch (action) {case MotionEvent.ACTION_MOVE: {// If we're refreshing, and the flag is set. Eat all MOVE eventsif (!mScrollingWhileRefreshingEnabled && isRefreshing()) {return true;}if (isReadyForPull()) {final float y = event.getY(), x = event.getX();final float diff, oppositeDiff, absDiff;// We need to use the correct values, based on scroll// directionswitch (getPullToRefreshScrollDirection()) {case HORIZONTAL:diff = x - mLastMotionX;oppositeDiff = y - mLastMotionY;break;case VERTICAL:default:diff = y - mLastMotionY;oppositeDiff = x - mLastMotionX;break;}absDiff = Math.abs(diff);if (absDiff > mTouchSlop && (!mFilterTouchEvents || absDiff > Math.abs(oppositeDiff))) {if (mMode.showHeaderLoadingLayout() && diff >= 1f && isReadyForPullStart()) {mLastMotionY = y;mLastMotionX = x;mIsBeingDragged = true;if (mMode == Mode.BOTH) {mCurrentMode = Mode.PULL_FROM_START;}} else if (mMode.showFooterLoadingLayout() && diff <= -1f && isReadyForPullEnd()) {mLastMotionY = y;mLastMotionX = x;mIsBeingDragged = true;if (mMode == Mode.BOTH) {mCurrentMode = Mode.PULL_FROM_END;}}}}break;}case MotionEvent.ACTION_DOWN: {if (isReadyForPull()) {mLastMotionY = mInitialMotionY = event.getY();mLastMotionX = mInitialMotionX = event.getX();mIsBeingDragged = false;}break;}}return mIsBeingDragged;}

到这里就很简单了,给每一个判断都打上断点,一步步走。最后发现mIsBeingDragged这个值为false。这就导致在onTouchEvent中并不会执行我们的刷新逻辑。

switch (event.getAction()) {//...省略部分代码case MotionEvent.ACTION_MOVE: {if (mIsBeingDragged) {mLastMotionY = event.getY();mLastMotionX = event.getX();//处理刷新和加载事件pullEvent();return true;}break;}case MotionEvent.ACTION_DOWN: {if (isReadyForPull()) {mLastMotionY = mInitialMotionY = event.getY();mLastMotionX = mInitialMotionX = event.getX();return true;}break;}//...省略部分代码
}

可以看到在move事件中,并不会执行我们刷新逻辑。
到这里就可以明白肯定是在onInterceptTouchEvent中,部分逻辑判断失败了,导致mIsBeingDragged值为false。
重新回到上一个逻辑中,就可以发现isReadyForPullStart()方法返回值为false就无法执行到mIsBeingDragged赋值为true的逻辑。
最终会执行到isFirstItemVisible()中,一起来看看吧。

private boolean isFirstItemVisible() {final Adapter adapter = mRefreshableView.getAdapter();if (null == adapter || adapter.isEmpty()) {if (DEBUG) {Log.d(LOG_TAG, "isFirstItemVisible. Empty View.");}return true;} else {/*** This check should really just be:* mRefreshableView.getFirstVisiblePosition() == 0, but PtRListView* internally use a HeaderView which messes the positions up. For* now we'll just add one to account for it and rely on the inner* condition which checks getTop().*/if (mRefreshableView.getFirstVisiblePosition() <= 1) {final View firstVisibleChild = mRefreshableView.getChildAt(0);if (firstVisibleChild != null) {return firstVisibleChild.getTop() >= mRefreshableView.getTop();}}}return false;}

最后就是看这句代码return firstVisibleChild.getTop() >= mRefreshableView.getTop();在debug下计算这段,就会发现firstVisibleChild.getTop()的值为0,而mRefreshableView.getTop()的值为30,什么情况呢。
再去看源码会发现,mRefreshableView其实就是我们的ListView。那么这里判断的就是第一个item距离上边界的距离和ListView距离上边界的距离。
那么这里我们就要去找找为什么ListView的距离要比item的距离大。

在项目中找到了如下代码,没想到简简单单的一句代码影响这么大。

lp.setMargins(0, ViewUtil.dip2px(mActivity, 10), 0, 0);
mListview.setLayoutParams(lp);

注释这段设置margin的代码,转为在上一个控件设置margin或者在item中设置margin。不能下拉刷新就完美解决了,泰裤辣!!!

http://www.yayakq.cn/news/652192/

相关文章:

  • 上海闵行网站制作公司淘宝代运营是什么意思
  • 中山网站建设价位ppt网站建设答案
  • 宁波建网站公司品牌提升方案
  • 网站设计集团优化一个网站
  • 无锡外贸网站制作网站首页效果图怎么设计
  • 的建站网站深圳航空公司
  • 青海建设兵团网站小院离婚协议书正规模板
  • 深圳网站程序开发制作罗湖做网站报价
  • 网站开发项目经理不相关的网站做单项链接可以吗
  • 网站改版的原因有什么网站可以在线做试题
  • 深圳网站设计师培训学校大连开发区网站设计公司
  • 网站规划与建设大作业答案重庆涪陵网站设计公司哪家专业
  • 网站建设费用计入哪个科目网站推广代运营
  • 携程网站建设江门建网站
  • 做网站需要什么备案云县网站建设 云县网
  • 怎么做自我介绍网站网站与微信内容建设与运维总结
  • 微信网站开发设计在哪个网站可以查做项目中标的
  • 建立网站ppt网页网站怎么做的
  • 沈阳设计网站公司中小学 网站建设 通知
  • 网站地图 制作工具高校网站建设要点
  • wordpress增加网址大全深圳网站设计专家乐云seo
  • 做响应式网站费用企业网站设计解决方案
  • 娱乐新闻做的好的网站做网站的收益来源
  • 福建大舟建设集团有限公司 网站wordpress提醒用法
  • 网站推广沈阳互联网经营许可证
  • 超酷个人网站六灶网站建设
  • 软文网站名称h5科技 网站
  • 微网站建设合同网站根目录文件
  • 网站建设期末实践报告wordpress前台编辑
  • 重庆石桥铺网站建设公司乌班图系统做网站