refactored UI ticks

This commit is contained in:
thrust26 2020-11-12 18:14:26 +01:00
parent 54055126e5
commit df16dcbe50
20 changed files with 80 additions and 73 deletions

View File

@ -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;

View File

@ -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);

View File

@ -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};

View File

@ -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);

View File

@ -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);

View File

@ -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

View File

@ -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();
} }

View File

@ -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();

View File

@ -107,6 +107,13 @@ void DialogContainer::draw(bool full)
}); });
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void DialogContainer::tick()
{
if(!myDialogStack.empty())
myDialogStack.top()->tick();
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void DialogContainer::render() void DialogContainer::render()
{ {

View File

@ -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).
*/ */

View File

@ -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;
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

View File

@ -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); }

View File

@ -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)
{ {

View File

@ -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();
} }
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

View File

@ -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;

View File

@ -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;

View File

@ -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();

View File

@ -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);

View File

@ -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()
{ {

View File

@ -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();