Is there any difference between OnTouchListener
and OnClickListener
? I am not asking from programming point of view, but from User Experience point
OnClickListener
- is used for a basic purpose, when we just need a click from a user i.e., click of a button, no drag or gestures on the screen
OnTouchListener
is basically a more fine-tuned control than OnClickListener. It performs and action on a press/ release on the screen It allows user with combination of move,down-touch,up-touch,finger drag or any movement gesture on the screen
One good reason to use ontouch events over onclick events is to get a faster response upon the user click. Where the onclick event suffers a delay in responding and proceeding with required action. ontouch events are better for delivering high performing mobile web apps.
Prefer to use onTouch. Give you an example: when you have a ViewPager and a TextView in it. if you implement setOnClickListener on textView, you will not be able to swipe the ViewPager when you touch/swipe on the TextView
A "Touch" event is when someone puts their finger on the screen. It gets called throughout the movement of the finger, down, drag, and up. A "Click" need not even come from the screen. It could be someone pressing the enter key.
Use OnTouchListener
when you want to receive events from someone's finger on the screen.
Use OnClickListener
when you want to detect clicks.
onClickListener
is used whenever a click event for any view is raised, say for example: click event for Button, ImageButton.
onTouchListener
is used whenever you want to implement Touch kind of functionality, say for example if you want to get co-ordinates of screen where you touch exactly.
from official doc, definition for both are:
onClickListner
: Interface definition for a callback to be invoked when a view is clicked.onTouchListener
: Interface definition for a callback to be invoked when a touch event is dispatched to this view. The callback will be invoked before the touch event is given to the view.which one is better to use?
It really depends on your requirement.
onTouch
gives you Motion Event. Thus, you can do a lot of fancy things as it help you separate state of movement. Just to name a few:
Those are common actions we usually implement to get desire result such as dragging view on screen.
On the other hand, onClick
doesn't give you much except which view user interacts. onClick
is a complete event comprising of focusing,pressing and releasing. So, you have little control over it. One side up is it is very simple to implement.
do we need to implement both?
It is not necessary unless you want to mess up with your user. If you just want simple click event, go for onClick
. If you want more than click, go for onTouch
. Doing both will complicate the process.
From User point of view, it is unnoticeable if you implement onTouch
carefully to look like onClick
.