首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Android笔记——ViewPager循环、自动滚动效果

ViewPager循环、自动滚动,这种效果很常见,一般app首页都会有焦点图、或者用户引导页面。第三方比较好用的我推荐阿里开源的UltraViewPager,毕竟大公司的,用着放心吧 ๑乛◡乛๑。...有2种方案实现循环滚动,一种是在PagerAdapter设置最大数量为int最大值,另一种就是本文实现的。前一种感觉有点奇怪,如果不带自动循环滚动的话还可以用,毕竟用户一般不会切换这么多次能看到头。...而对于循环滚动的话,需要本文的类似思路实现起来比较好一点吧,原理看上图即可。例子效果图在最后。...autoPlay){ handler.removeCallbacks(runnable); } } } 注意主要几点 组合控件,一个FrameLayout布局包含...onPageScrollStateChanged状态改变的时候,即停止滑动的时候滑到指定位置,当手指拖动的时候需要停止自动播放; 小圆点指示器,是一个线性布局根据图片数量添加原点,原点背景为selector

2.2K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    浅议内滚动布局

    一、什么是内滚动布局? 所谓“内滚动布局”,顾名思义就是主滚动条在页面内部的布局,是相对于传统的滚动而言的,例如,下图所示滚动条,是从头部下方开始: ?...或者这么说吧,把所有页面内容放在一个page中,此时page就好比一个可以移动的房子,回头你跳槽来腾讯了,房子可以一起带过来,原来的位置可以被其他房子代替。...对于固定的头部header或者固定的侧边side, 你可以使用语义明确的position:fixed定位,或者直接使用position:absolute,因为滚动容器跟他们平级,所以,absolute其实就是...就是使用本文介绍的内滚动布局,然后底部使用position:absolute模拟fixed效果。 ?...因为使用的是内滚动布局,如下图示意,屏幕就这么高,滚动在里面,自然自适应: ? 看上去是内滚动布局带来的一个小小的“赏”,但是,实际上,埋下了一个不小的“罚”。

    2.5K50

    浅议内滚动布局

    一、什么是内滚动布局? 所谓“内滚动布局”,顾名思义就是主滚动条在页面内部的布局,是相对于传统的滚动而言的,例如,下图所示滚动条,是从头部下方开始: ?...或者这么说吧,把所有页面内容放在一个page中,此时page就好比一个可以移动的房子,回头你跳槽来腾讯了,房子可以一起带过来,原来的位置可以被其他房子代替。...就是使用本文介绍的内滚动布局,然后底部使用position:absolute模拟fixed效果。 ?...很简单: .overlay { position: absolute; left: 0; top: 0; width: 100%; height: 100%; } 为啥一行CSS就能搞定所有场景?...因为使用的是内滚动布局,如下图示意,屏幕就这么高,滚动在里面,自然自适应: ? 看上去是内滚动布局带来的一个小小的“赏”,但是,实际上,埋下了一个不小的“罚”。

    1.2K20

    ViewPager2实现内部Item的动态滚动

    就在我以为又可以摸鱼一个ViewPager2就可以搞定之时。突然,产品同学发了新指示,下意识预感不妙。 产品:得加一个第一次使用时的提示啊,要不然用户都不知道页面可以下滑呢?...解决方法 既然如此,ViewPager2是基于RecyclerView,那么我去调用RecyclerView滚动不就行吗,思路如下: ViewPager2-> RecyclerView, RecyclerView...() 支持滚动到偏移位置 伪代码如下: val layoutManager = (getChildAt(0) as?...-item动态滚动问题。...后续 当然用ViewPager2去写仍然有种大材小用的感觉,毕竟只有两个item,所以,比较好的方式依然是使用自定义的滑动ViewGroup实现,所以我会在下篇博客来以一个自定义的方式来解决此问题。

    1.7K20

    viewpager循环滚动和自动轮播的问题

    ViewPager是一个常用的android组件,不过通常我们使用ViewPager的时候不能实现左右无限循环滑动,在滑到边界的时候会看到一个不能翻页的动画,可能影响用户体验。...   this.viewlist = viewlist;           }   @Override public int getCount() {   //设置成最大,使用户看不到边界...轮播效果的实现:使用Handler进行更新 这里我定义了一个Handler来处理ViewPager的轮播。所谓的“轮播”效果实现起来是这样的:每隔一定时间(这里是3秒)切换一次显示的页面。...为此,我们可以使用Handler的sendEmptyMessageDelayed()方法来实现定时更新,并 注意用户也可能会对带有轮播效果的ViewPager手动进行滑动操作,因此我认为用户这时候是希望查看指定页面的...int MSG_PAGE_CHANGED  = 4;   //轮播间隔时间 protected static final long MSG_DELAY = 3000;   //使用弱引用避免

    3.5K60

    ViewPager 详解(五)—–使用Fragment实现ViewPager滑动

    前言:前几篇文章讲解了ViewPager的普通实现方法,但android官方最推荐的一种实现方法却是使用fragment,下面我们使用fragment来重新实现一下第一篇《ViewPager 详解(一)...第二页面向第三个页面滑动 一、概述 从前面几篇文章,我们知道,实现ViewPager是要有适配器的,我们前面用的适配器是PagerAdapter,而对于fragment,它所使用的适配器是...尽管不可见的视图有时会被销毁,但用户所有访问过的fragment都会被保存在内存中。因此fragment实例会保存大量的各种状态,这就造成了很大的内存开销。...所以如果要处理大量的页面切换,建议使用FragmentStatePagerAdapter....每一个使用FragmentPagerAdapter的ViewPager都要有一个有效的ID集合,有效ID的集合就是Fragment的集合(感谢夫诸同学的提示) 对于FragmentPagerAdapter

    1.6K20

    浅议内滚动布局 - 腾讯ISUX

    或者这么说吧,把所有页面内容放在一个page中,此时page就好比一个可以移动的房子,回头你跳槽来腾讯了,房子可以一起带过来,原来的位置可以被其他房子代替。...对于固定的头部header或者固定的侧边side, 你可以使用语义明确的position:fixed定位,或者直接使用position:absolute,因为滚动容器跟他们平级,所以,absolute其实就是...就是使用本文介绍的内滚动布局,然后底部使用position:absolute模拟fixed效果。...因为使用的是内滚动布局,如下图示意,屏幕就这么高,滚动在里面,自然自适应: 看上去是内滚动布局带来的一个小小的“赏”,但是,实际上,埋下了一个不小的“罚”。...感谢你的阅读,本文由 腾讯ISUX 版权所有,转载时请注明出处,违者必究,谢谢你的合作。

    1.4K30

    之滚动布局的监听的和smoothScrollBy方法分析使用

    地址:http://blog.csdn.net/xiangyong_1521/article/details/50957563 scroollview、listview、gridview是我们常用的滚动类型布局...,应工作中的一个需求,需要监听这些布局的页面停留状态,以配合更新页面UI,然后通过按钮点击以控制这些页面的滚动; 目录 scroollview监听方法 listview监听方法 gridview监听方法...view, int scrollState) {} @Override public void onScroll(AbsListView view, //报告滚动状态的视图...} } } 此方法调用OnScrollListener接口来实现Scroll页面的监听,在方法onScroll内,我们可以拿到几个重要的数值,在实际的使用中...listView.smoothScrollBy(-300, 1000); } } } }); 通过smoothScrollBy,我们可以控制页面的滚动

    2.8K60

    【布局技巧】Flex 布局下居中溢出滚动截断问题

    在页面布局中,我们经常会遇到/使用这么一类常见的布局,也就是列表内容水平居中于容器中,像是这样: ...overflow: auto; } 效果就变成了这样: 我们尝试滚动一下这个容器,会发现一个致命问题:容器只能向左滚动,无法向右滚动,因此只能看到后半部分被截断的内容,而无法看到前半部分被截断的内容:...的样式进行排布,这样可以保证内容在滚动的过程中能够全部看到。...方法一:Flex 布局下关键字 safe、unsafe 其实,规范也已经注意到了布局下的这个居中滚动问题。...完整的代码,你可以戳这里:CodePen Demo - 使用额外嵌套层解决 Flex 居中溢出问题 总结一下 好,我们快速总结一下三种方式的优劣对比: 方法一:Flex 布局下关键字 safe、unsafe

    51010

    CoordinatorLayout+AppBarLayout实现上滑隐藏ToolBar-Android M新控件

    滚动事件,那么在CoordinatorLayout布局里其它标记了app:layout_behavior的子View(LinearLayout、RecyclerView、NestedScrollView...layout_scrollFlags说明 value comment scroll 所有想滚动出屏幕的view都需要设置这个flag, 没有设置这个flag的view将被固定在屏幕顶部。...enterAlwaysCollapsed 当你的视图已经设置minHeight属性又使用此标志时,你的视图只能已最小高度进入,只有当滚动视图到达顶部时才扩大到完整高度 exitUntilCollapsed...– (Tab宽度不固定,同时可以横向滚动),还实现了所有Tab居中显示。...为了使得Toolbar有滑动效果,必须做到如下三点: CoordinatorLayout必须作为整个布局的父布局容器。

    2.2K30

    ViewPager2:官方Viewpager升级版来临

    目前还只是推出了第一个预览版,我们可以直接引入来使用了: implementation 'androidx.viewpager2:viewpager2:1.0.0-alpha01' 我们先来看看有哪些功能和使用上的变化...: 新功能: 支持RTL布局 支持竖向滚动 完整支持notifyDataSetChanged API的变动: FragmentStateAdapter替换了原来的 FragmentStatePagerAdapter...的核心实现就是RecyclerView+LinearLayoutManager了,因为LinearLayoutManager本身就支持竖向和横向两种布局方式,所以ViewPager2也能很容易地支持这两种滚动方向了...使用 通过android:orientation来指定滚动方向 viewpager2.widget.ViewPager2 android:id="@+id/viewpager2...小结 viewpager2利用recyclerview来实现viewpager的功能,无疑使使其可扩展性大大提升,代码也变得更优雅简洁,使用起来也更灵活。

    1.8K10

    Android Scroller完全解析,关于Scroller你所需知道的一切

    Scroller是一个专门用于处理滚动效果的工具类,可能在大多数情况下,我们直接使用Scroller的场景并不多,但是很多大家所熟知的控件在内部都是使用Scroller来实现的,如ViewPager、ListView...如果当前事件是ACTION_MOVE,说明用户正在拖动布局,那么我们就应该对布局内容进行滚动从而影响拖动事件,实现的方式就是使用我们刚刚所学的scrollBy()方法,用户拖动了多少这里就scrollBy...如果当前事件是ACTION_UP时,说明用户手指抬起来了,但是目前很有可能用户只是将布局拖动到了中间,我们不可能让布局就这么停留在中间的位置,因此接下来就需要借助Scroller来完成后续的滚动操作。...首先这里我们先根据当前的滚动位置来计算布局应该继续滚动到哪一个子控件的页面,然后计算出距离该页面还需滚动多少距离。...好的,那么本篇文章就到这里,相信通过这篇文章的学习,大家已经能够熟练掌握Scroller的使用方法了,当然ViewPager的内部实现要比这复杂得多,如果有朋友对ViewPager的源码感兴趣也可以尝试去读一下

    1.6K60
    领券