有趣的android触摸问题
我遇到的问题是我正在使用 onTouch 事件的触摸监听器,当我只触摸一次时,触摸似乎被多次调用。 以下是我的代码
final TextView tv = (TextView)findViewById(R.id.TextView01);
tv.setOnTouchListener(new View.OnTouchListener() {
int count1 =0;
int count2=0;
public boolean onTouch(View arg0, MotionEvent event) {
Log.d("Code777","Touch is being called finger");
int i = event.getPointerCount();
if(i==1 )
{
if(count1==0)
{
Log.d("Code777","Touched with 1 finger");
count1++;
count2=0;
}
}
if (i==2 )
{
if(count2==0)
{
Log.d("Code777","Touched with 2 fingers");
edit.append(tv.getText());
count2++;
count1=0;
}
}
return true;
}
});
我做错了什么吗? 对于单点触摸和双点触摸,它打印日志超过 3-4 次
问题更新的问题是,这两个事件现在都被触发
if(event.getAction() == MotionEvent.ACTION_POINTER_2_DOWN)
{
Log.d("Code777","2 finger touch");
return true;
}else if(event.getAction() == MotionEvent.ACTION_DOWN)
{
Log.d("Code777","Touched with 1 finger");
return true;
}
The problem that i am having is I am using a touch listener for the onTouch event it seems that the touch is being called more than once when i just touch it once.
The following is my code
final TextView tv = (TextView)findViewById(R.id.TextView01);
tv.setOnTouchListener(new View.OnTouchListener() {
int count1 =0;
int count2=0;
public boolean onTouch(View arg0, MotionEvent event) {
Log.d("Code777","Touch is being called finger");
int i = event.getPointerCount();
if(i==1 )
{
if(count1==0)
{
Log.d("Code777","Touched with 1 finger");
count1++;
count2=0;
}
}
if (i==2 )
{
if(count2==0)
{
Log.d("Code777","Touched with 2 fingers");
edit.append(tv.getText());
count2++;
count1=0;
}
}
return true;
}
});
Am i doing something wrong ??
It prints the log more than 3-4 times for both single touch and double touch
The problem updated problem is that both the events are getting fired now
if(event.getAction() == MotionEvent.ACTION_POINTER_2_DOWN)
{
Log.d("Code777","2 finger touch");
return true;
}else if(event.getAction() == MotionEvent.ACTION_DOWN)
{
Log.d("Code777","Touched with 1 finger");
return true;
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
您的代码将在每次触摸事件期间执行。第一次激活时,可能会执行
ACITON_DOWN
事件(当用户第一次触摸屏幕时)。第二次,可能是针对ACTION_UP
事件(当用户从屏幕上抬起手指时)。同样,如果您在屏幕上滑动手指,对于ACTION_MOVE
事件,相同的代码将会执行多次。您必须检查触摸的类型。做这样的事情:编辑:
Android 中的多点触控充其量是奇怪的。并非所有设备都能处理它。并非所有设备都可以处理超过 x 次的触摸等。如果您想处理单个手指的向下情况,则可以使用
ACTION_POINTER_X
项。如果您要发生这样的一系列事件:将被触发的事件将如下所示:
等等。
You're code will execute during every touch event. The first time it activates, it's likely do to an
ACITON_DOWN
event (when the user first touches the screen). The second time, it is likely do to anACTION_UP
event (when the user lifts the finger from the screen). Likewise, if you were to swipe your finger around the screen, the same code will execute many times for anACTION_MOVE
event. You have to check for the types of touches that it is. Do something like this:EDIT:
Multitouch in Android is odd at best. Not all devices can handle it. Not all device can handle more than x number of touches, etc. If you want to handle DOWN cases for individual fingers, then you can use the
ACTION_POINTER_X
items. If you were to have this series of events like so:The events that will be fired will be like this:
And so on.
onTouchListener
通过MotionEvents
向您发送多个操作。您可以使用MotionEvent.getAction()
获取当前事件的操作。您在这里注意到的很可能是您收到一个
ACTION_DOWN
(手指已放在显示屏上) 事件,然后是一些小的ACTION_MOVE
事件当您稍微移动手指时。最后您将得到ACTION_UP
(手指已抬起) 您可以通过忽略具有错误操作的事件来过滤掉这些内容。例如,当发生移动事件时,仅从 onTouch() 返回。
或使用开关来区分所有相关事件。
请参阅 MotionEvent 类文档以获取可能操作的列表。
。
An
onTouchListener
sends you multiple actions viaMotionEvents
. You can get the action for the current event withMotionEvent.getAction()
.What you notice here is most likely that you get one
ACTION_DOWN
(a finger has been placed on the display) event followed by some smallACTION_MOVE
events when you move the finger(s) slightly. In the end you will getACTION_UP
(a finger has been lifted) You can filter these out by ignoring events with the wrong action.For example just return from onTouch() when a move event occured.
or use a switch to differentiate between all relevant events.
See the MotionEvent class documentation for a list of possible actions.
.