Как вызвать removeView () в диалоговом окне номер один, чтобы отобразить номер диалогового окна 2

Junta спросил: 28 апреля 2018 в 08:20 в: java

Я работаю с приложением, которое связано с диалоговыми окнами, которые должны появляться один за другим. Я имею в виду, что, когда я нажимаю на положительную кнопку первого диалогового окна, он должен вызвать еще одно второе диалоговое окно. Проблема, с которой я столкнулась, - это второе диалоговое окно, второе не будет всплывать, и это приведет к сбою приложения.

Я получаю сообщение об ошибке "java.lang.IllegalStateException: указанный дочерний элемент уже имеет родителя. Сначала вы должны вызвать removeView () для родительского родителя."

public static void showBusinessOrPrivateStartDialog(final Context context, final CallLogEntry call)
       {
          if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M)
          {
             // If new version of android, then check permission
             if (!Settings.canDrawOverlays(context))
             {
                Log.e(TAG, "Permission Denied: Draw overlays (for popup)");
                return;
             }
          }          LayoutInflater inflater = (LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
          //View view = inflater.inflate(R.layout.dialog_call_type, null);          AlertDialog.Builder builder = new AlertDialog.Builder(context, Theme_Material_Light_Dialog_Alert);          builder.setTitle("Was this a private or a business call?");
          builder.setMessage("Please select a call type");
          builder.setIcon(R.drawable.ic_deviceinsight);
          builder.setCancelable(true);
          //builder.setView(view);          builder.setOnCancelListener(new DialogInterface.OnCancelListener() {
             @Override
             public void onCancel(DialogInterface dialog) {
                // Occurs when user cancels the dialog, or clicks somewhere else in the screen or presses the back button
                Log.i(TAG, "cancelled");                saveCallEntry(context, call, CLASSIFICATION_TYPE_BUSINESS, "", true, "");
             }
          });          builder.setPositiveButton("Business", new DialogInterface.OnClickListener() {
             public void onClick(DialogInterface dialog, int which) {
                CallClassification.showBusinessCallPopup(context, call);
             }
          });
          builder.setNegativeButton("Private", new DialogInterface.OnClickListener() {
             public void onClick(DialogInterface dialog, int which) {
                saveCallEntry(context, call, CLASSIFICATION_TYPE_PRIVATE, "", false, "");
             }
          });          AlertDialog dialog = builder.create();
          // Rather use something like TYPE_SYSTEM_ALERT, if possible.
          dialog.getWindow().setType(WindowManager.LayoutParams.TYPE_SYSTEM_ALERT); // TYPE_SYSTEM_ERROR
          dialog.show();
       }

Это второй метод для второго диалогового окна, и мое приложение вылетает из диалога dialog.show

public static void showBusinessCallPopup(final Context context, final CallLogEntry call)
       {
          // NEW NRF
          if (AppPreferences.isNRF(context)) {
             CallItem callItem = saveCallEntry(context, call, CLASSIFICATION_TYPE_BUSINESS, "", false, "");             // SHOW NEW FORM
             Intent intent = new Intent(context, CallClassificationFormActivity.class);
             intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
             EventBus.getDefault().postSticky(callItem);
             context.startActivity(intent);             return;
          }          if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M)
          {
             // If new version of android, then check permission
             if (!Settings.canDrawOverlays(context))
             {
                Log.e(TAG, "Permission Denied: Draw overlays (for popup)");
                return;
             }
          }          LayoutInflater inflater = (LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
          View view = inflater.inflate(R.layout.dialog_call_details, null);          AlertDialog.Builder builder = new AlertDialog.Builder(context, Theme_Material_Light_Dialog_Alert);          String toOrFrom = call.Type == CallLog.Calls.INCOMING_TYPE ? "from" : "to";          //builder.setTitle("Business call");
          builder.setCustomTitle(view);
          //builder.setMessage("Please enter reference details for the call " + toOrFrom + " " + call.Number);
          //builder.setIcon(R.drawable.ic_deviceinsight);
          builder.setCancelable(true);
          builder.setView(view);          final EditText etReference = (EditText)view.findViewById(R.id.etReference);
          final EditText etComment = (EditText)view.findViewById(R.id.etComment);          builder.setPositiveButton("Confirm", new DialogInterface.OnClickListener() {
             public void onClick(DialogInterface dialog, int which) {                String reference = etReference.getText().toString();
                String comment = etComment.getText().toString();                saveCallEntry(context, call, CLASSIFICATION_TYPE_BUSINESS, reference, false, comment);
             }
          });
          builder.setOnCancelListener(new DialogInterface.OnCancelListener() {
             @Override
             public void onCancel(DialogInterface dialog) {
                Log.i(TAG, "cancelled");
             }
          });          AlertDialog dialog = builder.create();
          dialog.getWindow().setType(WindowManager.LayoutParams.TYPE_SYSTEM_ALERT); // TYPE_SYSTEM_ERROR
          dialog.show();
       }

