Как вызвать removeView () в диалоговом окне номер один, чтобы отобразить диалоговое окно номер 2 - PullRequest
0 голосов
/ 22 мая 2018

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

Я получаю сообщение об ошибке «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();
       }

Thisэто второй метод для второго диалогового окна, и мое приложение падает на 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 ]

0 голосов
/ 24 мая 2018

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

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

AlertDialog dialog = null;

в классе Затем в,

    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();
    }

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

0 голосов
/ 24 мая 2018

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

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

:)

0 голосов
/ 22 мая 2018

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

CallClassification.showBusinessCallPopup (context, call);

вам необходимо позвонить

dialog.dismiss ();

в том же onClick ().

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

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...