zoukankan      html  css  js  c++  java
  • 滚动到底部或顶部响应的ScrollView使用

    最新内容建议直接访问原文:滚动到底部或顶部响应(如加载更多)的ScrollView的使用

     

    本文介绍滚动到底部或顶部响应(如加载更多)的ScrollView的使用。网上关于到达底部加载更多的listView示例很多,对于ScrollView却寥寥无几,下面介绍使用自定义的ScrollView来完成该功能的实例。

    本文示例APK地址TrineaAndroidDemo.apk,示例代码地址见BorderScrollViewDemo,效果图如下:

    onBottom ScrollView Demo

     
    BorderScrollView继承自ScrollView,可以自定义滚动到底部或顶部时需要完成的任务。使用如下:
    一、自定义layout
    只需将定义的ScrollView标签换成com.trinea.android.common.view.BorderScrollView标签即可,源码如下(其中的多个TextView只是为了将ScrollView撑满一屏幕):

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

    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是有可能被多次执行的,需要自己控制,将在后面的实现原理中介绍具体原因~。

  • 相关阅读:
    css3动画栈效果_1
    页面滚动时出现固定导航
    jquery定位到指定元素
    seajs之学习2
    seajs之学习1
    变态ie6之要求css与页面编码一致引发的问题
    ASP.NET学习笔记一
    C++学习笔记三(类和对象)
    C++学习笔记二
    unity3D学习笔记一
  • 原文地址:https://www.cnblogs.com/trinea/p/3110173.html
Copyright © 2011-2022 走看看