Androidの円形の画像を設定するための特別な方法を共有します。
CardviewはImageViewに協力して円形図の効果図を表示します。
カスタム
1.レイアウトファイル
2.Aciticyコード
使用するGlideで画像のロードを行います。
3.まとめ
以前は一つのカスタム
カスタム
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
。幅と高さは200 dpで、円角半径は100 dpに設定します。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
を使用していましたが、ただの円形図が欲しいなら、この方法も考えられます。この方法は誰が使ったか分かりません。絵に文字を入れるのも便利です。この方法はもっと簡単だと思います。以上がこの文章の全部です。皆さんの開発に役に立ちますように。