当前位置: 移动技术网 > 移动技术>移动开发>Android > 分享一个Android设置圆形图片的特别方法

分享一个Android设置圆形图片的特别方法

2019年07月24日  | 移动技术网移动技术  | 我要评论

cardview配合imageview显示圆形图效果图:

刚在看自定义view的知识点时,突然想起来,如果cardview宽高相等,cardview设置圆角的半径为宽高的一半时,不就是一个圆形嘛?!

1.布局文件

<android.support.v7.widget.cardview
 android:id="@+id/cv_img_activity"
 android:layout_width="200dp"
 android:layout_height="200dp"
 app:cardcornerradius="100dp"
 app:cardelevation="10dp"
 app:cardpreventcorneroverlap="true">

 <imageview
  android:id="@+id/iv_cv_img_activity"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:scaletype="centercrop"/>
 <textview
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:textcolor="@color/coloraccent"
  android:textsize="30sp"
  android:layout_gravity="bottom|center_horizontal"
  android:text="圆"/>
</android.support.v7.widget.cardview>

cardview继承的framlayout。宽和高都为200dp,设置圆角半径为100dp

2.aciticy中代码

使用的glide进行图片加载

public class imgactivity extends appcompatactivity {
 private static final string url = "https://timgsa.baidu.com/timg?image&quality=80&size=b10000_10000&sec=1473082549776&di=cb9749bd976beb119da065ee56ebbc60&imgtype=jpg&src=http%3a%2f%2fstatic.oneplus.cn%2fdata%2fattachment%2fforum%2f201410%2f18%2f111437v9ll9869qqmq76n7.jpg";
 private cardview cardview;
 private imageview iv_cv;
 @override
 protected void oncreate(bundle savedinstancestate) {
  super.oncreate(savedinstancestate);
  setcontentview(r.layout.activity_img);
  init();
 }

 private void init() {
  cardview = (cardview) findviewbyid(r.id.cv_img_activity);
  iv_cv = (imageview) findviewbyid(r.id.iv_cv_img_activity);
 }

 @override
 public void onwindowfocuschanged(boolean hasfocus) {
  super.onwindowfocuschanged(hasfocus);
  if (hasfocus){
    glide.with(imgactivity.this).load(url).override(cardview.getwidth(),cardview.getheight()).into(iv_cv);
  }
 }

}

onwindowfocuschanged(boolean hasfocus)这个方法可以用来判断activity是否已经获得焦点,这个时候可以拿到控件的宽和高,是拿到控件宽高的一种办法。

3.总结

以前都是使用一个自定义的circleimageview,如果只是想要一个圆形图,这种方法也可以考虑使用。不晓得这种方法有没有人使用过。图上添加文字,也蛮方便。感觉这种方式还比较简单一些。以上就是这篇文章的全部内容,希望对大家的开发能有所帮助。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网