ScrollView 使用小结

忙忙碌碌的一个多月又结束了,连续奋战到凌晨四点的两周也成为了过去式….此次上线因为添加了视频直播和点播功能,所以比较赶,真是分分钟要猝死的赶脚.不过此次又是上线又是对旧知识的巩固和对新技术的探究,此次用到的ScrollView比较多,写一篇文章用以积累.

ScrollView

从谷歌的文档我们可以得到ScrollView是一个可以滚动的用户布局容器,它可以让在手机屏幕上展示不开的情况下滚动展示。ScrollView是一个FrameLayout,所以你应该把一个子控件包含在它的整个内容滚动;这个子控件本身可以是一个复杂的层次结构对象的布局管理器,这个子控件一般是在垂直方向的一个LinearLayout呈现,用户可以通过滚动的顶级项目的垂直阵列。如果一个ScrollView有多个布局就会报出以下的错误:

ScrollView_bug

当然,也可以通过below和above让Scrollview在哪两个控件之间滚动,根据自己的项目实时调整.
xml中常用到的属性:
android:fadingEdge=”none”
设置拉滚动条时 ,边框渐变的放向。none(边框颜色不变),horizontal(水平方向颜色变淡),vertical(垂直方向颜色变淡).
android:overScrollMode=”never”
删除ScrollView拉到尽头(顶部、底部),然后继续拉出现的阴影效果,适用于2.3及以上的 否则不用设置.
android:scrollbars=”none”
设置滚动条显示。none(隐藏),horizontal(水平),vertical(垂直)。见下列代码演示使用该属性让EditText内有滚动条。但是其他容器如LinearLayout设置了但是没有效果。

ScrollView本身的高度设置为match_parent,其子View的高度也设置为match_parent,自然状态下该子View的高度并不会占满ScrollView的高度。 原因是match_parent针对一般布局而言,是子view的高度和parent的高度一致,但在ScrollView身上,工作机制并非如此,而是ScrollView的高度随着子View的高度变化而变化(子View高度大于ScrollView时)。在子View高度小于ScrollView高度时,必需在xml里为ScrollView加上Android:fillViewport=”true”,这样子View小于ScrollView高度时就会占满父View.
解决方法:
xml里为ScrollView加上android:fillViewport=“true”

ScrollView 中常用到的方法:
Scrollview禁止滑动:

scrollView.setOnTouchListener(new View.OnTouchListener() {
    @Override
    public boolean onTouch(View view, MotionEvent motionEvent) {
        return true;
    }
});

可滑动

scrollView.setOnTouchListener(new View.OnTouchListener() {
    @Override
    public boolean onTouch(View view, MotionEvent motionEvent) {
        return false;
    }
});

滚到到底部:

scrollView.post(new Runnable() {
    @Override
    public void run() {//滑动顶部
        scrollView.fullScroll(ScrollView.FOCUS_UP);
    }
});

滚动到顶部:

scrollView.post(new Runnable() {
    @Override
    public void run() {//滑动顶部
        scrollView.fullScroll(ScrollView.FOCUS_UP);
    }
});

滚动到某个位置:

 scrollView.post(new Runnable() {
     @Override
     public void run() {
         int offset = 100;偏移值
         scrollView.smoothScrollTo(0, offset);
     }
 });

注意:ScrollView 滚动的时候需要post 一个runnable,让其在消息队列中执行滚动!
第一,handler.post(runnable);并不是新开线程,只是让UI主线程去并发执行run()方法。
第二,之所以放在handler里,是为了保证View都已经绘制完成。不然,你放在resume()中执行,应该也可以的。
第三,smoothScrollTo类似于scrollTo,但是滚动的时候是平缓的而不是立即滚动到某处。另外,smoothScrollTo()方法可以打断滑动动画。
监听ScrollView滑动到底部,加载数据:
有时候我们想让在ScrollView滑动到底部的时候去做一些事情,但是scrollview并没有直接提供这样的方法,此时我们可以通过简单的继承一下ScrollView,为ScrollView滑动到底部设置一下监听:

public class ScrollBottomScrollView extends ScrollView {
    private OnScrollBottomListener listener;
    private int calCount;

    public interface OnScrollBottomListener {
        void scrollToBottom();
    }

    public void onScrollViewScrollToBottom(OnScrollBottomListener l) {
        listener = l;
    }

    public ScrollBottomScrollView(Context context, AttributeSet attrs)    {
        super(context, attrs);
    }

    @Override
    protected void onScrollChanged(int l, int t, int oldl, int oldt) {
        View view = this.getChildAt(0);
        if (this.getHeight() + this.getScrollY() == view.getHeight()) {
            calCount++;
            if (calCount == 1) {
                if (listener != null) {
                    listener.scrollToBottom();
                }
            }
        } else {
            calCount = 0;
        }
    }
}

在需要的地方调用如下:

scrollView.onScrollViewScrollToBottom(new ScrollBottomScrollView.OnScrollBottomListener() {
            @Override
            public void scrollToBottom() {
               //请求数据
            }
        });

另外如果你的布局中是ScrollView嵌入RecycerView那么久势必就会出现滑动冲突的问题,此时我们可以把RecycerView的滑动监听给禁止,这样就不会有冲突的问题了.

LinearLayoutManager linearLayoutManager = new LinearLayoutManager(this) {//禁止recycleview竖直滑动
            @Override
            public boolean canScrollVertically() {
                return false;
            }
        };

大概就用到了这么多,以后有新的研究还会继续更新.另外有时间会把horizontalscrollview总结记录一下,想想都觉得激动.

谷歌官方文档https://developer.android.com/reference/android/widget/ScrollView.html

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值