mirror of https://github.com/stella-emu/stella.git
removed +/-10 buttons for TimeMachineDialog
updated documentation
This commit is contained in:
parent
f56286fac9
commit
6d1c5b1301
Binary file not shown.
After Width: | Height: | Size: 2.2 KiB |
|
@ -1622,32 +1622,38 @@
|
||||||
</tr>
|
</tr>
|
||||||
|
|
||||||
<tr>
|
<tr>
|
||||||
<td>Rewind by one state (pauses emulation)</td>
|
<td>Enter/Exit the <a href="#TimeMachine"><b>Time Machine</b></a> dialog</td>
|
||||||
|
<td>t/Escape</td>
|
||||||
|
<td>t/Escape</td>
|
||||||
|
</tr>
|
||||||
|
|
||||||
|
<tr>
|
||||||
|
<td>Rewind by one state (enters the <a href="#TimeMachine"><b>Time Machine</b></a> dialog)</td>
|
||||||
<td>Alt + Left arrow</td>
|
<td>Alt + Left arrow</td>
|
||||||
<td>Cmd + Left arrow</td>
|
<td>Cmd + Left arrow</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>Rewind by 10 states (pauses emulation)</td>
|
<td>Rewind by 10 states (enters the <a href="#TimeMachine"><b>Time Machine</b></a> dialog)</td>
|
||||||
<td>Shift-Alt + Left arrow</td>
|
<td>Shift-Alt + Left arrow</td>
|
||||||
<td>Shift-Cmd + Left arrow</td>
|
<td>Shift-Cmd + Left arrow</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>Rewind all states (pauses emulation)</td>
|
<td>Rewind all states (enters the <a href="#TimeMachine"><b>Time Machine</b></a> dialog)</td>
|
||||||
<td>Alt + Down arrow</td>
|
<td>Alt + Down arrow</td>
|
||||||
<td>Cmd + Down arrow</td>
|
<td>Cmd + Down arrow</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>Unwind by one state (pauses emulation)</td>
|
<td>Unwind by one state (enters the <a href="#TimeMachine"><b>Time Machine</b></a> dialog)</td>
|
||||||
<td>Alt + Right arrow</td>
|
<td>Alt + Right arrow</td>
|
||||||
<td>Cmd + Right arrow</td>
|
<td>Cmd + Right arrow</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>Unwind by 10 states (pauses emulation)</td>
|
<td>Unwind by 10 states (enters the <a href="#TimeMachine"><b>Time Machine</b></a> dialog)</td>
|
||||||
<td>Shift-Alt + Right arrow</td>
|
<td>Shift-Alt + Right arrow</td>
|
||||||
<td>Shift-Cmd + Right arrow</td>
|
<td>Shift-Cmd + Right arrow</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>Unwind all states (pauses emulation)</td>
|
<td>Unwind all states (enters the <a href="#TimeMachine"><b>Time Machine</b></a> dialog)</td>
|
||||||
<td>Alt + Up arrow</td>
|
<td>Alt + Up arrow</td>
|
||||||
<td>Cmd + Up arrow</td>
|
<td>Cmd + Up arrow</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
@ -1794,36 +1800,42 @@
|
||||||
<a name="TimeMachine">Stella's 'Time Machine'</a></h2>
|
<a name="TimeMachine">Stella's 'Time Machine'</a></h2>
|
||||||
|
|
||||||
<p>A special feature of Stella is the 'Time Machine' mode. In this mode, Stella
|
<p>A special feature of Stella is the 'Time Machine' mode. In this mode, Stella
|
||||||
automatically creates savestates in regular, user-defined intervals. You can then
|
automatically creates savestates in regular, user-defined intervals. At any time,
|
||||||
interrupt the current emulation and navigate back and forth within the timeline.
|
the user can interrupt the current emulation and navigate back and forth
|
||||||
|
within the saved timeline.
|
||||||
This can be done either by using the Time Machine hotkeys described in
|
This can be done either by using the Time Machine hotkeys described in
|
||||||
<a href="#Hotkeys"><b>Hotkeys</b> - Other Keys</a> or by using the Time Machine
|
<a href="#Hotkeys"><b>Hotkeys</b> - Other Keys</a> or by using the Time Machine
|
||||||
dialog. To enter this dialog, either use one of the hotkeys or press 'T'.</p>
|
dialog. This dialog is automatically entered when using one of the Time Machine
|
||||||
|
hotkeys. The hotkeys continue to function within the dialog.</p>
|
||||||
|
|
||||||
<p><b>Time Machine</b> dialog:</p>
|
<p><b>Time Machine</b> dialog:</p>
|
||||||
<table border="5" cellpadding="2" frame="box" rules="none">
|
<td><img src="graphics/timemachine.png"></td>
|
||||||
<tr>
|
|
||||||
<td>TODO: Screenshot</td>
|
<p>The dialog items are explained in the following two tables.</p>
|
||||||
<td> </td>
|
|
||||||
<td valign="top">
|
<p><b>Top row (left to right)</b></p>
|
||||||
<table border="1" cellpadding="4">
|
<table border="1" cellpadding="4">
|
||||||
<tr><th>Item</th><th>Description</th></tr>
|
<tr><th>Item</th><th>Description</th></tr>
|
||||||
<tr><td>Button</td><td>TODO</td></tr>
|
<tr><td>Current state</td><td>Shows the currently loaded state</td></tr>
|
||||||
<tr><td>Button</td><td></td></tr>
|
<tr><td>'Time Line' slider</td><td>Shows the position of the current state in the recorded timeline. You can drag the slider with the mouse to select a state.</td></tr>
|
||||||
<tr><td>Button</td><td></td></tr>
|
<tr><td>Total states</td><td>Shows the total number of save states in the Time Machine</td></tr>
|
||||||
<tr><td>Button</td><td></td></tr>
|
</table>
|
||||||
<tr><td>Button</td><td></td></tr>
|
<p><b>Bottom row (left to right)</b></p>
|
||||||
<tr><td>Button</td><td></td></tr>
|
<table border="1" cellpadding="4">
|
||||||
<tr><td>Button</td><td></td></tr>
|
<tr><th>Item</th><th>Description</th></tr>
|
||||||
</table>
|
<tr><td>Current time</td><td>Shows the time of the currently selected status, relative to the first one</td></tr>
|
||||||
</td>
|
<tr><td>'Rewind All' button</td><td>Navigates back to the begin of the timeline</td></tr>
|
||||||
</tr>
|
<tr><td>'Rewind One' button</td><td>Navigates back by one state</td></tr>
|
||||||
</table>
|
<tr><td>'Continue' button</td><td>Exits the dialog and continues emulation.</td></tr>
|
||||||
|
<tr><td>Navigation info</td><td>Informs about the interval of the user's last Time Machine navigation. The interval can vary if the timeline is compressed.</td></tr>
|
||||||
|
<tr><td>'Unwind One' button</td><td>Navigates forward by one state</td></tr>
|
||||||
|
<tr><td>'Unwind All' button</td><td>Navigates forward to the end of the timeline</td></tr>
|
||||||
|
<tr><td>Total time</td><td>Shows the total time covered by the save states (aka 'Horizon')</td></tr>
|
||||||
|
</table>
|
||||||
<br>
|
<br>
|
||||||
|
|
||||||
|
|
||||||
<p>The 'Time Machine' mode can be configured by the user. For details see
|
<p>The 'Time Machine' mode can be configured by the user. For details see
|
||||||
<a href="#Debugger"><b>Developer Options</b> - Time Machine dialog</a></h2>.</p>
|
<a href="#Debugger"><b>Developer Options</b> - Time Machine</a></h2> tab.</p>
|
||||||
|
|
||||||
<!-- ///////////////////////////////////////////////////////////////////////// -->
|
<!-- ///////////////////////////////////////////////////////////////////////// -->
|
||||||
<br><br>
|
<br><br>
|
||||||
|
|
|
@ -75,23 +75,6 @@ TimeMachineDialog::TimeMachineDialog(OSystem& osystem, DialogContainer& parent,
|
||||||
0b0110000110000110,
|
0b0110000110000110,
|
||||||
0
|
0
|
||||||
};
|
};
|
||||||
static uInt32 REWIND_10[BUTTON_H] =
|
|
||||||
{
|
|
||||||
0,
|
|
||||||
0b0000010000100110,
|
|
||||||
0b0000110001100110,
|
|
||||||
0b0001110011100110,
|
|
||||||
0b0011110111100110,
|
|
||||||
0b0111111111100110,
|
|
||||||
0b1111111111100110,
|
|
||||||
0b1111111111100110,
|
|
||||||
0b0111111111100110,
|
|
||||||
0b0011110111100110,
|
|
||||||
0b0001110011100110,
|
|
||||||
0b0000110001100110,
|
|
||||||
0b0000010000100110,
|
|
||||||
0
|
|
||||||
};
|
|
||||||
static uInt32 REWIND_1[BUTTON_H] =
|
static uInt32 REWIND_1[BUTTON_H] =
|
||||||
{
|
{
|
||||||
0,
|
0,
|
||||||
|
@ -126,23 +109,6 @@ TimeMachineDialog::TimeMachineDialog(OSystem& osystem, DialogContainer& parent,
|
||||||
0b0011100011000000,
|
0b0011100011000000,
|
||||||
0
|
0
|
||||||
};
|
};
|
||||||
static uInt32 UNWIND_10[BUTTON_H] =
|
|
||||||
{
|
|
||||||
0,
|
|
||||||
0b0110010000100000,
|
|
||||||
0b0110011000110000,
|
|
||||||
0b0110011100111000,
|
|
||||||
0b0110011110111100,
|
|
||||||
0b0110011111111110,
|
|
||||||
0b0110011111111111,
|
|
||||||
0b0110011111111111,
|
|
||||||
0b0110011111111110,
|
|
||||||
0b0110011110111100,
|
|
||||||
0b0110011100111000,
|
|
||||||
0b0110011000110000,
|
|
||||||
0b0110010000100000,
|
|
||||||
0
|
|
||||||
};
|
|
||||||
static uInt32 UNWIND_ALL[BUTTON_H] =
|
static uInt32 UNWIND_ALL[BUTTON_H] =
|
||||||
{
|
{
|
||||||
0,
|
0,
|
||||||
|
@ -208,10 +174,6 @@ TimeMachineDialog::TimeMachineDialog(OSystem& osystem, DialogContainer& parent,
|
||||||
BUTTON_W, BUTTON_H, kRewindAll);
|
BUTTON_W, BUTTON_H, kRewindAll);
|
||||||
xpos += buttonWidth + BUTTON_GAP;
|
xpos += buttonWidth + BUTTON_GAP;
|
||||||
|
|
||||||
myRewind10Widget = new ButtonWidget(this, font, xpos, ypos, buttonWidth, buttonHeight, REWIND_10,
|
|
||||||
BUTTON_W, BUTTON_H, kRewind10);
|
|
||||||
xpos += buttonWidth + BUTTON_GAP;
|
|
||||||
|
|
||||||
myRewind1Widget = new ButtonWidget(this, font, xpos, ypos, buttonWidth, buttonHeight, REWIND_1,
|
myRewind1Widget = new ButtonWidget(this, font, xpos, ypos, buttonWidth, buttonHeight, REWIND_1,
|
||||||
BUTTON_W, BUTTON_H, kRewind1);
|
BUTTON_W, BUTTON_H, kRewind1);
|
||||||
xpos += buttonWidth + BUTTON_GAP*2;
|
xpos += buttonWidth + BUTTON_GAP*2;
|
||||||
|
@ -224,10 +186,6 @@ TimeMachineDialog::TimeMachineDialog(OSystem& osystem, DialogContainer& parent,
|
||||||
BUTTON_W, BUTTON_H, kUnwind1);
|
BUTTON_W, BUTTON_H, kUnwind1);
|
||||||
xpos += buttonWidth + BUTTON_GAP;
|
xpos += buttonWidth + BUTTON_GAP;
|
||||||
|
|
||||||
myUnwind10Widget = new ButtonWidget(this, font, xpos, ypos, buttonWidth, buttonHeight, UNWIND_10,
|
|
||||||
BUTTON_W, BUTTON_H, kUnwind10);
|
|
||||||
xpos += buttonWidth + BUTTON_GAP;
|
|
||||||
|
|
||||||
myUnwindAllWidget = new ButtonWidget(this, font, xpos, ypos, buttonWidth, buttonHeight, UNWIND_ALL,
|
myUnwindAllWidget = new ButtonWidget(this, font, xpos, ypos, buttonWidth, buttonHeight, UNWIND_ALL,
|
||||||
BUTTON_W, BUTTON_H, kUnwindAll);
|
BUTTON_W, BUTTON_H, kUnwindAll);
|
||||||
xpos = myUnwindAllWidget->getRight() + BUTTON_GAP * 3;
|
xpos = myUnwindAllWidget->getRight() + BUTTON_GAP * 3;
|
||||||
|
@ -405,9 +363,7 @@ void TimeMachineDialog::handleWinds(Int32 numWinds)
|
||||||
myLastIdxWidget->setValue(r.getLastIdx());
|
myLastIdxWidget->setValue(r.getLastIdx());
|
||||||
// Enable/disable buttons
|
// Enable/disable buttons
|
||||||
myRewindAllWidget->setEnabled(!r.atFirst());
|
myRewindAllWidget->setEnabled(!r.atFirst());
|
||||||
myRewind10Widget->setEnabled(!r.atFirst());
|
|
||||||
myRewind1Widget->setEnabled(!r.atFirst());
|
myRewind1Widget->setEnabled(!r.atFirst());
|
||||||
myUnwindAllWidget->setEnabled(!r.atLast());
|
myUnwindAllWidget->setEnabled(!r.atLast());
|
||||||
myUnwind10Widget->setEnabled(!r.atLast());
|
|
||||||
myUnwind1Widget->setEnabled(!r.atLast());
|
myUnwind1Widget->setEnabled(!r.atLast());
|
||||||
}
|
}
|
||||||
|
|
|
@ -61,10 +61,8 @@ class TimeMachineDialog : public Dialog
|
||||||
|
|
||||||
ButtonWidget* myPlayWidget;
|
ButtonWidget* myPlayWidget;
|
||||||
ButtonWidget* myRewindAllWidget;
|
ButtonWidget* myRewindAllWidget;
|
||||||
ButtonWidget* myRewind10Widget;
|
|
||||||
ButtonWidget* myRewind1Widget;
|
ButtonWidget* myRewind1Widget;
|
||||||
ButtonWidget* myUnwind1Widget;
|
ButtonWidget* myUnwind1Widget;
|
||||||
ButtonWidget* myUnwind10Widget;
|
|
||||||
ButtonWidget* myUnwindAllWidget;
|
ButtonWidget* myUnwindAllWidget;
|
||||||
|
|
||||||
StaticTextWidget* myCurrentTimeWidget;
|
StaticTextWidget* myCurrentTimeWidget;
|
||||||
|
|
Loading…
Reference in New Issue