温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Android中View跟随手指滑动效果的实例代码

发布时间:2020-09-21 08:03:14 来源:脚本之家 阅读:523 作者:meetings 栏目:移动开发

本文讲述了Android中View跟随手指滑动效果的实例代码。分享给大家供大家参考,具体如下:

1、android View 主要6种滑动方法,分别是

  • layout()
  • offsetLeftAndRight()和offsetTopAndBottom()
  • LayoutParams
  • scrollBy()和 scrollTo()
  • Scroller
  • 动画

2、实现效果图

Android中View跟随手指滑动效果的实例代码

3、自定义中使用layout()方法实习view的滑动

public class MoveView extends View { 
 private int lastX, lastY; 
 public MoveView(Context context, @Nullable AttributeSet attrs) { 
 super(context, attrs); 
 } 
 public MoveView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) { 
 super(context, attrs, defStyleAttr); 
 } 
 public MoveView(Context context) { 
 super(context); 
 } 
 public boolean onTouchEvent(MotionEvent event) { 
 int x = (int) event.getX(); 
 int y = (int) event.getY(); 
 switch (event.getAction()) { 
 case MotionEvent.ACTION_DOWN: 
 lastX = x; 
 lastY = y; 
 break; 
 case MotionEvent.ACTION_MOVE: 
 int offsetX = x - lastX;//计算滑动的距离 
 int offsetY = y - lastY; 
 //重新放置新的位置 
 layout(getLeft() + offsetX, getTop() + offsetY, getRight() + offsetX, getBottom() + offsetY); 
 } 
 return true; 
 } 
} 

2、offsetLeftAndRight()和offsetTopAndBottom()

 public boolean onTouchEvent(MotionEvent event) { 
 int x = (int) event.getX(); 
 int y = (int) event.getY(); 
 switch (event.getAction()) { 
 case MotionEvent.ACTION_DOWN: 
 lastX = x; 
 lastY = y; 
 break; 
 case MotionEvent.ACTION_MOVE: 
 int offsetX = x - lastX;//计算滑动的距离 
 int offsetY = y - lastY; 
 //重新放置新的位置 
// layout(getLeft() + offsetX, getTop() + offsetY, getRight() + offsetX, getBottom() + offsetY); 
 offsetLeftAndRight(offsetX); 
 offsetTopAndBottom(offsetY); 
 } 
 return true; 
 } 

3、LayoutParams 改变布局参数的方法:

public boolean onTouchEvent(MotionEvent event) { 
 int x = (int) event.getX(); 
 int y = (int) event.getY(); 
 switch (event.getAction()) { 
 case MotionEvent.ACTION_DOWN: 
 lastX = x; 
 lastY = y; 
 break; 
 case MotionEvent.ACTION_MOVE: 
 int offsetX = x - lastX;//计算滑动的距离 
 int offsetY = y - lastY; 
 //重新放置新的位置 
// layout(getLeft() + offsetX, getTop() + offsetY, getRight() + offsetX, getBottom() + offsetY); 
// offsetLeftAndRight(offsetX); 
// offsetTopAndBottom(offsetY); 
 LinearLayout.LayoutParams layoutParams = (LinearLayout.LayoutParams) getLayoutParams(); 
 layoutParams.leftMargin = getLeft()+offsetX; 
 layoutParams.topMargin = getTop() +offsetY; 
 setLayoutParams(layoutParams); 
 } 
 return true; 
 } 

4、当然使用动画 ,scrollBy()和 scrollTo()也可以使view滑动,不足的是使用scrollBy()和 scrollTo()滑动时,是瞬间完成的,用户体验不太好。

5、Scroller和 View的computeScroll() 结合使用,实现view平滑的移动

public class MoveView extends View { 
 private Scroller mScroller; 
 public MoveView(Context context, @Nullable AttributeSet attrs) { 
 super(context, attrs); 
 mScroller = new Scroller(context); 
 } 
 public MoveView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) { 
 super(context, attrs, defStyleAttr); 
 } 
 public MoveView(Context context) { 
 super(context); 
 } 
 //重写computeScroll方法 
 @Override 
 public void computeScroll() { //view在onDraw的时候会调用此方法 
 super.computeScroll(); 
 if (mScroller.computeScrollOffset()) { 
 ((View) getParent()).scrollTo(mScroller.getCurrX(), mScroller.getCurrY()); 
 invalidate(); 
 } 
 } 
 //在外部调用这个方法即可 
 public void smoothScrollTo(int destX, int destY) { 
 int scrollX = getScrollX(); 
 int delta = destX - scrollX; 
 mScroller.startScroll(scrollX, 0, delta,0 ,6000); 
 invalidate(); 
 } 
}

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对亿速云的支持。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI