CardView cardElevation 在 CardView 内绘制随机正方形
Posted
技术标签:
【中文标题】CardView cardElevation 在 CardView 内绘制随机正方形【英文标题】:CardView cardElevation draws random square inside of CardView 【发布时间】:2021-08-21 04:18:10 【问题描述】:一个简单的问题,我使用 CardView
为 Button 添加高度,但是在分配 cardElevation
时,CardView
在自身内部绘制了一个框,我尝试切换高度和其他属性,我可以最小化通过增加cardElevation
来影响它的效果,但这不是解决方案。
这是来自 XML 的 CardView
。
<androidx.cardview.widget.CardView
android:layout_
android:layout_
app:cardElevation="5sp"
android:layout_gravity="end"
android:layout_marginTop="60sp"
android:layout_marginRight="12sp"
android:layout_marginEnd="12sp"
app:cardBackgroundColor="#97FFFFFF"></androidx.cardview.widget.CardView>
应用程序中的CardView
。 (右上角的方框)
整个XML文件,最后一个CardView
是图片上的那个。
<?xml version="1.0" encoding="utf-8"?>
<com.flipboard.bottomsheet.BottomSheetLayout
android:id="@+id/bottomsheet"
android:layout_
android:layout_
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<fragment xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/map"
android:name="com.google.android.gms.maps.SupportMapFragment"
android:layout_
android:layout_
tools:context=".ui.map.MapFragment">
<LinearLayout
android:layout_
android:layout_
android:orientation="vertical">
<androidx.cardview.widget.CardView
android:layout_
android:layout_
app:cardElevation="20dp"
android:layout_gravity="end"
android:layout_marginTop="60dp"
android:layout_marginRight="12dp"
android:layout_marginEnd="12dp"
app:cardBackgroundColor="#97FFFFFF">
<ImageButton
android:layout_
android:layout_
android:padding="1dp"
android:src="@drawable/ic_baseline_refresh_24"
android:background="#00FFFFFF"
android:elevation="10dp"
android:id="@+id/btn_reset_map"/>
</androidx.cardview.widget.CardView>
<androidx.cardview.widget.CardView
android:layout_
android:layout_
app:cardElevation="20dp"
android:layout_gravity="end"
android:layout_marginTop="10dp"
android:layout_marginRight="12dp"
android:layout_marginEnd="12dp"
app:cardBackgroundColor="#97FFFFFF">
<ImageButton
android:layout_
android:layout_
android:padding="1dp"
android:src="@drawable/ic_baseline_layers_24"
android:background="#00FFFFFF"
android:elevation="10dp"
android:id="@+id/btn_layer_map"/>
</androidx.cardview.widget.CardView>
<androidx.cardview.widget.CardView
android:layout_
android:layout_
app:cardElevation="5dp"
android:layout_gravity="end"
android:layout_marginTop="40dp"
android:layout_marginRight="12dp"
android:layout_marginEnd="12dp"
app:cardBackgroundColor="#97FFFFFF"></androidx.cardview.widget.CardView>
</LinearLayout>
</fragment>
</com.flipboard.bottomsheet.BottomSheetLayout>
【问题讨论】:
为什么你的单位都在sp?您是否尝试将它们更改为 dp? 我一直在使用 sp 没有什么特别的原因,现在我读到 sp 用于字体大小,而 dp 用于其他所有内容。现在也用 dp 尝试过,没有任何改变,正方形仍然存在。 我想知道您的 xml 是如何构造的。 cardview的父母是什么?是否可以共享该特定卡片视图所在布局的所有代码? 我在问题末尾添加了xml文件,最后一个CardView是图像上显示的那个。 为什么要使用片段标签作为视图组? 【参考方案1】:您可以通过编程将CardView
背景颜色设置为与app:cardBackgroundColor
设置的颜色相同的颜色
CardView cardview = findViewById(R.id.cardview);
cardview.setBackgroundColor(ContextCompat.getColor(this, R.color.cardview_color));
并在colors.xml中创建这个颜色
<color name="cardview_color">#97FFFFFF</color>
并将这个id添加到xml中:
<androidx.cardview.widget.CardView
android:id="@+id/cardview"
....
注意:由于某种原因,android:background="#97FFFFFF"
不起作用
【讨论】:
CardView 问题中的正方形现在已修复,尽管它删除了 cardCornerRadius,我现在似乎无法添加它。另外,如果我有更多的 CardViews,每个 CardViews 是否应该以相同的方式设置背景颜色? @EdwardAarma 你说得对……让我想想 @EdwardAarma 我猜你需要删除app:cardBackgroundColor
颜色的不透明度,这就是你看到内部正方形的原因.. 所以你可以将它设置为app:cardBackgroundColor="#EDEDED"
这将使它不透明..并使用答案中提到的setBackgroundColor
取消以上是关于CardView cardElevation 在 CardView 内绘制随机正方形的主要内容,如果未能解决你的问题,请参考以下文章
xml CardView继承自FrameLayout并提供了默认的elevation和圆角,使得卡在不同的平台间保持一致。你也可以通过cardElevation和cardCornerRadius属性自
xml CardView继承自FrameLayout并提供了默认的elevation和圆角,使得卡在不同的平台间保持一致。你也可以通过cardElevation和cardCornerRadius属性自
xml CardView继承自FrameLayout并提供了默认的elevation和圆角,使得卡在不同的平台间保持一致。你也可以通过cardElevation和cardCornerRadius属性自