onClickListener не работает, при переопределении onTouchEvent в пользовательском представлении - PullRequest
0 голосов
/ 30 ноября 2018

Я хочу начать рисовать линию, когда я нажимаю кнопку, и заканчивать рисовать ее, когда я наводю курсор мыши на другую кнопку.Я переопределил onTouchEvent, чтобы нарисовать эту линию, но проблема сейчас в том, что TouchListener даже не запускается.Перемещение newView на фон заставляет его работать, но я хочу, чтобы нарисованная линия была на переднем плане.Я думаю, проблема в том, что когда я добавляю представление из кода, onTouchEvent для newView имеет какой-то приоритет над Button в другой ViewGroup. Дерево компонентов , добавлен новый вид в frameLayout1

class MainActivity : AppCompatActivity() {

    private val paint = Paint()
    private val array1 = FloatArray(2)
    private val array2 = FloatArray(2)
    private var buttonwidth = 0;
    private var buttonheight=0;
    private var buttonIsTouched=false
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main);
        button1.setOnTouchListener { _, event ->
            if (event.action == MotionEvent.ACTION_DOWN) {
                buttonIsTouched=true
                Toast.makeText(this,"ora",Toast.LENGTH_SHORT).show()
            }
            if (event.action == MotionEvent.ACTION_UP) {
                buttonIsTouched=false
                Toast.makeText(this,"muda",Toast.LENGTH_SHORT).show()
            }
            false
        }

    }

    override fun onResume() {
        super.onResume()

        buttonwidth = button1.width;
        buttonheight = button1.height;
        array1[0]=button1.x
        array1[1]=button1.y
        array2[0]=button2.x
        array2[1]=button2.y
        val newView = MyView(this)
        newView.bringToFront()
        newView.layoutParams= FrameLayout.LayoutParams(FrameLayout.LayoutParams.MATCH_PARENT,FrameLayout.LayoutParams.MATCH_PARENT)
        frameLayout1.addView(newView)
        Toast.makeText(this,array1[0].toString()+" "+array1[1].toString(),Toast.LENGTH_SHORT).show()

    }

    internal inner class MyView(context: Context)// TODO Auto-generated constructor stub
        : View(context) {
        private var startX: Int = 0
        private var startY: Int = 0
        private var endX: Int = 0
        private var endY: Int = 0
        override fun onDraw(canvas: Canvas) {

            super.onDraw(canvas)
            paint.strokeWidth=21f
            paint.color = Color.parseColor("#CD5C5C")
            //canvas.drawLine(array1[0]+20f+buttonwidth/2,array1[1]+20f+buttonheight/2,array2[0]+20f+buttonwidth/2,array2[1]+20f+buttonheight/2,paint)
            canvas.drawLine(startX.toFloat(),startY.toFloat(),endX.toFloat(),endY.toFloat(),paint)
        }

        override fun onTouchEvent(event: MotionEvent): Boolean {
            super.onTouchEvent(event)
                when (event.action) {
                    MotionEvent.ACTION_DOWN -> {
                        startX = event.x.toInt()
                        startY = event.y.toInt()
                        endX = event.x.toInt()
                        endY = event.y.toInt()
                        invalidate()
                    }
                    MotionEvent.ACTION_MOVE -> {
                        endX = event.x.toInt()
                        endY = event.y.toInt()
                        invalidate()
                    }
                    MotionEvent.ACTION_UP -> {
                        endX = event.x.toInt()
                        endY = event.y.toInt()
                        invalidate()

                    }
                }

            return true

        }
    }

}

1 Ответ

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

Вы не ссылались на кнопку после

setContentView(R.layout.activity_main)

как

button1 = findViewById(R.id.btn1)
...