广告
返回顶部
首页 > 资讯 > 精选 >Android view如何实现滑动悬浮固定效果
  • 661
分享到

Android view如何实现滑动悬浮固定效果

android 2023-05-30 18:05:51 661人浏览 薄情痞子
摘要

这篇文章主要介绍了Android view如何实现滑动悬浮固定效果,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1.背景在项目开发过程中,有时候会碰到这样的需求:在滑动的过程

这篇文章主要介绍了Android view如何实现滑动悬浮固定效果,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

1.背景

项目开发过程中,有时候会碰到这样的需求:在滑动的过程中,在某时要将子view固定在顶部(常见的是将界面中的tab在滑动到顶部的时候进行固定)。

之前写过一篇滑动组件悬浮固定在顶部的文章,但感觉还是有些复杂,因此就有了这次的实现。效果图:

Android view如何实现滑动悬浮固定效果

2.思路

(CoordinatorLayout+AppBarLayout+CollapsingToolbarLayout)+TabLayout+ViewPager

3.代码实现

a.主布局代码

<?xml version="1.0" encoding="utf-8"?> <android.support.design.widget.CoordinatorLayout xmlns:android="Http://schemas.android.com/apk/res/android"   xmlns:app="http://schemas.android.com/apk/res-auto"   xmlns:tools="http://schemas.android.com/tools"   android:layout_width="match_parent"   android:layout_height="match_parent"   android:fitsSystemwindows="true"   tools:context="com.ganshenml.slideholdsmoothdemo.ScrollingActivity">    <android.support.design.widget.AppBarLayout     android:id="@+id/app_bar"     android:layout_width="match_parent"     android:layout_height="wrap_content"     android:fitsSystemWindows="true"     android:theme="@style/AppTheme.AppBarOverlay">      <android.support.design.widget.CollapsingToolbarLayout       android:id="@+id/toolbar_layout"       android:layout_width="match_parent"       android:layout_height="wrap_content"       android:fitsSystemWindows="true"       app:contentScrim="?attr/colorPrimary"       app:layout_scrollFlags="scroll|exitUntilCollapsed"       app:titleEnabled="false">        <android.support.v7.widget.Toolbar         android:id="@+id/toolbar"         android:layout_width="match_parent"         android:layout_height="30dp"         app:popupTheme="@style/AppTheme.PopupOverlay"></android.support.v7.widget.Toolbar>        <ImageView         android:layout_width="match_parent"         android:layout_height="280dp"         android:scaleType="centerCrop"         android:src="@drawable/bg" />        <android.support.design.widget.TabLayout         android:id="@+id/tabLayout"         android:layout_width="match_parent"         android:layout_height="30dp"         android:layout_gravity="bottom"         android:background="@color/colorAccent"></android.support.design.widget.TabLayout>      </android.support.design.widget.CollapsingToolbarLayout>   </android.support.design.widget.AppBarLayout>    <include layout="@layout/content_scrolling" /> </android.support.design.widget.CoordinatorLayout>

需要注意的是:

  1. app:layout_scrollFlags="scroll|exitUntilCollapsed"——>设置可以滑动且当前view可以一直退出直到折叠视图显现。

  2. <include layout="@layout/content_scrolling" />——>引用的子view布局其实就是一个ViewPager(需要注意的是要在布局中设置:app:layout_behavior="@string/appbar_scrolling_view_behavior")

b.主界面Activity代码

public class ScrollingActivity extends AppCompatActivity {   private TabLayout tabLayout;   private ViewPager viewPager;    @Override   protected void onCreate(Bundle savedInstanceState) {     super.onCreate(savedInstanceState);     setContentView(R.layout.activity_scrolling);     initViews();   }    private void initViews() {     tabLayout = (TabLayout) findViewById(R.id.tabLayout);     viewPager = (ViewPager) findViewById(R.id.viewPager);      viewPager.setOffscreenPageLimit(2);     viewPager.setAdapter(new MPagerAdapter(getSupportFragmentManager()));     tabLayout.setupWithViewPager(viewPager);   }  }

c.适配器MPagerAdapter代码

