shape.xml中corners不生效是因为缺少solid或stroke;按钮按压态失效是selector状态未配对或顺序错误;圆角不一致应优先用android:radius;文字裁切需增大padding。

shape.xml 里 corners 不生效?检查 solid 或 stroke 是否缺失
Android 的 shape 要显示圆角,光写 不够——它只是定义了“想圆”,但没告诉系统“用什么颜色填”或“要不要边框”。没有 solid(填充色)或 stroke(描边),系统渲染时可能直接跳过整个 drawable,按钮就变成透明或默认背景。
-
solid必须存在才能让圆角有视觉表现,哪怕只是android:color="#00000000"(全透明) - 如果只要边框不要填充,用
stroke+corners即可,但不能三者全无 - 注意:API 21+ 支持
tint,但shape本身不支持动态变色,别指望靠属性改圆角色
按钮按压态失效?state_pressed 状态没配对或 selector 顺序错了
圆角背景要响应点击,得用 selector 包一层。常见错误是只写了一个 shape,或者 selector 里两个 item 的条件重叠(比如都漏写了 android:state_pressed="false"),导致系统永远匹配第一个、按压态不切换。
- 必须为每个状态单独定义一个
shape,例如bg_btn_normal.xml和bg_btn_pressed.xml -
selector中,更具体的 state(如android:state_pressed="true")建议放前面,否则会被通配的android:state_enabled="true"拦截 - 别在
selector里直接写corners,那是shape的职责;selector只负责“选哪个 shape”
圆角在不同 Android 版本上表现不一致?优先用 radius 而非 topLeftRadius 等独立属性
topLeftRadius 这类细分属性从 API 23 才完全稳定,低版本(尤其是 4.4)容易忽略或渲染错位。统一用 android:radius 最稳妥,所有角等半径——除非你明确需要不对称圆角且已兼容测试过。
- 如果真要差异化圆角,用
android:topLeftRadius等时,务必补上android:bottomRightRadius等其余三个,否则未声明的角会回退到 0 - XML 中单位必须是
dp,写px或不带单位会导致高密度屏上圆角过小甚至不可见 - 注意:MaterialButton 默认用
app:cornerRadius,和shape无关,二者别混用
按钮文字被圆角裁切?不是 shape 问题,是 padding 没留够
shape.xml 只管背景绘制区域,不控制内容布局。文字被切,99% 是因为按钮的 padding 太小,尤其用了大圆角(比如 16dp)却只设 padding="4dp",文字直接顶到弧线边缘。
- 圆角半径每增加
4dp,建议padding至少同步加2dp,保证文字内边距安全 - 用
backgroundTint替代background时,shape里的solid颜色会被覆盖,但 padding 不受影响——别误以为是背景样式导致裁切 - 调试时临时把
background换成纯色ColorDrawable,确认是否真是 shape 渲染问题
真正麻烦的是嵌套在 ConstraintLayout 里又被设置了 app:layout_constrainedWidth="true" 的按钮——这时候圆角和约束宽度会相互挤压,得手动调 minWidth 和 padding 才能稳住。










