如何更改扩展浮动动作按钮的形状?

时间:2019-09-09 20:38:01

标签: android android-layout android-button floating-action-button material-components-android

我正在尝试将操作按钮的形状从该默认形状更改为矩形。这是我的xml:

<com.google.android.material.floatingactionbutton.ExtendedFloatingActionButton
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintBottom_toBottomOf="parent"
        app:cornerRadius="90dp"
        android:text="@string/create_player_text"
        android:fontFamily="@font/proximanova_semibold"
        app:layout_constraintHorizontal_bias="0.99"
        app:layout_constraintVertical_bias="0.01"/>

enter image description here

3 个答案:

答案 0 :(得分:1)

我认为Material Button可以完美地满足您的需求,而且Material Button的形状为矩形,且边角半径较小。您应该改为使用“扩展浮动操作按钮”。

检查官方文档如何按照准则使用

Material Button

答案 1 :(得分:0)

创建这样的xml文件:

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
    <item>
        <shape
            android:shape="rectangle">
            <corners android:radius="@dimen/_100sdp"/>
        </shape>
    </item>
</layer-list>

并在您的扩展工厂中使用-与shapeAppearanceOverlay

一起使用
<com.google.android.material.floatingactionbutton.ExtendedFloatingActionButton
            style="@style/Widget.MaterialComponents.ExtendedFloatingActionButton"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            app:shapeAppearanceOverlay="@drawable/bg_circle_black"
            android:text="Sign in to setup follow page"
            android:textAlignment="center"
            app:layout_anchor="@id/scrollView"
            app:layout_anchorGravity="bottom|center|center_horizontal" />

答案 2 :(得分:0)

如果要更改ExtendedFloatingActionButton的形状,可以在布局中使用 shapeAppearanceOverlay 属性:

    <com.google.android.material.floatingactionbutton.ExtendedFloatingActionButton
        app:shapeAppearanceOverlay="@style/ShapeAppearanceOverlayExtended"
        ../>

使用:

  <style name="ShapeAppearanceOverlayExtended" parent="">
    <item name="cornerFamily">rounded</item>
    <item name="cornerSize">0dp</item>
  </style>

如果您想要拐角半径,只需更改<item name="cornerSize">0dp</item>中的值即可。

enter image description here