public class MPagerAdapter extends FragmentStatePagerAdapter {   private String[] tabTitle = new String[]{"tab01", "tab02"};   private FirstFragment firstFragment;   private SecondFragment secondFragment;    public MPagerAdapter(FragmentManager fm) {     super(fm);   }    @Override   public Fragment getItem(int position) {     if (position == 0) {       if (firstFragment == null) {         firstFragment = new FirstFragment();       }       return firstFragment;     } else if (position == 1) {       if (secondFragment == null) {         secondFragment = new SecondFragment();       }       return secondFragment;     }     return null;   }    @Override   public int getCount() {     return tabTitle.length;   }    @Override   public CharSequence getPageTitle(int position) {     return tabTitle[position];   }  }

两个Fragment的代码非常简单。仅仅加载布局而已,所以在此就不贴出来了。

4.扩展

a.关于CollapsingToolbarLayout中子view的排列顺序对显示结果造成的影响

如图:

Android view如何实现滑动悬浮固定效果

可以看到图中黑色边框显示的内容不一致,因此ToolBar和ImageView的排列顺序会对视图的显示结果造成影响。

推测——>CollapsingToolbarLayout中以上三种view不同排序的剖面展示效果为:

顺序:Toolbar——>ImageView——>TabLayout(设置layout_gravity="bottom")

Android view如何实现滑动悬浮固定效果

顺序:ImageView——>Toolbar——>TabLayout(设置layout_gravity="bottom")

Android view如何实现滑动悬浮固定效果

不负责任滴猜测:把Toolbar看做一张画布,只有覆盖在画布投射区域范围内的内容才显示出来在该画布内。
(因此,1.在画布下的内容就无法显示出来;2.无法覆盖画布的内容就显示为画布默认的样式)
所以,如果不想要有视差效果的话,那么就将Toolbar与TabLayout的高度设置一致。如果将Toolbar去掉,那么所有的CollapsingToolbarLayout中的View都会滑出界面,此时布局就变成了普通布局了(相当于CollapsingToolbarLayout变成了CollapsingLayout)。

b.去掉Toolbar实现固定效果

<android.support.design.widget.AppBarLayout     android:id="@+id/app_bar"     android:layout_width="match_parent"     android:layout_height="wrap_content"     android:fitsSystemWindows="true"     android:theme="@style/AppTheme.AppBarOverlay">      <android.support.design.widget.CollapsingToolbarLayout       android:id="@+id/toolbar_layout"       android:layout_width="match_parent"       android:layout_height="wrap_content"       android:fitsSystemWindows="true"       app:contentScrim="?attr/colorPrimary"       app:layout_scrollFlags="scroll|exitUntilCollapsed"       app:titleEnabled="false">        <ImageView         android:layout_width="match_parent"         android:layout_height="280dp"         android:scaleType="centerCrop"         android:src="@drawable/bg" />      </android.support.design.widget.CollapsingToolbarLayout>      <android.support.design.widget.TabLayout       android:id="@+id/tabLayout"       android:layout_width="match_parent"       android:layout_height="30dp"       android:layout_gravity="top"       android:background="@color/colorAccent"></android.support.design.widget.TabLayout>    </android.support.design.widget.AppBarLayout>

只要将TabLayout从CollapsingToolbarLayout中移到AppBarLayout的一级子View即可。

(这样也避免了:在CollapsingToolbarLayout中,因为视图折叠覆盖的问题,会导致整个ImageView被TabLayout覆盖一部分而显示不完全的问题。)

感谢你能够认真阅读完这篇文章,希望小编分享的“Android view如何实现滑动悬浮固定效果”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网精选频道,更多相关知识等着你来学习!

--结束END--

