前言:隨著用戶體驗(yàn)的不斷的加深,良好的UI視覺效果也必不可少,以前方方正正的對(duì)話框樣式在APP已不復(fù)存在,取而代之的是帶有圓角效果的Dialog,之前設(shè)置對(duì)畫框的圓角效果都是通過drawable/shape屬性來完成,隨著Google API的不斷更新,API 21(Android 5.0)添加了新的控件CardView,這使得圓角的實(shí)現(xiàn)更加方便快捷。
創(chuàng)新互聯(lián)建站是專業(yè)的定南網(wǎng)站建設(shè)公司,定南接單;提供成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè),網(wǎng)頁設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(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.布局引用
1.cardCornerRadius屬性:設(shè)置圓角的弧度大小,這里設(shè)置的為10dp
2.CardView還有padding、cardUseCompatPadding(內(nèi)邊距)、background等屬性
3.CardView繼承自FrameLayout,使用時(shí)可以重新嵌套布局
2.代碼實(shí)現(xiàn)
/** * 展示對(duì)話框 */ 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("退出成功,請(qǐng)重新登錄"); 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)對(duì)話框的圓角效果更加的方便,不用編寫shape屬性,當(dāng)標(biāo)題欄需要背景色時(shí),也無需考慮設(shè)置標(biāo)題欄的shape(不使用CardView時(shí),如果不使用shape設(shè)置背景色,會(huì)導(dǎo)致左上和右上不會(huì)變成圓角)。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。