<com.google.android.material.imageview.ShapeableImageView
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:layout_margin=“10dp”
android:src=“@mipmap/ic_avatar”
app:shapeAppearance=“@style/RoundedStyle” />
-
没有直接设置圆角的属性,需要用到
app:shapeAppearance
,后面会说 -
cornerFamily 角的处理方式,rounded圆角,cut裁剪
-
cornerSize 圆角大小
圆
<com.google.android.material.imageview.ShapeableImageView
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:layout_margin=“10dp”
android:src=“@mipmap/ic_avatar”
app:shapeAppearance=“@style/CircleStyle” />
- 圆角的大小可以用百分比,也可以自己计算,比如宽高100dp,圆角50dp
描边
<com.google.android.material.imageview.ShapeableImageView
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:layout_margin=“10dp”
android:padding=“2dp”
android:src=“@mipmap/ic_avatar”
app:shapeAppearance=“@style/CircleStyle”
app:strokeColor=“@color/red”
app:strokeWidth=“4dp” />
-
app:strokeColor 描边颜色
-
app:strokeWidth 描边宽度
-
注意这里padding的数值是描边宽度的一半,后面会说
切角
<com.google.android.material.imageview.ShapeableImageView
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:layout_margin=“10dp”
android:padding=“2dp”
android:src=“@mipmap/ic_avatar”
app:shapeAppearance=“@style/CutStyle”
app:strokeColor=“@color/red”
app:strokeWidth=“4dp” />
- cornerFamily:cut 处理模式变为裁剪
菱形
<com.google.android.material.imageview.ShapeableImageView
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:layout_margin=“10dp”
android:padding=“2dp”
android:src=“@mipmap/ic_avatar”
app:shapeAppearance=“@style/RhombusStyle”
app:strokeColor=“@color/red”
app:strokeWidth=“4dp” />
- 同样,裁剪模式下圆角大小也可以计算
叶子
<com.google.android.material.imageview.ShapeableImageView
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:layout_margin=“10dp”
android:padding=“2dp”
android:src=“@mipmap/ic_avatar”
app:shapeAppearance=“@style/LeafStyle”
app:strokeColor=“@color/red”
app:strokeWidth=“4dp” />
-
cornerSizeTopLeft 左上圆角
-
cornerSizeBottomRight 右下圆角
-
以此类推,左上、左下、右上、右下等
半圆
<com.google.android.material.imageview.ShapeableImageView
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:layout_margin=“10dp”
android:padding=“2dp”
android:src=“@mipmap/ic_avatar”
app:shapeAppearance=“@style/SemicircleStyle”
app:strokeColor=“@color/red”
app:strokeWidth=“4dp” />
六边形
<com.google.android.material.imageview.ShapeableImageView
android:layout_width=“wrap_content”
android:layout_height=“50dp”
android:layout_margin=“10dp”
android:padding=“2dp”
android:scaleType=“centerCrop”
android:src=“@mipmap/ic_avatar”
app:shapeAppearance=“@style/HexagonStyle”
app:strokeColor=“@color/red”
app:strokeWidth=“4dp” />
author:yechaoa
=============================================================
关于xml属性,我也做了一个整理,属性不多,只有4个
| 属性 | 描述 |
| — | — |
| strokeWidth | 描边宽度 |
| strokeColor | 描边颜色 |
| shapeAppearance | 外观样式 |
| shapeAppearanceOverlay | 同上,叠加层 |
=============================================================
前面为了整体的排版,埋了几个伏笔,下面来一一解答。
会涉及到源码,但是经过去繁从简,看起来也非常轻松的。
shapeAppearance
Shape appearance overlay style reference for ShapeableImageView.
ShapeableImageView的形状外观覆盖样式参考。
前面可以看到我们设置圆角其实是用的style
,那为什么不直接用attrs
呢,不是更加直观方便吗,带着疑问来看看源码是怎么处理的。
直接看ShapeableImageView
的次构造方法:
public class ShapeableImageView extends AppCompatImageView implements Shapeable {
…
public ShapeableImageView(Context context, @Nullable AttributeSet attrs, int defStyle) {
super(wrap(context, attrs, defStyle, DEF_STYLE_RES), attrs, defStyle);
// Ensure we are using the correctly themed context rather than the context that was passed in.
context = getContext();
clearPaint = new Paint();
clearPaint.setAntiAlias(true);
clearPaint.setColor(Color.WHITE);
clearPaint.setXfermode(new PorterDuffXfermode(Mode.DST_OUT));
destination = new RectF();
maskRect = new RectF();
maskPath = new Path();
TypedArray attributes =
context.obtainStyledAttributes(
attrs, R.styleable.ShapeableImageView, defStyle, DEF_STYLE_RES);
strokeColor =
MaterialResources.getColorStateList(
context, attributes, R.styleable.ShapeableImageView_strokeColor);
strokeWidth = attributes.getDimensionPixelSize(R.styleable.ShapeableImageView_strokeWidth, 0);
borderPaint = new Paint();
borderPaint.setStyle(Style.STROKE);
borderPaint.setAntiAlias(true);
shapeAppearanceModel =
ShapeAppearanceModel.builder(context, attrs, defStyle, DEF_STYLE_RES).build();
shadowDrawable = new MaterialShapeDrawable(shapeAppearanceModel);
if (VERSION.SDK_INT >= VERSION_CODES.LOLLIPOP) {
setOutlineProvider(new OutlineProvider());
}
}
}
常规操作,获取自定义属性。
关键的两行代码:
shapeAppearanceModel = ShapeAppearanceModel.builder(context, attrs, defStyle, DEF_STYLE_RES).build();
shadowDrawable = new MaterialShapeDrawable(shapeAppearanceModel);
也就是说我们给shapeAppearance
设置的style,并不是ShapeableImageView
自己来处理的,而是由ShapeAppearanceModel
来构建的,然后又交给MaterialShapeDrawable
来绘制的。
ShapeAppearanceModel
这个类就厉害了,有点像Flutter
中的Decoration,可以构建出花里胡哨的效果。
来看ShapeAppearanceModel
部分源码:
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
学习福利
【Android 详细知识点思维脑图(技能树)】
其实Android开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。
虽然 Android 没有前几年火热了,已经过去了会四大组件就能找到高薪职位的时代了。这只能说明 Android 中级以下的岗位饱和了,现在高级工程师还是比较缺少的,很多高级职位给的薪资真的特别高(钱多也不一定能找到合适的),所以努力让自己成为高级工程师才是最重要的。
这里附上上述的面试题相关的几十套字节跳动,京东,小米,腾讯、头条、阿里、美团等公司19年的面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。
由于篇幅有限,这里以图片的形式给大家展示一小部分。
详细整理在GitHub可以见;
网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。
.(img-7wFkMUKM-1711291616187)]
其实Android开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。
虽然 Android 没有前几年火热了,已经过去了会四大组件就能找到高薪职位的时代了。这只能说明 Android 中级以下的岗位饱和了,现在高级工程师还是比较缺少的,很多高级职位给的薪资真的特别高(钱多也不一定能找到合适的),所以努力让自己成为高级工程师才是最重要的。
这里附上上述的面试题相关的几十套字节跳动,京东,小米,腾讯、头条、阿里、美团等公司19年的面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。
由于篇幅有限,这里以图片的形式给大家展示一小部分。
[外链图片转存中…(img-wLzoUgOq-1711291616187)]
详细整理在GitHub可以见;
网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。