热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

AndroidSupportDesignLibrary之FloatingActionButton

为了文章的精彩,前三个标题实现FloatingActionButton的特效,最后一节讲解其属性详情。1.自定义Behavior实现掌阅底部菜单与按钮联动效果。我们来

为了文章的精彩,前三个标题实现FloatingActionButton的特效,最后一节讲解其属性详情。



1.自定义Behavior实现掌阅底部菜单与按钮联动效果。


我们来看看掌阅的菜单效果:



以前没有这个支持库的时候,需要写两个动画,一个按钮的动画一个菜单的动画,现在因为有了Behavior,那么一个在另一个的相对位置就可以实现其效果。


另外标记一下这个库最重要的知识点就是Behavior,其他的与基本控件无异。下面我们来实现其效果。


自定义Behavior代码:


public class LYJBehavior extends CoordinatorLayout.Behavior {
    private int targetId;  //获取自定义属性值的ID  public LYJBehavior(Context context, AttributeSet attrs) {
        super(context, attrs);  TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.Follow);  for (int i = 0; i ; i++) {
            int attr = a.getIndex(i);  if(a.getIndex(i) == R.styleable.Follow_target){
                targetId = a.getResourceId(attr, -1);  }
        }
        a.recycle();   }
    //获取相对空间ID,并设置到其中  @Override  public boolean layoutDependsOn(CoordinatorLayout parent, View child, View dependency) {
        return dependency.getId() == targetId;  }
    //相对位置效果代码写在这里  @Override  public boolean onDependentViewChanged(CoordinatorLayout parent, View child, View dependency) {
        child.setY(dependency.getY()-170);//child不管dependency怎么移动,其都在dependency上面,也就是不管菜单有移动,FAB都在其上面  return true;  }
}



这里为什么child控件(也就是FAB)获取到菜单的Y坐标后,为什么还要减去170,我们来看图说明。



我们知道,一个控件在屏幕上绘制都是根据其左上角坐标绘制的,那么获取他的Y坐标也一定在其左上角坐标的Y,而如果不减去170那么显示的位置就会如屏幕白色圆圈的位置,那么如果单单只减去FAB自身控件的高度,也会没有间距,所以减去170会悬浮在上面且有一定间距,170的大小就如图大括号的距离。当然,我这里为了简单直接写的170,你可以获取FAB控件高度在减去你设置的间距。毕竟什么东西都不能写死。(这里做演示用)


自定义属性在res/attr.xml中,代码如下:


name="Follow">  name="target" format="reference"/> 


设置到布局中:


<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"  xmlns:app="http://schemas.android.com/apk/res-auto"  android:id="@+id/coordinatorlayout"  android:layout_match_parent"  android:layout_match_parent">   <android.support.design.widget.FloatingActionButton  android:id="@+id/lyj_fab"  android:layout_wrap_content"  android:layout_wrap_content"  android:layout_margin="16dp"  app:layout_behavior="com.example.liyuanjing.snackbardemo.LYJBehavior"  app:target="@+id/lyj_framelayout"  android:src="@drawable/blog_tag_parent_expert" />     android.support.design.widget.CoordinatorLayout>


红色代码就是设置其行为效果。


public class MainActivity extends AppCompatActivity { private FloatingActionButton fab;  private CoordinatorLayout coordinatorLayout;  private boolean flag=true;//值为true不有显示,false表示显示了。  private View view;  @Override  protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState);  setContentView(R.layout.activity_main);  this.fab = (FloatingActionButton) findViewById(R.id.lyj_fab);  this.coordinatorLayout = (CoordinatorLayout) findViewById(R.id.coordinatorlayout);  view=LayoutInflater.from(MainActivity.this).inflate(R.layout.popup_menu_layout, null);  FrameLayout frameLayout=(FrameLayout)findViewById(R.id.lyj_framelayout);  frameLayout.addView(view);  this.fab.setOnClickListener(new View.OnClickListener() { @Override  public void onClick(View v) { if(flag){ view.setVisibility(View.VISIBLE);  view.setAnimation(AnimationUtils.loadAnimation(MainActivity.this, R.anim.info_menu_popup_window_show));  flag=false;  }else{ view.setAnimation(AnimationUtils.loadAnimation(MainActivity.this, R.anim.info_menu_popup_window_hide));  view.setVisibility(View.GONE);  flag=true;  } } });  } }


那么菜单布局如下popup_menu_layout:


xml version="1.0" encoding="utf-8"?>
xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_match_parent"
    android:layout_wrap_content"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:orientation="vertical"
    android:visibility="gone"
    android:background="#aa000000">
    
            android:layout_match_parent"
        android:layout_wrap_content"
        android:orientation="horizontal">
        
                    android:layout_0dp"
            android:layout_wrap_content"
            android:orientation="vertical"
            android:layout_weight="1"
            android:background="@drawable/lyj_menu_shape"
            android:gravity="center">

                            android:layout_wrap_content"
                android:layout_wrap_content"
                android:src="@drawable/menu_icon_import"/>

