epoger@google.com | ec3ed6a | 2011-07-28 14:26:00 +0000 | [diff] [blame] | 1 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 2 | /* |
epoger@google.com | ec3ed6a | 2011-07-28 14:26:00 +0000 | [diff] [blame] | 3 | * Copyright 2006 The Android Open Source Project |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 4 | * |
epoger@google.com | ec3ed6a | 2011-07-28 14:26:00 +0000 | [diff] [blame] | 5 | * Use of this source code is governed by a BSD-style license that can be |
| 6 | * found in the LICENSE file. |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 7 | */ |
| 8 | |
epoger@google.com | ec3ed6a | 2011-07-28 14:26:00 +0000 | [diff] [blame] | 9 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 10 | #ifndef SkEventSink_DEFINED |
| 11 | #define SkEventSink_DEFINED |
| 12 | |
| 13 | #include "SkRefCnt.h" |
| 14 | #include "SkEvent.h" |
| 15 | |
| 16 | struct SkTagList; |
| 17 | |
| 18 | /** \class SkEventSink |
| 19 | |
| 20 | SkEventSink is the base class for all objects that receive SkEvents. |
| 21 | */ |
| 22 | class SkEventSink : public SkRefCnt { |
| 23 | public: |
robertphillips@google.com | a22e211 | 2012-08-16 14:58:06 +0000 | [diff] [blame] | 24 | SK_DECLARE_INST_COUNT(SkEventSink) |
| 25 | |
| 26 | SkEventSink(); |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 27 | virtual ~SkEventSink(); |
| 28 | |
reed@google.com | 87fac4a | 2011-08-04 13:50:17 +0000 | [diff] [blame] | 29 | /** |
| 30 | * Returns this eventsink's unique ID. Use this to post SkEvents to |
| 31 | * this eventsink. |
| 32 | */ |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 33 | SkEventSinkID getSinkID() const { return fID; } |
| 34 | |
reed@google.com | 87fac4a | 2011-08-04 13:50:17 +0000 | [diff] [blame] | 35 | /** |
| 36 | * Call this to pass an event to this object for processing. Returns true if the |
| 37 | * event was handled. |
| 38 | */ |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 39 | bool doEvent(const SkEvent&); |
reed@google.com | 87fac4a | 2011-08-04 13:50:17 +0000 | [diff] [blame] | 40 | |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 41 | /** Returns true if the sink (or one of its subclasses) understands the event as a query. |
| 42 | If so, the sink may modify the event to communicate its "answer". |
| 43 | */ |
| 44 | bool doQuery(SkEvent* query); |
| 45 | |
reed@google.com | 87fac4a | 2011-08-04 13:50:17 +0000 | [diff] [blame] | 46 | /** |
| 47 | * Add sinkID to the list of listeners, to receive events from calls to sendToListeners() |
| 48 | * and postToListeners(). If sinkID already exists in the listener list, no change is made. |
| 49 | */ |
| 50 | void addListenerID(SkEventSinkID sinkID); |
| 51 | |
| 52 | /** |
| 53 | * Copy listeners from one event sink to another, typically from parent to child. |
| 54 | * @param from the event sink to copy the listeners from |
| 55 | */ |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 56 | void copyListeners(const SkEventSink& from); |
reed@google.com | 87fac4a | 2011-08-04 13:50:17 +0000 | [diff] [blame] | 57 | |
| 58 | /** |
| 59 | * Remove sinkID from the list of listeners. If sinkID does not appear in the list, |
| 60 | * no change is made. |
| 61 | */ |
| 62 | void removeListenerID(SkEventSinkID); |
| 63 | |
| 64 | /** |
| 65 | * Returns true if there are 1 or more listeners attached to this eventsink |
| 66 | */ |
| 67 | bool hasListeners() const; |
| 68 | |
| 69 | /** |
| 70 | * Posts a copy of evt to each of the eventsinks in the lisener list. |
| 71 | * This ignores the targetID and target proc in evt. |
| 72 | */ |
| 73 | void postToListeners(const SkEvent& evt, SkMSec delay = 0); |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 74 | |
| 75 | enum EventResult { |
| 76 | kHandled_EventResult, //!< the eventsink returned true from its doEvent method |
| 77 | kNotHandled_EventResult, //!< the eventsink returned false from its doEvent method |
| 78 | kSinkNotFound_EventResult //!< no matching eventsink was found for the event's getSink(). |
| 79 | }; |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 80 | |
reed@google.com | 87fac4a | 2011-08-04 13:50:17 +0000 | [diff] [blame] | 81 | /** |
| 82 | * DoEvent handles dispatching the event to its target ID or proc. |
| 83 | */ |
| 84 | static EventResult DoEvent(const SkEvent&); |
| 85 | |
| 86 | /** |
| 87 | * Returns the matching eventsink, or null if not found |
| 88 | */ |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 89 | static SkEventSink* FindSink(SkEventSinkID); |
| 90 | |
| 91 | protected: |
| 92 | /** Override this to handle events in your subclass. Be sure to call the inherited version |
| 93 | for events that you don't handle. |
| 94 | */ |
| 95 | virtual bool onEvent(const SkEvent&); |
| 96 | virtual bool onQuery(SkEvent*); |
| 97 | |
| 98 | SkTagList* findTagList(U8CPU tag) const; |
| 99 | void addTagList(SkTagList*); |
| 100 | void removeTagList(U8CPU tag); |
| 101 | |
| 102 | private: |
| 103 | SkEventSinkID fID; |
| 104 | SkTagList* fTagHead; |
| 105 | |
| 106 | // for our private link-list |
| 107 | SkEventSink* fNextSink; |
robertphillips@google.com | a22e211 | 2012-08-16 14:58:06 +0000 | [diff] [blame] | 108 | |
| 109 | typedef SkRefCnt INHERITED; |
reed@android.com | 8a1c16f | 2008-12-17 15:59:43 +0000 | [diff] [blame] | 110 | }; |
| 111 | |
| 112 | #endif |