Android实现滑动效果

本文实例为大家分享了Android实现滑动效果的具体代码,供大家参考,具体内容如下

坐标系与视图坐标系相辅相成

1、坐标系:描述了View在屏幕中的位置关系(以屏幕最左上角的顶点作为Android坐标系的原点)

2、视图坐标系:描述了子视图在父视图中的位置关系(以父视图最左上角为坐标系原点)

获取坐标值的方法

1.View提供的获取坐标方法

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

2. MotionEvent提供的方法

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

实现滑动的七种方法

1.layout方法

case MotionEvent.ACTION_MOVE:
  //计算偏移量
  int offsetX=x-lastX;
  int offsetY=y-lastY;
  layout(getLeft()+offsetX,getTop()+offsetY,getRight()+offsetX,getBottom()+offsetY);
  break;

2.offsetLeftAndRight()与 offsetTopAndBottom()

offsetLeftAndRight(offsetX);
offsetTopAndBottom(offsetY);

3.LayoutParams

LinearLayout.LayoutParams params= (LinearLayout.LayoutParams) getLayoutParams();
params.leftMargin= getLeft()+offsetX;
params.topMargin= getTop()+offsetY;
setLayoutParams(params);

4.scrollBy()与scrollTo()

scrollBy(x,y)表示移动到一个具体的位置
scrollTo(dx,dy)表示移动的增量为dx,dy

int offsetX=x-lastX;
int offsetY=y-lastY;
View parent= (View) getParent();
parent.scrollBy(-offsetX,-offsetY);

5.Scroller

通过Scroller类可以实现平滑移动的效果,而不是瞬间完成的效果,与动画的实现原理基本相似

@Override
 public void computeScroll() {
 super.computeScroll();
 //判断scroller是否执行完毕
 if (scroller.computeScrollOffset()){
 View view= (View) getParent();
  //获得当前的滑动坐标
 view.scrollTo(scroller.getCurrX(),scroller.getCurrY());
 //通过重绘来不断调用computeScroll
 invalidate();
 //invalidate()--->draw()---->computeScroll()
 }
 }
case MotionEvent.ACTION_UP:
 //手指离开时,执行滑动过程
 View viewGroup= (View) getParent();
 scroller.startScroll(
  viewGroup.getScrollX(),
  viewGroup.getScrollY(),
  -viewGroup.getScrollX(),
  -viewGroup.getScrollY(),500);
 invalidate();
 break;

6.属性动画

7.ViewDragHelper类

public class DrawGroup extends FrameLayout {
 private ViewDragHelper helper;
 private View mainView,menuView;

 public DrawGroup(@NonNull Context context) {
 super(context);
 inView();

 }

 public DrawGroup(@NonNull Context context, @Nullable AttributeSet attrs) {
 super(context, attrs);
 inView();
 }

 public DrawGroup(@NonNull Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
 super(context, attrs, defStyleAttr);
 inView();
 }
 private void inView(){
 helper=ViewDragHelper.create(this, new ViewDragHelper.Callback() {
 @Override
 public boolean tryCaptureView(@NonNull View child, int pointerId) {
 //如果当前触摸的child是mainView时开始检测
 return child==mainView;
 }

 @Override
 public int clampViewPositionHorizontal(@NonNull View child, int left, int dx) {
 //水平方向上的滑动
 return left;
 }

 @Override
 public int clampViewPositionVertical(@NonNull View child, int top, int dy) {
 //垂直方向上的滑动
 return 0;
 }

 @Override
 public void onViewReleased(@NonNull View releasedChild, float xvel, float yvel) {
 //拖动结束后调用
 super.onViewReleased(releasedChild, xvel, yvel);
 //手指抬起后缓慢移动到指定位置
 if (mainView.getLeft()<300){
  //关闭菜单
  helper.smoothSlideViewTo(mainView,0,0);
  //相当于scroller的startScroll方法
 }else {
  //打开菜单
  helper.smoothSlideViewTo(mainView,300,0);
 }
 ViewCompat.postInvalidateOnAnimation(DrawGroup.this);
 }
 });
 }

 @Override
 public boolean onInterceptTouchEvent(MotionEvent ev) {
 return helper.shouldInterceptTouchEvent(ev);
 }

 @Override
 public boolean onTouchEvent(MotionEvent event) {
 //将触摸事件传递给ViewDragHelper,此操作必不可少
 helper.processTouchEvent(event);
 return true;
 }

 @Override
 public void computeScroll() {
 if (helper.continueSettling(true)){
 ViewCompat.postInvalidateOnAnimation(this);
 }
 }

 @Override
 protected void onFinishInflate() {
 super.onFinishInflate();
 //加载完布局调用
 menuView=getChildAt(0);
 mainView=getChildAt(1);
 }

