为什么按钮文本不显示在 MaterialComponents 的默认中心?
Why does button text not showing in bydefault center in MaterialComponents?
当我使用 AppCompat 时,它工作正常,但当我更改为 MaterialComponents 时,它看起来很糟糕。
查看当前图片:
看到“W”它没有正确显示。对于 'H' 同样的问题。
注意:我尝试使用 Button、AndroidXbutton 和 MaterialButton,在 MateriaComponents 的情况下没有任何效果。
代码:
<androidx.cardview.widget.CardView
android:id="@+id/circle_card_payment"
android:layout_width="40dp"
android:layout_height="40dp"
android:elevation="12dp"
android:innerRadius="0dp"
android:shape="ring"
android:thicknessRatio="1.9"
app:cardCornerRadius="20dp">
<ImageView
android:id="@+id/icon"
android:layout_width="match_parent"
android:layout_height="40dp"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:visibility="gone"></ImageView>
<com.google.android.material.button.MaterialButton
android:id="@+id/logo"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:text="A"
android:textColor="@color/colorWhite"
android:textSize="16sp"
android:visibility="gone"></com.google.android.material.button.MaterialButton>
</androidx.cardview.widget.CardView>
我正在以编程方式设置可绘制背景,因为在 material 组件中,它不会影响 XML。
logo.setBackgroundResource(R.drawable.bg_circle_btn);
bg_circle_btn.xml:
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="oval">
<solid android:color="?attr/toolbar_color" />
<size
android:width="120dp"
android:height="120dp" />
</shape>
请注意,如果我将 cardview 大小从 40dp 更改为 50dp,这个问题会解决,但尺寸会更大,看起来很糟糕。
完成XML:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="?attr/cardbackgroundColor"
android:orientation="vertical">
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="16dp">
<androidx.cardview.widget.CardView
android:id="@+id/circle_card_payment"
android:layout_width="40dp"
android:layout_height="40dp"
android:elevation="12dp"
android:innerRadius="0dp"
android:shape="ring"
android:thicknessRatio="1.9"
app:cardCornerRadius="20dp">
<ImageView
android:id="@+id/icon"
android:layout_width="match_parent"
android:layout_height="40dp"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:visibility="gone"></ImageView>
<com.google.android.material.button.MaterialButton
android:id="@+id/logo"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:text="A"
android:textColor="@color/colorWhite"
android:textSize="16sp"
android:visibility="gone"></com.google.android.material.button.MaterialButton>
</androidx.cardview.widget.CardView>
<TextView
android:id="@+id/tv_category_item"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_marginLeft="12dp"
android:layout_toLeftOf="@+id/next"
android:layout_toRightOf="@+id/circle_card_payment"
android:text="Category"
android:textColor="?attr/day_colorDarkGray_night_colorWhite"
android:textSize="16sp" />
<ImageView
android:id="@+id/next"
android:layout_width="40dp"
android:layout_height="40dp"
android:layout_alignParentEnd="true"
android:layout_centerVertical="true"
android:padding="6dp"
android:tint="@color/colorVeryLightGray"
android:visibility="visible"
app:srcCompat="@drawable/ic_navigate_next_black_24dp" />
<ImageView
android:id="@+id/hamburger_menu"
android:layout_width="40dp"
android:layout_height="40dp"
android:layout_centerVertical="true"
android:layout_toLeftOf="@+id/next"
android:padding="6dp"
android:tint="?attr/day_colorBlack_night_colorWhite"
android:visibility="gone"
app:srcCompat="@drawable/ic_more_vert_black_24dp" />
</RelativeLayout>
<View
android:layout_width="match_parent"
android:layout_height="0.5dp"
android:layout_marginLeft="70dp"
android:background="@color/colorVeryLightGray" />
</LinearLayout>
在MaterialButton
中你不应该使用setBackground*
方法。
您可以查看 logcat,您应该会找到类似以下内容的内容:
W/MaterialButton: Do not set the background; MaterialButton manages its own background drawable
您可以在 MaterialButton
中以不同的方式定义 custom shape。例如你可以这样做:
<com.google.android.material.button.MaterialButton
android:id="@+id/logo"
android:layout_width="48dp"
android:layout_height="48dp"
android:text="W"
android:padding="0dp"
app:strokeWidth="0dp"
android:insetLeft="0dp"
android:insetTop="0dp"
android:insetRight="0dp"
android:insetBottom="0dp"
android:textColor="#FFFFFF"
android:textSize="16sp"
app:shapeAppearanceOverlay="@style/ShapeAppearanceOverlay_ButtonCircle50"
/>
其中 ShapeAppearanceOverlay_ButtonCircle50
定义为:
<style name="ShapeAppearanceOverlay_ButtonCircle50">
<item name="cornerFamily">rounded</item>
<item name="cornerSize">50%</item>
</style>
当我使用 AppCompat 时,它工作正常,但当我更改为 MaterialComponents 时,它看起来很糟糕。
查看当前图片:
看到“W”它没有正确显示。对于 'H' 同样的问题。
注意:我尝试使用 Button、AndroidXbutton 和 MaterialButton,在 MateriaComponents 的情况下没有任何效果。
代码:
<androidx.cardview.widget.CardView
android:id="@+id/circle_card_payment"
android:layout_width="40dp"
android:layout_height="40dp"
android:elevation="12dp"
android:innerRadius="0dp"
android:shape="ring"
android:thicknessRatio="1.9"
app:cardCornerRadius="20dp">
<ImageView
android:id="@+id/icon"
android:layout_width="match_parent"
android:layout_height="40dp"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:visibility="gone"></ImageView>
<com.google.android.material.button.MaterialButton
android:id="@+id/logo"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:text="A"
android:textColor="@color/colorWhite"
android:textSize="16sp"
android:visibility="gone"></com.google.android.material.button.MaterialButton>
</androidx.cardview.widget.CardView>
我正在以编程方式设置可绘制背景,因为在 material 组件中,它不会影响 XML。
logo.setBackgroundResource(R.drawable.bg_circle_btn);
bg_circle_btn.xml:
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="oval">
<solid android:color="?attr/toolbar_color" />
<size
android:width="120dp"
android:height="120dp" />
</shape>
请注意,如果我将 cardview 大小从 40dp 更改为 50dp,这个问题会解决,但尺寸会更大,看起来很糟糕。
完成XML:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="?attr/cardbackgroundColor"
android:orientation="vertical">
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="16dp">
<androidx.cardview.widget.CardView
android:id="@+id/circle_card_payment"
android:layout_width="40dp"
android:layout_height="40dp"
android:elevation="12dp"
android:innerRadius="0dp"
android:shape="ring"
android:thicknessRatio="1.9"
app:cardCornerRadius="20dp">
<ImageView
android:id="@+id/icon"
android:layout_width="match_parent"
android:layout_height="40dp"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:visibility="gone"></ImageView>
<com.google.android.material.button.MaterialButton
android:id="@+id/logo"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:text="A"
android:textColor="@color/colorWhite"
android:textSize="16sp"
android:visibility="gone"></com.google.android.material.button.MaterialButton>
</androidx.cardview.widget.CardView>
<TextView
android:id="@+id/tv_category_item"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_marginLeft="12dp"
android:layout_toLeftOf="@+id/next"
android:layout_toRightOf="@+id/circle_card_payment"
android:text="Category"
android:textColor="?attr/day_colorDarkGray_night_colorWhite"
android:textSize="16sp" />
<ImageView
android:id="@+id/next"
android:layout_width="40dp"
android:layout_height="40dp"
android:layout_alignParentEnd="true"
android:layout_centerVertical="true"
android:padding="6dp"
android:tint="@color/colorVeryLightGray"
android:visibility="visible"
app:srcCompat="@drawable/ic_navigate_next_black_24dp" />
<ImageView
android:id="@+id/hamburger_menu"
android:layout_width="40dp"
android:layout_height="40dp"
android:layout_centerVertical="true"
android:layout_toLeftOf="@+id/next"
android:padding="6dp"
android:tint="?attr/day_colorBlack_night_colorWhite"
android:visibility="gone"
app:srcCompat="@drawable/ic_more_vert_black_24dp" />
</RelativeLayout>
<View
android:layout_width="match_parent"
android:layout_height="0.5dp"
android:layout_marginLeft="70dp"
android:background="@color/colorVeryLightGray" />
</LinearLayout>
在MaterialButton
中你不应该使用setBackground*
方法。
您可以查看 logcat,您应该会找到类似以下内容的内容:
W/MaterialButton: Do not set the background; MaterialButton manages its own background drawable
您可以在 MaterialButton
中以不同的方式定义 custom shape。例如你可以这样做:
<com.google.android.material.button.MaterialButton
android:id="@+id/logo"
android:layout_width="48dp"
android:layout_height="48dp"
android:text="W"
android:padding="0dp"
app:strokeWidth="0dp"
android:insetLeft="0dp"
android:insetTop="0dp"
android:insetRight="0dp"
android:insetBottom="0dp"
android:textColor="#FFFFFF"
android:textSize="16sp"
app:shapeAppearanceOverlay="@style/ShapeAppearanceOverlay_ButtonCircle50"
/>
其中 ShapeAppearanceOverlay_ButtonCircle50
定义为:
<style name="ShapeAppearanceOverlay_ButtonCircle50">
<item name="cornerFamily">rounded</item>
<item name="cornerSize">50%</item>
</style>