URL:
The implementation of hitTest:withEvent:
in UIResponder does the following:
It calls
pointInside:withEvent:
ofself
If the return is NO,
hitTest:withEvent:
returnsnil
. the end of the story.If the return is YES, it sends
hitTest:withEvent:
messages to its subviews. it starts from the top-level subview, and continues to other views until a subview returns a non-nil
object, or all subviews receive the message.If a subview returns a non-
nil
object in the first time, the firsthitTest:withEvent:
returns that object. the end of the story.If no subview returns a non-
nil
object, the firsthitTest:withEvent:
returnsself
This process repeats recursively, so normally the leaf view of the view hierarchy is returned eventually.
However, you might override hitTest:withEvent
to do something differently. In many cases, overriding pointInside:withEvent:
is simpler and still provides enough options to tweak event handling in your application.
I think you are confusing subclassing with the view hierarchy. What the doc says is as follows. Say you have this view hierarchy. By hierarchy I'm not talking about class hierarchy, but views within views hierarchy, as follows:
you put your finger inside D
. Here's what will happen:
hitTest:withEvent:
is called onA
, the top-most view of the view hierarchy.pointInside:withEvent:
is called recursively on each view.pointInside:withEvent:
is called onA
, and returnsYES
pointInside:withEvent:
is called onB
, and returnsNO
pointInside:withEvent:
is called onC
, and returnsYES
pointInside:withEvent:
is called onD
, and returnsYES
On the views that returned
YES
, it will look down on the hierarchy to see the subview where the touch took place. In this case, fromA
,C
andD
, it will beD
.D
will be the hit-test view