8

我正在动态地将 ImageViews 添加到父布局,onTouch并对添加的图像执行放大/缩小操作。

我想用onLongPress它删除添加的视图。

img.setOnLongClickListener(longClickAction);
img.setOnTouchListener(touchAction); 
 

长按:

OnLongClickListener longClickAction = new OnLongClickListener() {
    @Override
    public boolean onLongClick(View v) {
        parentLayout.removeView((ImageView)v);
        return false;
    }
};

触摸:

OnTouchListener touchAction = new OnTouchListener() {
    @Override
    public boolean onTouch(View v, MotionEvent event) {
        ImageView i = (ImageView)v;

        // Perform zoom operation onTouch of ImageView
        zoom(i, event);
        return true; 
    }
};

为什么只有 onTouch 事件有效?

我怎样才能让他们都工作?

我应该怎么做才能删除添加的视图?

4

6 回答 6

21

onTouch总是为您的视图调用,因为这是将事件分派到视图的初始状态。当您长按您的视图时,它仍然会首先调用,onTouch并且由于您返回(这意味着您已经使用了此事件并且不应进一步分派它),您将不会被调用。诀窍是返回trueonTouchonLongPressfalseonTouch

于 2012-06-08T10:09:56.610 回答
2

正如@asenovm 所讨论的,onTouch () 总是被调用,因为它是将事件分派到视图的初始状态,但如果我们在onTouch()中返回值false ,那么两者都会像魅力一样工作,问题就会得到解决。

编辑:我对用户的建议是,不要同时实现 OnLongClickListener() 和 OnTouch(),而是尝试在双击事件中使用 OnLongClickListener() 的功能。

您可以通过以下方式实现双击:

int i = 0;
btn.setOnClickListener(new OnClickListener() {

@Override
public void onClick(View v) {
    // TODO Auto-generated method stub
    i++;
    Handler handler = new Handler();
    Runnable r = new Runnable() {

        @Override
        public void run() {
            i = 0;
        }
    };

    if (i == 1) {
        //Single click
        handler.postDelayed(r, 250);
    } else if (i == 2) {
        //Double click
        i = 0;
        ShowDailog();
    }


  }
});
于 2017-01-31T07:55:07.890 回答
1

试试这个,它对我来说很好用。

boolean isMoving= false;

yourView.setOnTouchListener(new View.OnTouchListener(){
    @Override
    public boolean onTouch(View v, MotionEvent event) {
        if (event.getAction() == MotionEvent.ACTION_MOVE) {
            isMoving = true;
            Log.i("isMoving:", "true");
        }
        if(event.getAction()==MotionEvent.ACTION_UP){
            isMoving=false;
            Log.i("isMoving:","false");
        }
        return false;
    }
});
yourView.setOnLongClickListener(new View.OnLongClickListener() {
    @Override
    public boolean onLongClick(View v) {
        if(!isMoving){
            //do onlongclick event here
        }
        return true;
    }
});;
于 2015-07-28T06:41:52.483 回答
0

动态删除控件

可以帮助你

使用 onTouch 和 onLongClick

于 2012-06-08T10:07:01.637 回答
0

如果您需要手指保持静止,那么在Kotlin中最简单的方法就是这样

onCreateView

view.setOnTouchListener(this)
view.setOnClickListener(this)
view.setOnLongClickListener {
    if (! isFingerMoving) {
        Toast.makeText(activity, "Long click detected", Toast.LENGTH_LONG).show()
        //do something
    }
    false
}

onTouch中:

fun onTouch(v: View?, event: MotionEvent): Boolean {
    when (event.actionMasked) {
        MotionEvent.ACTION_DOWN -> {
            isFingerMoving = false
            lastTouchX = event.getX(0)
            lastTouchY = event.getY(0)
            ...
        }
        
        MotionEvent.ACTION_MOVE -> {
            val deltaX = (x - lastTouchX) * event.xPrecision
            val deltaY = (y - lastTouchY) * event.yPrecision
            if ((deltaX.absoluteValue > 0.1) || (deltaY.absoluteValue > 0.1)) 
                isFingerMoving = true            
            ...                 
        }
    }
    return false
}
于 2020-07-21T04:21:58.473 回答
0

您无法通过 setOnLongClickListener 和 setOnTouchListener 一起实现这一点,因为当您在 onTouch 方法中返回 true 时,它​​假定您处理所有触摸事件,您可以通过延迟后实现长点击并在超时后调用方法,但您需要检查是否仍在按下或操作被解雇可能是这个代码快照帮助你

 mBinding.iv2.setOnTouchListener(object : View.OnTouchListener {

        var stillPress = false
        override fun onTouch(view: View?, motionEvent: MotionEvent?): Boolean {
            if(motionEvent?.action == MotionEvent.ACTION_DOWN){
                 stillPress = true
                Handler(Looper.getMainLooper()).postDelayed({
                    if(stillPress)
                        zoomImageFromThumb(view!!,R.drawable.ic_baseline_adb_24)
                },1000)
            }

            if(motionEvent?.action == MotionEvent.ACTION_UP){
                stillPress = false
                mBinding.expandedImage.performClick()
            }
            return true

        }
    })
于 2022-02-07T15:21:30.133 回答