Scroller使用

本文介绍了一种自定义Android TextView实现平滑滚动的方法。通过继承TextView并利用Scroller类,实现了视图从一个位置平滑过渡到另一个位置的效果。详细解析了Scroller的工作原理及其在视图更新中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这里写图片描述

public class MyTextView extends TextView {
    Scroller mScroller;
    public MyTextView(Context context) {
        this(context,null);
    }

    public MyTextView(Context context, AttributeSet attrs) {
        super(context, attrs);
        mScroller = new Scroller(context);
    }

    public void smoothScrollTo(int desx,int desy) {
        int currX = getScrollX();
        int dx = desx - currX;
        mScroller.startScroll(currX,0,dx,0,1000);
        invalidate();

    }
    //经测试,该方法运行在主线程
    @Override
    public void computeScroll() {
        super.computeScroll();
        if (mScroller.computeScrollOffset()) {
            scrollTo(mScroller.getCurrX(),mScroller.getCurrY());
            postInvalidate();//因为是主线程,这里调用invalidate也可以
        }
    }
}

在代码中我们这样调用

//负号代表向右移动
 myTextView.smoothScrollTo(-300,-300);

在解释Scroller的试用前,我们先来解释一个问题:关于thi和super的问题
http://www.cnblogs.com/iamzhoug37/p/4372934.html

接下来我们讲解Scroller的用法及原理。
首先说一下,
我们创建了一个Scroller对象,然后调用了getScroller方法获取view中内容的当前位置,具体来说是是View的左边缘和View的内容之间的距离,
然后计算需要偏移的距离dx,
然后调用Scroller的startScroll方法,我们看看

 public void startScroll(int startX, int startY, int dx, int dy, int duration) {
        mMode = SCROLL_MODE;
        mFinished = false;
        mDuration = duration;
        mStartTime = AnimationUtils.currentAnimationTimeMillis();
        mStartX = startX;
        mStartY = startY;
        mFinalX = startX + dx;
        mFinalY = startY + dy;
        mDeltaX = dx;
        mDeltaY = dy;
        mDurationReciprocal = 1.0f / (float) mDuration;
    }

startScroll只是保存了我们传入的几个参数,那么我们如何让view开始滑动呢,就是接下来的invalidate方法,
invalidate会导致view重绘,调用draw方法,在draw方法里面会调用computeScroll方法,在View中,computeScroll是一个空的实现,我们在自定义View中实现这个方法,然后通过Scroller获取当前的位置,不断重绘,View的每一次重绘都会导致View进行小幅度的滑动,而多次的小幅度滑动就组成了弹性滑动,这就是Scroller的工作机制。

Vue-virtual-scroller是一个用于渲染大量数据的Vue组件。它通过只渲染可见的部分来提高性能,而不是将整个列表都渲染出来。 以下是使用Vue-virtual-scroller的步骤: 1. 安装Vue-virtual-scroller 你可以使用npm来安装Vue-virtual-scroller: ``` npm install vue-virtual-scroller ``` 2. 导入Vue-virtual-scroller 在需要使用Vue-virtual-scroller的组件中导入它: ``` import { VirtualScroller } from 'vue-virtual-scroller'; ``` 3. 注册组件 将VirtualScroller组件注册到你的Vue应用中: ``` export default { components: { VirtualScroller }, // ... } ``` 4. 使用组件 在模板中使用VirtualScroller组件来渲染你的数据: ``` <virtual-scroller :items="items"> <template slot-scope="{ item }"> <!-- 渲染你的数据 --> </template> </virtual-scroller> ``` 其中,items是你要渲染的数据数组,slot-scope用于传递数据到模板中。 5. 配置组件 你可以通过props来配置VirtualScroller组件: - itemsPerPage:每页显示的数据数量(默认为30) - buffer:缓存的数据数量(默认为0) - itemSize:每个数据项的高度(可以是固定的数字,也可以是一个返回高度的函数) - minIndex:最小的数据索引 - maxIndex:最大的数据索引 例如,你可以这样配置VirtualScroller: ``` <virtual-scroller :items="items" :items-per-page="50" :buffer="10" :item-size="50"> <template slot-scope="{ item }"> <!-- 渲染你的数据 --> </template> </virtual-scroller> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值