ShapeImageView-图形裁剪ImageView

ShapeImageView

ICON

图形裁剪ImageView,API 21 及以上 使用 setOutlineProvider 方式实现,支持动态图;以下使用 BitmapShader 方式实现。
支持固定高宽缩放比缩放,支持前景Drawable,支持ImageView的所有ScaleType,且API 21具备更高性能。

预览

Screenshots

要求

minSdkVersion 4

链接

使用

  • 基本布局
<am.widget.shapeimageview.ShapeImageView
    android:id="@+id/siv_image_c"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_margin="5dp"
    android:layout_weight="1"
    android:clickable="true"
    android:scaleType="centerCrop"
    android:src="@drawable/bg_welcome"
    app:sivBorderColor="@color/colorAccent"
    app:sivBorderWidth="2dp"
    app:sivForeground="@drawable/bg_common_press_dark"
    app:sivHeightScale="1"
    app:sivScaleTarget="height"
    app:sivShape="Circle"
    app:sivWidthScale="1" />
  • 基本代码
ShapeImageView sivCircle = (ShapeImageView) findViewById(id);
sivCircle.setBorderColor(color);
sivCircle.setFixedSize(width, height);
sivCircle.setBorderWidth(border);
sivCircle.setImageShape(new RoundRectImageShape(radius));

注意

  • 基本可以通过布局实现基础代码
  • 布局sivRoundRectRadius属性只在sivShape="RoundRect"时有效
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,860评论 25 709
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,262评论 4 61
  • 你有拖延症吗?拖延症者的内心是怎么想的?他们的大脑是如何运作的? 视频较长,14分钟,如果没耐心可以直接看后面图文...
    万金油刘二蛋儿阅读 874评论 0 0
  • 朋友,这个概念我一直都不陌生,因为我有这样一群朋友,我已经不记得我们是什么时候相识相知,但只记得相互调侃吐槽。我很...
    Ta_nG阅读 881评论 0 1
  • 文/阿琦不是琪 时间在青春兵荒马乱中一寸寸流逝 每天忙忙碌碌 碌碌无为 与柴米油盐斤斤计较 在世界上的不同城市中穿...
    你夢阅读 691评论 0 1