                            android:layout_wrap_content"
                android:layout_wrap_content"
                android:textSize="15sp"
                android:textColor="@android:color/white"
                android:text="@string/lyj_menu_popup_one"/>

        
        
                    android:layout_0dp"
            android:layout_wrap_content"
            android:orientation="vertical"
            android:gravity="center"
            android:background="@drawable/lyj_menu_shape"
            android:layout_weight="1">

                            android:layout_wrap_content"
                android:layout_wrap_content"
                android:src="@drawable/menu_icon_cloud"/>

                            android:layout_wrap_content"
                android:layout_wrap_content"
                android:textSize="15sp"
                android:textColor="@android:color/white"
                android:text="@string/lyj_menu_popup_two"/>

        
        
                    android:layout_0dp"
            android:layout_wrap_content"
            android:orientation="vertical"
            android:gravity="center"
            android:background="@drawable/lyj_menu_shape"
            android:layout_weight="1">

                            android:layout_wrap_content"
                android:layout_wrap_content"
                android:src="@drawable/bookshelf_sort_icon"/>

                            android:layout_wrap_content"
                android:layout_wrap_content"
                android:textSize="15sp"
                android:textColor="@android:color/white"
                android:text="@string/lyj_menu_popup_three"/>

        
        
                    android:layout_0dp"
            android:layout_wrap_content"
            android:orientation="vertical"
            android:gravity="center"
            android:background="@drawable/lyj_menu_shape"
            android:layout_weight="1">

                            android:layout_wrap_content"
                android:layout_wrap_content"
                android:src="@drawable/menu_icon_booksmanage"/>

                            android:layout_wrap_content"
                android:layout_wrap_content"
                android:textSize="15sp"
                android:textColor="@android:color/white"
                android:text="@string/lyj_menu_popup_four"/>

        
    


    
            android:layout_match_parent"
        android:layout_wrap_content"
        android:orientation="horizontal">

        
                    android:layout_0dp"
            android:layout_wrap_content"
            android:orientation="vertical"
            android:layout_weight="1"
            android:background="@drawable/lyj_menu_shape"
            android:gravity="center">

                            android:layout_wrap_content"
                android:layout_wrap_content"
                android:src="@drawable/menu_icon_eye"/>

                            android:layout_wrap_content"
                android:layout_wrap_content"
                android:textSize="15sp"
                android:textColor="@android:color/white"
                android:text="@string/lyj_menu_popup_five"/>

        
        
                    android:layout_0dp"
            android:layout_wrap_content"
            android:orientation="vertical"
            android:gravity="center"
            android:background="@drawable/lyj_menu_shape"
            android:layout_weight="1">

                            android:layout_wrap_content"
                android:layout_wrap_content"
                android:src="@drawable/menu_icon_plug"/>

                            android:layout_wrap_content"
                android:layout_wrap_content"
                android:textSize="15sp"
                android:textColor="@android:color/white"
                android:text="@string/lyj_menu_popup_six"/>

        
        
                    android:layout_0dp"
            android:layout_wrap_content"
            android:orientation="vertical"
            android:gravity="center"
            android:background="@drawable/lyj_menu_shape"
            android:layout_weight="1">

                            android:layout_wrap_content"
                android:layout_wrap_content"
                android:src="@drawable/menu_icon_set"/>

                            android:layout_wrap_content"
                android:layout_wrap_content"
                android:textSize="15sp"
                android:textColor="@android:color/white"
                android:text="@string/lyj_menu_popup_seven"/>

        
        
                    android:layout_0dp"
            android:layout_wrap_content"
            android:orientation="vertical"
            android:gravity="center"
            android:background="@drawable/lyj_menu_shape"
            android:layout_weight="1">

                            android:layout_wrap_content"
                android:layout_wrap_content"
                android:src="@drawable/menu_icon_about"/>

                            android:layout_wrap_content"
                android:layout_wrap_content"
                android:textSize="15sp"
                android:textColor="@android:color/white"
                android:text="@string/lyj_menu_popup_eight"/>

        

    


这样我们就实现了掌阅的菜单样式:



2.FloatingActionButton与CollapsingToolbarLayout的配合


布局文件如下:


xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_match_parent"
    android:layout_match_parent">

            android:id="@+id/appbar"
        android:layout_match_parent"
        android:layout_200dp"
        android:fitsSystemWindows="true"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

                    android:id="@+id/collapsing_toolbar"
            android:layout_match_parent"
            android:layout_match_parent"
            android:fitsSystemWindows="true"
            app:cOntentScrim="?attr/colorPrimary"
            app:expandedTitleMarginEnd="64dp"
            app:expandedTitleMarginStart="48dp"
            app:layout_scrollFlags="scroll|exitUntilCollapsed">

                            android:id="@+id/toolbar"
                android:layout_match_parent"
                android:layout_?attr/actionBarSize"
                app:layout_collapseMode="pin"
                app:popupTheme="@style/ThemeOverlay.AppCompat.Light" />

