刚在看自定义View
的知识点时,忽然想起来,若是CardView
宽高相等,CardView
设置圆角的半径为宽高的一半时,不就是一个圆形嘛?!android
Cardview配合ImageView显示圆形图app
<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
ide
使用的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
是否已经得到焦点,这个时候能够拿到控件的宽和高,是拿到控件宽高的一种办法。优化
之前都是使用一个自定义的CircleImageView
,若是只是想要一个圆形图,这种方法也能够考虑使用。不晓得这种方法有没有人使用过。图上添加文字,也蛮方便,感受这种方式还比较简单一些this
进入开发者选项,打开显示GPU过分绘制url
overdrawcode
上面是自定义一个CircleImagview
,下面是CardView+ImageView
继承
很明显,CardView+ImageView
绘制效率不如自定义CircleImagview
,出现了一圈重绘的区域,整个圆形区域也是绿色,绘制了两次。图片
若十分追求优化就不要采用了,我的感受这样使用问题也不大 : )