Scroller 实现控件缓慢平移的效果
来源:互联网 发布:苏联骗西班牙黄金 知乎 编辑:程序博客网 时间:2024/06/05 17: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>
0 0
- Scroller 实现控件缓慢平移的效果
- android 使用Scroller实现缓慢移动
- android 使用Scroller实现缓慢移动
- Android通过scroller实现缓慢移动
- Android学习Scroller(三)——控件平移划过屏幕 (Scroller简单使用)
- android关于Scroller与GestureDetector实现滚动的效果
- 采用Scroller实现任意布局的上下左右弹性效果
- 采用Scroller实现任意布局的上下左右弹性效果
- android 使用Scroller实现缓慢移动 (笔记)
- 属性动画实现平移效果
- 平移加旋转实现效果
- 《js实现图片缓慢缩放的效果》之学习总结
- 《js实现图片缓慢缩放的效果》之学习总结
- 两种实现大图内容平移效果的方法
- css3平移、旋转、倾斜、缩放、动画效果的实现
- Android Scroller实战(二)窗帘效果实现
- android 通过Scroller实现过渡滑动效果
- iOS 利用平移缩放旋转手势对view实现对应的平移缩放旋转效果(一)
- mysql 默认引擎innodb 初探(三)
- 走近XML(1)
- php判断一个字符串包含另一个字符串
- 六个可以替代传统事务解决并发问题的建议
- Ubuntu 16.04 LTS直接双击安装deb包失败的解决方法
- Scroller 实现控件缓慢平移的效果
- Mac上安装Appium环境
- Ubuntu 16.04 LTS连接无线上网慢的解决
- MVVM With ReactiveCocoa让移动开发更简单
- java.集合(Ⅲ).Set.HashSet
- NYOJ 448 寻找最大数
- 3.8求二叉树中节点的最大距离
- HDU 1540Tunnel Warfare xds
- PHP字符串——编码与转义