一 问题现象
可以很明显看到横线和竖线的差异,高度指定为1px,竖线的宽度也是1px,对应的drawable都为同一个:
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle">
<solid android:color="#EEEEEE" />
<stroke android:color="#EEEEEE"/>
</shape>
使用shape="line"也是一样的效果。
二 问题解决
最终发现是CardView的属性Elevation的原因,上述图中的竖线是存在于两个CardView之间,设置为0dp即可。
app:cardElevation="0dp"
三 问题原因
通过日志输出可以发现:
默认cardElevation值=7.0
设置cardElevation=0后值=0.0
默认情况下cardElevation是有值的,为7.0。追踪源码设置可以发现CardView的样式默认配置:
<style name="Base.CardView" parent="android:Widget">
<item name="cardCornerRadius">@dimen/cardview_default_radius</item>
<item name="cardElevation">@dimen/cardview_default_elevation</item>
<item name="cardMaxElevation">@dimen/cardview_default_elevation</item>
<item name="cardUseCompatPadding">false</item>
<item name="cardPreventCornerOverlap">true</item>
</style>
cardview_default_evevation = 2dp,因为 displayMetrics.density = 3.5 ,所以最终是7.0。因为此宽度更宽,所以导致了视觉上的色值差。
四 总结
这类问题一般解决方法很简单,但是出现的事情较难定位。在寻找原因的过程中首先要相信系统的运行是正常的,先去除极端情况的可能性从数据追根溯源开始,这样才能减少不必要因素方面的干扰。
网友评论