web-dev-qa-db-ja.com

Kotlin-AndroidクラスにOnClickListenerを実装できますか?

Kotlinから始めて、アクティビティクラスに実装してもonClickがトリガーされないようです

class MainActivity : AppCompatActivity(), View.OnClickListener{

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

        tvTitle.text = "Hi There"

//        tvTitle.setOnClickListener { this } // NOT WORKING??
        tvTitle.setOnClickListener { doSomething() }
    }


    override fun onClick(v: View) {
        Log.d("click", "Hello")
    }

    fun doSomething(){
        Log.d("do", "Something")
    }
}

Android Studio 3.0のkotlin_version 1.1.51を使用しています。よろしくお願いします。

6
johnguild

これを試して

class MainActivity : AppCompatActivity(), View.OnClickListener{

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

    tvTitle.text = "Hi There"

    tvTitle.setOnClickListener(this)
   //   tvTitle.setOnClickListener { doSomething() }
}


override fun onClick(v: View) {
    Log.d("click", "Hello")
}

fun doSomething(){
    Log.d("do", "Something")
}
}
12
Asharali V U

これは私のkotlinコードです:

import Android.os.Bundle
import Android.support.v7.app.AppCompatActivity
import Android.view.View
import Android.widget.LinearLayout
import Android.widget.Toast

class Activity_T : AppCompatActivity(), View.OnClickListener {
    private var linear_exit: LinearLayout? = null
    private var linear_history: LinearLayout? = null
    private var linear_recipe: LinearLayout? = null

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        initView()
        setOnClicks()
    }

    private fun setOnClicks() {
        linear_exit!!.setOnClickListener(this)
        linear_history!!.setOnClickListener(this)
        linear_recipe!!.setOnClickListener(this)
    }

    private fun initView() {
        linear_exit = findViewById(R.id.linear_exit)
        linear_history = findViewById(R.id.linear_history)
        linear_recipe = findViewById(R.id.linear_recipe)
    }

    override fun onClick(v: View) {
        val item_id = v.id
        when (item_id) {
            R.id.linear_recipe -> Toast.makeText(this, "recipe", Toast.LENGTH_SHORT).show()
            R.id.linear_history -> Toast.makeText(this, "history", Toast.LENGTH_SHORT).show()

            R.id.linear_exit -> Toast.makeText(this, "exit", Toast.LENGTH_SHORT).show()
        }
    }
}

そして、これはonclicksがあった私のxmlレイアウトの一部です:

    <LinearLayout
        Android:layout_width="match_parent"
        Android:layout_height="50dp"
        Android:layout_alignParentBottom="true">


        <LinearLayout
            Android:layout_width="match_parent"
            Android:layout_height="match_parent">

            <LinearLayout
                Android:id="@+id/linear_exit"

                Android:layout_width="0dp"
                Android:layout_height="match_parent"
                Android:layout_margin="10dp"
                Android:layout_weight="1"
                Android:background="@color/border_green"
                Android:gravity="center">

                <net.kibotu.heartrateometer.utils.MyTextView
                    Android:textSize="13sp"
                    Android:textColor="@Android:color/white"
                    Android:layout_width="wrap_content"
                    Android:layout_height="wrap_content"
                    Android:text="@string/exit" />
            </LinearLayout>

            <LinearLayout
                Android:id="@+id/linear_history"

                Android:layout_width="0dp"
                Android:layout_height="match_parent"
                Android:layout_margin="10dp"
                Android:layout_weight="1"
                Android:background="@color/border_green"
                Android:gravity="center">

                <net.kibotu.heartrateometer.utils.MyTextView
                    Android:textSize="13sp"
                    Android:textColor="@Android:color/white"
                    Android:layout_width="wrap_content"
                    Android:layout_height="wrap_content"
                    Android:text="@string/history" />
            </LinearLayout>

            <LinearLayout
                Android:id="@+id/linear_recipe"
                Android:layout_width="0dp"
                Android:layout_height="match_parent"
                Android:layout_margin="10dp"
                Android:layout_weight="1"
                Android:background="@color/border_green"

                Android:gravity="center">

                <net.kibotu.heartrateometer.utils.MyTextView
                    Android:textSize="13sp"
                    Android:textColor="@Android:color/white"
                    Android:layout_width="wrap_content"
                    Android:layout_height="wrap_content"
                    Android:text="@string/recipe" />
            </LinearLayout>
        </LinearLayout>
    </LinearLayout>
2
dariush

まずprintln( "Something")を試してください。

0
Maxim Firsoff

この方法を試すことができます。

override fun onCreate(savedInstanceState: Bundle?) {
         super.onCreate(savedInstanceState)
         setContentView(R.layout.activity_main)
         val tvTitle = findViewById<TextView>(R.id.tvTitle)
         tvTitle.setText("Hello Kotlin")

         tvTitle.setOnClickListener(object : View.OnClickListener{
                override fun onClick(v: View?) {
                    Toast.makeText(this@MainActivity,"You Clicked on " + tvTitle.text.toString(),Toast.LENGTH_SHORT).show()
                }
          })
    }
0
khushbu vadi