如果大家在非黑色背景下使用ListView控件时,Android默认可能在滚动ListView时这个列表控件的背景突然变成黑色。这样可能导致程序的黑色的背景和主程序的主题既不协调。...解决的方法Google在设计Android时也考虑了,在Layout的ListView中加入 android:cacheColorHint="#00000000" 的属性即可。
是我们常用的滚动类型布局,应工作中的一个需求,需要监听这些布局的页面停留状态,以配合更新页面UI,然后通过按钮点击以控制这些页面的滚动; 目录 scroollview监听方法 listview监听方法...view, int scrollState) {} @Override public void onScroll(AbsListView view, //报告滚动状态的视图...---- 二、listview监听方法 ListView().setOnScrollListener(new OnScrollListener() { @Override...(-300, 1000); } } } }); 通过smoothScrollBy,我们可以控制页面的滚动,我们看下在HorizontalScrollView...y - mScrollY); } smoothScrollBy(x,y)方法在判断滑动间隔的时间长短后判定是一蹴而就还是慢慢滑向终点,关键方法是调用View的srcoll(x,y)方法,或借助
enterAlways - 实现quick return效果, 当向下移动时,立即显示View(比如Toolbar). exitUntilCollapsed - 向上滚动时收缩View,但可以固定Toolbar...enterAlwaysCollapsed - 当你的View已经设置minHeight属性又使用此标志时,你的View只能以最小高度进入,只有当滚动视图到达顶部时才扩大到完整高度。...解决NestedScrollView嵌套listView问题。 貌似网上一抓一大把,本文采用其中之一方案,复写listView。...滚动时无响应bug。...在最新的23.2.0包会出现问题,解决办法是用android:layout_gravity="bottom|end" 替换。
CustomScrollView CustomScrollView是使用Sliver组件创建自定义滚动效果的滚动组件,使用场景: ListView和GridView相互嵌套场景,ListView嵌套GridView...时,需要给GridView指定高度,但我们希望高度随内容而变化(不指定),ListView和GridView作为整体滚动效果。...相互嵌套场景 在实际业务场景中经常见到这样的布局,顶部是网格布局(GridView),然后是列表布局(ListView),滚动的时候做为一个整体,此场景是无法使用GridView+ListView来实现的...reverse参数表示反转滚动方向,并不是垂直转为水平,而是垂直方向滚动时,默认向下滚动,reverse设置false,滚动方向改为向上,同理水平滚动改为水平向左。...primary设置为true时,不能设置controller,因为primarytrue时,controller使用PrimaryScrollController,这种机制带来的好处是父组件可以控制子树中可滚动组件的滚动行为
,小于这个值,DragGridView向下滚动 mDownScrollBorder = getHeight() /4; //获取DragGridView自动向下滚动的偏移量... mHandler.post(mScrollRunnable); } /** * 当moveY的值大于向上滚动的边界值,触发GridView自动向上滚动... * 当moveY的值小于向下滚动的边界值,触犯GridView自动向下滚动 * 否则不进行滚动 */ private Runnable mScrollRunnable... mHandler.removeCallbacks(mScrollRunnable); } //当我们的手指到达GridView向上或者向下滚动的偏移量的时候...在界面上面的交换,但是数据交换我这里没有做,所以我提供了回调接口OnChanageListener,我们只需要自己实现数据的交换逻辑然后刷新DragGridView即可,我们还需要实现DragGridView的自动向上滚动或者向下滚动
初始化的时候,让下拉头向上偏移出屏幕,这样我们看到的就只有ListView了。...然后对ListView的touch事件进行监听,如果当前ListView已经滚动到顶部并且手指还在向下拉的话,那就将下拉头显示出来,松手后进行刷新操作,并将下拉头隐藏。原理示意图如下: ?...之后每当手指在ListView上滑动时,onTouch方法就会执行。...在onTouch方法中的第一行就调用了setIsAbleToPull方法来判断ListView是否滚动到了最顶部,只有滚动到了最顶部才会执行后面的代码,否则就视为正常的ListView滚动,不做任何处理...当ListView滚动到了最顶部时,如果手指还在向下拖动,就会改变下拉头的偏移值,让下拉头显示出来,下拉的距离设定为手指移动距离的1/2,这样才会有拉力的感觉。
@Override public void onPullUpToRefresh(PullToRefreshBaseListView> refreshView) { } } 设置正在刷新时,listview...是否可以滚动 //正在刷新的时候,listView 禁止滚动 pullToRefreshListView.setScrollingWhileRefreshingEnabled( false...); //正在刷新的时候,listView 可以滚动 pullToRefreshListView.setScrollingWhileRefreshingEnabled( true ); 设置刷新时显示的字体的颜色...-- ptrScrollingWhileRefreshingEnabled 刷新的时候,是否允许ListView或GridView滚动。觉得为true比较好。 --> 滚动时刷新头部会一起滚动。
需求模仿腾讯课堂视频播放详情页面,效果如图: 1外层滚动控件到顶部,内层控制滚动 2内层滚动到顶部,外层控制滚动 835108-20170331111709149-156183149.gif 835108...ViewGroup是否拦截事件,是通过onTnterceptTouchEvent返回值来确定,当返回true时,表示拦截该事件,那么该系列事件全部传递给ViewGroup的onTouchEvent,如果返回...了解那些触摸事件 down(落下事件如果被消耗即返回true,那么后续move->...move->up事件不会转发) move--手指屏幕移动事件(可以根据down的x,y值与move事件中判断手势是否向上或者向下滑动...一开始的思路是切换tab页面的话其他tab页面Listview控件可见状态会不可见或者消失,完全不是这么回事,后来发现其实View的视图状态一直是可见的,不过那时候技术老大提醒说点击不同的tab时listview...y2 = ev.getY(); //是否到底部 默认为已到底部 isbottom = isAtBottom(); //向上移动
的其他item会出现向上或者向下滚动的效果,感觉效果很棒,所以在GitHub上面搜索了下,发现很多开源库都有这个效果,比如ListViewAnimations, android-swipelistview...使ListView的其他item产生向上挤压或者向下挤压的效果 大致的思路这是这四步,其中的一些细节接下来我会一一为大家解答的,接下来我们就用代码来实现这种效果吧 首先我们新建一个工程,叫Swipedismisslistview...null; } mSwiping = false; } /** * 在此方法中执行item删除之后,其他的item向上或者向下滚动的动画...的左右滑动删除item的效果啦,但是还有一个效果,item删除之后,ListView的其他item向上或者向下缓缓滑动的效果,实现这个也很容易,就是动态设置item的高度,item高度逐渐变小,这样其他的...item就会出现向上或者向下挤压的效果啦!
项目地址 在这里,如果有好的意见欢迎提 issue或pr。 开始 我们先来看下,腾讯课堂视频播放详情页面是怎么样的? ?...120时,滚动条到底部了,视频播发控件的区域距离屏幕顶部还有80。...跑起来运行后发现的一个严重的问题是,如果Tab导航控件的内容区域存在ScrollView或者ListView时,无法滚动,只有最外层可以滚动,也就是手势滚动被拦截了?...,向下滑 在通过isAtBottom方法,判断RNFixScrollView是否滑到底部。...:不拦截 RNFixScrolView未到底部&&向上滑:拦截 RNFixScrolView未到底部&&向下滑&&子ScrollView已到顶部:拦截 RNFixScrolView已到底部&&向下滑
NestedScrollView 可以在其内部嵌套其他滚动视图的组件,其滚动位置是固有链接的。...滚动隐藏AppBar 比如实现如下场景,当列表滚动时,隐藏AppBar,用法如下: NestedScrollView( headerSliverBuilder: (BuildContext context...bool innerBoxIsScrolled) { return [SliverAppBar( title: Text('老孟'), )]; }, body: ListView.builder.../20180918/2018091815372344164.jpg', fit: BoxFit.fitHeight, ), ), )]; }, body: ListView.builder...reverse参数表示反转滚动方向,并不是由垂直转为水平,而是垂直方向滚动时,默认向下滚动,reverse设置false,滚动方向改为向上,同理水平滚动改为水平向左。
同理,拉动AppBarLayout也有类似情况,当松开手指后,AppBarLayout得判断要不要继续向上收缩,或是继续向下展开。...如果仅仅声明scroll,没有声明其它标志,则滚动效果如下图所示: ? 2、enterAlways : 头部与主体先一起滚动,头部滚到位后,主体继续向上或者向下滚。...具体的滚动说明如下所示: 向上滚动:头部先往上收缩,一直滚到折叠的最小高度。然后头部固定不动,主体继续向上滚动。 向下滚动:头部固定不动,主体先向下滚动,一直滚到主体全部拉出。然后头部向下展开。...具体的滚动说明如下所示: 向上滚动:头部先往上收缩,一直滚到折叠的最小高度。然后头部与主体先一起滚动,头部滚到位后,主体继续向上。 向下滚动:头部与主体先一起滚动,一直滚到头部折叠的最小高度。...然后主体向下滚动,滚到位后头部继续向下展开。 5、snap : 在用户手指松开时,系统自行判断,接下来是全部向上滚到顶,还是全部向下展开。
关于这个 setRecyclerListener函数在解决 listView滑出屏幕(包括向上滑出和向下滑出)处理相关UI操作或者释放相关资源,真的很好用, 比listView的setOnScrollListener...当Adapter中的数据个数未发生变化时,此时用户可能只是滚动,或点击等操作,ListView中item的个数会发生变化,因此,需要将可视的item加入到mActiveView中来管理。...第三种情况,这个最简单: 一开始,listview稳定后,显示N个,此时mScrapView中是没有缓存view的,当我们向上滚动一小段距离(第一个此时仍显示部分),新的view将会显示,此时listview...第二种情况: 在a中,我们继续向上滚动,直接第一个view完全移出屏幕(假设没有新的item),此时,第一个view就会被detach,并被加入到mScrapView中;然后,我们还继续向上滚动,直接后面又将要显示新的.... // 滚动时,不在可见范围内的item放入回收站。。。。。。。
用RecyclerView替换ListViews 目前,你需要用RecyclerView来替换ListView。就如这节所描述的,RecyclerView是ListView的继承者。...ScrollAwareFABBehavior(Context context, AttributeSet attrs) { super(); } /** * 处理垂直方向上的滚动事件...directTargetChild, target, nestedScrollAxes); } /** * 检查Y的位置,并决定按钮是否动画进入或退出...向下移动 FAB消失,向上移动时,FAB出现。 ---- embedding(嵌入)-floatingactionbutton-in-header 效果图 ?..., ScrollView 或者 RecyclerView 关联起来,这样按钮就会随着list的向下滚动而隐藏,向上滚动而重现: ListView listView = (ListView) findViewById
6.1.1 Scrollable组件 在Flutter中,一个可滚动的组件直接或间接包含一个Scrollable组件,它是可滚动组件的基础组件。...CustomScrollView作为容器组件时,子组件不能是ListView、GridView等可滚动组件,会造成滚动冲突。...6.2 列表组件 6.2.1 ListView ListView,即列表组件,作用类似于Android的RecyclerView或ListView。...ListView可以沿一个线性方向排布相同或相似的子组件元素,并支持基于Sliver的延迟。...,为了不造成滚动时的冲突,需要对子组件添加禁止滚动属性。
第96行处的逻辑是完全相同的,只不过一个是向上移动,一个是向下移动,这里就不再赘述。...另外还有一点改动,就是我们在第115行调用fillGap()方法的时候添加了一个参数,原来的fillGap()方法只接收一个布尔型参数,用于判断向上还是向下滑动,然后在方法的内部自己获取第一个或最后一个元素的位置来获取偏移值...getColumnToAppend()方法是用于判断当ListView向下滑动时,新进入屏幕的子View应该添加到哪一列的。...getColumnToPrepend()方法是用于判断当ListView向上滑动时,新进入屏幕的子View应该添加到哪一列的。...因为向上滑动时,新进入屏幕的子View其实都是之前被移出屏幕后回收的,它们不需要关心每一列最高子View或最低子View的位置,而是只需要遵循一个原则,就是当它们第一次被添加到屏幕时所属于哪一列,那么向上滑动时它们仍然还属于哪一列
当列表滚动到相应位置时,ListView会调用该方法创建对应的子Widget。 itemCount,表示列表项的数量,如果为空,则表示ListView为无限列表。...这时,各自视图的滚动和布局模型就是相互独立、分离的,就很难保证整个页面统一一致的滑动效果。 那么,Flutter是如何解决多ListView嵌套时,页面滑动效果不一致的问题的呢?...在Flutter中,因为Widget并不是渲染到屏幕的最终视觉元素(RenderObject才是),所以我们无法像原生的iOS或Android一样,向持有的Widget对象获取或设置最终渲染相关的视觉信息...if(_controller.offset > 1000) {// 如果 ListView 已经向下滚动了 1000,则启用 Top 按钮 setState(() {isToTop...= true;}); } else if(_controller.offset ListView 向下滚动距离不足 300,则禁用 Top 按钮
滚动鼠标# 向上滚动100单位pyautogui.scroll(100)# 向下滚动100单位pyautogui.scroll(-100)解析:使用 pyautogui.scroll(amount) 可以控制鼠标的滚动...,正值向上滚动,负值向下滚动。..., interval=0.1)# 按下 Enter 键pyautogui.press('enter')# 按下 Ctrl+Cpyautogui.hotkey('ctrl', 'c')# 向上滚动鼠标pyautogui.scroll...(100)注意事项在执行自动化操作时,确保目标应用程序在活动状态,并处于可交互状态。...如果你有其他具体需求或想法,请随时告诉我。
ListView 1.1 ListView介绍 移动端数据量比较大时,一般都是通过列表来进行展示的,比如商品数据、聊天列表、通信录、朋友圈等。...在Android中,我们可以使用ListView或RecyclerView来实现,在Ios中,我们可以通过UITableView来实现。...4.滚动事件监听 4.1 滚动事件监听介绍 对于滚动的视图,我们经常需要监听它的一些滚动事件,在监听到滚动事件时执行对应的操作。...比如视图滚动到底部时,我们可能希望做上拉加载更多;比如滚动到一定位置时显示一个回到顶部的按钮,点击回到顶部的按钮,回到顶部;比如监听滚动什么时候开始,什么时候结束; 在Flutter中监听滚动相关的内容由两部分组成...该回调可以返回一个布尔值,代表是否阻止该事件继续向上冒泡,如果为true时,则冒泡终止,事件停止向上传播,如果不返回或者返回值为false 时,则冒泡继续。
指定 itemExtent 的值比让子元素决定自身长度在绘制时更高效,特别是在滚动位置频繁变化的状态下,因为设置 itemExtent 可以让滚动系统提前知道列表的长度。...(当选择将列表项包裹在 RepaintBoundary 时,在滚动过程中可以避免重绘,如果此列表项需要自己维护 KeepAlive 状态,那么此参数需为 false) addSemanticIndexes...ListView.builder 当 listview 的列表项较多或数量未知时,就需要使用 ListView.builder 来构建列表了 import 'package:flutter/material.dart...ListView.separated 当 listview 的 item 间需要分割线时,我们就需要用到 ListView.separated import 'package:flutter/material.dart...当我们需要将不同的可滑动组件组合在一起时,就需要使用此对象来完成。ListView 和 GridView 都有对应的组合对象如:SliverList 和 SliverGrid。
领取专属 10元无门槛券
手把手带您无忧上云