1#ifndef Ajax_ScreeMgr_Api_h_
2#define Ajax_ScreeMgr_Api_h_
15#include "colony_config.h"
34#ifndef OPTION_AJAX_SCREEN_MGR_TICK_TIME_MS
35#define OPTION_AJAX_SCREEN_MGR_TICK_TIME_MS 50
41#ifndef OPTION_AJAX_SCREEN_MGR_NAV_STACK_SIZE
42#define OPTION_AJAX_SCREEN_MGR_NAV_STACK_SIZE 3
83 size_t numElementsInNavigtationStackArray,
100 void pop(
unsigned count=1 ) noexcept;
#define AjaxScreenMgrEvent_T
Application specific type for Events.
Definition Event.h:21
Type for 'elements' in the Navigation Stack.
Definition Api.h:61
NavigationElement()
Constructor.
Definition Api.h:64
ScreenApi * m_screenPtr
Screen Pointer.
Definition Api.h:67
This class implements the Screen Manager.
Definition Api.h:57
Cpl::Dm::SubscriberComposer< Api, MpStaticScreenApiPtr > m_obHaltUimMP
Subscriber.
Definition Api.h:142
Cpl::Dm::SubscriberComposer< Api, Cpl::Dm::Mp::Uint32 > m_obEventQueueCountMP
Subscriber.
Definition Api.h:151
void homeScreenMp_changed(MpScreenApiPtr &modelPointThatChanged, Cpl::Dm::SubscriberApi &clientObserver) noexcept
MP Change notification.
void request(OpenMsg &msg)
Starts/initializes the manager.
bool m_shuttingDown
Shutdown flag.
Definition Api.h:196
Cpl::System::TimerComposer< Api > m_timer
20Hz tick timer
Definition Api.h:154
Cpl::Dm::SubscriberComposer< Api, Cpl::Dm::Mp::Bool > m_obSleepReqMP
Subscriber.
Definition Api.h:145
ScreenApi * m_curScreenHdl
Current Screen.
Definition Api.h:184
StaticScreenApi * m_pendingHaltScr
Pending transition to the error screen.
Definition Api.h:190
Cpl::Dm::Mp::Bool & m_mpDisplaySleepRequest
Sleep request MP (true:= turn off the display)
Definition Api.h:163
void shutdownMp_changed(MpStaticScreenApiPtr &modelPointThatChanged, Cpl::Dm::SubscriberApi &clientObserver) noexcept
MP Change notification.
uint32_t m_timerMarker
Timer marker of last Tick call.
Definition Api.h:187
void popTo(ScreenApi &returnToScreen) noexcept
See Ajax::ScreenMgr::Navigation.
Cpl::Dm::SubscriberComposer< Api, MpStaticScreenApiPtr > m_obShutdownReqMP
Subscriber.
Definition Api.h:148
void eventQueueCountMp_changed(Cpl::Dm::Mp::Uint32 &modelPointThatChanged, Cpl::Dm::SubscriberApi &clientObserver) noexcept
MP Change notification.
bool m_halted
The UI is halted (due to an application error)
Definition Api.h:193
Cpl::Container::RingBufferMP< AjaxScreenMgrEvent_T > & m_eventQueue
Thread safe Event queue.
Definition Api.h:175
void transitionToHaltScreen() noexcept
Helper method.
Api(Cpl::Dm::MailboxServer &uiMbox, MpScreenApiPtr &homeScreenMP, MpStaticScreenApiPtr &haltUiMP, Cpl::Dm::Mp::Bool &displaySleepRequestMP, MpStaticScreenApiPtr &shutdownMP, DisplayApi &display, NavigationElement memoryForNavigationStack[], size_t numElementsInNavigtationStackArray, Cpl::Container::RingBufferMP< AjaxScreenMgrEvent_T > &eventRingBuffer)
Constructor.
MpStaticScreenApiPtr & m_mpHaltUi
Halt screen MP.
Definition Api.h:160
Cpl::Dm::SubscriberComposer< Api, MpScreenApiPtr > m_obHomeScreenMP
Subscriber.
Definition Api.h:139
bool isCurrentScreenHaltError() noexcept
See Ajax::ScreenMgr::Navigation.
void haltUiMp_changed(MpStaticScreenApiPtr &modelPointThatChanged, Cpl::Dm::SubscriberApi &clientObserver) noexcept
MP Change notification.
bool m_opened
My open state.
Definition Api.h:199
MpScreenApiPtr & m_mpHomeScreen
Home screen MP.
Definition Api.h:157
Cpl::Container::DList< NavigationElement > m_freeStackMemoryList
Free 'memory' for the navigation stack.
Definition Api.h:178
void popToHome() noexcept
See Ajax::ScreenMgr::Navigation.
Cpl::Container::DList< NavigationElement > m_navigationStack
The Navigation stack.
Definition Api.h:181
MpStaticScreenApiPtr & m_mpShutdownScreen
Shutdown request MP.
Definition Api.h:166
DisplayApi & m_display
Handle to the 'display'.
Definition Api.h:172
void request(CloseMsg &msg)
Shutdowns the manager.
void sleepRequestMp_changed(Cpl::Dm::Mp::Bool &modelPointThatChanged, Cpl::Dm::SubscriberApi &clientObserver) noexcept
MP Change notification.
ScreenApi * m_homeScreenHdl
Current Home Screen Handle.
Definition Api.h:169
void timerExpired(void)
20Hz timer expired
ScreenApi * getCurrentScreen() noexcept
See Ajax::ScreenMgr::Navigation.
void push(ScreenApi &newScreen) noexcept
See Ajax::ScreenMgr::Navigation.
void pop(unsigned count=1) noexcept
See Ajax::ScreenMgr::Navigation.
This class defines the Screen Manager's interface to Graphic library.
Definition DisplayApi.h:29
This class provides a concrete implementation for a Point who's data is a ScreenApi pointer.
Definition MpScreenApiPtr.h:41
This class provides a concrete implementation for a Point who's data is a StaticScreenApi pointer.
Definition MpStaticScreenApiPtr.h:42
This class defines the interface - used by ScreenApi instances - to navigate to other screen instance...
Definition Navigation.h:27
This class defines the interface for a 'Screen'.
Definition ScreenApi.h:31
This class defines interface for Screens that only contain static data.
Definition StaticScreenApi.h:31
This class is used by the Container classes to implement a various types of DOUBLY linked containers.
Definition Item.h:91
This template class implements a THREAD SAFE Ring Buffer.
Definition RingBufferMT.h:33
This class extends the Cpl::Dm::EventLoop and Cpl::Itc:Mailbox classes to support the asynchronous ch...
Definition MailboxServer.h:43
This class provides a concrete implementation for a Point who's data is a bool.
Definition Bool.h:40
This partially concrete class implements the synchronous ITC close call for the CloseApi.
Definition CloseSync.h:34
This template class represents a service request message to a particular server.
Definition RequestMessage.h:34
The 'Ajax' namespace is the root name space all GM6000 application specific source code.
The 'Cpl' namespace is the root name space for the Colony.
Definition Api16.h:20