返回顶部
首页 > 资讯 > 精选 >Android实现移动小球和CircularReveal页面切换动画实例代码
  • 194
分享到

Android实现移动小球和CircularReveal页面切换动画实例代码

android小球移动circularreveal 2023-05-30 21:05:25 194人浏览 八月长安
摘要

前言本文主要给大家介绍了关于Android如何实现移动小球和CircularReveal页面切换动画的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。效果图如下是在fragment中跳转activity实现的效果,

前言

本文主要给大家介绍了关于Android如何实现移动小球和CircularReveal页面切换动画的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。

效果图如下

Android实现移动小球和CircularReveal页面切换动画实例代码

是在fragment中跳转activity实现的效果,fragment跳fragment,activity跳activity类似~~

实现过程

  • 重写FloatingActionButton的onTouchListener()方法,使小球可以移动,并判断边界
  • 点击fab时记录坐标传到下一个页面,在下一个页面展示动画。
  • 点击后退或者重写onBackPressed()方法,执行动画

重写Fab的onTouchListener()

 floatingActionButton.setOnTouchListener(new View.OnTouchListener() {  @Override  public boolean onTouch(View view, MotionEvent ev) {  switch (ev.getAction()) {   case MotionEvent.ACTION_DOWN:   downX = ev.getX();   downY = ev.getY();   isClick = true;   break;   case MotionEvent.ACTION_MOVE:   isClick = false;   moveX = ev.getX();   moveY = ev.getY();   int offsetX = (int) (moveX - downX);   int offsetY = (int) (moveY - downY);   //这里使用了setTranslation来移动view。。。尝试过layout。不知道为什么fragment切换回来的时候会恢复原位   floatingActionButton.setTranslationX(floatingActionButton.getTranslationX() + offsetX);   floatingActionButton.setTranslationY(floatingActionButton.getTranslationY() + offsetY);   break;   case MotionEvent.ACTION_UP:   //用来触发点击事件   if (isClick) {    startAct();    return false;   }   //用来判断移动边界   if (floatingActionButton.getX() < 0) {    floatingActionButton.setX(0);   }   if (floatingActionButton.getX() + floatingActionButton.getWidth() > ScreenUtil.getScreenWidth(getContext())) {    floatingActionButton.setX(ScreenUtil.getScreenWidth(getContext()) - floatingActionButton.getWidth());   }   if (floatingActionButton.getY() < titleHeight) {    floatingActionButton.setY(0);   }   if (floatingActionButton.getY() + floatingActionButton.getHeight() + titleHeight >    getActivity().findViewById(R.id.activity_main_mainLl).getHeight() - getActivity().findViewById(R.id.fc_rg).getHeight()) {    floatingActionButton.setY(getBottomY());   }   break;  }  return true;  }  private void startAct() {  //跳转Activity,传递动画参数  Intent intent = new Intent(getActivity(), CheckWorkActivity.class);  intent.putExtra("x", (int) floatingActionButton.getX() + floatingActionButton.getWidth() / 2);  intent.putExtra("y", (int) floatingActionButton.getY() + floatingActionButton.getHeight() / 2);  intent.putExtra("start_radius", floatingActionButton.getWidth() / 2);  intent.putExtra("end_radius", DialogFragment.this.view.getHeight());  startActivity(intent);  } });

--结束END--

本文标题: Android实现移动小球和CircularReveal页面切换动画实例代码

本文链接: https://lsjlt.com/news/221100.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作