Lateinit свойство mScrollView не было инициализировано - PullRequest
0 голосов
/ 20 декабря 2018

Я не понимаю, почему у меня такая ошибка:

kotlin.UninitializedPropertyAccessException: lateinit property mScrollView has not been initialized

Я имею в виду, у меня есть такой код:

@BindView(R.id.scroll_view)
lateinit var mScrollView: ScrollView

А здесь вы можете найти на onCreateView

override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
    AndroidSupportInjection.inject(this)
    val view = inflater.inflate(R.layout.fragment_delete_account_reason, container, false)

    mUnbinder = ButterKnife.bind(this, view)
    ViewUtils.setupUI(view, activity)
    hideNextBtnOnKeyboardOpens(mScrollView, mNextBtn)

    setupLayout()
    mPresenter.getReasonKeyOfDeleteAccount()

    return view
}

private fun setupLayout() {
    mScrollView.viewTreeObserver.addOnGlobalLayoutListener {
        val r = Rect()
        mScrollView.getWindowVisibleDisplayFrame(r)
        val screenHeight = mScrollView.rootView.height
        val keypadHeight = screenHeight - r.bottom

        if (keypadHeight > screenHeight * 0.15 && mInput.hasFocus()) { // Keyboard is visible
            val bottom = mNbCharactersMax.getBottom() + mNbCharactersMax.getPaddingBottom()
            val sy = mScrollView.scrollY
            val sh = mScrollView.height
            val delta = bottom - (sy + sh)
            mScrollView.smoothScrollBy(0, delta)
        }
    }
}

Вы можете найти здесь мой XML.Все остальные идентификаторы работают (все идентификаторы совпадают), но у меня есть только проблема с scrollView, я не знаю почему.Если я удалю ScrollView, все будет работать, но мне это нужно.

<android.support.constraint.ConstraintLayout
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:layout_width="match_parent"
android:layout_height="match_parent">

<ScrollView
    android:id="@+id/scroll_view"
    android:layout_width="0dp"
    android:layout_height="0dp"
    android:animateLayoutChanges="true"
    android:layout_marginBottom="@dimen/general_padding"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintEnd_toEndOf="parent"
    app:layout_constraintTop_toTopOf="parent"
    app:layout_constraintBottom_toTopOf="@id/delete_account_next"
    android:fillViewport="true">

    <android.support.constraint.ConstraintLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

        <TextView
            android:id="@+id/delete_account_description"
            fontPath="fonts/SourceSansPro-SemiBold.ttf"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_marginStart="@dimen/general_padding"
            android:layout_marginTop="@dimen/general_padding"
            android:layout_marginEnd="@dimen/general_padding"
            android:letterSpacing="@dimen/general_letter_spacing"
            android:text="@string/delete_account_reason_description"
            android:textColor="@color/vision"
            android:textSize="18dp"
            app:layout_constraintTop_toTopOf="parent"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            tools:ignore="MissingPrefix,SpUsage" />

        <RadioGroup
            android:id="@+id/delete_account_radio_group"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:orientation="vertical"
            android:layout_marginEnd="@dimen/two_third_padding"
            android:layout_marginStart="@dimen/two_third_padding"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toBottomOf="@id/delete_account_description">

        </RadioGroup>

        <android.support.design.widget.TextInputLayout
            android:id="@+id/delete_account_input_reason_layout"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:hint="@string/delete_account_reason_specify_hint"
            android:layout_marginStart="17dp"
            android:layout_marginEnd="17dp"
            android:layout_marginTop="@dimen/general_padding"
            android:visibility="invisible"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintTop_toBottomOf="@id/delete_account_radio_group">

            <android.support.v7.widget.AppCompatEditText
                android:id="@+id/delete_account_input_password"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                fontPath="fonts/SourceSansPro-SemiBold.ttf"
                tools:ignore="MissingPrefix,SpUsage"
                android:imeOptions="actionDone"
                android:textColor="@color/jiren"
                android:textSize="16dp" />

        </android.support.design.widget.TextInputLayout>

        <TextView
            android:id="@+id/delete_account_reason_nb_caracters"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            fontPath="fonts/SourceSansPro-SemiBold.ttf"
            app:layout_constraintTop_toBottomOf="@id/delete_account_input_reason_layout"
            app:layout_constraintEnd_toStartOf="@id/delete_account_reason_nb_caracters_max"
            android:layout_marginEnd="@dimen/quarter_padding"
            android:textColor="@color/wolverine"
            android:textSize="14dp"
            android:text="0"
            android:visibility="invisible"
            android:letterSpacing="@dimen/general_letter_spacing"
            tools:ignore="HardcodedText,MissingPrefix,SpUsage"/>

        <TextView
            android:id="@+id/delete_account_reason_nb_caracters_max"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            fontPath="fonts/SourceSansPro-SemiBold.ttf"
            app:layout_constraintTop_toBottomOf="@id/delete_account_input_reason_layout"
            app:layout_constraintEnd_toEndOf="parent"
            android:layout_marginEnd="@dimen/general_padding"
            android:text="@string/delete_account_reason_specify_max_characters"
            android:textColor="@color/wolverine"
            android:textSize="14dp"
            android:visibility="invisible"
            android:letterSpacing="@dimen/general_letter_spacing"
            tools:ignore="MissingPrefix,SpUsage"/>

    </android.support.constraint.ConstraintLayout>