                            android:id="@+id/lyj_image"
                android:layout_match_parent"
                android:layout_200dp"
                android:scaleType="centerCrop"
                android:fitsSystemWindows="true"
                android:src="@drawable/biz_live_foot_bg"
                app:layout_collapseMode="parallax"
                />

        

    

            android:id="@+id/recyclerview"
        android:layout_match_parent"
        android:layout_match_parent"
        app:layout_behavior="@string/appbar_scrolling_view_behavior"/>

            android:id="@+id/lyj_showbut"
        android:layout_wrap_content"
        android:layout_wrap_content"
        app:backgroundTint="#FF3030"
        app:rippleColor="#FF4500"
        android:src="@drawable/add_attention"
        app:elevation="6dp"
        app:fabSize="normal"
        app:pressedTranslatiOnZ="12dp"
        app:border0dp"
        app:layout_anchor="@id/collapsing_toolbar"
        app:layout_anchorGravity="bottom|center"/>



布局文件中FAB以CollapsingToolbarLayout为锚点,在其底部的中间位置bottom,center。那么得到的效果图如下:



FAB就像一个标签,嵌入标题栏了。


3.FloatingActionButton与RecyclerView配合


更改FAB中的两个属性即可:


app:layout_anchor="@id/recyclerview"
app:layout_anchorGravity="bottom|right"


得到如下效果:



FAB悬浮在底部了。


4.FloatingActionButton属性详解


①app:fabSize:两个取值,一个为mini,一个为normal,用来定义FAB大小的,normal为正常大小,mini为小巧。


②app:backgroundTint:FAB背景色,如果在Style文件中配置其为colorAccent。


③app:pressedTranslationZ :FAB被按下时候阴影增大的动画。


④app:elevation:FAB空闲状态阴影效果。


⑤app:rippleColor:点击时候的涟漪色,也可以理解为波浪,如果要style配置其为colorControlHighlight。


⑥app:borderWidth:该属性尤为重要,如果不设置0dp,那么在4.1的sdk上FAB会显示为正方形,而且在5.0以后的sdk没有阴影效果。所以设置为border。


⑦app:layout_anchor:设置FAB的锚点,即以哪个控件为参照点设置位置。


⑧app:layout_anchorGravity:设置FAB相对锚点的位置,值有 bottom、center、right、left、top等。




推荐阅读
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 今天就跟大家聊聊有关怎么在Android应用中实现一个换肤功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 本文介绍了使用kotlin实现动画效果的方法,包括上下移动、放大缩小、旋转等功能。通过代码示例演示了如何使用ObjectAnimator和AnimatorSet来实现动画效果,并提供了实现抖动效果的代码。同时还介绍了如何使用translationY和translationX来实现上下和左右移动的效果。最后还提供了一个anim_small.xml文件的代码示例,可以用来实现放大缩小的效果。 ... [详细]
  • 2021年最详细的Android屏幕适配方案汇总
    1Android屏幕适配的度量单位和相关概念建议在阅读本文章之前,可以先阅读快乐李同学写的文章《Android屏幕适配的度量单位和相关概念》,这篇文章 ... [详细]
  • 本文介绍了如何使用PHP向系统日历中添加事件的方法,通过使用PHP技术可以实现自动添加事件的功能,从而实现全局通知系统和迅速记录工具的自动化。同时还提到了系统exchange自带的日历具有同步感的特点,以及使用web技术实现自动添加事件的优势。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 本文介绍了在Linux下安装Perl的步骤,并提供了一个简单的Perl程序示例。同时,还展示了运行该程序的结果。 ... [详细]
  • 拥抱Android Design Support Library新变化(导航视图、悬浮ActionBar)
    转载请注明明桑AndroidAndroid5.0Loollipop作为Android最重要的版本之一,为我们带来了全新的界面风格和设计语言。看起来很受欢迎࿰ ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 在开发app时,使用了butterknife后,在androidStudio打包apk时可能会遇到报错。为了解决这个问题,可以通过打开proguard-rules.pro文件进行代码混淆来解决。本文介绍了具体的混淆代码和方法。 ... [详细]
  • Android开发实现的计时器功能示例
    本文分享了Android开发实现的计时器功能示例,包括效果图、布局和按钮的使用。通过使用Chronometer控件,可以实现计时器功能。该示例适用于Android平台,供开发者参考。 ... [详细]
  • 本文介绍了Android中的assets目录和raw目录的共同点和区别,包括获取资源的方法、目录结构的限制以及列出资源的能力。同时,还解释了raw目录中资源文件生成的ID,并说明了这些目录的使用方法。 ... [详细]
  • 近来有一个需求,是需要在androidjava基础库中插入一些log信息,完成这个工作需要的前置条件有编译好的android源码具体android源码如何编译,这 ... [详细]
  • 【CTF 攻略】第三届 SSCTF 全国网络安全大赛—线上赛 Writeup
    【CTF 攻略】第三届 SSCTF 全国网络安全大赛—线上赛 Writeup ... [详细]
author-avatar
大西guoguo_120
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有