kotlin.NotImplementedError: una operación no está implementada: no implementada Error de ImageButton Click

4 minutos de lectura

avatar de usuario
Aprende rápido

Obtener este error

kotlin.NotImplementedError: una operación no está implementada: no implementada

Estoy implementando un detector de clics ImageButton

Requisito :- Quiero realizar una acción al hacer clic en el botón de imagen, pero obtengo el error mencionado anteriormente

Corrígeme y también si hay algún otro trabajo para implementar el oyente de clics de botón de imagen, proporciónalo, gracias

Aquí está el fragment clase java

class FragmentClass : Fragment(), View.OnClickListener {
    override fun onClick(v: View?) {
        TODO("not implemented") //To change body of created functions use File | Settings | File Templates.
        when (v?.id) {
            R.id.back_icon -> {
                Toast.makeText(activity, "back button pressed", Toast.LENGTH_SHORT).show()
                activity.onBackPressed()
            }

            else -> {
            }
        }
    }

    override fun onCreateView(inflater: LayoutInflater?, container: ViewGroup?,
                              savedInstanceState: Bundle?): View? {
        val view: View = inflater!!.inflate(R.layout.fragment_class, container,
                false)
        val activity = getActivity()
        var input_name = view.findViewById(R.id.input_name) as EditText
        var tv_addbucket = view.findViewById(R.id.tv_addbucket) as TextView
        val back_icon: ImageButton = view.findViewById(R.id.back_icon)
        back_icon.setOnClickListener(this)

        tv_addbucket.setOnClickListener(View.OnClickListener {
            Toast.makeText(activity, input_name.text, Toast.LENGTH_SHORT).show()
        })


        return view;
    }


}

y luego el fragment_class. xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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">

    <RelativeLayout
        android:id="@+id/header"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:focusable="true"
        android:focusableInTouchMode="true"
        android:clickable="true"
        android:padding="10dp">

        <ImageButton
            android:id="@+id/back_icon"
            android:layout_width="40dp"
            android:layout_height="40dp"
            android:background="#0000"
            android:focusable="true"
            android:focusableInTouchMode="true"
            android:clickable="true"
            android:src="https://stackoverflow.com/questions/50503780/@drawable/back_icon" />

        <TextView
            android:id="@+id/tv_header"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerHorizontal="true"
            android:text="Add Bucket" />
    </RelativeLayout>

    <ScrollView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_below="@+id/header"
        android:fillViewport="true">

        <LinearLayout
            android:layout_width="fill_parent"
            android:layout_height="match_parent"

            android:layout_marginTop="?attr/actionBarSize"
            android:orientation="vertical"
            android:paddingLeft="20dp"
            android:paddingRight="20dp"
            android:paddingTop="60dp">

            <android.support.design.widget.TextInputLayout
                android:id="@+id/input_layout_name"
                android:layout_width="match_parent"
                android:layout_height="wrap_content">

                <EditText
                    android:id="@+id/input_name"
                    android:layout_width="match_parent"
                    android:layout_height="wrap_content"
                    android:hint="Bucket Name"
                    android:singleLine="true" />
            </android.support.design.widget.TextInputLayout>


            <TextView
                android:id="@+id/tv_addbucket"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_marginTop="40dp"
                android:background="@drawable/blue_stroke_background"
                android:gravity="center"
                android:padding="15dp"
                android:text="Add"
                android:textColor="@color/white" />


        </LinearLayout>
    </ScrollView>

</RelativeLayout>

solo elimina TODO( ... ) desde su onClickListener:

override fun onClick(v: View?) {
    // No TODO here
    when (v?.id) {
        ...
    }
}

TODO(...) es la función de Kotlin que siempre arroja NotImplementedError. Si desea marcar algo con TODO pero no arrojar una excepción, simplemente use TODO con comentarios:

override fun onClick(v: View?) {
    //TODO: implement later
    when (v?.id) {
        ...
    }
}

  • Bueno, cómo deshacerse de eso todo el ide lo pone allí y es molesto.

    –Steve Moretz

    16 de abril de 2019 a las 9:01

  • Nunca lo pensé. Gracias !

    – Giedrius Šlikas

    24 de abril de 2019 a las 11:24

  • ¿Qué pasa si se requiere un tipo de devolución pero aún no hay implementación? por ejemplo, implementar una interfaz

    – Rafael

    27 de noviembre de 2020 a las 14:56


  • @Rafael, entonces tiene que devolver el valor del código auxiliar (por ejemplo, 0/falso/nulo/””, override fun test(): Int = 0) o lanzar una excepción (por ejemplo override fun test(): Int = throw IllegalStateException("Not implemented yet")

    – hluhovskyi

    29 de noviembre de 2020 a las 13:14

avatar de usuario
cilindrando

TODO() es una función en línea en Kotlin. SIEMPRE arrojará NotImplementedError. Ver #documentación: https://kotlinlang.org/api/latest/jvm/stdlib/kotlin/-todo.html

Si solo desea marcar que este fragmento de código aún necesita trabajo, use // TODO. Entonces, la marca será visible en la sección TODO, pero no arrojará una excepción.

avatar de usuario
Shaon

Implementé esto

  val extraTime = arrayListOf<String>("1 hour")
    val extraTimeAdapter = CustomSpinDeliveryExtraTimeAdapter(context!!, R.layout
            .simple_spinner_text_middle_down_arrow, extraTime)
    spinCustomTime.adapter = extraTimeAdapter
    spinCustomTime.onItemSelectedListener = object : AdapterView.OnItemSelectedListener {
        override fun onNothingSelected(parent: AdapterView<*>?) {
            TODO("not implemented") //To change body of created functions use File | Settings | File Templates.
        }

        override fun onItemSelected(parent: AdapterView<*>?, view: View?, position: Int, id: Long) {
            TODO("not implemented") //To change body of created functions use File | Settings | File Templates.
        }

    }

Después de eliminar todo de este código a continuación

 spinCustomTime.onItemSelectedListener = object : AdapterView.OnItemSelectedListener {
    override fun onNothingSelected(parent: AdapterView<*>?) {

    }

    override fun onItemSelected(parent: AdapterView<*>?, view: View?, position: Int, id: Long) {

    }

}

resolvió mi problema

También vea este enlace de documento para aclaraciones Ver #documentación: https://kotlinlang.org/api/latest/jvm/stdlib/kotlin/-todo.html

avatar de usuario
Harry

solo elimina TODO("not implemented") de tu onClickListener:

¿Ha sido útil esta solución?