From a1ac20d9cbe90b566bffe3ed39a6e07700c3248f Mon Sep 17 00:00:00 2001 From: wjc <1243177876@qq.com> Date: 星期一, 19 六月 2023 10:30:06 +0800 Subject: [PATCH] Merge branch 'wjc' --- app/src/main/java/com/hdl/photovoltaic/widget/ConfirmationDialog.java | 192 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 192 insertions(+), 0 deletions(-) diff --git a/app/src/main/java/com/hdl/photovoltaic/widget/ConfirmationDialog.java b/app/src/main/java/com/hdl/photovoltaic/widget/ConfirmationDialog.java new file mode 100644 index 0000000..8eca038 --- /dev/null +++ b/app/src/main/java/com/hdl/photovoltaic/widget/ConfirmationDialog.java @@ -0,0 +1,192 @@ +package com.hdl.photovoltaic.widget; + +import android.app.Dialog; +import android.content.Context; +import android.os.Bundle; +import android.text.TextUtils; +import android.view.View; + +import androidx.annotation.NonNull; + +import com.hdl.photovoltaic.R; +import com.hdl.photovoltaic.databinding.LoadingConfirmBinding; + +/** + * 纭妗� + */ +public class ConfirmationDialog extends Dialog { + public ConfirmationDialog(@NonNull Context context) { + super(context, R.style.Custom_AlertDialog); + this.mContext = context; + } + + private final Context mContext; + private onNoOnclickListener noOnclickListener;//鍙栨秷鎸夐挳琚偣鍑讳簡鐨勭洃鍚櫒 + private onYesOnclickListener yesOnclickListener;//纭畾鎸夐挳琚偣鍑讳簡鐨勭洃鍚櫒 + private LoadingConfirmBinding viewBinding; + private String titleStr, contentStr, yesStr, noStr; + + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + viewBinding = LoadingConfirmBinding.inflate(getLayoutInflater()); + setContentView(viewBinding.getRoot()); +// setCancelable(true);//绯荤粺鍚庨��鍙互鍙栨秷 + //绌虹櫧澶勪笉鑳藉彇娑堝姩鐢� + setCanceledOnTouchOutside(false); + //鍒濆鍖栫晫闈㈡帶浠� + initView(); + //鍒濆鍖栫晫闈㈡暟鎹� + initData(); + //鍒濆鍖栫晫闈㈡帶浠剁殑浜嬩欢 + initEvent(); + + } + + /** + * 鑷畾涔�"鏍囬"鏂囨湰 + * + * @param title 鍐呭 + */ + public void setTitle(String title) { + if (TextUtils.isEmpty(title)) { + return; + } + titleStr = title; + if (viewBinding != null) { + viewBinding.loadingConfirmationTitleTv.setText(titleStr); + } + + } + + /** + * 鑷畾涔�"纭"鏂囨湰 + * + * @param confirm 鍐呭 + */ + public void setConfirmation(String confirm) { + if (TextUtils.isEmpty(confirm)) { + return; + } + yesStr = confirm; + + + if (viewBinding != null) { + viewBinding.dialogConfirmTv.setText(yesStr); + } + + + } + + /** + * 鑷畾涔�"鍙栨秷"鏂囨湰 + * + * @param cancel 鍐呭 + */ + public void setCancel(String cancel) { + if (TextUtils.isEmpty(cancel)) { + return; + } + noStr = cancel; + if (viewBinding != null) { + viewBinding.dialogCancelTv.setText(noStr); + } + + } + + /** + * 鑷畾涔�"鍐呭"鏂囨湰 + * + * @param content 鍐呭 + */ + public void setContentText(String content) { + if (TextUtils.isEmpty(content)) { + return; + } + contentStr = content; + if (viewBinding != null) { + viewBinding.loadingConfirmationContentTv.setText(contentStr); + } + } + + private void initEvent() { + viewBinding.dialogCancelLy.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + if (noOnclickListener != null) { + noOnclickListener.Cancel(); + } + } + }); + viewBinding.dialogConfirmLy.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + if (yesOnclickListener != null) { + yesOnclickListener.Confirm(); + } + } + }); + + + } + + + /** + * 鍒濆鍖栫晫闈㈡帶浠剁殑鏄剧ず鏁版嵁 + */ + private void initData() { + //濡傛灉鐢ㄦ埛鑷畾浜唗itle鍜宮essage + if (!TextUtils.isEmpty(titleStr)) { + viewBinding.loadingConfirmationTitleTv.setText(titleStr); + } + if (!TextUtils.isEmpty(contentStr)) { + viewBinding.loadingConfirmationContentTv.setText(contentStr); + } + //濡傛灉璁剧疆鎸夐挳鏂囧瓧 + if (!TextUtils.isEmpty(yesStr)) { + viewBinding.dialogConfirmTv.setText(yesStr); + } + if (!TextUtils.isEmpty(noStr)) { + viewBinding.dialogCancelTv.setText(noStr); + } + } + + private void initView() { + + + } + + + /** + * 璁剧疆鍙栨秷鎸夐挳鐩戝惉 + * + * @param onNoOnclickListener - + */ + public void setNoOnclickListener(onNoOnclickListener onNoOnclickListener) { + if (onNoOnclickListener != null) { + this.noOnclickListener = onNoOnclickListener; + } + } + + /** + * 璁剧疆纭畾鎸夐挳鐩戝惉 + * + * @param yesOnclickListener - + */ + public void setYesOnclickListener(onYesOnclickListener yesOnclickListener) { + if (yesOnclickListener != null) { + this.yesOnclickListener = yesOnclickListener; + } + + } + + public interface onNoOnclickListener { + void Cancel(); + + } + + public interface onYesOnclickListener { + void Confirm(); + } +} -- Gitblit v1.8.0