</ScrollView>

<Button
    style="?borderlessButtonStyle"
    android:id="@+id/delete_account_next"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:minWidth="0dp"
    android:minHeight="0dp"
    android:textSize="17dp"
    android:paddingTop="@dimen/half_padding"
    android:paddingBottom="@dimen/half_padding"
    android:paddingStart="@dimen/one_half_padding"
    android:paddingEnd="@dimen/one_half_padding"
    android:textAllCaps="false"
    android:layout_marginTop="@dimen/double_padding"
    android:layout_marginBottom="@dimen/one_half_padding"
    android:textColor="@color/white"
    android:textAlignment="center"
    android:background="@drawable/button_blue"
    android:letterSpacing="@dimen/general_letter_spacing"
    android:text="@string/delete_account_next_label"
    android:enabled="false"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintEnd_toEndOf="parent"
    app:layout_constraintBottom_toBottomOf="parent"
    fontPath="fonts/SourceSansPro-SemiBold.ttf"
    tools:ignore="MissingPrefix,SpUsage"/>

Вы понимаете, почему?

Ответы [ 3 ]

0 голосов
/ 20 декабря 2018

Я предлагаю избавиться от ButterKnife в Android с Kotlin, потому что он имеет встроенную функцию synthetic.В вашем случае вы можете использовать представление с именем scroll_view непосредственно в вашем коде:

private fun setupLayout() {
    scroll_view.viewTreeObserver.addOnGlobalLayoutListener {
        val r = Rect()
        scroll_view.getWindowVisibleDisplayFrame(r)
        val screenHeight = scroll_view.rootView.height
        val keypadHeight = screenHeight - r.bottom

        if (keypadHeight > screenHeight * 0.15 && mInput.hasFocus()) { // Keyboard is visible
            val bottom = mNbCharactersMax.getBottom() + mNbCharactersMax.getPaddingBottom()
            val sy = scroll_view.scrollY
            val sh = scroll_view.height
            val delta = bottom - (sy + sh)
            scroll_view.smoothScrollBy(0, delta)
        }
    }
}

Причины scroll_view не являются соглашением имен Java / Kotlin, поэтому вы можете переименовать его в XML во что-то вроде scrollView и вам не нужна переменная класса вообще.Вам просто нужно импортировать что-то вроде import kotlinx.android.synthetic.main.main_activity.*, но IDE сгенерирует его автоматически.

0 голосов
/ 20 декабря 2018

В Kotlin вы также можете использовать расширения Kotlin для привязки просмотра.Настройте зависимость в своем Gradle. Перейдите по этой ссылке

. Затем импортируйте идентификаторы видов макета с помощью import kotlinx.android.synthetic.main.<layout>.*. Вы избавитесь от Butterknife, и ваши представления всегда будут связаны вкод без каких-либо findviewbyids или аннотаций @BindViews

0 голосов
/ 20 декабря 2018

В onCreateView() инициализировать mScrollView:

mScrollView = view.findViewById<ScrollView>(R.id.scroll_view)
setupLayout()
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...