Как исправить эту ошибку с помощью Kotlin, не удалось найти конструктор Fragment? - PullRequest
0 голосов
/ 11 сентября 2018

Я занимаюсь разработкой Android приложения с использованием Kotlin. В моем приложении содержится Tab с ViewPager, поэтому я реализую две вкладки. Когда я перехожу к другому действию и выполняю компакцию в просмотр вкладок, приложение получает четыре остановки иlogcat показано под ошибкой.

java.lang.RuntimeException: невозможно запустить действие ComponentInfo {com.crypto.wallet / com.crypto.wallet.activities.MainActivity}: android.support.v4.app.Fragment $ InstantiationException: Невозможно создать экземпляр фрагмента. com.crypto.wallet.activities.ReceiveFragment: не удалось найти конструктор фрагмента

MyFragment.kt

@SuppressLint("ValidFragment")
class ReceiveFragment(private val transactionList: List<TransactionEntity>, val appDatabase: AppDatabase, private val direction: TransactionAdapterDirection,
                      val networkDefinitionProvider: NetworkDefinitionProvider) : Fragment(){

    private var linearLayoutManager: LinearLayoutManager? = null

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)

    }

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

        val rootView = inflater.inflate(R.layout.receive_fragment, container, false)
        val recyclerView = rootView.findViewById<RecyclerView>(R.id.transaction_recycler_in) as RecyclerView
        linearLayoutManager = LinearLayoutManager(getActivity(), LinearLayout.VERTICAL, false)
        recyclerView.layoutManager = linearLayoutManager
        recyclerView.adapter = TransactionRecyclerAdapter(transactionList,appDatabase,direction,networkDefinitionProvider)
        recyclerView.setHasFixedSize(true);
        return rootView
    }
}

ViewPager.kt

override fun getItem(position: Int): Fragment? {
        var fragment: Fragment? = null
        when (position) {
            //0 -> fragment = ReceiveFragment(MytransactionList,MyappDatabase,Myincoming,MynetworkDefinitionProvider)
            0 -> fragment = ReceiveFragment(MyIT,MyAppDatabase,MyIncoming,MyNetwork)
            1 -> fragment = SendFragment()
        }

        return fragment
    }

Main.kt OnCreate ()

val viewPager = findViewById<ViewPager>(R.id.viewpager)
                if (viewPager != null) {
                    val adapter = ViewPagerAdapter(supportFragmentManager,it,appDatabase,INCOMING,networkDefinitionProvider)
                    viewPager.adapter = adapter
                }

 val pref = applicationContext.getSharedPreferences("MyPref", 0) // 0 - for private mode
                val editor = pref.edit()
                val gson = Gson()
                val json = gson.toJson(it)
                editor.putString("MyObject", json)
                editor.apply()

OnResume ()

val prefs = applicationContext.getSharedPreferences("MyPref", 0)
        val gson = Gson()
        val json = prefs.getString("MyObject", "")
        val person1: List<TransactionEntity> = gson.fromJson(json, ArrayList<TransactionEntity>()::class.java)

ОБНОВЛЕНИЕ: После того, как я попробовал это, я получаю ту же ошибку (я пробовал и Bundle и Shared pref):

companion object {
        @JvmStatic
        fun newInstance(myIT: List<TransactionEntity>, myAppDatabase: AppDatabase, myIncoming: TransactionAdapterDirection,
                        myNetwork: NetworkDefinitionProvider,
                        bundle: Bundle) =
                ReceiveFragment(myIT, myAppDatabase, myIncoming, myNetwork,bundle).apply {
                    arguments = Bundle().apply {
                       /* val prefs = getActivity()!!.getApplicationContext().getSharedPreferences("myPrefs", 0)
                        val gson = Gson()
                        val json = prefs.getString("MyObject", "")
                        val person1: List<TransactionEntity> = gson.fromJson(json,
                                ArrayList<TransactionEntity>()::class.java)
                        Log.d("Karthi", "Frag-GSON " + person1)*/

                        val dd = bundle.getSerializable("MySerializable")
                        Log.d("Karthi", "Frag-GSON " + dd)
                    }
                }
    }

Main.kt:

