滚动到底部或顶部响应的ScrollView使用

listView示例很多,对于ScrollView却寥寥无几,下面介绍使用自定义的ScrollView来完成该功能的实例。

示例APK可从这些地址下载:Google Play, 360手机助手, 百度手机助手, 小米应用商店, 豌豆荚

示例代码地址见BorderScrollViewDemo,效果图如下:


1、引入公共库

引入TrineaAndroidCommon@Github(欢迎star和fork^_^)作为你项目的library(如何拉取代码及添加公共库),或是自己抽取其中的BorderScrollView@Github部分使用,BorderScrollView继承自ScrollView,可以自定义滚动到底部或顶部时需要完成的任务。

2、自定义layout
只需将定义的ScrollView标签换成cn.trinea.android.common.view.BorderScrollView标签即可,源码如下(其中的多个TextView只是为了将ScrollView撑满一屏幕):

layout xml源码

3、设置onTop和onBottom事件
通过borderScrollView.setOnBorderListener(OnBorderListener onBorderListener)设置到达底部和顶部的响应。
OnBorderListener有onTop()和void onBottom()两个函数可以实现,分别在滑动到顶部和底部时被调用执行。代码如下:

Java部分实现源码

Java


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38


public class BorderScrollViewDemo extends Activity {

private BorderScrollView borderScrollView;

private TextView textView1;

private TextView textView2;

private Context context;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.border_scroll_view_demo);

context = getApplicationContext();

borderScrollView = (BorderScrollView)findViewById(R.id.scroll_view);

borderScrollView.setOnBorderListener(new OnBorderListener() {

@Override

public void onTop() {

// may be done multi times, u should control it

Toast.makeText(context, "has reached top", Toast.LENGTH_SHORT).show();

}

@Override

public void onBottom() {

// may be done multi times, u should control it

Toast.makeText(context, "has reached bottom", Toast.LENGTH_SHORT).show();

}

});

textView1 = (TextView)findViewById(R.id.text1);

textView2 = (TextView)findViewById(R.id.text2);

Display display = getWindowManager().getDefaultDisplay();

textView1.setHeight(display.getHeight() / 2);

textView2.setHeight(display.getHeight() / 2);

}

}

注意onTop和onBottom是有可能被多次执行的,需要自己控制,将在后面的实现原理中介绍具体原因~。

时间: 2025-01-24 19:53:05

滚动到底部或顶部响应的ScrollView使用的相关文章

滑动到底部或顶部响应的ScrollView实现

本文主要介绍实现ScrollView滑动到底部或顶部响应的两种方式 关于使用可见:滚动到底部或顶部响应的ScrollView使用 示例APK可从这些地址下载:Google Play, 360手机助手, 百度手机助手, 小米应用商店, 豌豆荚 两种实现方式的主要不同点在于判断滑动位置的地方,第一种方式在onScrollChanged函数中判断, 第二种在OnTouchListener的onTouch中判断.其他如是否滚动到边缘的判断.响应事件接口OnBorderListener.对外暴露的接口都一

Android设置ScrollView滚动到底部和顶部

转载请备注原文地址: http://www.niwoxuexi.com/blog/android/article/221.html 我们在开发的过程中,经常会遇到ScrollView滚动到底部和顶部的情况,下面是一种简单的设置方法 1,设置ScrollView滚动到顶部 //设置ScrollView滚动到顶部 scrollView.fullScroll(ScrollView.FOCUS_UP); 2,设置ScrollView滚动到底部 //设置ScrollView滚动到顶部 scrollView

下拉刷新及滚动到底部加载更多的Listview使用

本文主要介绍可同时实现下拉刷新及滑动到底部加载更多的ListView的使用. 该ListView优点包括:a. 可自定义下拉响应事件(如下拉刷新) b.可自定义滚动到底部响应的事件(如滑动到底部加载更多) c.可自定义丰富的样式 d.高效(若下拉样式关闭不会加载其布局,同listView效率一致) e. 丰富的设置. 更多下拉刷新开源项目可见 Android 下拉刷新.底部加载更多开源项目可见 Android 底部加载更多. 示例APK可从这些地址下载:Google Play, 360手机助手,

Android开发之Activity的中部或底部回到顶部

我们浏览淘宝商品详情的时候会遇到回到顶部这个功能,下面就说说这个功能的简单实现 <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" > <ScrollView android:id="

js判断滚动条是否已到页面最底部或顶部实例_javascript技巧

本文实例讲述了js判断滚动条是否已到页面最底部或顶部的方法.分享给大家供大家参考.具体分析如下: 我们经常会看到很多的网站一个返回顶部效果就是当我们滚动条到指定位置时返回顶部出来了,否则就自动隐藏了,下面就来给大家介绍这种效果实现原理与方法. 当可视区域小于页面的实际高度时,判定为出现滚动条,即: 复制代码 代码如下: if (document.documentElement.clientHeight < document.documentElement.offsetHeight) scroll

精确监听AbsListView滚动至底部

用户使用android客户端时,当ListView滚动至底部,可以由一个按钮来提示用户是否读下一页,那么如果使用GridView呢?现在很多WEB 2.0上的体验就是当底部时自动读取下一页数据,GridView(ListView也可)可以采用这种方法.网上已经有很多文章介绍了如何判断ListView是否滚动至底部,原理是 AbsListView.getLastVisiblePosition() = (AbsListView.getCount() - 1) 即到底,如果往上拖一点,用户看起来已经离

js判断iframe内的网页是否滚动到底部触发事件

 这篇文章主要介绍了js判断iframe内的网页是否滚动到底部触发事件,需要的朋友可以参考下 之前有个需求是要判断iframe内的网页是否滚动到底部触发事件, 网上找了许多资料都是说在当前页面下的, 索性就自己研究了一下, 找到了解决方法.    clientHeight:这个元素的高度,占用整个空间的高度    offsetHeight:是指元素内容的高度    scrollTop:可以理解为滚动条可以滚动的长度    以下是源代码   代码如下: <iframe src="~/File

js判断iframe内的网页是否滚动到底部触发事件_javascript技巧

之前有个需求是要判断iframe内的网页是否滚动到底部触发事件, 网上找了许多资料都是说在当前页面下的, 索性就自己研究了一下, 找到了解决方法. clientHeight:这个元素的高度,占用整个空间的高度 offsetHeight:是指元素内容的高度 scrollTop:可以理解为滚动条可以滚动的长度 以下是源代码 复制代码 代码如下: <iframe src="~/Files/3.html" id="iframepage" width="825

uitableview-表视图滚动到底部的获取

问题描述 表视图滚动到底部的获取 iPhone中有表试图.想实现两个功能: 1.用户将表滚动到底部时. 2.用户拉下了tableview时. 例如: If(UserScrollThe tableViewToTop) { perform action: 1 } If(UserScrollThe tableViewToDown) { perform action: 2 } 如何获取用户进行了这两个动作? 解决方案 UITableView is a subclass of UIScrollView,