как передать авто полный текстовый вид в списке адаптер котлин - PullRequest
0 голосов
/ 06 декабря 2018

Я пытаюсь использовать автозаполнение текста в моем приложении, используя адаптер списка и данные, чтобы получить данные JSON из URL.мое приложение работало нормально для поиска результатов без проблем, прежде чем я использовал автозаполнение текста.Теперь я хочу передать автозаполнение текста в моем списке адаптера в основной деятельности, но не работает я получаю красную линию под текстом ошибки адаптера

Type parameter bound for T in 

fun <T : ListAdapter!> setAdapter
(adapter: T!)
: Unit where T : Filterable!
is not satisfied: inferred type FlightSearch.FlightSearchAdpater! is not a subtype of Filterable

вот что я делаю

  var adapter = FlightSearchAdpater(this@FlightSearch, list)
        beforflightDepbgwlist.adapter = adapter
        autoCompleteTextView.threshold=0
        autoCompleteTextView.setAdapter(adapter)

основная деятельность

class FlightSearch : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_flight_search)


    }

    fun getflightsearchresult(view:View){

        val FlightNumber=flightnumbertext.text.toString()
        val url = "/flight/list.json?query="+FlightNumber+""
        Arr().execute(url)
    }
    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
            connection.connectTimeout = 700

            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("response")

//            MaterText.text=mater
//        val data = arrivals.getJSONObject("data")
            val jsonArray = JSONArray(response.get("data").toString())

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

                val jsonObject = jsonArray.getJSONObject(x)



                list.add(
                    FlightShdu(
                        jsonObject.getJSONObject("identification").getJSONObject("number").getString("default"),
                        jsonObject.getJSONObject("airline").getString("name"),
                        jsonObject.getJSONObject("status").getJSONObject("generic").getJSONObject("status").getString("text"),
                        jsonObject.getJSONObject("airline").getJSONObject("code").getString("icao"),
                        jsonObject.getJSONObject("time").getJSONObject("scheduled").getString("arrival"),
                        jsonObject.getJSONObject("airport").getJSONObject("origin").getJSONObject("code").getString("iata"),
                        jsonObject.getJSONObject("aircraft").getJSONObject("model").getString("code"),
//                    for more information
                        jsonObject.getJSONObject("time").getJSONObject("real").getString("departure"),
                        jsonObject.getJSONObject("time").getJSONObject("estimated").getString("arrival"),
//                    jsonObject.getJSONObject("flight").getJSONObject("time").getJSONObject("estimated").getString("arrival"),
                        jsonObject.getJSONObject("aircraft").getString("registration"),
                        jsonObject.getJSONObject("status").getJSONObject("generic").getJSONObject("status").getString("diverted"),
                        response.getString("timestamp"),
                        jsonObject.getJSONObject("status").getString("icon")


                    )
                )


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

            var adapter = FlightSearchAdpater(this@FlightSearch, list)
            beforflightDepbgwlist.adapter = adapter
            autoCompleteTextView.threshold=0
            autoCompleteTextView.setAdapter(adapter)


        }


    }
    class FlightSearchAdpater (val context: Context, val list: ArrayList<FlightShdu>): BaseAdapter() {


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

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

            val list = list[p0]
            val LogoAriline = view.findViewById(R.id.logo_image) as ImageView
            val status = view.findViewById(R.id.ali_id) as AppCompatTextView
            val Airport = view.findViewById(R.id.airportid) as AppCompatTextView
            val code = view.findViewById(R.id.code_id) as AppCompatTextView
            val TimeFlight = view.findViewById(R.id.time_id) as AppCompatTextView
            val checkiflive = view.checkifliveTextId
            view.callsign_id.text=list.Callsign
            view.airline_id.text=list.Airline
            code.text = list.code
            view.ali_id.text=list.Stauts
            status.text= list.Stauts
            TimeFlight.text = getDateTime(list.TimeFlight)

            Picasso.with(context).load(Uri.parse("https://www.flightradar24.com/static/images/data/operators/"+status.text.toString()+"_logo0.png"))
                .error(R.drawable.logo).into(LogoAriline)

            Airport.text= list.Airport
            view.model_id.text=list.Model
            checkiflive.text=list.IfLive

            if (p0 == 0) {
                view.checkliveId.setVisibility(View.VISIBLE)
            }

            if (checkiflive.text == "green") {
                view.checkliveId.setVisibility(View.VISIBLE)
            }else if(checkiflive.text == "null"){

                view.checkliveId.setVisibility(View.INVISIBLE)

            }

//        if (p0 == 0) {
//
////        رحلات وصلات مسبقلا
//            val mAddTaskButton = view.findViewById<TextView>(R.id.btn_click_me)
//
//            mAddTaskButton.setOnClickListener {
//                val intent = Intent(context, FlightsArrivelBeforBGW::class.java)
//                context!!.startActivity(intent)
//            }
//
//            mAddTaskButton.setVisibility(View.VISIBLE)
//
//        }



            return view


        }

        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
        }



    }

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