Как открыть фрагмент из onClickListener внутри фрагмента в kotlin? - PullRequest
0 голосов
/ 23 февраля 2020

Я очень плохо знаком с Kotlin, и сейчас я изучаю его в школе. Так что дело в том, что у меня есть 3 вкладки, которые должны содержать вещи. Как только я нажимаю «добавить» на одной из вкладок, я хочу открыть новое окно, чтобы ввести некоторую информацию для сохранения. Я пытался использовать фрагмент, на котором я нахожусь, чтобы создать новый фрагмент, содержащий очень простое поле ввода.

Если бы кто-нибудь мог сказать мне, где мне нужно разместить мой onClickListener и что печатать, чтобы он работал, я был бы очень благодарен.

Любые советы по рефакторингу моего кода, чтобы сделать его более читабельным для новичка ie, также приветствуются.

(ОТКАЗ ОТ ОТВЕТСТВЕННОСТИ: В настоящее время приложение взломает sh из-за "Невозможно найти явный класс активности ..." Я немного поковырялся в манифесте, чтобы исправить это, но безрезультатно. Он чувствует себя неправильно, если проблема есть.)

Frag1.kt


import android.content.Intent
import android.os.Bundle
import androidx.fragment.app.Fragment
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import kotlinx.android.synthetic.main.fragment_frag1.view.*


class Frag1 : Fragment() {

    override fun onCreateView(
        inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {

        // Inflate the layout for this fragment
        val view: View = inflater.inflate(R.layout.fragment_frag1, container, false)

        view.btnAddPerson.setOnClickListener {
            requireActivity().startActivity(
                Intent(requireActivity(), RegisterPersonFrag::class.java)
            )
        }
        return view
    }

}

фрагмент_фрагмента1. xml

<androidx.constraintlayout.widget.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:id="@+id/frameLayout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".Frag1">

    <!-- TODO: Update blank fragment layout -->
    <TextView
        android:id="@+id/textView"
        android:layout_width="0dp"
        android:layout_height="0dp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <com.google.android.material.floatingactionbutton.FloatingActionButton
        android:id="@+id/btnAddPerson"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:clickable="true"
        android:focusable="true"
        android:src="@android:drawable/ic_input_add"
        app:backgroundTint="#FFFFFF"
        app:layout_constraintBottom_toBottomOf="@+id/textView"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.825"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.896"
        app:rippleColor="#FFFFFF" />

</androidx.constraintlayout.widget.ConstraintLayout>

RegisterPersonFrag.kt



import android.os.Bundle
import androidx.fragment.app.Fragment
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup

/**
 * A simple [Fragment] subclass.
 */
class RegisterPersonFrag : Fragment() {

    override fun onCreateView(
        inflater: LayoutInflater, container: ViewGroup?,
        savedInstanceState: Bundle?
    ): View? {
        // Inflate the layout for this fragment
        return inflater.inflate(R.layout.fragment_register_person, container, false)
    }


}

frag_register_person. xml

<androidx.constraintlayout.widget.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:id="@+id/frameLayout3"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".RegisterPersonFrag">

    <com.google.android.material.textfield.TextInputLayout
        android:layout_width="409dp"
        android:layout_height="wrap_content"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="1.0"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.161">

        <com.google.android.material.textfield.TextInputEditText
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:hint="Name" />
    </com.google.android.material.textfield.TextInputLayout>
</androidx.constraintlayout.widget.ConstraintLayout>

MainActivity.kt


import MyAdapter
import android.os.Bundle
import com.google.android.material.tabs.TabLayout
import androidx.viewpager.widget.ViewPager
import androidx.appcompat.app.AppCompatActivity

class MainActivity : AppCompatActivity() {

    var tabLayout: TabLayout? = null
    var viewPager: ViewPager? = null
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        tabLayout = findViewById<TabLayout>(R.id.tabs)
        viewPager = findViewById<ViewPager>(R.id.view_pager)

        tabLayout!!.addTab(tabLayout!!.newTab().setText("UPCOMING"))
        tabLayout!!.addTab(tabLayout!!.newTab().setText("PAST"))
        tabLayout!!.addTab(tabLayout!!.newTab().setText("GIFTS TO BUY"))
        tabLayout!!.tabGravity = TabLayout.GRAVITY_FILL

        val adapter = MyAdapter(this, supportFragmentManager, tabLayout!!.tabCount)
        viewPager!!.adapter = adapter


        viewPager!!.addOnPageChangeListener(TabLayout.TabLayoutOnPageChangeListener(tabLayout))

        tabLayout!!.addOnTabSelectedListener(object : TabLayout.OnTabSelectedListener {
            override fun onTabSelected(tab: TabLayout.Tab) {
                viewPager!!.currentItem = tab.position
            }
            override fun onTabUnselected(tab: TabLayout.Tab) {

            }
            override fun onTabReselected(tab: TabLayout.Tab) {

            }
        })

    }
}

1 Ответ

0 голосов
/ 23 февраля 2020

Один совет для вас: Не используйте оператор !!, это кодовый запах. Вместо этого вы можете объявить вашу переменную tabLayout как lateinit var tabLayout: TabLayout, поэтому в будущем после ее объявления tabLayout = findViewById<TabLayout>(R.id.tabs) вы сможете получить доступ без преобразования с обнуляемого значения в необнуляемое.

По вашему вопросу, если вы хотите открыть новое действие через Intent, второй параметр должен быть Activity, а не Fragment (ваш класс RegisterPersonFrag.kt равен Fragment)! Итак, у вас есть два пути:

  1. Создайте новый Activity и назовите его так, как вы.
  2. Читайте о fragmentManager и replace или add вашего фрагмента в конкретный контейнер.
...