и вот мой xml. Я включил xml в этот пост, потому что я где-то читал, что способ определения высоты и ширины моих текстовых полей является причиной проблемы.

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              xmlns:app="http://schemas.android.com/apk/res-auto"
              xmlns:tools="http://schemas.android.com/tools"
              android:id="@+id/layout"
              android:layout_width="match_parent"
              android:layout_height="wrap_content"
              android:orientation="vertical"
              android:paddingLeft="5dp"
              android:paddingRight="5dp"
              android:paddingTop="5dp"
              tools:context=".calls.CallClassification">  <TextView
         android:id="@+id/tvMessage"
         android:layout_width="match_parent"
         android:layout_height="wrap_content"
         android:layout_marginBottom="5dp"
         android:padding="5dp"
         android:text="Please enter reference details for the call "
         android:textColor="@color/colorPrimaryDark"
         android:textSize="16sp"/>   <AutoCompleteTextView
         android:id="@+id/etReference"
         android:layout_width="match_parent"
         android:layout_height="wrap_content"
         android:backgroundTint="@color/colorAccent"
         android:hint="Matter Code *"
         android:imeOptions="actionNext"
         android:inputType="text"
         android:maxLength="255"
         android:text=""
         android:textColor="@color/colorPrimary"
         android:textColorHint="@color/colorTextHint"
         android:textSize="14sp"/>   <CheckBox
         android:id="@+id/cbBillable"
         android:layout_width="match_parent"
         android:layout_height="wrap_content"
         android:layout_marginLeft="5dp"
         android:layout_marginRight="5dp"
         android:button="@null"
         android:buttonTint="@color/colorAccent"
         android:checked="true"
         android:drawableRight="?android:attr/listChoiceIndicatorMultiple"
         android:paddingBottom="3dp"
         android:paddingTop="3dp"
         android:text="Billable"
         android:textColor="@color/colorPrimaryDark"
         android:textSize="14sp"/>   <EditText
         android:id="@+id/etComment"
         android:layout_width="match_parent"
         android:layout_height="wrap_content"
         android:backgroundTint="@color/colorAccent"
         android:hint="Enter comment"
         android:imeOptions="actionDone"
         android:inputType="text"
         android:lines="1"
         android:maxLength="1000"
         android:maxLines="4"
         android:minLines="1"
         android:text=""
         android:textColor="@color/colorPrimary"
         android:textColorHint="@color/colorTextHint"
         android:textSize="14sp"/>   <LinearLayout
         android:layout_width="match_parent"
         android:layout_height="match_parent"
         android:orientation="horizontal">      <Button
            android:id="@+id/bCancel"
            style="@style/Widget.AppCompat.Button.Borderless.Colored"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="Cancel"/>      <Button
            android:id="@+id/bOk"
            style="@style/Widget.AppCompat.Button.Borderless.Colored"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="GO"/>
   </LinearLayout></LinearLayout>

3 ответа

Есть решение
Yashaswi Bharadwaj ответил: 29 апреля 2018 в 05:20

Узнав о своем опыте, я мог бы придумать еще одно решение. Вместо объявления переменной AlertDialog внутри каждого из методов объявите одну глобальную переменную, чтобы вы могли убедиться, что в любом экземпляре отображается только один диалог.

При объявлении сделайте

AlertDialog dialog = null;

в classThen in,

    showBusinessOrPrivateStartDialog() {
    if(dialog == null) {
    dialog = build.create();
    }
    }    builder.setPositiveButton("Business", new DialogInterface.OnClickListener() {
          public void onClick(DialogInterface dialog, int which) {
                    dialog.dismiss();
                    CallClassification.showBusinessCallPopup(context, call);
                 }
              });builder.setOnDismissListener(new OnDismissListener() {
public void onDismiss() {
dialog = null;
}
}

Затем снова в showBusinessCallPopup (),

if(dialog == null) {
    dialog = build.create();
    }

Надеюсь, это поможет вам.

Yashaswi Bharadwaj ответил: 28 апреля 2018 в 09:45

Перед вызовом

CallClassification.showBusinessCallPopup (контекст, вызов);

вам нужно вызвать диалог

.dismiss ();

внутри одного и того же onClick ().

Надеюсь, что это решает ваш случай.

Junta ответил: 28 апреля 2018 в 12:37
Спасибо, я попробую, а потом вернусь назад
Junta ответил: 28 апреля 2018 в 01:34
к сожалению, приложение продолжает сбой даже после вставки dialog.dismiss ()
jsancheh ответил: 29 апреля 2018 в 05:35

В вашем втором коде вы дважды добавляете представление, возможно, вам следует удалить один из них.

    builder.setCustomTitle(view); -> Here
    builder.setCancelable(true);
    builder.setView(view); --> Here

:)