2013-09-20 22:23:13 +08:00
|
|
|
/****************************************************************************
|
2018-01-29 16:25:32 +08:00
|
|
|
Copyright (c) 2013-2016 Chukong Technologies Inc.
|
|
|
|
Copyright (c) 2017-2018 Xiamen Yaji Software Co., Ltd.
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2022-10-01 16:24:52 +08:00
|
|
|
https://axmolengine.github.io/
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2013-09-20 22:23:13 +08:00
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
|
|
in the Software without restriction, including without limitation the rights
|
|
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
|
|
furnished to do so, subject to the following conditions:
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2013-09-20 22:23:13 +08:00
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
all copies or substantial portions of the Software.
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2013-09-20 22:23:13 +08:00
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
THE SOFTWARE.
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#ifndef __CCEVENT_H__
|
|
|
|
#define __CCEVENT_H__
|
|
|
|
|
2023-06-11 13:08:08 +08:00
|
|
|
#include "base/Ref.h"
|
|
|
|
#include "platform/PlatformMacros.h"
|
2013-09-20 22:23:13 +08:00
|
|
|
|
2015-03-24 18:22:52 +08:00
|
|
|
/**
|
|
|
|
* @addtogroup base
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
2022-07-11 17:50:21 +08:00
|
|
|
NS_AX_BEGIN
|
2013-09-20 22:23:13 +08:00
|
|
|
|
|
|
|
class Node;
|
|
|
|
|
2015-03-23 18:39:27 +08:00
|
|
|
/** @class Event
|
|
|
|
* @brief Base class of all kinds of events.
|
2013-09-20 22:23:13 +08:00
|
|
|
*/
|
2022-07-15 19:17:01 +08:00
|
|
|
class AX_DLL Event : public Ref
|
2013-09-20 22:23:13 +08:00
|
|
|
{
|
2013-10-25 10:35:48 +08:00
|
|
|
public:
|
2015-03-23 18:39:27 +08:00
|
|
|
/** Type Event type.*/
|
2013-10-28 16:00:01 +08:00
|
|
|
enum class Type
|
2013-10-25 10:35:48 +08:00
|
|
|
{
|
2013-10-28 16:00:01 +08:00
|
|
|
TOUCH,
|
|
|
|
KEYBOARD,
|
|
|
|
ACCELERATION,
|
2013-10-31 14:19:36 +08:00
|
|
|
MOUSE,
|
2014-05-04 11:44:51 +08:00
|
|
|
FOCUS,
|
2014-06-30 00:28:21 +08:00
|
|
|
GAME_CONTROLLER,
|
2013-10-28 16:00:01 +08:00
|
|
|
CUSTOM
|
2013-10-25 10:35:48 +08:00
|
|
|
};
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2022-03-18 21:46:07 +08:00
|
|
|
/** Constructor */
|
|
|
|
Event(Type type);
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2013-09-20 22:23:13 +08:00
|
|
|
public:
|
2015-03-23 18:39:27 +08:00
|
|
|
/** Destructor.
|
|
|
|
*/
|
2013-09-20 22:23:13 +08:00
|
|
|
virtual ~Event();
|
|
|
|
|
2015-03-23 18:39:27 +08:00
|
|
|
/** Gets the event type.
|
|
|
|
*
|
|
|
|
* @return The event type.
|
|
|
|
*/
|
2016-09-12 09:44:21 +08:00
|
|
|
Type getType() const { return _type; }
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2015-03-23 18:39:27 +08:00
|
|
|
/** Stops propagation for current event.
|
|
|
|
*/
|
2016-09-12 09:44:21 +08:00
|
|
|
void stopPropagation() { _isStopped = true; }
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2015-03-23 18:39:27 +08:00
|
|
|
/** Checks whether the event has been stopped.
|
|
|
|
*
|
|
|
|
* @return True if the event has been stopped.
|
|
|
|
*/
|
2016-09-12 09:44:21 +08:00
|
|
|
bool isStopped() const { return _isStopped; }
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2015-03-23 18:39:27 +08:00
|
|
|
/** Gets current target of the event.
|
|
|
|
* @return The target with which the event associates.
|
2015-09-22 16:08:23 +08:00
|
|
|
* @note It's only available when the event listener is associated with node.
|
2013-09-20 22:23:13 +08:00
|
|
|
* It returns 0 when the listener is associated with fixed priority.
|
|
|
|
*/
|
2016-09-12 09:44:21 +08:00
|
|
|
Node* getCurrentTarget() { return _currentTarget; }
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2013-09-20 22:23:13 +08:00
|
|
|
protected:
|
|
|
|
/** Sets current target */
|
2016-09-12 09:44:21 +08:00
|
|
|
void setCurrentTarget(Node* target) { _currentTarget = target; }
|
2021-12-25 10:04:45 +08:00
|
|
|
|
|
|
|
Type _type; ///< Event type
|
|
|
|
|
2013-09-20 22:23:13 +08:00
|
|
|
bool _isStopped; ///< whether the event has been stopped.
|
|
|
|
Node* _currentTarget; ///< Current target
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2013-09-20 22:23:13 +08:00
|
|
|
friend class EventDispatcher;
|
|
|
|
};
|
|
|
|
|
2022-07-11 17:50:21 +08:00
|
|
|
NS_AX_END
|
2013-09-20 22:23:13 +08:00
|
|
|
|
2015-03-24 18:22:52 +08:00
|
|
|
// end of base group
|
|
|
|
/// @}
|
2013-09-20 22:23:13 +08:00
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
#endif // __CCEVENT_H__
|