我是靠谱客的博主 无辜枕头,这篇文章主要介绍Android 实现滑动的六种方式,现在分享给大家,希望可以做个参考。

1、效果视频

2、剖析Android坐标系

滑动的本质是移动,滑动的原理就是通过不断的改变View的坐标而实现。

Android系统提供了很多方法获取坐标值,可以将其分为两种类别,具体如下:

View 提供的获取坐标的方法:

  • getTop():获取到的是View自身的顶边到其父布局顶边的距离
  • getLeft():获取到的是View自身的左边到其父布局左边的距离
  • getRight():获取到的是View自身的右边到其父布局左边的距离
  • getBottom():获取到的是View自身的底边到其父布局顶边的距离

MotionEvent 提供的方法:

  • getX():获取点击事件距离控件左边的距离,即视图坐标
  • getY():获取点击事件距离控件顶边的距离,即视图坐标
  • getRawX():获取点击事件距离整个屏幕左边的距离,即绝对坐标
  • getRawY():获取点击事件距离整个屏幕顶边的距离,即绝对坐标

3、实现方式

3.1 layout

使用绝对坐标系,每次执行移动逻辑后需要重新设置初始化坐标

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
@Override public boolean onTouchEvent(MotionEvent event) { int rawX = (int) (event.getRawX()); int rawY = (int) (event.getRawY()); switch (event.getAction()){ case MotionEvent.ACTION_DOWN: lastX = rawX; lastY = rawY; break; case MotionEvent.ACTION_MOVE: int offsetX = rawX - lastX; int offsetY = rawY - lastY; layout( getLeft()+offsetX,getTop()+offsetY,getRight()+offsetX,getBottom()+offsetY ); lastX = rawX; lastY = rawY; break; case MotionEvent.ACTION_UP: break; } return true; }

3.2 scrollBy

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
@Override 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; ((View) getParent()).scrollBy( -offsetX, -offsetY ); break; case MotionEvent.ACTION_UP: break; } return true; }

3.3 offsetLeftAndRight offsetTopAndButton

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
@Override 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; offsetLeftAndRight( offsetX ); offsetTopAndBottom( offsetY ); break; case MotionEvent.ACTION_UP: break; } return true; }

3.4 LayoutParams

通过getLayoutParams()获取LayoutParams时,需要根据不同的父类型使用设置不同的类型,比如父布局为LinearLayout则设置类型为 LinearLayout.LayoutParams

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
@Override 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; LinearLayout.LayoutParams layoutParams = (LinearLayout.LayoutParams)getLayoutParams(); layoutParams.leftMargin = getLeft()+offsetX; layoutParams.topMargin = getTop()+offsetY; setLayoutParams( layoutParams ); break; case MotionEvent.ACTION_UP: break; } return true; }

更方便的是直接使用ViewGroup,不需要判断父布局类型

复制代码
1
2
3
4
ViewGroup.MarginLayoutParams layoutParams = (ViewGroup.MarginLayoutParams)getLayoutParams(); layoutParams.leftMargin = getLeft()+offsetX; layoutParams.topMargin = getTop()+offsetY; setLayoutParams( layoutParams );

3.5 Scroller

初始化Scroller:

复制代码
1
scroller = new Scroller( context );

重写computeScroll()方法

使用computeScrollOffset()判定是否完成了整个滑动:

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
@Override public void computeScroll() { if (scroller.computeScrollOffset()) { ((View) getParent()).scrollTo( scroller.getCurrX(), scroller.getCurrY() ); invalidate(); } super.computeScroll(); } @Override public boolean onTouchEvent(MotionEvent mv) { View parent = (View) getParent(); switch (mv.getAction()) { case MotionEvent.ACTION_DOWN: lastX = (int) mv.getX(); lastY = (int) mv.getY(); break; case MotionEvent.ACTION_MOVE: int upX = (int) (mv.getX() - lastX); int upY = (int) (mv.getY() - lastY); parent.scrollBy( -upX, -upY ); break; case MotionEvent.ACTION_UP: scroller.startScroll( parent.getScrollX(), parent.getScrollY(), -parent.getScrollX(), -parent.getScrollY(), 1000 ); invalidate(); break; } return super.onTouchEvent( mv ); }

3.6 平移动画

效果视频:

复制代码
1
2
3
4
private void InitAnimation(){ animation = new TranslateAnimation( 0,200,0,200 ); animation.setDuration( 1000 ); }
复制代码
1
moveButton.startAnimation( animation );

到此这篇关于Android 实现滑动的六种方式的文章就介绍到这了,更多相关Android 实现滑动的方式内容请搜索靠谱客以前的文章或继续浏览下面的相关文章希望大家以后多多支持靠谱客!

最后

以上就是无辜枕头最近收集整理的关于Android 实现滑动的六种方式的全部内容,更多相关Android内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(100)

评论列表共有 0 条评论

立即
投稿
返回
顶部