Scroller 实现控件缓慢平移的效果

原创 2016年05月31日 12:24:05

废话不多说直接上代码 看一下就懂了我有注释:

package com.example.k.scroller;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.ListView;

public class MainActivity extends AppCompatActivity {

    private ListView listView = null;
    private MyViewGroup myViewGroup;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        myViewGroup = (MyViewGroup) findViewById(R.id.myviewGroup);

    }

    public void scrook(View view) {

        myViewGroup.beginScroll();

    }

}
====================================================================================


package com.example.k.scroller;

import android.content.Context;
import android.util.AttributeSet;
import android.util.Log;
import android.widget.LinearLayout;
import android.widget.Scroller;

/**
 * Created by k on 2016/5/31.
 */
public class MyViewGroup extends LinearLayout {
    private boolean s1=true;
    Scroller mScroller=null;
    public MyViewGroup(Context context, AttributeSet attrs) {
        super(context, attrs);
        mScroller=new Scroller(context);
        // TODO Auto-generated constructor stub
    }
    //计算滚动,draw()方法中会调用此方法,而draw()在invalidate()或postInvalidate()后就会被调用,
    @Override
    public void computeScroll() {
        //mScroller.computeScrollOffset()方法在invalidate()方法没被调用之前返回值一直是false,当到达了目标坐标就会继续返回false就结束了
        Log.i("ok","==========="+mScroller.computeScrollOffset());
        if (mScroller.computeScrollOffset()) {
            scrollTo(mScroller.getCurrX(), 0);
            postInvalidate();
        }
    }
    public void beginScroll(){
        if (!s1) {
            /*下面的方法第1个参数开始移动的X坐标,第2个位开始的Y坐标,第3个为目标X坐标,第4个位目标Y坐标,第五个是整个移动过程的时间
            *可以想象屏幕后面有一块大画板,然后一块和画板一样宽的木板盖上去,木板中间被挖了一个长方形的洞,现在长方形左上角的坐标为0,0;
            *我们在长方形上放一个组件按钮;然后设置第一个参数为-500,注意是负500,此时这块木板就会往左移动500像素,屏幕上的组件也就实现了
            * 向右移动了500像素,很简单,想象一下就明白了。
             */
            mScroller.startScroll(-500, 0, 500, 0, 300);
            s1 = true;
        } else {
            //正值往右边移,负值反之
            mScroller.startScroll(0, 0, -500, 0, 300);
            s1 = false;
        }
        invalidate();
    }
}
=====================================================================================

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >

    <Button
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="scroll"
        android:onClick="scrook" />


    <com.example.k.scroller.MyViewGroup
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:orientation="horizontal"
        android:id="@+id/myviewGroup">

        <Button
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="New Button"
            android:id="@+id/button"
            android:layout_gravity="center_horizontal" />

    </com.example.k.scroller.MyViewGroup>

</LinearLayout>

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

自定义控件ViewGroup绘制过程以及使用Scroller类处理滑动效果

知识点: 1 ViewGroup的绘制 2 Scroller类的用法 1 ViewGroup绘制 对于View绘制的基本过程在参考了一篇博客,里面较为详细的介绍了绘制的基本流程:h...

Android通过scroller实现缓慢移动

Android中实现view的移动有多种方式,可以通过动画,可以通过layoutparams,相对简单的可以通过scroller类来实现。 我们新建一个自定义view,它继承自LinearLayout...

Android使用Scroller实现下拉刷新控件

最近看到Scroller的具体原理,看到书上实现下拉刷新的例子觉得很有意思,想着自己也来动手写写看,也算是理解一下Scroller,顺便也能锻炼一下自己自定义ViewGroup的技能。我会着重讲一讲实...

CSS3实现鼠标移动到图片上图片变大(缓慢变大,有过渡效果,放大的过程是有动画过渡的,这个过渡的时间可以自定义)

CSS3的transform:scale()可以实现按比例放大或者缩小功能。 CSS3的transition允许CSS的属性值在一定的时间区间内平滑地过渡。这种效果可以在鼠标单击、获得焦点、被点击或对...

Android 使用Scroller实现绚丽的ListView左右滑动删除Item效果

本文出自xiaanming的博客(http://blog.csdn.net/xiaanming/article/details/17539199)
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)