前言:隨著用戶體驗(yàn)的不斷的加深,良好的UI視覺效果也必不可少,以前方方正正的對話框樣式在APP已不復(fù)存在,取而代之的是帶有圓角效果的Dialog,之前設(shè)置對畫框的圓角效果都是通過drawable/shape屬性來完成,隨著Google API的不斷更新,API 21(Android 5.0)添加了新的控件CardView,這使得圓角的實(shí)現(xiàn)更加方便快捷。
創(chuàng)新互聯(lián)建站是專業(yè)的定南網(wǎng)站建設(shè)公司,定南接單;提供成都網(wǎng)站設(shè)計、網(wǎng)站建設(shè),網(wǎng)頁設(shè)計,網(wǎng)站設(shè)計,建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行定南網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來合作!
效果圖:

導(dǎo)入CardView依賴(API 21新控件)
implementation 'com.android.support:cardview-v7:26.1.0'
1.布局引用
<android.support.v7.widget.CardView
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:cardCornerRadius="@dimen/dp_10">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<TextView
android:id="@+id/tv_title"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/colorTabClick"
android:gravity="center"
android:padding="@dimen/dp_10"
android:text="溫馨提示:確定修改維護(hù)詳情信息?"
android:textColor="@color/bg_mainWhite"
android:textSize="@dimen/dp_16" />
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="@color/bg_line" />
<TextView
android:id="@+id/tv_des"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="@dimen/dp_10"
android:gravity="top"
/>
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="@color/bg_line" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="50dp"
android:orientation="horizontal">
<TextView
android:id="@+id/tv_cancel"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1.0"
android:gravity="center"
android:text="取消"
android:textSize="@dimen/dp_16" />
<View
android:layout_width="1dp"
android:layout_height="match_parent"
android:background="@color/bg_line" />
<TextView
android:id="@+id/tv_confirm"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="1.0"
android:gravity="center"
android:text="確定"
android:textSize="@dimen/dp_16" />
</LinearLayout>
</LinearLayout>
</android.support.v7.widget.CardView>1.cardCornerRadius屬性:設(shè)置圓角的弧度大小,這里設(shè)置的為10dp
2.CardView還有padding、cardUseCompatPadding(內(nèi)邊距)、background等屬性
3.CardView繼承自FrameLayout,使用時可以重新嵌套布局
2.代碼實(shí)現(xiàn)
/**
* 展示對話框
*/
private void showDialog(String title) {
//初始化布局文件
View dialogView = View.inflate(mContext, R.layout.dialog_layout_test, null);
//標(biāo)題
TextView tvTitle = (TextView) dialogView.findViewById(R.id.tv_title);
//確定按鈕
TextView tvConfirm = (TextView) dialogView.findViewById(R.id.tv_confirm);
//取消按鈕
TextView tvCancel = (TextView) dialogView.findViewById(R.id.tv_cancel);
//描述信息
TextView tvDes= (TextView) dialogView.findViewById(R.id.tv_des);
//設(shè)置標(biāo)題及描述信息
tvTitle.setText(title);
tvDes.setText("退出當(dāng)前登錄后將要重新登錄!");
//確定和取消按鈕監(jiān)聽事件
tvConfirm.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent(mContext,LoginActivity.class);
startActivity(intent);
UIUtil.toast("退出成功,請重新登錄");
getActivity().finish();
mDialog.dismiss();
}
});
tvCancel.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
mDialog.dismiss();
}
});
mMessageBuilder = new AlertDialog.Builder(mContext);
mDialog = mMessageBuilder.create();
//設(shè)置背景色為透明,解決設(shè)置圓角后有白色直角的問題
Window window=mDialog.getWindow();
window.setBackgroundDrawable(new ColorDrawable(Color.TRANSPARENT));
mDialog.setView(dialogView);
mDialog.setCanceledOnTouchOutside(false);//點(diǎn)擊屏幕不消失
mDialog.show();
//設(shè)置參數(shù)必須在show之后,不然沒有效果
WindowManager.LayoutParams params = mDialog.getWindow().getAttributes();
mDialog.getWindow().setAttributes(params);
}使用的是V7包的AlertDialog實(shí)現(xiàn)的,當(dāng)然也可以使用Dialog實(shí)現(xiàn)。
總結(jié):CardView實(shí)現(xiàn)對話框的圓角效果更加的方便,不用編寫shape屬性,當(dāng)標(biāo)題欄需要背景色時,也無需考慮設(shè)置標(biāo)題欄的shape(不使用CardView時,如果不使用shape設(shè)置背景色,會導(dǎo)致左上和右上不會變成圓角)。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。
當(dāng)前文章:Android使用CardView實(shí)現(xiàn)圓角對話框
標(biāo)題路徑:http://www.chinadenli.net/article4/gjopoe.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供關(guān)鍵詞優(yōu)化、移動網(wǎng)站建設(shè)、小程序開發(fā)、網(wǎng)站維護(hù)、微信公眾號、外貿(mào)網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)