val bundle = Bundle()
                val gson_budle = Gson()
                val json_bundle = gson_budle.toJson(it)
                bundle.putSerializable("MySerializable", json_bundle)

                val sharedPreferences = getSharedPreferences(myPreferences, Context.MODE_PRIVATE)
                val editor = sharedPreferences.edit()
                val gson = Gson()
                val json = gson.toJson(it)
                editor.putString("MyObject", json)
                editor.putString("MyObject_json_bundle", json_bundle)
                Log.d("Karthi","After - IT" + json)
                Log.d("Karthi","After - IT" + json_bundle)
                editor.apply()

ФАТАЛЬНОЕ ИСКЛЮЧЕНИЕ: основной процесс: com.crypto.wallet, PID: 29313 java.lang.RuntimeException: UnaЧтобы начать действие ComponentInfo {com.crypto.wallet / com.crypto.wallet.activities.MainActivity}: android.support.v4.app.Fragment $ InstantiationException: Невозможно создать экземпляр фрагмента com.crypto.wallet.activities.ReceiveFragment: могли быне найти конструктор фрагмента в android.support.v4.app.FragmentController.restoreAllState (FragmentController.java:152) в android.support.v4.app.FragmentActivity.onCreate (FragmentActivity.java:330) в android.support.v7.app.AppCompatActivity.onCreate (AppCompatActivity.java:84) в com.crypto.wallet.activities.MainActivity.onCreate (MainActivity.kt: 194)

Ответы [ 2 ]

0 голосов
/ 11 сентября 2018

Что вы можете сделать, это сделать конструктор по умолчанию с нулевыми параметрами

companion object {
    /**
     * Use this factory method to create a new instance of
     * this fragment using the provided parameters.
     *
     * @param param1 Parameter 1.
     * @param param2 Parameter 2.
     * @return A new instance of fragment LoginFragment.
     */
    // TODO: Rename and change types and number of parameters
    @JvmStatic
    fun newInstance(param1: String, param2: String) =
            ReceiveFragment().apply {
                arguments = Bundle().apply {
                    putString(ARG_PARAM1, param1)
                    putString(ARG_PARAM2, param2)
                }
// Or from your code, you can use Gson
   val prefs = applicationContext.getSharedPreferences("MyPref", 0)
   val gson = Gson()
   val json = prefs.getString("MyObject", "")
   val person1: List<TransactionEntity> = gson.fromJson(json, 
   ArrayList<TransactionEntity>()::class.java)

            }
}

И вы можете использовать его как

   0 -> receiveFragment= ReceiveFragment.newInstance(firstParam, secondParam)

И вы можете получить эти параметры в onCreate

 override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    arguments?.let {
        email = it.getString(ARG_PARAM1)
        password = it.getString(ARG_PARAM2)

    }
  // Or from your code, you can use Gson
   val prefs = applicationContext.getSharedPreferences("MyPref", 0)
   val gson = Gson()
   val json = prefs.getString("MyObject", "")
   val person1: List<TransactionEntity> = gson.fromJson(json, 
   ArrayList<TransactionEntity>()::class.java)
}

И ваш конструктор фрагментов вот так

class ReceiveFragment: Fragment()

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

0 голосов
/ 11 сентября 2018

Когда вы получите краткое описание ошибки, вы увидите:

Избегайте конструкторов не по умолчанию в фрагментах: используйте конструктор по умолчанию плюс Fragment setArguments(Bundle) вместо меньшего.Из документации Fragment:

Каждый фрагмент должен иметь пустой конструктор, чтобы его можно было создать при восстановлении состояния его активности.Настоятельно рекомендуется, чтобы у подклассов не было других конструкторов с параметрами, поскольку эти конструкторы не будут вызываться при повторном создании фрагмента;вместо этого аргументы могут быть предоставлены вызывающей стороной с помощью setArguments(Bundle), а затем извлечены фрагментом с помощью getArguments().

, например:

 fun newInstance(bundle : Bundle) : ReceiveFragment{
        val fragment = ReceiveFragment()
         fragment.arguments=bundle           
        return fragment
    }

Теперь вызовите фрагмент:

 0 -> fragment = ReceiveFragment.newInstance(new Bundle)

Дополнительная информация: http://developer.android.com/reference/android/app/Fragment.html#Fragment()

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