❶ 为什么ios和android的下拉列表
最直接的原因在于,iOS 中的列表滚动是有“回弹”的。当列表拉到头的时候还可以继续往下拉一段距离,让用户感觉上面还有内容。所以 Loren Bichter 最早在 Tweetie 中加入 pull to refresh 功能的时候,大家会觉得这种刷新的方法很自然。
而 Android 系统则没有回弹特性,列表拉到头无法继续往下拉(CM 中可以,这个另当别论)。如果硬是要用下拉加载,反而显得比较生硬。
❷ android中scrollview怎么实现阻尼回弹
1。你可以用ViewFlipper 来实现效果,每一张图片为一页,加上滑屏动画效果,这个网上资料很全。2。你可以使用gallery来显示图片,这个跟ListView的使用方法是一样的,网上资料和SDK文档里面都介绍很详细。3。用手势监听需要给View上面实现OntouchListener,具体方法跟ViewFlipper的翻页效果是一样的
❸ 【Android】打造下拉放大效果
在其他App上看到了这样的一个效果,感觉有点意思,于是决定实现一个类似的效果。
( 其实是iOS的同学在实现功能的时候随意发挥了一下 )
效果大概值这样子的:
UI看完后
“这个效果不错啊”
“要不你们Android也么做?” 于是~~
作为一个有追求的程序员,决定也要实现一个这样的效果 (满脑子都是草泥马在奔腾)
这样的效果嘛~~
利用自定义的 ViewGroup ,通过对手势的处理,应该就能实现了吧?
主要应该分两部分:
比较麻烦的应该是在第一部分,需要对事件的分发有一些理解。
说到手势的判断,难免需要对事件分发进行处理。
下拉部分
1、在 onInterceptTouchEvent 中对事件进行处理,如果为下拉事件,则将该事件拦截,交给 onTouchEvent 处理;
2、在 onTouchEvent 中通过计算得到下拉的距离,然后动态改变 Header 的配置,实现放大的效果。
重置部分
在 onTouchEvent 的 ACTION_UP 中重置 Header ,实现回弹
知道思路以后,实现起来就比较简单了
创建一个 ViewGroup (这么命名为 FlexibleLayout )继承 LinearLayout 。
onInterceptTouchEvent的处理
先通过两个条件判断是否为下拉事件:
然后通过 mIsBeingDragged 来标记开始拖拽
onTouchEvent的处理
修改头部大小
得到下拉的距离后,就可以来改变 Header 的大小,实现放大效果了。
放大、重置的部分大家可以自由发挥
这里利用 Math.pow(offsetY, 0.8) 得到实际需要增加的高度,通过计算得到对应的宽度以及偏移(类似阻尼效果)。
重置头部
直接将宽高以及偏移设置成原来的参数即可。
(如果觉得这样重置过程不够丝滑,可以通过动画来完成一个流畅的重置效果,这里就不演示了)
到这里,一个简易拉下放大的效果就做完了。试试效果
使用
直接在需要下拉放大的布局外面套上 FlexibleLayout 即可,例如 ScrollView
效果
ScrollVIew:
RecyclerView:
CoordinatorLayout:
大功告成!!!
当然里面还有一些细节的处理,比如下拉的条件、回弹的动画、最大高度等,具体内容的可以在 源码 中看到。
完成下拉放大后,貌似把一个很重要的功能遗忘了下拉刷新 ??
光顾这下拉放大,刷新怎么办?【黑人问号】
这个功能留着下周实现吧,我的7小时睡眠已遥遥无期~~
虽然没有直接实现下拉刷新的功能,不过源码中已经暴露了一个下拉的监听,你也可以通过这个监听实现下拉刷新的操作
到这里就结束了
(来还上周欠下的债~~)
和下拉放大类似,通过希手指下滑的监听,利用 View 的 translationY 和 rotation 实现移动和旋转。
具体的实现过程这里就不贴出来了,直接看效果吧
有兴趣的可以直接去 Github 上看源码以及用法。
Github
PullZoomView
Android事件分发机制 详解攻略,您值得拥有
❹ android中怎样把listview就是拉出范围之后有回弹效果
网上有开源控件:下拉刷新控件PullToRefreshListView, 网络搜一下就知道了,网上还有用法
❺ android 中如何去掉listView自带的回弹效果
在xml中,listView的一个属性
android:overScrollMode="never"
在代码中
mListView.setOverScrollMode(View.OVER_SCROLL_NEVER);
设置后,魅族等手机下拉时就不会显示HOLD了
❻ Android 页面拉倒最边上,有个蓝色的回弹效果,这个效果学名叫做什么,如何修改。如图所示
ScrollView 滑动到顶部的阴影效果 阻尼才是回弹