在Android开发中,圆角设计十分常见,那么实现边框圆角有几种形式呢?
文章目录
- 设置圆角边框样式
- 使用ClipToOutline进行裁切
- 最后
设置圆角边框样式
常见的方式是在drawable文件夹下设置一个xml文件的边框样式,比如
<shape android:shape="rectangle"><solid android:color="@color/grid_item_bg_normal" /><corners android:radius="35px" /></shape>
其实这样的操作是改变背景,同时会导致内容穿透的效果。
使用ClipToOutline进行裁切
此方法是Android5.0之后提供,具体操作如下
private final ViewOutlineProvider viewOutlineProvider = new ViewOutlineProvider() {@Overridepublic void getOutline(View view, Outline outline) {Rect selfRect = new Rect(0, 0, view.getWidth(), view.getHeight());outline.setRoundRect(selfRect, 20);}};ivQrCode.setOutlineProvider(viewOutlineProvider);
ivQrCode.setClipToOutline(true);
先声明ViewOutlineProvider此类,自定义实现需要设置的属性,该类是专门用来处理阴影和裁切的,然后在应用裁切即可。
最后
Outline相对于shape来说,是真正的实现边缘裁切的,shape其实只是设置背景而已,它的view的范围还是那个正方形的范围。最明显的表现于,shape如果内容填满布局,会看到内容超出圆角,而Outline不会。当然如果你shape配合padding的话肯定也不会出现这种情况。
参考
Android边框裁切的正确姿势实现示例