- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当我使用 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>
关于android - 为什么按钮文本不显示在 MaterialComponents 的默认中心?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58309705/
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: How to align a to the middle of the page 这是一个简单的问题,应该有一个简
我想知道如何在屏幕中央的ListView中生成2个itens。 class _CategoriesState extends State { List categories = ["Anterio
我需要修复 UICollectionView 的一个小问题,当在 6s 设备尺寸上时,我得到如下布局: 但是,我想知道将它们居中以使其成为两条线的最佳方法是什么,或者我应该将它们缩小一点以便可以放置其
我尝试在 UIImageView 中居中 CAShapeLayer 但没有成功,我找到了解决方案,将其(CAShapeLayer)添加到 UIVIew,然后将 UIVIew 添加到 ImageView
一直在从线性布局和相对布局切换,因为我想实现图像的居中。 显示图片:
* { margin:0; padding:0; } /** General Style Info **/ body { background: #003d4c; co
我目前正在尝试修改我在 Wordpress 上的 Royal Slider 插件 (http://dimsemenov.com/plugins/royal-slider/) 我的目标是将所有标题的文本
我已经坚持了一段时间,因此简化了我的要求。当您单击标记时,信息窗口将打开,当用户缩放时,我希望该标记位于 map 的中心。这不起作用,但我认为它很接近: function bindInfoWindow
/* Linked Styles */ body { padding: 0 !important;
这个问题在这里已经有了答案: How do I center floated elements? (12 个答案) 关闭 7 年前。
这个问题在这里已经有了答案: Is there an equivalent to background-size: cover and contain for image elements? (1
我试图让我的页眉停留在页面的中间,不管我在什么窗口大小。 我试过使用 Bootstrap。 StackOverflow 还有这个 CSS。 .section-t
我有一个 1600 像素宽的页面。主要区域虽然只有 900 像素宽。我有一个导航应该固定在页面的中心(它是)。我的问题是当我打开页面时,页面固定在左侧而不是在打开时居中。当用户访问该网站时,我需要做什
我正在尝试找到 View 的中心。对于非旋转 View ,该值是正确的,但对于旋转 View ,它不正确,因为中心 (0,0) 正在旋转。在缩放的情况下,即使缩放后宽度和高度也保持不变 我正在使用以下
预期效果是将 Kartennummer 和 Passwort 集中。 这怎么可能? 我为此使用了一个自定义类: import 'package:flutter/material.dart'; impo
我管理着许多 Maven 项目。他们中的大多数部署到我们的内部 maven 存储库。现在我想开始向 Maven Central 发布一个项目。到目前为止,我有一个父 POM,它指定了我们内部存储库的
我试图锚定两个进展,但我看不到获得预期结果的方法。 我希望左边的进度条固定在左边,右边的条固定在中心固定(如下图所示) (下图显示调整大小的表格) 我尝试将控件放在具有各种 anchor 的停靠面板上
我正在玩 Angular 模态 ui 对话框。我想知道有什么方法可以让它居中?我发现了一个类似的问题: Twitter Bootstrap - Center Modal Dialog 但无法使其工作,
是否可以将值标签放置在条形上,使它们位于条形的中心? 如果我设置条形 align: "center",则条形上的标签将关闭且不居中。 $(function() { var d
http://www.asp.net/signalr/overview/signalr-20/getting-started-with-signalr-20/tutorial-signalr-20-s
我是一名优秀的程序员,十分优秀!