Как вызвать removeView у родителя ребенка - PullRequest
0 голосов
/ 05 января 2020

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

Я пытался вызвать removeView на mDialog, но не могу. Эта ошибка встречается часто, поэтому я попытался реализовать решения на других постах; при накачивании mCustomDatePicker я пытался установить root (в конструкторе) в качестве родителя накаченного представления, но это не помогло.

class SignupStageOne : AppCompatActivity() {

    private var mCalendar : Calendar? = null
    private var day: Int? = null
    private var month: Int? = null
    private var year: Int? = null

    private var age: String? = null

    private val firebaseDatabase = FirebaseDatabase.getInstance().reference
    private val firebaseAuth = FirebaseAuth.getInstance()
    val user = firebaseAuth.currentUser

override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(com.example.meet.R.layout.activity_signup_stage_one)

        val mCustomDatePicker = layoutInflater.inflate(com.example.meet.R.layout.custom_date_picker, datePickerLayout, false)

        var mDatePicker = mCustomDatePicker.findViewById(com.example.meet.R.id.mDatePicker) as DatePicker
        mDatePicker.maxDate = (Calendar.getInstance().getTime().getTime())

        val mDialog = AlertDialog.Builder(this)
        mDialog.setView(mCustomDatePicker)

        mDialog.setPositiveButton("OK", object : DialogInterface.OnClickListener {
            override fun onClick( dialog: DialogInterface, which: Int) {

            }
        }).setNegativeButton("Cancel", object: DialogInterface.OnClickListener {
            @Override
            override fun onClick( dialog: DialogInterface, which: Int) {
                dialog.dismiss()
            }
        })

        mDialog.create()

        ageET.setOnFocusChangeListener{ view, hasFocus ->
            if (hasFocus) {
                mDialog.show()
            }
        }
    }

Я также пытался надувать представление так :

layoutInflater.inflate(com.example.meet.R.layout.custom_date_picker, null, false)

Но это не помогло.

Мой XML:

<RelativeLayout
    android:id="@+id/datePickerLayout"
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:gravity="center">

    <DatePicker
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:id="@+id/mDatePicker"
        android:layout_gravity="center_horizontal"
        android:spinnersShown="true"
        android:calendarViewShown="false"
        android:layout_alignParentTop="true"/>
</RelativeLayout>

1 Ответ

0 голосов
/ 05 января 2020

Мое отсутствие знаний в Kotlin не позволило мне решить эту проблему, при обращении к родителю mCustomDatePicker мы должны привести его к виду ViewGroup:

override fun onClick( dialog: DialogInterface, which: Int) {
    ageET.clearFocus()
    val parent = mCustomDatePicker.parent as ViewGroup?
    parent?.removeAllViews()
    dialog.dismiss()
}

Это решило проблему.

...