2015-08-12 10:53:41 +00:00
|
|
|
/**
|
|
|
|
* Class definition for a MicroBitEvent.
|
|
|
|
*
|
|
|
|
* The MicroBitEvent is the event object that represents an event that has occurred on the ubit.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "MicroBit.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructor.
|
|
|
|
* @param src ID of the MicroBit Component that generated the event e.g. MICROBIT_ID_BUTTON_A.
|
|
|
|
* @param value Component specific code indicating the cause of the event.
|
|
|
|
* @param fire whether the event should be fire immediately upon construction
|
|
|
|
*
|
|
|
|
* Example:
|
|
|
|
* @code
|
|
|
|
* MicrobitEvent evt(id,MICROBIT_BUTTON_EVT_CLICK,true); // auto fire
|
|
|
|
* @endcode
|
|
|
|
*/
|
2015-09-12 10:34:16 +00:00
|
|
|
MicroBitEvent::MicroBitEvent(uint16_t source, uint16_t value, MicroBitEventLaunchMode mode)
|
2015-08-12 10:53:41 +00:00
|
|
|
{
|
|
|
|
this->source = source;
|
|
|
|
this->value = value;
|
|
|
|
this->timestamp = ticks;
|
|
|
|
|
2015-09-12 10:34:16 +00:00
|
|
|
if(mode != CREATE_ONLY)
|
|
|
|
this->fire(mode);
|
2015-08-12 10:53:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Default constructor - initialises all values, and sets timestamp to the current time.
|
|
|
|
*/
|
|
|
|
MicroBitEvent::MicroBitEvent()
|
|
|
|
{
|
|
|
|
this->source = 0;
|
|
|
|
this->value = 0;
|
|
|
|
this->timestamp = ticks;
|
|
|
|
}
|
|
|
|
|
2015-09-12 10:34:16 +00:00
|
|
|
/**
|
2015-11-23 19:46:20 +00:00
|
|
|
* Fires the represented event onto the default message bus.
|
2015-09-12 10:34:16 +00:00
|
|
|
*/
|
|
|
|
void MicroBitEvent::fire(MicroBitEventLaunchMode mode)
|
|
|
|
{
|
|
|
|
if (mode == CREATE_AND_QUEUE)
|
2015-11-23 19:46:20 +00:00
|
|
|
MicroBitMessageBus::defaultMessageBus->send(*this);
|
2015-09-12 10:34:16 +00:00
|
|
|
|
|
|
|
else if (mode == CREATE_AND_FIRE)
|
2015-11-23 19:46:20 +00:00
|
|
|
MicroBitMessageBus::defaultMessageBus->process(*this);
|
2015-09-12 10:34:16 +00:00
|
|
|
}
|
|
|
|
|
2015-08-12 10:53:41 +00:00
|
|
|
/**
|
|
|
|
* Fires the represented event onto the message bus.
|
|
|
|
*/
|
|
|
|
void MicroBitEvent::fire()
|
|
|
|
{
|
2015-09-12 10:34:16 +00:00
|
|
|
fire(MICROBIT_EVENT_DEFAULT_LAUNCH_MODE);
|
2015-08-12 10:53:41 +00:00
|
|
|
}
|
2015-09-11 15:39:38 +00:00
|
|
|
|
2015-09-12 10:34:16 +00:00
|
|
|
|
2015-09-11 15:39:38 +00:00
|
|
|
/**
|
|
|
|
* Constructor.
|
|
|
|
* Create a new MicroBitEventQueueItem.
|
|
|
|
* @param evt The event to be queued.
|
|
|
|
*/
|
|
|
|
MicroBitEventQueueItem::MicroBitEventQueueItem(MicroBitEvent evt)
|
|
|
|
{
|
|
|
|
this->evt = evt;
|
|
|
|
this->next = NULL;
|
|
|
|
}
|
|
|
|
|