отобразить список просмотра во фрагменте kotlin - PullRequest
0 голосов
/ 23 ноября 2018

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

l получена ошибка в адаптере класса под строкой val view : View = LayoutInflater.from(context,this).inflate(R.layout.arr_list,parent,false)

фрагмент класса

class fragment_Arr :Fragment(), View.OnClickListener {
        override fun onClick(v: View?) {
    //        val intent = Intent(context, FlightsArrbefor::class.java)
    //        context!!.startActivity(intent)
        }


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


            val url = "xxxxxxxx/airport.json?code=BGW"
            Arr().execute(url)

            return view
        }
        inner class Arr : AsyncTask<String, String, String>(){



            override fun onPreExecute() {
                super.onPreExecute()



            }

            //        for build connection
            override fun doInBackground(vararg url: String?): String{

                var text : String
                val connection = URL(url[0]).openConnection() as HttpURLConnection

                try {
                    connection.connect()
                    text = connection.inputStream.use { it.reader().use{reader -> reader.readText()} }


                } finally{

                    connection.disconnect()

                }
                return text
            }

            override fun onPostExecute(result: String?) {

                super.onPostExecute(result)
                handleJson(result)


            }

            override fun onProgressUpdate(vararg text: String?) {


            }
            @SuppressLint("WrongViewCast")
            private fun handleJson (jsonString: String?) {

                val jsonObj = JSONObject(jsonString)
                val result = jsonObj.getJSONObject("result")
                val response = result.getJSONObject("respe")
                val airport = response.getJSONObject("airport")
                val pluginData = airport.getJSONObject("Data")
                val schedule = pluginData.getJSONObject("schedule")
                val arrivals = schedule.getJSONObject("arrivals")

    //        val data = arrivals.getJSONObject("data")
                val jsonArray = JSONArray(arrivals.get("data").toString())

                val list = ArrayList<FlightShdu>()
                var x = 0
                while (x < jsonArray.length()) {

                    val jsonObject = jsonArray.getJSONObject(x)



                    list.add(
                        FlightShdu(
                            jsonObject.getJSONObject("flight").getJSONObject("identification").getJSONObject("number").getString("default"),
                            jsonObject.getJSONObject("flight").getJSONObject("airline").getString("short"),
                            jsonObject.getJSONObject("flight").getJSONObject("status").getJSONObject("generic").getJSONObject("status" )

                        )
                    )


                    x++
                }
                list.forEach(::println)

                var adapter = ListAdapteArr(this@MainActivity, list)
                flight_arrivel_list.adapter = adapter




            }

        }

Список Aadpter Class

class ListAdapteArr (val context: fragment_Arr, var list: ArrayList<FlightShdu>): BaseAdapter() {

    @SuppressLint("ViewHolder", "NewApi")
    override fun getView(p0: Int, convertView: View?, parent: ViewGroup?): View {

        val view : View = LayoutInflater.from(context,this).inflate(R.layout.arr_list,parent,false)

           val list = list[p0]

        val code = view.findViewById(R.id.code_id) as AppCompatTextView

        view.callsign_id.text=list.Callsign
        view.airline_id.text=list.Airline
        code.text = list.code


        view.setOnClickListener {

            val intent = Intent(context, FlightDeatilasArr::class.java)

            intent.putExtra("Stauts",list.Stauts!!)
            intent.putExtra("Callsign",list.Callsign!!)
            intent.putExtra("Airline",list.Airline!!)

            context!!.startActivity(intent)
        }











    }

    private fun getDateTime(s: String): String? {
        try {
            val sdf = SimpleDateFormat("EE, MMM d KK:mm a")
            val netDate = Date(s.toLong() * 1000)
            return sdf.format(netDate)
        } catch (e: Exception) {
            return e.toString()

        }
    }

    override fun getItem(p0: Int): Any {
        return list [p0]
    }

    override fun getItemId(p0: Int): Long {
        return p0.toLong()
    }

    override fun getCount(): Int {
        return list.size
    }



}

1 Ответ

0 голосов
/ 24 ноября 2018

Согласно документации, есть метод с одним параметром LayoutInflater.html#from(android.content.Context), но вы вызываете его с 2 параметрами

LayoutInflater.from (context, this) .inflate (R.layout.arr_list, parent, false)

И, кстати, context, который вы передаете, на самом деле не Context, а фрагмент

классListAdapteArr (val context: frag_Arr, ...)

Чтобы решить вашу проблему, используйте следующий подход

override fun getView(p0: Int, convertView: View?, parent: ViewGroup?): View? {
   val view: View = LayoutInflater.from(parent!!.context).inflate(R.layout.arr_list,parent,false)
   ...
   return view
}

Согласно документации , parent следуетникогда не будет нулевым.

Родитель, к которому в конечном итоге будет присоединено это представление

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