本文标题: Android view如何实现滑动悬浮固定效果

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

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

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Android view如何实现滑动悬浮固定效果
    这篇文章主要介绍了Android view如何实现滑动悬浮固定效果,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1.背景在项目开发过程中,有时候会碰到这样的需求:在滑动的过程...
    99+
    2023-05-30
    android
  • Android滑动组件悬浮固定在顶部效果
    要想实现的效果是如下: 场景:有些时候是内容中间的组件当滑动至顶部的时候固定显示在顶部。 实现的思路: 1.目标组件(button)有两套,放在顶部和内容中间; 2.当内容...
    99+
    2022-06-06
    Android
  • vue+jquery+lodash如何实现滑动时顶部悬浮固定效果
    这篇文章给大家分享的是有关vue+jquery+lodash如何实现滑动时顶部悬浮固定效果的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。这个效果是一个项目中抽出来的一个demo效...
    99+
    2022-10-19
  • Android如何实现View滑动效果
    这篇文章给大家分享的是有关Android如何实现View滑动效果的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、View的滑动简介View的滑动是Android实现自定义控件的基础,同时在开发中我们也难免会遇到...
    99+
    2023-06-14
  • Android如何自定View实现滑动验证效果
    本篇内容主要讲解“Android如何自定View实现滑动验证效果”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Android如何自定View实现滑动验证效果”吧!效果图自定义属性代码<xm...
    99+
    2023-06-22
  • Android自定义view实现滑动解锁效果
    本文实例为大家分享了Android自定义view实现滑动解锁的具体代码,供大家参考,具体内容如下 1. 需求如下: 近期需要做一个类似屏幕滑动解锁的功能,右划开始,左划暂停。 2. ...
    99+
    2022-11-12
  • Flutter实现Android滚动悬浮效果过程
    目录1、计算每个区块的高度2、实现分析-tabBar透明度渐变3、实现分析-app上下滚动触发tabBar4、实现分析-tabBar切换触发app滚动5、源码有以下几种效果 1、ta...
    99+
    2023-01-29
    Flutter滚动悬浮 Flutter滚动悬浮效果
  • Android中自定义view实现侧滑效果
    效果图: 看网上的都是两个view拼接,默认右侧的不显示,水平移动的时候把右侧的view显示出来。但是看最新版QQ上的效果不是这样的,但给人的感觉却很好,所以献丑来一发比较高...
    99+
    2022-06-06
    view 自定义view Android
  • Android自定义View实现竖向滑动回弹效果
    本文实例为大家分享了Android自定义View实现滑动回弹的具体代码,供大家参考,具体内容如下 前言 Android 页面滑动的时候的回弹效果 一、关键代码 public clas...
    99+
    2022-11-13
  • Android自定View实现滑动验证效果的代码
    效果图 自定义属性代码 <?xml version="1.0" encoding="utf-8"?> <resources> &...
    99+
    2022-11-12
  • Android实现滑动到顶部悬停的效果
    先来看下要实现效果图: 查阅资料后,发现网上大部分都是用这种方法实现的: 多写一个和需要悬浮的部分一模一样的layout,先把浮动区域的可见性设置为gone。当浮动区域滑动到...
    99+
    2022-06-06
    Android
  • Android实现View滑动效果的6种方法
    本文实例为大家分享了Android实现View滑动效果的具体代码,供大家参考,具体内容如下 一、View的滑动简介 View的滑动是Android实现自定义控件的基础,同时在开发中我...
    99+
    2022-11-12
  • js如何实现3d悬浮效果
    这篇文章主要介绍了js如何实现3d悬浮效果,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。效果如下:代码如下:<!DOCTYPE&nbs...
    99+
    2022-10-19
  • js如何实现悬浮窗效果
    小编给大家分享一下js如何实现悬浮窗效果,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!效果图:代码如下:<!DOCTYPE...
    99+
    2022-10-19
  • Android怎么自定义View实现竖向滑动回弹效果
    这篇文章主要介绍“Android怎么自定义View实现竖向滑动回弹效果”,在日常操作中,相信很多人在Android怎么自定义View实现竖向滑动回弹效果问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Andro...
    99+
    2023-06-30
  • Android中怎么实现view随触碰滑动效果
    Android中怎么实现view随触碰滑动效果,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。布局文件里面就是一个Relativelayout中有一个ImageView。如下...
    99+
    2023-05-30
    android view
  • 怎么在Android中通过自定义view实现滑动解锁效果
    怎么在Android中通过自定义view实现滑动解锁效果?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。自定义view如下@SuppressLint("Clicka...
    99+
    2023-06-15
  • 如何在Android应用中使用ScrollView实现悬浮效果
    如何在Android应用中使用ScrollView实现悬浮效果?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。新建一个Android项目,<&#63;xml v...
    99+
    2023-05-31
    android scrollview roi
  • css3如何实现鼠标悬浮停止动画效果
    小编给大家分享一下css3如何实现鼠标悬浮停止动画效果,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧! 在css中,可以利用“:hover”选择器和“animat...
    99+
    2022-10-19
  • vue如何实现鼠标悬浮框效果
    这篇文章将为大家详细讲解有关vue如何实现鼠标悬浮框效果,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体内容如下效果:html:<div  @mouseenter="...
    99+
    2023-06-29
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作