Android中实现滑动(拖动)的几种方法,玩转SlideMenu

本文介绍了Android中实现滑动的多种方法,包括通过重写onTouchEvent、使用LayoutParams、ScrollBy和ScrollTo,以及利用Scroller实现平滑动画。通过实例详细解析了滑动原理和坐标体系,特别是如何创建一个自定义的SlideMenu侧滑菜单。
摘要由CSDN通过智能技术生成


潜水已久,看了CSDN上很多大牛的博客,学了不少东西,很钦佩这种无私奉献共享的精神。

自己平时有些笔记的习惯,虽然都是一些很基础的东西,最近安定了下来,整理一下复习复习,毕竟自己一个马大哈来着。。。各种健忘


滑动一个View,改变其当前所处的位置,这个在我们APP开发中实现常用的,例如侧滑菜单,购物车的拖动等等,所以学习一下是非常有必要的


CSDN客户端上也有一个侧滑的效果





在学习如何实现滑动之前,首先要对Android中窗口坐标体系有一个大概的了解


Android坐标系:

这个没什么好说的,已屏幕最左上角的顶点作为Android坐标系的原点,往右是X轴的正方向,往下是Y轴的正方向


视图坐标系:

描述了子View与父容器之前的位置关系,在这里,原点就不再是屏幕的最上角了,而是父视图左上角为原点

                                 



MotionEvent对象:封装了触控事件中一些事件常量和常用的坐标方法


事件常量:

ACTION_DOWN        单点按下动作

ACTION_UP               单点离开动作

ACTION_MOVE          触摸移动动作

ACTION_ACTION_OUTSIDE      触摸动作超出边界

ACTION_POINTER_DOWN       多点触摸按下动作

ACTION_CANCEL     触摸动作取消

ACTION_POINTER_UP       多点离开动作


此外,还提供了很多方法来获取相应的坐标值,基本上就是通过这些坐标值来实现滑动的效果


为了防止遗忘也便于以后查询,画了个图来加深下记忆


View提供获取坐标的方法:


getTop:View  顶部   到父容器    定边的距离

getLeft:View   左边   到父容器   左边的距离

getRight:View   右边  到父容器   左边的距离(将参考点想成父容器的左边,即父容器到该View右边的距离)

etBottom:View  底部  到父容器 顶边的距离

MotionEvent提供的方法:

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个简单的实现launcher式抽屉的代码示例: 1. 创建一个主界面布局文件,包括一个按钮和一个侧滑菜单布局: ```xml <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/main_layout" android:layout_width="match_parent" android:layout_height="match_parent" android:background="#ffffff"> <Button android:id="@+id/menu_button" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="菜单" android:layout_alignParentTop="true" android:layout_alignParentRight="true" android:layout_marginTop="10dp" android:layout_marginRight="10dp" /> <RelativeLayout android:id="@+id/slide_menu" android:layout_width="240dp" android:layout_height="match_parent" android:layout_gravity="start" android:background="#ffffff" android:visibility="gone"> <!-- 侧滑菜单布局内容 --> </RelativeLayout> </RelativeLayout> ``` 2. 在Activity设置按钮的点击事件,控制侧滑菜单的显示和隐藏: ```java public class MainActivity extends AppCompatActivity { private RelativeLayout slideMenu; private Button menuButton; private boolean isMenuShown = false; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); slideMenu = findViewById(R.id.slide_menu); menuButton = findViewById(R.id.menu_button); menuButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { if (isMenuShown) { slideMenu.setVisibility(View.GONE); isMenuShown = false; } else { slideMenu.setVisibility(View.VISIBLE); isMenuShown = true; } } }); } } ``` 3. 在侧滑菜单布局添加菜单项: ```xml <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent"> <TextView android:id="@+id/menu_item1" android:layout_width="match_parent" android:layout_height="48dp" android:layout_marginTop="16dp" android:gravity="center_vertical" android:paddingLeft="16dp" android:text="菜单项1" android:textColor="#333333" android:textSize="16sp" /> <TextView android:id="@+id/menu_item2" android:layout_width="match_parent" android:layout_height="48dp" android:layout_below="@id/menu_item1" android:gravity="center_vertical" android:paddingLeft="16dp" android:text="菜单项2" android:textColor="#333333" android:textSize="16sp" /> <TextView android:id="@+id/menu_item3" android:layout_width="match_parent" android:layout_height="48dp" android:layout_below="@id/menu_item2" android:gravity="center_vertical" android:paddingLeft="16dp" android:text="菜单项3" android:textColor="#333333" android:textSize="16sp" /> </RelativeLayout> ``` 这样就实现了一个简单的launcher式抽屉效果。当用户点击按钮时,侧滑菜单会从左侧滑出,再次点击时会滑回去。用户可以在侧滑菜单选择需要的操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值