 @Override
 protected void onSizeChanged(int w, int h, int oldw, int oldh) {
 super.onSizeChanged(w, h, oldw, oldh);
 }
}
  • onViewCaptured():在用户触摸到View后回调
  • onViewDragStateChanged():在拖拽状态改变时回调(idle,dragging…)
  • onViewPositionChanged():在位置改变时回调,常用于滑动时更改scale进行缩放等效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android App中ViewPager所带来的滑动冲突问题解决方法

    叙述 滑动冲突可以说是日常开发中比较常见的一类问题,也是比较让人头疼的一类问题,尤其是在使用第三方框架的时候,两个原本完美的控件,组合在一起之后,忽然发现整个世界都不好了. 关于滑动冲突 滑动冲突分类: 滑动冲突,总的来说就是两类. 1.同方向滑动冲突 比如ScrollView嵌套ListView,或者是ScrollView嵌套自己 2.不同方向滑动冲突 比如ScrollView嵌套ViewPager,或者是ViewPager嵌套ScrollView,这种情况其实很典型.现在大部分应用最外层都是

  • Android仿今日头条滑动页面导航效果

    最近项目中用到了滑动页面,也就是和目前市场上很火的"今日头条"页面滑动类似,在网上找了一下,大部分都是用ViewPager来实现的,刚开始我用的是ViewPager+ViewGroup,上面的标题按钮用的是HorizontalScrollView,写完之后感觉效果比较生硬,果断换掉,发现了一个效果比较好的第三方,也就是今天的主题:PagerSlidingTabStrip.好了,下面来具体介绍一下PagerSlidingTabStrip,进行一下源码解析. 一.看一下demo的样子吧 二

  • Android中实现监听ScrollView滑动事件

    时候我们需要监听ScroView的滑动情况,比如滑动了多少距离,是否滑到布局的顶部或者底部.可惜的是SDK并没有相应的方法,不过倒是提供了一个 复制代码 代码如下: protected void onScrollChanged(int x, int y, int oldx, int oldy) 方法,显然这个方法是不能被外界调用的,因此就需要把它暴露出去,方便使用.解决方式就是写一个接口, 复制代码 代码如下: package com.example.demo1;    public inter

  • Android中实现可滑动的Tab的3种方式

    1. 第一种,使用 TabHost + ViewPager 实现该方法会有一个Bug,当设置tabHost.setCurrentTab()为0时,ViewPager不显示(准确的说是加载),只有点击其他任意一个tab后才会加载. 有解的同学吼一声~~~~~~~ Activity: 复制代码 代码如下: package com.swordy.demo.android.fragment; import java.util.Random; import android.os.Bundle;import

  • Android中实现水平滑动(横向滑动)ListView示例

    水平的ListView-HorizontalListView的使用 Android中ListView默认的是竖直方向的滑动,由于项目的需求,需要ListView是水平滑动的.有很多的方式可以实现,但是比较好的一种方式就是自己封装一个控件,使用方式和ListView的使用方式是一样的.需要完善的地方:获取到的图片大小没有处理.在界面上展示的是图片的原大小.为了更好的展示效果,应该压缩成统一的尺寸. HorizontalListView.java 代码如下: /** * 横向的ListView *

  • Android滑动冲突的完美解决方案

    关于滑动冲突 在Android开发中,如果是一些简单的布局,都很容易搞定,但是一旦涉及到复杂的页面,特别是为了兼容小屏手机而使用了ScrollView以后,就会出现很多点击事件的冲突,最经典的就是ScrollView中嵌套了ListView.我想大部分刚开始接触Android的同学们都踩到过这个坑,下面跟着小编一起来看看解决方案吧.. 同方向滑动冲突 比如ScrollView嵌套ListView,或者是ScrollView嵌套自己 这里先看一张效果图 上图是在购物软件上常见的上拉查看图文详情,关

  • android中使用Activity实现监听手指上下左右滑动

    用Activity的onTouchEvent方法实现监听手指上下左右滑动 应用了Activity的ontouchEvent方法监听手指点击事件,手指滑动的时候会先按下,滑倒另一个地方再抬起,我们就可以根据按下的坐标和抬起的坐标算出用户是往哪一个方向滑动了. package com.example.testtt; import android.app.Activity; import android.os.Bundle; import android.view.MotionEvent; impor

  • Android 顶部标题栏随滑动时的渐变隐藏和渐变显示效果

    各位早上好,话不多说,先上效果图: 注意顶部:首页TextView的变化(显示和隐藏)! 首先分析下:UI状态,其是由RecyclerView添加头部组成+RecyclerView 头部添加和RecyclerView分别引用如下:具体的分装数据的过程这里就不在说明,下篇博客会更加深入的写关于 RecyclerView总添加多种不同type类型 compile 'com.bartoszlipinski.recyclerviewheader:library:1.2.1' compile 'com.a

  • 解析Android中实现滑动翻页之ViewFlipper的使用详解

    1)View切换的控件-ViewFlipper介绍 ViewFilpper类继承于ViewAnimator类.而ViewAnimator类继承于FrameLayout. 查看ViewAnimator类的源码可以看出此类的作用主要是为其中的View切换提供动画效果.该类有如下几个和动画相关的方法. setInAnimation:设置View进入屏幕时候使用的动画.该方法有两个重载方法,即可以直接传入Animation对象,也可以传入定义的Animation文件的resourceID. setOut

  • android 通过向viewpage中添加listview来完成滑动效果(类似于qq滑动界面)

    文件名:page.xml 复制代码 代码如下: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:tools="http://schemas.android.com/tools"    android:layout_width="fill_parent"    android:layout_height="fill

随机推荐