mirror of https://github.com/stella-emu/stella.git
refactored UI ticks
This commit is contained in:
parent
54055126e5
commit
df16dcbe50
|
@ -76,7 +76,7 @@ class DebuggerDialog : public Dialog
|
||||||
void saveConfig() override;
|
void saveConfig() override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void center() override { positionAt(0); }
|
void setPosition() override { positionAt(0); }
|
||||||
void loadConfig() override;
|
void loadConfig() override;
|
||||||
void handleKeyDown(StellaKey key, StellaMod mod, bool repeated) override;
|
void handleKeyDown(StellaKey key, StellaMod mod, bool repeated) override;
|
||||||
void handleCommand(CommandSender* sender, int cmd, int data, int id) override;
|
void handleCommand(CommandSender* sender, int cmd, int data, int id) override;
|
||||||
|
|
|
@ -100,7 +100,7 @@ void RomListSettings::show(uInt32 x, uInt32 y, const Common::Rect& bossRect, int
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void RomListSettings::center()
|
void RomListSettings::setPosition()
|
||||||
{
|
{
|
||||||
// First set position according to original coordinates
|
// First set position according to original coordinates
|
||||||
surface().setDstPos(_xorig, _yorig);
|
surface().setDstPos(_xorig, _yorig);
|
||||||
|
|
|
@ -38,8 +38,8 @@ class RomListSettings : public Dialog, public CommandSender
|
||||||
('data' will be the currently selected line number in RomListWidget) */
|
('data' will be the currently selected line number in RomListWidget) */
|
||||||
void show(uInt32 x, uInt32 y, const Common::Rect& bossRect, int data = -1);
|
void show(uInt32 x, uInt32 y, const Common::Rect& bossRect, int data = -1);
|
||||||
|
|
||||||
/** This dialog uses its own positioning, so we override Dialog::center() */
|
/** This dialog uses its own positioning, so we override Dialog::setPosition() */
|
||||||
void center() override;
|
void setPosition() override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
uInt32 _xorig{0}, _yorig{0};
|
uInt32 _xorig{0}, _yorig{0};
|
||||||
|
|
|
@ -351,6 +351,7 @@ void FrameBuffer::update(bool force)
|
||||||
#ifdef GUI_SUPPORT
|
#ifdef GUI_SUPPORT
|
||||||
case EventHandlerState::OPTIONSMENU:
|
case EventHandlerState::OPTIONSMENU:
|
||||||
{
|
{
|
||||||
|
myOSystem.menu().tick();
|
||||||
redraw |= myOSystem.menu().needsRedraw();
|
redraw |= myOSystem.menu().needsRedraw();
|
||||||
if(redraw)
|
if(redraw)
|
||||||
{
|
{
|
||||||
|
@ -363,6 +364,7 @@ void FrameBuffer::update(bool force)
|
||||||
|
|
||||||
case EventHandlerState::CMDMENU:
|
case EventHandlerState::CMDMENU:
|
||||||
{
|
{
|
||||||
|
myOSystem.commandMenu().tick();
|
||||||
redraw |= myOSystem.commandMenu().needsRedraw();
|
redraw |= myOSystem.commandMenu().needsRedraw();
|
||||||
if(redraw)
|
if(redraw)
|
||||||
{
|
{
|
||||||
|
@ -375,6 +377,7 @@ void FrameBuffer::update(bool force)
|
||||||
|
|
||||||
case EventHandlerState::MESSAGEMENU:
|
case EventHandlerState::MESSAGEMENU:
|
||||||
{
|
{
|
||||||
|
myOSystem.messageMenu().tick();
|
||||||
redraw |= myOSystem.messageMenu().needsRedraw();
|
redraw |= myOSystem.messageMenu().needsRedraw();
|
||||||
if(redraw)
|
if(redraw)
|
||||||
{
|
{
|
||||||
|
@ -387,6 +390,7 @@ void FrameBuffer::update(bool force)
|
||||||
|
|
||||||
case EventHandlerState::TIMEMACHINE:
|
case EventHandlerState::TIMEMACHINE:
|
||||||
{
|
{
|
||||||
|
myOSystem.timeMachine().tick();
|
||||||
redraw |= myOSystem.timeMachine().needsRedraw();
|
redraw |= myOSystem.timeMachine().needsRedraw();
|
||||||
if(redraw)
|
if(redraw)
|
||||||
{
|
{
|
||||||
|
@ -433,6 +437,7 @@ void FrameBuffer::update(bool force)
|
||||||
|
|
||||||
case EventHandlerState::LAUNCHER:
|
case EventHandlerState::LAUNCHER:
|
||||||
{
|
{
|
||||||
|
myOSystem.launcher().tick();
|
||||||
redraw |= myOSystem.launcher().needsRedraw();
|
redraw |= myOSystem.launcher().needsRedraw();
|
||||||
if(redraw)
|
if(redraw)
|
||||||
myOSystem.launcher().draw(force);
|
myOSystem.launcher().draw(force);
|
||||||
|
@ -445,6 +450,7 @@ void FrameBuffer::update(bool force)
|
||||||
#ifdef DEBUGGER_SUPPORT
|
#ifdef DEBUGGER_SUPPORT
|
||||||
case EventHandlerState::DEBUGGER:
|
case EventHandlerState::DEBUGGER:
|
||||||
{
|
{
|
||||||
|
myOSystem.debugger().tick();
|
||||||
redraw |= myOSystem.debugger().needsRedraw();
|
redraw |= myOSystem.debugger().needsRedraw();
|
||||||
if(redraw)
|
if(redraw)
|
||||||
myOSystem.debugger().draw(force);
|
myOSystem.debugger().draw(force);
|
||||||
|
|
|
@ -77,7 +77,7 @@ void ContextMenu::show(uInt32 x, uInt32 y, const Common::Rect& bossRect, int ite
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void ContextMenu::center()
|
void ContextMenu::setPosition()
|
||||||
{
|
{
|
||||||
// First set position according to original coordinates
|
// First set position according to original coordinates
|
||||||
surface().setDstPos(_xorig, _yorig);
|
surface().setDstPos(_xorig, _yorig);
|
||||||
|
|
|
@ -71,8 +71,8 @@ class ContextMenu : public Dialog, public CommandSender
|
||||||
const string& getSelectedName() const;
|
const string& getSelectedName() const;
|
||||||
const Variant& getSelectedTag() const;
|
const Variant& getSelectedTag() const;
|
||||||
|
|
||||||
/** This dialog uses its own positioning, so we override Dialog::center() */
|
/** This dialog uses its own positioning, so we override Dialog::setPosition() */
|
||||||
void center() override;
|
void setPosition() override;
|
||||||
|
|
||||||
/** The following methods are used when we want to select *and*
|
/** The following methods are used when we want to select *and*
|
||||||
send a command for the new selection. They are only to be used
|
send a command for the new selection. They are only to be used
|
||||||
|
|
|
@ -91,7 +91,7 @@ void Dialog::open()
|
||||||
const uInt32 scale = instance().frameBuffer().hidpiScaleFactor();
|
const uInt32 scale = instance().frameBuffer().hidpiScaleFactor();
|
||||||
_surface->setDstSize(_w * scale, _h * scale);
|
_surface->setDstSize(_w * scale, _h * scale);
|
||||||
|
|
||||||
center();
|
setPosition();
|
||||||
|
|
||||||
if(_myTabList.size())
|
if(_myTabList.size())
|
||||||
// (Re)-build the focus list to use for all widgets of all tabs
|
// (Re)-build the focus list to use for all widgets of all tabs
|
||||||
|
@ -143,32 +143,20 @@ void Dialog::setTitle(const string& title)
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void Dialog::center()
|
void Dialog::setPosition()
|
||||||
{
|
{
|
||||||
positionAt(instance().settings().getInt("dialogpos"));
|
positionAt(instance().settings().getInt("dialogpos"));
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void Dialog::setDirty()
|
|
||||||
{
|
|
||||||
_dirty = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
bool Dialog::isDirty()
|
|
||||||
{
|
|
||||||
return _dirty;
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
bool Dialog::isChainDirty() const
|
bool Dialog::isChainDirty() const
|
||||||
{
|
{
|
||||||
bool dirty = false;
|
bool dirty = false;
|
||||||
|
|
||||||
// Check if widget or any subwidgets are dirty
|
// Recursively check if dialog or any chick dialogs or widgets are dirty
|
||||||
Widget* w = _firstWidget;
|
Widget* w = _firstWidget;
|
||||||
|
|
||||||
while(!dirty && w)
|
while(w && !dirty)
|
||||||
{
|
{
|
||||||
dirty |= w->needsRedraw();
|
dirty |= w->needsRedraw();
|
||||||
w = w->_next;
|
w = w->_next;
|
||||||
|
@ -177,6 +165,19 @@ bool Dialog::isChainDirty() const
|
||||||
return dirty;
|
return dirty;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void Dialog::tick()
|
||||||
|
{
|
||||||
|
// Recursively tick dialog and all child dialogs and widgets
|
||||||
|
Widget* w = _firstWidget;
|
||||||
|
|
||||||
|
while(w)
|
||||||
|
{
|
||||||
|
w->tick();
|
||||||
|
w = w->_next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void Dialog::positionAt(uInt32 pos)
|
void Dialog::positionAt(uInt32 pos)
|
||||||
{
|
{
|
||||||
|
@ -224,7 +225,7 @@ void Dialog::redraw()
|
||||||
return;// false;
|
return;// false;
|
||||||
|
|
||||||
// Draw this dialog
|
// Draw this dialog
|
||||||
center();
|
setPosition();
|
||||||
drawDialog();
|
drawDialog();
|
||||||
render();
|
render();
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,16 +56,13 @@ class Dialog : public GuiObject
|
||||||
bool isVisible() const override { return _visible; }
|
bool isVisible() const override { return _visible; }
|
||||||
bool isOnTop() const { return _onTop; }
|
bool isOnTop() const { return _onTop; }
|
||||||
|
|
||||||
virtual void center();
|
virtual void setPosition();
|
||||||
virtual void drawDialog();
|
virtual void drawDialog();
|
||||||
virtual void loadConfig() { }
|
virtual void loadConfig() { }
|
||||||
virtual void saveConfig() { }
|
virtual void saveConfig() { }
|
||||||
virtual void setDefaults() { }
|
virtual void setDefaults() { }
|
||||||
|
|
||||||
// A dialog being dirty indicates that its underlying surface needs to be
|
void tick() override;
|
||||||
// redrawn and then re-rendered; this is taken care of in ::render()
|
|
||||||
void setDirty() override;
|
|
||||||
bool isDirty() override; // TODO: remove
|
|
||||||
bool isChainDirty() const override;
|
bool isChainDirty() const override;
|
||||||
void redraw();
|
void redraw();
|
||||||
void render();
|
void render();
|
||||||
|
|
|
@ -107,6 +107,13 @@ void DialogContainer::draw(bool full)
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void DialogContainer::tick()
|
||||||
|
{
|
||||||
|
if(!myDialogStack.empty())
|
||||||
|
myDialogStack.top()->tick();
|
||||||
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void DialogContainer::render()
|
void DialogContainer::render()
|
||||||
{
|
{
|
||||||
|
|
|
@ -119,6 +119,11 @@ class DialogContainer
|
||||||
*/
|
*/
|
||||||
void handleJoyHatEvent(int stick, int hat, JoyHatDir hdir, int button);
|
void handleJoyHatEvent(int stick, int hat, JoyHatDir hdir, int button);
|
||||||
|
|
||||||
|
/**
|
||||||
|
Tick the dialog and all its widgets.
|
||||||
|
*/
|
||||||
|
void tick();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Draw the stack of menus (full indicates to redraw all items).
|
Draw the stack of menus (full indicates to redraw all items).
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -62,8 +62,9 @@ void EditableWidget::setText(const string& str, bool)
|
||||||
|
|
||||||
setDirty();
|
setDirty();
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
bool EditableWidget::isDirty()
|
void EditableWidget::tick()
|
||||||
{
|
{
|
||||||
if(_hasFocus && _editable && isVisible() && _boss->isVisible())
|
if(_hasFocus && _editable && isVisible() && _boss->isVisible())
|
||||||
{
|
{
|
||||||
|
@ -75,8 +76,7 @@ bool EditableWidget::isDirty()
|
||||||
_dirty = true;
|
_dirty = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Widget::tick();
|
||||||
return _dirty;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
|
|
@ -67,7 +67,7 @@ class EditableWidget : public Widget, public CommandSender
|
||||||
protected:
|
protected:
|
||||||
void receivedFocusWidget() override;
|
void receivedFocusWidget() override;
|
||||||
void lostFocusWidget() override;
|
void lostFocusWidget() override;
|
||||||
bool isDirty() override;
|
void tick() override;
|
||||||
|
|
||||||
virtual void startEditMode() { setFlags(Widget::FLAG_WANTS_RAWDATA); }
|
virtual void startEditMode() { setFlags(Widget::FLAG_WANTS_RAWDATA); }
|
||||||
virtual void endEditMode() { clearFlags(Widget::FLAG_WANTS_RAWDATA); }
|
virtual void endEditMode() { clearFlags(Widget::FLAG_WANTS_RAWDATA); }
|
||||||
|
|
|
@ -91,11 +91,15 @@ class GuiObject : public CommandReceiver
|
||||||
virtual void setHeight(int h) { _h = h; }
|
virtual void setHeight(int h) { _h = h; }
|
||||||
|
|
||||||
virtual bool isVisible() const = 0;
|
virtual bool isVisible() const = 0;
|
||||||
virtual void setDirty() = 0;
|
virtual void setDirty() { _dirty = true; }
|
||||||
virtual void clearDirty() { _dirty = false; }
|
virtual void clearDirty() { _dirty = false; }
|
||||||
virtual bool isDirty() { return _dirty; }
|
|
||||||
|
virtual void tick() = 0;
|
||||||
|
virtual bool isDirty() const { return _dirty; }
|
||||||
virtual bool isChainDirty() const = 0;
|
virtual bool isChainDirty() const = 0;
|
||||||
virtual bool needsRedraw() { return isDirty() || isChainDirty(); };
|
// The GUI indicates if its underlying surface needs to be redrawn
|
||||||
|
// and then re-rendered
|
||||||
|
virtual bool needsRedraw() { return isDirty() || isChainDirty(); }
|
||||||
|
|
||||||
void setFlags(uInt32 flags)
|
void setFlags(uInt32 flags)
|
||||||
{
|
{
|
||||||
|
|
|
@ -130,7 +130,7 @@ void InputTextDialog::show(uInt32 x, uInt32 y, const Common::Rect& bossRect)
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void InputTextDialog::center()
|
void InputTextDialog::setPosition()
|
||||||
{
|
{
|
||||||
if(!myEnableCenter)
|
if(!myEnableCenter)
|
||||||
{
|
{
|
||||||
|
@ -144,7 +144,7 @@ void InputTextDialog::center()
|
||||||
surface().setDstPos(myXOrig, myYOrig);
|
surface().setDstPos(myXOrig, myYOrig);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
Dialog::center();
|
Dialog::setPosition();
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
|
|
@ -58,7 +58,7 @@ class InputTextDialog : public Dialog, public CommandSender
|
||||||
void handleCommand(CommandSender* sender, int cmd, int data, int id) override;
|
void handleCommand(CommandSender* sender, int cmd, int data, int id) override;
|
||||||
|
|
||||||
/** This dialog uses its own positioning, so we override Dialog::center() */
|
/** This dialog uses its own positioning, so we override Dialog::center() */
|
||||||
void center() override;
|
void setPosition() override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
vector<EditTextWidget*> myInput;
|
vector<EditTextWidget*> myInput;
|
||||||
|
|
|
@ -101,7 +101,7 @@ class LauncherDialog : public Dialog
|
||||||
static constexpr int MIN_ROMINFO_ROWS = 7; // full lines
|
static constexpr int MIN_ROMINFO_ROWS = 7; // full lines
|
||||||
static constexpr int MIN_ROMINFO_LINES = 4; // extra lines
|
static constexpr int MIN_ROMINFO_LINES = 4; // extra lines
|
||||||
|
|
||||||
void center() override { positionAt(0); }
|
void setPosition() override { positionAt(0); }
|
||||||
void handleKeyDown(StellaKey key, StellaMod mod, bool repeated) override;
|
void handleKeyDown(StellaKey key, StellaMod mod, bool repeated) override;
|
||||||
void handleMouseDown(int x, int y, MouseButton b, int clickCount) override;
|
void handleMouseDown(int x, int y, MouseButton b, int clickCount) override;
|
||||||
void handleCommand(CommandSender* sender, int cmd, int data, int id) override;
|
void handleCommand(CommandSender* sender, int cmd, int data, int id) override;
|
||||||
|
|
|
@ -297,7 +297,7 @@ TimeMachineDialog::TimeMachineDialog(OSystem& osystem, DialogContainer& parent,
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void TimeMachineDialog::center()
|
void TimeMachineDialog::setPosition()
|
||||||
{
|
{
|
||||||
// Place on the bottom of the screen, centered horizontally
|
// Place on the bottom of the screen, centered horizontally
|
||||||
const Common::Size& screen = instance().frameBuffer().screenSize();
|
const Common::Size& screen = instance().frameBuffer().screenSize();
|
||||||
|
|
|
@ -44,8 +44,8 @@ class TimeMachineDialog : public Dialog
|
||||||
/** initialize timeline bar */
|
/** initialize timeline bar */
|
||||||
void initBar();
|
void initBar();
|
||||||
|
|
||||||
/** This dialog uses its own positioning, so we override Dialog::center() */
|
/** This dialog uses its own positioning, so we override Dialog::setPosition() */
|
||||||
void center() override;
|
void setPosition() override;
|
||||||
|
|
||||||
/** convert cycles into time */
|
/** convert cycles into time */
|
||||||
string getTimeString(uInt64 cycles);
|
string getTimeString(uInt64 cycles);
|
||||||
|
|
|
@ -51,48 +51,36 @@ Widget::~Widget()
|
||||||
_focusList.clear();
|
_focusList.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void Widget::setDirty()
|
|
||||||
{
|
|
||||||
// A widget being dirty indicates that its parent dialog is dirty
|
|
||||||
// So we inform the parent about it
|
|
||||||
//_boss->dialog().setDirty();
|
|
||||||
//cerr << "set dirty " << typeid(*this).name() << endl;
|
|
||||||
|
|
||||||
_dirty = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
bool Widget::isDirty()
|
|
||||||
{
|
|
||||||
//string name = typeid(*this).name();
|
|
||||||
//if(_dirty && name == "class TabWidget")
|
|
||||||
// cerr << "is dirty " << typeid(*this).name() << endl;
|
|
||||||
|
|
||||||
return _dirty;
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
bool Widget::isChainDirty() const
|
bool Widget::isChainDirty() const
|
||||||
{
|
{
|
||||||
string name = typeid(*this).name();
|
|
||||||
if(_dirty && name == "class TabWidget")
|
|
||||||
cerr << "is chain dirty " << typeid(*this).name() << endl;
|
|
||||||
|
|
||||||
bool dirty = false;
|
bool dirty = false;
|
||||||
|
|
||||||
// Check if widget or any subwidgets are dirty
|
// Recursively check if widget or any child dialogs or widgets are dirty
|
||||||
Widget* w = _firstWidget;
|
Widget* w = _firstWidget;
|
||||||
|
|
||||||
while(!dirty && w)
|
while(w && !dirty)
|
||||||
{
|
{
|
||||||
dirty |= w->isDirty();
|
dirty |= w->needsRedraw();
|
||||||
w = w->_next;
|
w = w->_next;
|
||||||
}
|
}
|
||||||
|
|
||||||
return dirty;
|
return dirty;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void Widget::tick()
|
||||||
|
{
|
||||||
|
// Recursively tick widget and all child dialogs and widgets
|
||||||
|
Widget* w = _firstWidget;
|
||||||
|
|
||||||
|
while(w)
|
||||||
|
{
|
||||||
|
w->tick();
|
||||||
|
w = w->_next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void Widget::draw()
|
void Widget::draw()
|
||||||
{
|
{
|
||||||
|
|
|
@ -69,8 +69,7 @@ class Widget : public GuiObject
|
||||||
virtual bool handleJoyHat(int stick, int hat, JoyHatDir hdir, int button = JOY_CTRL_NONE) { return false; }
|
virtual bool handleJoyHat(int stick, int hat, JoyHatDir hdir, int button = JOY_CTRL_NONE) { return false; }
|
||||||
virtual bool handleEvent(Event::Type event) { return false; }
|
virtual bool handleEvent(Event::Type event) { return false; }
|
||||||
|
|
||||||
void setDirty() override;
|
void tick() override;
|
||||||
bool isDirty() override; // TODO: remove
|
|
||||||
bool isChainDirty() const override;
|
bool isChainDirty() const override;
|
||||||
void draw() override;
|
void draw() override;
|
||||||
void receivedFocus();
|
void receivedFocus();
|
||||||
|
|
Loading…
Reference in New Issue