Android 一個另類的顯示圓形圖片方式

剛在看自定義View的知識點時,突然想起來,如果CardView寬高相等,CardView設(shè)置圓角的半徑為寬高的一半時,不就是一個圓形嘛?!

Cardview配合ImageView顯示圓形圖

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,設(shè)置圓角半徑為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是否已經(jīng)獲得焦點,這個時候可以拿到控件的寬和高,是拿到控件寬高的一種辦法。


3.最后

以前都是使用一個自定義的CircleImageView,如果只是想要一個圓形圖,這種方法也可以考慮使用。不曉得這種方法有沒有人使用過。圖上添加文字,也蠻方便,感覺這種方式還比較簡單一些


補充

進入開發(fā)者選項,打開顯示GPU過度繪制

overdraw

上面是自定義一個CircleImagview,下面是CardView+ImageView

很明顯,CardView+ImageView繪制效率不如自定義CircleImagview,出現(xiàn)了一圈重繪的區(qū)域,整個圓形區(qū)域也是綠色,繪制了兩次。

若十分追求優(yōu)化就不要采用了,個人感覺這樣使用問題也不大 : )

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內(nèi)容