zoukankan      html  css  js  c++  java
  • 如何自定义FloatingActionButton的大小

    Google最近为了让开发者更好的更规范的应用Material Design设计思想,特意放出了android support design library,里面含有更多Material Design的标志性组件,其中最常用的就是那个圆形按钮,叫做Floating Action Button,可以简称为FAB。一个使用该控件的例子为:

    <android.support.design.widget.FloatingActionButton
            android:id="@+id/fab"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginTop="20dp"
            android:layout_marginLeft="25dp"
            android:layout_gravity="start|top"
            app:borderWidth="0dp"
            app:fabSize="normal"
            app:elevation="4dp"
            android:scaleType="center"
            android:src="@drawable/btn_menu" />

    注意,在跟布局中需要配置app这个命令空间:

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

    这里关注FAB的app:fabSize这个属性,它是用来规定大小,但是发现只有两个值:mini和normal,默认情况下官方推荐的宽高是56dp,但是如果设计师需要你显示一个比较大一些的FAB,比如100dp(这里发现将fabSize设置成normal或者mini都很小),该怎么办?

    第一反应是修改layout_height和layout_width这两个属性,将他们设置成100dp,最后却发现成了这个怂样:

    看来改变上述两个属性是不行的,那么我们来看FloatingActionButton的源码,在它的构造函数中,有下列代码:

     ShadowViewDelegate delegate = new ShadowViewDelegate() {
                public float getRadius() {
                    return (float)FloatingActionButton.this.getSizeDimension() / 2.0F;
                }
    
                public void setShadowPadding(int left, int top, int right, int bottom) {
                    FloatingActionButton.this.mShadowPadding.set(left, top, right, bottom);
                    FloatingActionButton.this.setPadding(left + FloatingActionButton.this.mContentPadding, top + FloatingActionButton.this.mContentPadding, right + FloatingActionButton.this.mContentPadding, bottom + FloatingActionButton.this.mContentPadding);
                }
    
                public void setBackgroundDrawable(Drawable background) {
                    FloatingActionButton.super.setBackgroundDrawable(background);
                }
            };
            if(VERSION.SDK_INT >= 21) {
                this.mImpl = new FloatingActionButtonLollipop(this, delegate);
            } else {
                this.mImpl = new FloatingActionButtonEclairMr1(this, delegate);
            }

    这里的mImpl是一个FloatingActionButtonImpl的实现类,FloatingActionButton大部分的操作实际上都是在操作这个mImpl,这个mImpl在被new出来的时候会判断当前环境是不是API level大于等于21(实际上在小于21的时候,他用drawable绘制了一层阴影从而有类似于21以上的evevation的效果),随后创建mImpl的时候传入了delegate这个参数,ShadowViewDelegate实际上就是个drawable的包装类。我们看getRadius这个实现方法,显然它是计算半径的,所以要想定制FAB的宽高,得要从这里找文章。

    具体看getSizeDimension这个方法:

     final int getSizeDimension() {
            switch(this.mSize) {
            case 0:
            default:
                return this.getResources().getDimensionPixelSize(dimen.fab_size_normal);
            case 1:
                return this.getResources().getDimensionPixelSize(dimen.fab_size_mini);
            }
        }

    原来app:fabSize实际上是在调用fab_size_normal和fab_size_mini这两个dimen的值,相应的对应了normal和mini这两种情况,那么我们可以想到在我们的代码中国同样定义这两个dimen值对原来的进行覆盖,于是我们在醒目代码的dimen.xml中定义:

    <resources>
        <dimen name="fab_size_normal">100dp</dimen>
    </resources>

    这个时候再看效果:

    修改成功

  • 相关阅读:
    在 docker 容器中捕获信号
    python入门二维码生成
    SSH 端口转发
    Python之模块与包
    滑块验证demo示例
    上下界网络流初探
    大整数模板
    计算几何模板
    关于差分约束系统的脑洞
    并查集,以及可拆分并查集
  • 原文地址:https://www.cnblogs.com/soaringEveryday/p/4806668.html
Copyright © 2011-2022 走看看