* Taseditor: changed "Branches only work when Recording" to "Old control scheme for Branching"
* Taseditor: "Auto-adjust Input due to lag" checkbox
|
@ -320,10 +320,11 @@ static CFGSTRUCT fceuconfig[] = {
|
||||||
AC(taseditor_config.use_1p_rec),
|
AC(taseditor_config.use_1p_rec),
|
||||||
AC(taseditor_config.columnset_by_keys),
|
AC(taseditor_config.columnset_by_keys),
|
||||||
AC(taseditor_config.branch_full_movie),
|
AC(taseditor_config.branch_full_movie),
|
||||||
AC(taseditor_config.branch_only_when_rec),
|
AC(taseditor_config.old_branching_controls),
|
||||||
AC(taseditor_config.view_branches_tree),
|
AC(taseditor_config.view_branches_tree),
|
||||||
AC(taseditor_config.branch_scr_hud),
|
AC(taseditor_config.branch_scr_hud),
|
||||||
AC(taseditor_config.restore_position),
|
AC(taseditor_config.restore_position),
|
||||||
|
AC(taseditor_config.adjust_input_due_to_lag),
|
||||||
AC(taseditor_config.superimpose),
|
AC(taseditor_config.superimpose),
|
||||||
AC(taseditor_config.enable_auto_function),
|
AC(taseditor_config.enable_auto_function),
|
||||||
AC(taseditor_config.enable_hot_changes),
|
AC(taseditor_config.enable_hot_changes),
|
||||||
|
|
|
@ -286,7 +286,7 @@ BEGIN
|
||||||
MENUITEM "Bind Markers to Input", ID_CONFIG_BINDMARKERSTOINPUT,MFT_STRING,MFS_ENABLED
|
MENUITEM "Bind Markers to Input", ID_CONFIG_BINDMARKERSTOINPUT,MFT_STRING,MFS_ENABLED
|
||||||
MENUITEM "Empty new Marker Notes", ID_CONFIG_EMPTYNEWMARKERNOTES,MFT_STRING,MFS_ENABLED
|
MENUITEM "Empty new Marker Notes", ID_CONFIG_EMPTYNEWMARKERNOTES,MFT_STRING,MFS_ENABLED
|
||||||
MENUITEM MFT_SEPARATOR
|
MENUITEM MFT_SEPARATOR
|
||||||
MENUITEM "Branches work only when Recording", ID_CONFIG_BRANCHESWORKONLYWHENRECORDING,MFT_STRING,MFS_ENABLED
|
MENUITEM "Old control scheme for Branching", ID_CONFIG_OLDBRANCHINGCONTROLS,MFT_STRING,MFS_ENABLED
|
||||||
MENUITEM "Branches restore entire Movie", ID_CONFIG_BRANCHESRESTOREFULLMOVIE,MFT_STRING,MFS_ENABLED
|
MENUITEM "Branches restore entire Movie", ID_CONFIG_BRANCHESRESTOREFULLMOVIE,MFT_STRING,MFS_ENABLED
|
||||||
MENUITEM "HUD in Branch screenshots", ID_CONFIG_HUDINBRANCHSCREENSHOTS,MFT_STRING,MFS_ENABLED
|
MENUITEM "HUD in Branch screenshots", ID_CONFIG_HUDINBRANCHSCREENSHOTS,MFT_STRING,MFS_ENABLED
|
||||||
MENUITEM MFT_SEPARATOR
|
MENUITEM MFT_SEPARATOR
|
||||||
|
@ -294,7 +294,7 @@ BEGIN
|
||||||
END
|
END
|
||||||
POPUP "Help", 65535,MFT_STRING,MFS_ENABLED
|
POPUP "Help", 65535,MFT_STRING,MFS_ENABLED
|
||||||
BEGIN
|
BEGIN
|
||||||
MENUITEM "TAS Editor Help", ID_HELP_TASEDITORHELP,MFT_STRING,MFS_ENABLED
|
MENUITEM "Open TAS Editor Manual", ID_HELP_TASEDITORHELP,MFT_STRING,MFS_ENABLED
|
||||||
MENUITEM "Enable Tooltips", ID_HELP_TOOLTIPS,MFT_STRING,MFS_ENABLED
|
MENUITEM "Enable Tooltips", ID_HELP_TOOLTIPS,MFT_STRING,MFS_ENABLED
|
||||||
MENUITEM MFT_SEPARATOR
|
MENUITEM MFT_SEPARATOR
|
||||||
MENUITEM "About", ID_HELP_ABOUT,MFT_STRING,MFS_ENABLED
|
MENUITEM "About", ID_HELP_ABOUT,MFT_STRING,MFS_ENABLED
|
||||||
|
@ -1380,21 +1380,21 @@ BEGIN
|
||||||
EDITTEXT IDC_LABEL_NEWPPUUSED,76,166,155,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
EDITTEXT IDC_LABEL_NEWPPUUSED,76,166,155,12,ES_READONLY | NOT WS_BORDER | NOT WS_TABSTOP
|
||||||
END
|
END
|
||||||
|
|
||||||
TASEDITOR DIALOGEX 0, 0, 325, 353
|
TASEDITOR DIALOGEX 0, 0, 326, 359
|
||||||
STYLE DS_SETFONT | DS_SETFOREGROUND | DS_FIXEDSYS | WS_MINIMIZEBOX | WS_MAXIMIZEBOX | WS_POPUP | WS_VISIBLE | WS_CAPTION | WS_SYSMENU | WS_THICKFRAME
|
STYLE DS_SETFONT | DS_SETFOREGROUND | DS_FIXEDSYS | WS_MINIMIZEBOX | WS_MAXIMIZEBOX | WS_POPUP | WS_VISIBLE | WS_CAPTION | WS_SYSMENU | WS_THICKFRAME
|
||||||
CAPTION "TAS Editor"
|
CAPTION "TAS Editor"
|
||||||
MENU TASEDITORMENU
|
MENU TASEDITORMENU
|
||||||
FONT 8, "MS Shell Dlg", 400, 0, 0x1
|
FONT 8, "MS Shell Dlg", 400, 0, 0x1
|
||||||
BEGIN
|
BEGIN
|
||||||
CONTROL "",IDC_PROGRESS_BUTTON,"Button",BS_OWNERDRAW,200,36,116,12
|
CONTROL "",IDC_PROGRESS_BUTTON,"Button",BS_OWNERDRAW,200,36,116,12
|
||||||
CONTROL "",IDC_BRANCHES_BUTTON,"Button",BS_OWNERDRAW,207,167,104,11
|
CONTROL "",IDC_BRANCHES_BUTTON,"Button",BS_OWNERDRAW,207,179,104,10
|
||||||
CONTROL "",IDC_LIST1,"SysListView32",LVS_REPORT | LVS_SHOWSELALWAYS | LVS_ALIGNLEFT | LVS_OWNERDATA | LVS_NOSORTHEADER | WS_BORDER,5,13,187,320
|
CONTROL "",IDC_LIST1,"SysListView32",LVS_REPORT | LVS_SHOWSELALWAYS | LVS_ALIGNLEFT | LVS_OWNERDATA | LVS_NOSORTHEADER | WS_BORDER,5,13,187,328
|
||||||
GROUPBOX " Playback ",IDC_PLAYBACK_BOX,197,0,123,62,BS_CENTER,WS_EX_RIGHT
|
GROUPBOX " Playback ",IDC_PLAYBACK_BOX,197,0,123,75,BS_CENTER,WS_EX_RIGHT
|
||||||
GROUPBOX " Recorder ",IDC_RECORDER_BOX,197,63,123,46,BS_CENTER,WS_EX_RIGHT
|
GROUPBOX " Recorder ",IDC_RECORDER_BOX,197,75,123,46,BS_CENTER,WS_EX_RIGHT
|
||||||
GROUPBOX " Splicer ",IDC_SPLICER_BOX,197,110,123,30,BS_CENTER,WS_EX_RIGHT
|
GROUPBOX " Splicer ",IDC_SPLICER_BOX,197,122,123,30,BS_CENTER,WS_EX_RIGHT
|
||||||
GROUPBOX " Lua ",IDC_LUA_BOX,197,141,123,26,BS_CENTER,WS_EX_RIGHT
|
GROUPBOX " Lua ",IDC_LUA_BOX,197,153,123,26,BS_CENTER,WS_EX_RIGHT
|
||||||
GROUPBOX " Bookmarks ",IDC_BOOKMARKS_BOX,197,169,123,102,BS_CENTER,WS_EX_RIGHT
|
GROUPBOX " Bookmarks ",IDC_BOOKMARKS_BOX,197,180,123,102,BS_CENTER,WS_EX_RIGHT
|
||||||
GROUPBOX " History ",IDC_HISTORY_BOX,197,272,123,56,BS_CENTER,WS_EX_RIGHT
|
GROUPBOX " History ",IDC_HISTORY_BOX,197,283,123,52,BS_CENTER,WS_EX_RIGHT
|
||||||
PUSHBUTTON "<<",TASEDITOR_REWIND_FULL,201,9,23,14,NOT WS_TABSTOP
|
PUSHBUTTON "<<",TASEDITOR_REWIND_FULL,201,9,23,14,NOT WS_TABSTOP
|
||||||
PUSHBUTTON "<",TASEDITOR_REWIND,224,9,23,14,NOT WS_TABSTOP
|
PUSHBUTTON "<",TASEDITOR_REWIND,224,9,23,14,NOT WS_TABSTOP
|
||||||
PUSHBUTTON "||",TASEDITOR_PLAYSTOP,247,9,23,14,NOT WS_TABSTOP
|
PUSHBUTTON "||",TASEDITOR_PLAYSTOP,247,9,23,14,NOT WS_TABSTOP
|
||||||
|
@ -1403,31 +1403,33 @@ BEGIN
|
||||||
CONTROL "",IDC_PROGRESS1,"msctls_progress32",PBS_SMOOTH | WS_BORDER,201,39,115,6
|
CONTROL "",IDC_PROGRESS1,"msctls_progress32",PBS_SMOOTH | WS_BORDER,201,39,115,6
|
||||||
CONTROL " Follow cursor",CHECK_FOLLOW_CURSOR,"Button",BS_AUTOCHECKBOX,203,25,56,12
|
CONTROL " Follow cursor",CHECK_FOLLOW_CURSOR,"Button",BS_AUTOCHECKBOX,203,25,56,12
|
||||||
CONTROL " Auto-restore last position",CHECK_AUTORESTORE_PLAYBACK,
|
CONTROL " Auto-restore last position",CHECK_AUTORESTORE_PLAYBACK,
|
||||||
"Button",BS_AUTOCHECKBOX,203,48,105,12
|
"Button",BS_AUTOCHECKBOX,203,48,109,12
|
||||||
CONTROL "",IDC_BOOKMARKSLIST,"SysListView32",LVS_REPORT | LVS_SINGLESEL | LVS_ALIGNLEFT | LVS_OWNERDATA | LVS_NOSCROLL | LVS_NOCOLUMNHEADER | LVS_NOSORTHEADER | NOT WS_VISIBLE | WS_BORDER,202,178,113,89
|
CONTROL "",IDC_BOOKMARKSLIST,"SysListView32",LVS_REPORT | LVS_SINGLESEL | LVS_ALIGNLEFT | LVS_OWNERDATA | LVS_NOSCROLL | LVS_NOCOLUMNHEADER | LVS_NOSORTHEADER | NOT WS_VISIBLE | WS_BORDER,202,189,113,89
|
||||||
CONTROL "",IDC_HISTORYLIST,"SysListView32",LVS_REPORT | LVS_SINGLESEL | LVS_SHOWSELALWAYS | LVS_NOLABELWRAP | LVS_ALIGNLEFT | LVS_OWNERDATA | LVS_NOCOLUMNHEADER | LVS_NOSORTHEADER | WS_BORDER,202,282,113,42
|
CONTROL "",IDC_HISTORYLIST,"SysListView32",LVS_REPORT | LVS_SINGLESEL | LVS_SHOWSELALWAYS | LVS_NOLABELWRAP | LVS_ALIGNLEFT | LVS_OWNERDATA | LVS_NOCOLUMNHEADER | LVS_NOSORTHEADER | WS_BORDER,202,292,113,39
|
||||||
CONTROL " All",IDC_RADIO_ALL,"Button",BS_AUTORADIOBUTTON,291,71,24,10
|
CONTROL " All",IDC_RADIO_ALL,"Button",BS_AUTORADIOBUTTON,291,83,24,10
|
||||||
CONTROL " 1P",IDC_RADIO_1P,"Button",BS_AUTORADIOBUTTON,203,83,25,10
|
CONTROL " 1P",IDC_RADIO_1P,"Button",BS_AUTORADIOBUTTON,203,95,25,10
|
||||||
CONTROL " 2P",IDC_RADIO_2P,"Button",BS_AUTORADIOBUTTON,232,83,25,10
|
CONTROL " 2P",IDC_RADIO_2P,"Button",BS_AUTORADIOBUTTON,232,95,25,10
|
||||||
CONTROL " 3P",IDC_RADIO_3P,"Button",BS_AUTORADIOBUTTON,262,83,24,10
|
CONTROL " 3P",IDC_RADIO_3P,"Button",BS_AUTORADIOBUTTON,262,95,24,10
|
||||||
CONTROL " 4P",IDC_RADIO_4P,"Button",BS_AUTORADIOBUTTON,291,83,24,10
|
CONTROL " 4P",IDC_RADIO_4P,"Button",BS_AUTORADIOBUTTON,291,95,24,10
|
||||||
CONTROL " Superimpose",IDC_SUPERIMPOSE,"Button",BS_AUTO3STATE,203,96,55,10
|
CONTROL " Superimpose",IDC_SUPERIMPOSE,"Button",BS_AUTO3STATE,203,108,55,10
|
||||||
PUSHBUTTON "<<",TASEDITOR_PREV_MARKER,202,332,23,14,NOT WS_TABSTOP
|
PUSHBUTTON "<<",TASEDITOR_PREV_MARKER,202,340,23,14,NOT WS_TABSTOP
|
||||||
PUSHBUTTON "Similar",TASEDITOR_FIND_BEST_SIMILAR_MARKER,225,332,34,14,NOT WS_TABSTOP
|
PUSHBUTTON "Similar",TASEDITOR_FIND_BEST_SIMILAR_MARKER,225,340,34,14,NOT WS_TABSTOP
|
||||||
PUSHBUTTON "More",TASEDITOR_FIND_NEXT_SIMILAR_MARKER,259,332,34,14,NOT WS_TABSTOP
|
PUSHBUTTON "More",TASEDITOR_FIND_NEXT_SIMILAR_MARKER,259,340,34,14,NOT WS_TABSTOP
|
||||||
PUSHBUTTON ">>",TASEDITOR_NEXT_MARKER,292,332,23,14,NOT WS_TABSTOP
|
PUSHBUTTON ">>",TASEDITOR_NEXT_MARKER,292,340,23,14,NOT WS_TABSTOP
|
||||||
EDITTEXT IDC_PLAYBACK_MARKER_EDIT,65,0,127,13,ES_AUTOHSCROLL | ES_READONLY | NOT WS_TABSTOP
|
EDITTEXT IDC_PLAYBACK_MARKER_EDIT,65,0,127,13,ES_AUTOHSCROLL | ES_READONLY | NOT WS_TABSTOP
|
||||||
RTEXT "Marker 0",IDC_PLAYBACK_MARKER,4,2,60,10,SS_NOTIFY,WS_EX_RIGHT
|
RTEXT "Marker 0",IDC_PLAYBACK_MARKER,4,2,60,10,SS_NOTIFY,WS_EX_RIGHT
|
||||||
EDITTEXT IDC_SELECTION_MARKER_EDIT,65,333,127,13,ES_AUTOHSCROLL | ES_READONLY | NOT WS_TABSTOP
|
EDITTEXT IDC_SELECTION_MARKER_EDIT,65,341,127,13,ES_AUTOHSCROLL | ES_READONLY | NOT WS_TABSTOP
|
||||||
RTEXT "Marker 99999",IDC_SELECTION_MARKER,4,335,60,10,SS_NOTIFY,WS_EX_RIGHT
|
RTEXT "Marker 99999",IDC_SELECTION_MARKER,4,343,60,10,SS_NOTIFY,WS_EX_RIGHT
|
||||||
CONTROL "",IDC_BRANCHES_BITMAP,"Static",SS_OWNERDRAW | SS_NOTIFY | SS_REALSIZEIMAGE | NOT WS_VISIBLE,202,178,113,89
|
CONTROL "",IDC_BRANCHES_BITMAP,"Static",SS_OWNERDRAW | SS_NOTIFY | SS_REALSIZEIMAGE | NOT WS_VISIBLE,202,189,113,89
|
||||||
CONTROL " Turbo seek",CHECK_TURBO_SEEK,"Button",BS_AUTOCHECKBOX,263,25,50,12
|
CONTROL " Turbo seek",CHECK_TURBO_SEEK,"Button",BS_AUTOCHECKBOX,263,25,50,12
|
||||||
LTEXT "Selection: 0 rows, 16 columns",IDC_TEXT_SELECTION,204,118,112,10,SS_NOTIFY
|
LTEXT "Selection: 0 rows, 16 columns",IDC_TEXT_SELECTION,204,130,112,10,SS_NOTIFY
|
||||||
LTEXT "Clipboard: 0 rows, 16 columns",IDC_TEXT_CLIPBOARD,203,128,114,10,SS_NOTIFY
|
LTEXT "Clipboard: 0 rows, 16 columns",IDC_TEXT_CLIPBOARD,203,140,114,10,SS_NOTIFY
|
||||||
CONTROL " Recording",IDC_RECORDING,"Button",BS_AUTO3STATE,203,71,64,10
|
CONTROL " Recording",IDC_RECORDING,"Button",BS_AUTO3STATE,203,83,64,10
|
||||||
PUSHBUTTON "Run function",TASEDITOR_RUN_MANUAL,202,150,54,14,WS_DISABLED | NOT WS_TABSTOP
|
PUSHBUTTON "Run function",TASEDITOR_RUN_MANUAL,202,162,54,14,WS_DISABLED | NOT WS_TABSTOP
|
||||||
CONTROL "Auto function",IDC_RUN_AUTO,"Button",BS_AUTOCHECKBOX,261,152,55,10
|
CONTROL "Auto function",IDC_RUN_AUTO,"Button",BS_AUTOCHECKBOX,261,164,55,10
|
||||||
CONTROL " Use pattern",IDC_USEPATTERN,"Button",BS_AUTOCHECKBOX,262,96,53,10
|
CONTROL " Use pattern",IDC_USEPATTERN,"Button",BS_AUTOCHECKBOX,262,108,53,10
|
||||||
|
CONTROL " Auto-adjust Input due to lag",CHECK_AUTOADJUSTINPUTDUETOLAG,
|
||||||
|
"Button",BS_AUTOCHECKBOX,203,61,109,12
|
||||||
END
|
END
|
||||||
|
|
||||||
IDD_TASEDITOR_ABOUT DIALOGEX 0, 0, 238, 78
|
IDD_TASEDITOR_ABOUT DIALOGEX 0, 0, 238, 78
|
||||||
|
@ -1986,8 +1988,6 @@ BEGIN
|
||||||
|
|
||||||
"TASEDITOR", DIALOG
|
"TASEDITOR", DIALOG
|
||||||
BEGIN
|
BEGIN
|
||||||
RIGHTMARGIN, 323
|
|
||||||
BOTTOMMARGIN, 351
|
|
||||||
END
|
END
|
||||||
|
|
||||||
IDD_TASEDITOR_ABOUT, DIALOG
|
IDD_TASEDITOR_ABOUT, DIALOG
|
||||||
|
@ -2080,6 +2080,7 @@ END
|
||||||
#endif // Íåéòðàëüíûé resources
|
#endif // Íåéòðàëüíûé resources
|
||||||
/////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
/////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
// Àíãëèéñêèé (ÑØÀ) resources
|
// Àíãëèéñêèé (ÑØÀ) resources
|
||||||
|
|
||||||
|
@ -2295,6 +2296,26 @@ IDB_PIANO_LOSTPOS_16 BITMAP "res\\te_piano_16_lostpo
|
||||||
IDB_PIANO_LOSTPOS_17 BITMAP "res\\te_piano_17_lostpos.bmp"
|
IDB_PIANO_LOSTPOS_17 BITMAP "res\\te_piano_17_lostpos.bmp"
|
||||||
IDB_PIANO_LOSTPOS_18 BITMAP "res\\te_piano_18_lostpos.bmp"
|
IDB_PIANO_LOSTPOS_18 BITMAP "res\\te_piano_18_lostpos.bmp"
|
||||||
IDB_PIANO_LOSTPOS_19 BITMAP "res\\te_piano_19_lostpos.bmp"
|
IDB_PIANO_LOSTPOS_19 BITMAP "res\\te_piano_19_lostpos.bmp"
|
||||||
|
IDB_BITMAP_SELECTED0 BITMAP "res\\te_0_selected.bmp"
|
||||||
|
IDB_BITMAP_SELECTED1 BITMAP "res\\te_1_selected.bmp"
|
||||||
|
IDB_BITMAP_SELECTED2 BITMAP "res\\te_2_selected.bmp"
|
||||||
|
IDB_BITMAP_SELECTED3 BITMAP "res\\te_3_selected.bmp"
|
||||||
|
IDB_BITMAP_SELECTED4 BITMAP "res\\te_4_selected.bmp"
|
||||||
|
IDB_BITMAP_SELECTED5 BITMAP "res\\te_5_selected.bmp"
|
||||||
|
IDB_BITMAP_SELECTED6 BITMAP "res\\te_6_selected.bmp"
|
||||||
|
IDB_BITMAP_SELECTED7 BITMAP "res\\te_7_selected.bmp"
|
||||||
|
IDB_BITMAP_SELECTED8 BITMAP "res\\te_8_selected.bmp"
|
||||||
|
IDB_BITMAP_SELECTED9 BITMAP "res\\te_9_selected.bmp"
|
||||||
|
IDB_BITMAP_SELECTED10 BITMAP "res\\te_10_selected.bmp"
|
||||||
|
IDB_BITMAP_SELECTED11 BITMAP "res\\te_11_selected.bmp"
|
||||||
|
IDB_BITMAP_SELECTED12 BITMAP "res\\te_12_selected.bmp"
|
||||||
|
IDB_BITMAP_SELECTED13 BITMAP "res\\te_13_selected.bmp"
|
||||||
|
IDB_BITMAP_SELECTED14 BITMAP "res\\te_14_selected.bmp"
|
||||||
|
IDB_BITMAP_SELECTED15 BITMAP "res\\te_15_selected.bmp"
|
||||||
|
IDB_BITMAP_SELECTED16 BITMAP "res\\te_16_selected.bmp"
|
||||||
|
IDB_BITMAP_SELECTED17 BITMAP "res\\te_17_selected.bmp"
|
||||||
|
IDB_BITMAP_SELECTED18 BITMAP "res\\te_18_selected.bmp"
|
||||||
|
IDB_BITMAP_SELECTED19 BITMAP "res\\te_19_selected.bmp"
|
||||||
IDB_BRANCH_SPRITESHEET BITMAP "res\\branch_spritesheet.bmp"
|
IDB_BRANCH_SPRITESHEET BITMAP "res\\branch_spritesheet.bmp"
|
||||||
#endif // Àíãëèéñêèé (ÑØÀ) resources
|
#endif // Àíãëèéñêèé (ÑØÀ) resources
|
||||||
/////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
Before Width: | Height: | Size: 418 B After Width: | Height: | Size: 522 B |
After Width: | Height: | Size: 522 B |
Before Width: | Height: | Size: 418 B After Width: | Height: | Size: 522 B |
Before Width: | Height: | Size: 418 B After Width: | Height: | Size: 522 B |
After Width: | Height: | Size: 522 B |
Before Width: | Height: | Size: 418 B After Width: | Height: | Size: 522 B |
After Width: | Height: | Size: 522 B |
Before Width: | Height: | Size: 418 B After Width: | Height: | Size: 522 B |
After Width: | Height: | Size: 522 B |
Before Width: | Height: | Size: 418 B After Width: | Height: | Size: 522 B |
After Width: | Height: | Size: 522 B |
Before Width: | Height: | Size: 418 B After Width: | Height: | Size: 522 B |
After Width: | Height: | Size: 522 B |
Before Width: | Height: | Size: 418 B After Width: | Height: | Size: 522 B |
After Width: | Height: | Size: 522 B |
Before Width: | Height: | Size: 418 B After Width: | Height: | Size: 522 B |
After Width: | Height: | Size: 522 B |
Before Width: | Height: | Size: 418 B After Width: | Height: | Size: 522 B |
After Width: | Height: | Size: 522 B |
Before Width: | Height: | Size: 418 B After Width: | Height: | Size: 522 B |
After Width: | Height: | Size: 522 B |
Before Width: | Height: | Size: 418 B After Width: | Height: | Size: 522 B |
After Width: | Height: | Size: 522 B |
After Width: | Height: | Size: 522 B |
Before Width: | Height: | Size: 418 B After Width: | Height: | Size: 522 B |
After Width: | Height: | Size: 522 B |
Before Width: | Height: | Size: 418 B After Width: | Height: | Size: 522 B |
After Width: | Height: | Size: 522 B |
Before Width: | Height: | Size: 418 B After Width: | Height: | Size: 522 B |
After Width: | Height: | Size: 522 B |
Before Width: | Height: | Size: 418 B After Width: | Height: | Size: 522 B |
After Width: | Height: | Size: 522 B |
Before Width: | Height: | Size: 418 B After Width: | Height: | Size: 522 B |
After Width: | Height: | Size: 522 B |
Before Width: | Height: | Size: 418 B After Width: | Height: | Size: 522 B |
After Width: | Height: | Size: 522 B |
Before Width: | Height: | Size: 418 B After Width: | Height: | Size: 522 B |
After Width: | Height: | Size: 522 B |
Before Width: | Height: | Size: 418 B After Width: | Height: | Size: 522 B |
After Width: | Height: | Size: 522 B |
|
@ -284,6 +284,7 @@
|
||||||
#define IDB_PIANO_PLAYBACK_19 248
|
#define IDB_PIANO_PLAYBACK_19 248
|
||||||
#define IDB_PIANO_LOSTPOS_0 249
|
#define IDB_PIANO_LOSTPOS_0 249
|
||||||
#define IDB_PIANO_LOSTPOS_1 250
|
#define IDB_PIANO_LOSTPOS_1 250
|
||||||
|
#define BTN_NETMOO_CONNECT 250
|
||||||
#define IDB_PIANO_LOSTPOS_2 251
|
#define IDB_PIANO_LOSTPOS_2 251
|
||||||
#define IDB_PIANO_LOSTPOS_3 252
|
#define IDB_PIANO_LOSTPOS_3 252
|
||||||
#define IDB_PIANO_LOSTPOS_4 253
|
#define IDB_PIANO_LOSTPOS_4 253
|
||||||
|
@ -302,7 +303,26 @@
|
||||||
#define IDB_PIANO_LOSTPOS_17 266
|
#define IDB_PIANO_LOSTPOS_17 266
|
||||||
#define IDB_PIANO_LOSTPOS_18 267
|
#define IDB_PIANO_LOSTPOS_18 267
|
||||||
#define IDB_PIANO_LOSTPOS_19 268
|
#define IDB_PIANO_LOSTPOS_19 268
|
||||||
#define BTN_NETMOO_CONNECT 250
|
#define IDB_BITMAP_SELECTED0 269
|
||||||
|
#define IDB_BITMAP_SELECTED1 270
|
||||||
|
#define IDB_BITMAP_SELECTED2 271
|
||||||
|
#define IDB_BITMAP_SELECTED3 272
|
||||||
|
#define IDB_BITMAP_SELECTED4 273
|
||||||
|
#define IDB_BITMAP_SELECTED5 274
|
||||||
|
#define IDB_BITMAP_SELECTED6 275
|
||||||
|
#define IDB_BITMAP_SELECTED7 276
|
||||||
|
#define IDB_BITMAP_SELECTED8 277
|
||||||
|
#define IDB_BITMAP_SELECTED9 278
|
||||||
|
#define IDB_BITMAP_SELECTED10 279
|
||||||
|
#define IDB_BITMAP_SELECTED11 280
|
||||||
|
#define IDB_BITMAP_SELECTED12 281
|
||||||
|
#define IDB_BITMAP_SELECTED13 282
|
||||||
|
#define IDB_BITMAP_SELECTED14 283
|
||||||
|
#define IDB_BITMAP_SELECTED15 284
|
||||||
|
#define IDB_BITMAP_SELECTED16 285
|
||||||
|
#define IDB_BITMAP_SELECTED17 286
|
||||||
|
#define IDB_BITMAP_SELECTED18 287
|
||||||
|
#define IDB_BITMAP_SELECTED19 288
|
||||||
#define MENU_HIDE_MENU 300
|
#define MENU_HIDE_MENU 300
|
||||||
#define COMBO_FILTER 300
|
#define COMBO_FILTER 300
|
||||||
#define IDC_EDIT_AUTHORINFO 300
|
#define IDC_EDIT_AUTHORINFO 300
|
||||||
|
@ -638,6 +658,8 @@
|
||||||
#define IDC_TEXT_CLIPBOARD 1268
|
#define IDC_TEXT_CLIPBOARD 1268
|
||||||
#define IDC_RADIO_1PLAYER 1269
|
#define IDC_RADIO_1PLAYER 1269
|
||||||
#define IDC_TEXT_SELECTION2 1269
|
#define IDC_TEXT_SELECTION2 1269
|
||||||
|
#define CHECK_AUTORESTORE_PLAYBACK2 1269
|
||||||
|
#define CHECK_AUTOADJUSTINPUTDUETOLAG 1269
|
||||||
#define IDC_RADIO_2PLAYERS 1270
|
#define IDC_RADIO_2PLAYERS 1270
|
||||||
#define IDC_PLAYBACK_MARKER 1270
|
#define IDC_PLAYBACK_MARKER 1270
|
||||||
#define IDC_RADIO_FOURSCORE 1271
|
#define IDC_RADIO_FOURSCORE 1271
|
||||||
|
@ -999,7 +1021,7 @@
|
||||||
#define ID_VIEW_X 40471
|
#define ID_VIEW_X 40471
|
||||||
#define ID_VIEW_JUMPWHENMAKINGUNDO 40472
|
#define ID_VIEW_JUMPWHENMAKINGUNDO 40472
|
||||||
#define ID_CONFIG_BRANCHESRESTOREFULLMOVIE 40473
|
#define ID_CONFIG_BRANCHESRESTOREFULLMOVIE 40473
|
||||||
#define ID_CONFIG_BRANCHESWORKONLYWHENRECORDING 40474
|
#define ID_CONFIG_OLDBRANCHINGCONTROLS 40474
|
||||||
#define ID_CONFIG_HUDINBRANCHSCREENSHOTS 40475
|
#define ID_CONFIG_HUDINBRANCHSCREENSHOTS 40475
|
||||||
#define ID_CONFIG_SETAUTOSAVEPERIOD 40476
|
#define ID_CONFIG_SETAUTOSAVEPERIOD 40476
|
||||||
#define ACCEL_CTRL_Q 40478
|
#define ACCEL_CTRL_Q 40478
|
||||||
|
@ -1082,7 +1104,7 @@
|
||||||
//
|
//
|
||||||
#ifdef APSTUDIO_INVOKED
|
#ifdef APSTUDIO_INVOKED
|
||||||
#ifndef APSTUDIO_READONLY_SYMBOLS
|
#ifndef APSTUDIO_READONLY_SYMBOLS
|
||||||
#define _APS_NEXT_RESOURCE_VALUE 269
|
#define _APS_NEXT_RESOURCE_VALUE 289
|
||||||
#define _APS_NEXT_COMMAND_VALUE 40564
|
#define _APS_NEXT_COMMAND_VALUE 40564
|
||||||
#define _APS_NEXT_CONTROL_VALUE 1281
|
#define _APS_NEXT_CONTROL_VALUE 1281
|
||||||
#define _APS_NEXT_SYMED_VALUE 101
|
#define _APS_NEXT_SYMED_VALUE 101
|
||||||
|
|
|
@ -7,13 +7,14 @@ Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
------------------------------------------------------------------------------------
|
------------------------------------------------------------------------------------
|
||||||
Main - Logical center of the program
|
Main - Main gate between emulator and Taseditor
|
||||||
[Singleton]
|
[Singleton]
|
||||||
|
|
||||||
* the point of launching TAS Editor from emulator
|
* the point of launching TAS Editor from emulator
|
||||||
* the point of quitting from TAS Editor
|
* the point of quitting from TAS Editor
|
||||||
* regularly (at the end of every frame) updates all modules that need regular update
|
* regularly (at the end of every frame) updates all modules that need regular update
|
||||||
* implements operations of the "File" menu: creating New project, opening a file, saving, compact saving, import, export
|
* implements operations of the "File" menu: creating New project, opening a file, saving, compact saving, import, export
|
||||||
|
* handles some FCEUX hotkeys
|
||||||
------------------------------------------------------------------------------------ */
|
------------------------------------------------------------------------------------ */
|
||||||
|
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
|
@ -21,6 +22,7 @@ Main - Logical center of the program
|
||||||
#include "utils/xstring.h"
|
#include "utils/xstring.h"
|
||||||
#include "main.h" // for GetRomName
|
#include "main.h" // for GetRomName
|
||||||
#include "taseditor.h"
|
#include "taseditor.h"
|
||||||
|
#include "../../input.h"
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
|
@ -774,3 +776,83 @@ bool TaseditorIsRecording()
|
||||||
return true; // record
|
return true; // record
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// this gate handles FCEUX hotkeys (EMUCMD)
|
||||||
|
void Taseditor_EMUCMD(int command)
|
||||||
|
{
|
||||||
|
switch (command)
|
||||||
|
{
|
||||||
|
case EMUCMD_SAVE_SLOT_0:
|
||||||
|
case EMUCMD_SAVE_SLOT_1:
|
||||||
|
case EMUCMD_SAVE_SLOT_2:
|
||||||
|
case EMUCMD_SAVE_SLOT_3:
|
||||||
|
case EMUCMD_SAVE_SLOT_4:
|
||||||
|
case EMUCMD_SAVE_SLOT_5:
|
||||||
|
case EMUCMD_SAVE_SLOT_6:
|
||||||
|
case EMUCMD_SAVE_SLOT_7:
|
||||||
|
case EMUCMD_SAVE_SLOT_8:
|
||||||
|
case EMUCMD_SAVE_SLOT_9:
|
||||||
|
{
|
||||||
|
if (taseditor_config.old_branching_controls)
|
||||||
|
bookmarks.command(COMMAND_SELECT, command - EMUCMD_SAVE_SLOT_0);
|
||||||
|
else
|
||||||
|
bookmarks.command(COMMAND_JUMP, command - EMUCMD_SAVE_SLOT_0);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case EMUCMD_SAVE_SLOT_NEXT:
|
||||||
|
{
|
||||||
|
int slot = bookmarks.GetSelectedSlot() + 1;
|
||||||
|
if (slot >= TOTAL_BOOKMARKS) slot = 0;
|
||||||
|
bookmarks.command(COMMAND_SELECT, slot);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case EMUCMD_SAVE_SLOT_PREV:
|
||||||
|
{
|
||||||
|
int slot = bookmarks.GetSelectedSlot() - 1;
|
||||||
|
if (slot < 0) slot = TOTAL_BOOKMARKS - 1;
|
||||||
|
bookmarks.command(COMMAND_SELECT, slot);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case EMUCMD_SAVE_STATE:
|
||||||
|
bookmarks.command(COMMAND_SET);
|
||||||
|
break;
|
||||||
|
case EMUCMD_SAVE_STATE_SLOT_0:
|
||||||
|
case EMUCMD_SAVE_STATE_SLOT_1:
|
||||||
|
case EMUCMD_SAVE_STATE_SLOT_2:
|
||||||
|
case EMUCMD_SAVE_STATE_SLOT_3:
|
||||||
|
case EMUCMD_SAVE_STATE_SLOT_4:
|
||||||
|
case EMUCMD_SAVE_STATE_SLOT_5:
|
||||||
|
case EMUCMD_SAVE_STATE_SLOT_6:
|
||||||
|
case EMUCMD_SAVE_STATE_SLOT_7:
|
||||||
|
case EMUCMD_SAVE_STATE_SLOT_8:
|
||||||
|
case EMUCMD_SAVE_STATE_SLOT_9:
|
||||||
|
bookmarks.command(COMMAND_SET, command - EMUCMD_SAVE_STATE_SLOT_0);
|
||||||
|
break;
|
||||||
|
case EMUCMD_LOAD_STATE:
|
||||||
|
bookmarks.command(COMMAND_DEPLOY);
|
||||||
|
break;
|
||||||
|
case EMUCMD_LOAD_STATE_SLOT_0:
|
||||||
|
case EMUCMD_LOAD_STATE_SLOT_1:
|
||||||
|
case EMUCMD_LOAD_STATE_SLOT_2:
|
||||||
|
case EMUCMD_LOAD_STATE_SLOT_3:
|
||||||
|
case EMUCMD_LOAD_STATE_SLOT_4:
|
||||||
|
case EMUCMD_LOAD_STATE_SLOT_5:
|
||||||
|
case EMUCMD_LOAD_STATE_SLOT_6:
|
||||||
|
case EMUCMD_LOAD_STATE_SLOT_7:
|
||||||
|
case EMUCMD_LOAD_STATE_SLOT_8:
|
||||||
|
case EMUCMD_LOAD_STATE_SLOT_9:
|
||||||
|
bookmarks.command(COMMAND_DEPLOY, command - EMUCMD_LOAD_STATE_SLOT_0);
|
||||||
|
break;
|
||||||
|
case EMUCMD_RELOAD:
|
||||||
|
taseditor_window.LoadRecentProject(0);
|
||||||
|
break;
|
||||||
|
case EMUCMD_TASEDITOR_RESTORE_PLAYBACK:
|
||||||
|
playback.RestorePosition();
|
||||||
|
break;
|
||||||
|
case EMUCMD_TASEDITOR_CANCEL_SEEKING:
|
||||||
|
playback.CancelSeeking();
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -30,3 +30,5 @@ void ApplyMovieInputConfig();
|
||||||
|
|
||||||
bool TaseditorIsRecording();
|
bool TaseditorIsRecording();
|
||||||
|
|
||||||
|
void Taseditor_EMUCMD(int command);
|
||||||
|
|
||||||
|
|
|
@ -77,7 +77,7 @@ void BOOKMARKS::init()
|
||||||
// subclass the listview
|
// subclass the listview
|
||||||
hwndBookmarksList_oldWndProc = (WNDPROC)SetWindowLong(hwndBookmarksList, GWL_WNDPROC, (LONG)BookmarksListWndProc);
|
hwndBookmarksList_oldWndProc = (WNDPROC)SetWindowLong(hwndBookmarksList, GWL_WNDPROC, (LONG)BookmarksListWndProc);
|
||||||
// setup images for the listview
|
// setup images for the listview
|
||||||
himglist = ImageList_Create(9, 13, ILC_COLOR8 | ILC_MASK, 1, 1);
|
himglist = ImageList_Create(11, 13, ILC_COLOR8 | ILC_MASK, 1, 1);
|
||||||
HBITMAP bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP0));
|
HBITMAP bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP0));
|
||||||
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
DeleteObject(bmp);
|
DeleteObject(bmp);
|
||||||
|
@ -138,6 +138,66 @@ void BOOKMARKS::init()
|
||||||
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP19));
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP19));
|
||||||
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
DeleteObject(bmp);
|
DeleteObject(bmp);
|
||||||
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP_SELECTED0));
|
||||||
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
|
DeleteObject(bmp);
|
||||||
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP_SELECTED1));
|
||||||
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
|
DeleteObject(bmp);
|
||||||
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP_SELECTED2));
|
||||||
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
|
DeleteObject(bmp);
|
||||||
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP_SELECTED3));
|
||||||
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
|
DeleteObject(bmp);
|
||||||
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP_SELECTED4));
|
||||||
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
|
DeleteObject(bmp);
|
||||||
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP_SELECTED5));
|
||||||
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
|
DeleteObject(bmp);
|
||||||
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP_SELECTED6));
|
||||||
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
|
DeleteObject(bmp);
|
||||||
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP_SELECTED7));
|
||||||
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
|
DeleteObject(bmp);
|
||||||
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP_SELECTED8));
|
||||||
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
|
DeleteObject(bmp);
|
||||||
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP_SELECTED9));
|
||||||
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
|
DeleteObject(bmp);
|
||||||
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP_SELECTED10));
|
||||||
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
|
DeleteObject(bmp);
|
||||||
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP_SELECTED11));
|
||||||
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
|
DeleteObject(bmp);
|
||||||
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP_SELECTED12));
|
||||||
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
|
DeleteObject(bmp);
|
||||||
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP_SELECTED13));
|
||||||
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
|
DeleteObject(bmp);
|
||||||
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP_SELECTED14));
|
||||||
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
|
DeleteObject(bmp);
|
||||||
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP_SELECTED15));
|
||||||
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
|
DeleteObject(bmp);
|
||||||
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP_SELECTED16));
|
||||||
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
|
DeleteObject(bmp);
|
||||||
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP_SELECTED17));
|
||||||
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
|
DeleteObject(bmp);
|
||||||
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP_SELECTED18));
|
||||||
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
|
DeleteObject(bmp);
|
||||||
|
bmp = LoadBitmap(fceu_hInstance, MAKEINTRESOURCE(IDB_BITMAP_SELECTED19));
|
||||||
|
ImageList_AddMasked(himglist, bmp, 0xFFFFFF);
|
||||||
|
DeleteObject(bmp);
|
||||||
ListView_SetImageList(hwndBookmarksList, himglist, LVSIL_SMALL);
|
ListView_SetImageList(hwndBookmarksList, himglist, LVSIL_SMALL);
|
||||||
// setup columns
|
// setup columns
|
||||||
LVCOLUMN lvc;
|
LVCOLUMN lvc;
|
||||||
|
@ -156,6 +216,7 @@ void BOOKMARKS::init()
|
||||||
ListView_SetItemCountEx(hwndBookmarksList, TOTAL_BOOKMARKS, LVSICF_NOSCROLL | LVSICF_NOINVALIDATEALL);
|
ListView_SetItemCountEx(hwndBookmarksList, TOTAL_BOOKMARKS, LVSICF_NOSCROLL | LVSICF_NOINVALIDATEALL);
|
||||||
|
|
||||||
reset();
|
reset();
|
||||||
|
selected_slot = DEFAULT_SLOT;
|
||||||
// find rows top/height (for mouseover hittest calculations)
|
// find rows top/height (for mouseover hittest calculations)
|
||||||
RECT temp_rect;
|
RECT temp_rect;
|
||||||
if (ListView_GetSubItemRect(hwndBookmarksList, 0, 2, LVIR_BOUNDS, &temp_rect) && temp_rect.bottom != temp_rect.top)
|
if (ListView_GetSubItemRect(hwndBookmarksList, 0, 2, LVIR_BOUNDS, &temp_rect) && temp_rect.bottom != temp_rect.top)
|
||||||
|
@ -220,6 +281,15 @@ void BOOKMARKS::update()
|
||||||
case COMMAND_DEPLOY:
|
case COMMAND_DEPLOY:
|
||||||
deploy(slot);
|
deploy(slot);
|
||||||
break;
|
break;
|
||||||
|
case COMMAND_SELECT:
|
||||||
|
if (selected_slot != slot)
|
||||||
|
{
|
||||||
|
int old_selected_slot = selected_slot;
|
||||||
|
selected_slot = slot;
|
||||||
|
RedrawBookmark(old_selected_slot);
|
||||||
|
RedrawBookmark(selected_slot);
|
||||||
|
}
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
commands.resize(0);
|
commands.resize(0);
|
||||||
|
@ -267,28 +337,12 @@ void BOOKMARKS::update()
|
||||||
void BOOKMARKS::command(int command_id, int slot)
|
void BOOKMARKS::command(int command_id, int slot)
|
||||||
{
|
{
|
||||||
if (slot < 0)
|
if (slot < 0)
|
||||||
slot = branches.GetCurrentBranch();
|
slot = selected_slot;
|
||||||
switch (command_id)
|
|
||||||
{
|
|
||||||
case COMMAND_SET:
|
|
||||||
{
|
|
||||||
if (slot < 0 || slot >= TOTAL_BOOKMARKS)
|
|
||||||
slot = DEFAULT_BOOKMARK;
|
|
||||||
commands.push_back(command_id);
|
|
||||||
commands.push_back(slot);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case COMMAND_JUMP:
|
|
||||||
case COMMAND_DEPLOY:
|
|
||||||
{
|
|
||||||
if (slot >= 0 && slot < TOTAL_BOOKMARKS)
|
if (slot >= 0 && slot < TOTAL_BOOKMARKS)
|
||||||
{
|
{
|
||||||
commands.push_back(command_id);
|
commands.push_back(command_id);
|
||||||
commands.push_back(slot);
|
commands.push_back(slot);
|
||||||
}
|
}
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void BOOKMARKS::set(int slot)
|
void BOOKMARKS::set(int slot)
|
||||||
|
@ -345,7 +399,7 @@ void BOOKMARKS::jump(int slot)
|
||||||
|
|
||||||
void BOOKMARKS::deploy(int slot)
|
void BOOKMARKS::deploy(int slot)
|
||||||
{
|
{
|
||||||
if (taseditor_config.branch_only_when_rec && movie_readonly)
|
if (taseditor_config.old_branching_controls && movie_readonly)
|
||||||
{
|
{
|
||||||
jump(slot);
|
jump(slot);
|
||||||
return;
|
return;
|
||||||
|
@ -473,7 +527,7 @@ void BOOKMARKS::RedrawBookmarksCaption()
|
||||||
edit_mode = EDIT_MODE_BRANCHES;
|
edit_mode = EDIT_MODE_BRANCHES;
|
||||||
ShowWindow(hwndBookmarksList, SW_HIDE);
|
ShowWindow(hwndBookmarksList, SW_HIDE);
|
||||||
ShowWindow(hwndBranchesBitmap, SW_SHOW);
|
ShowWindow(hwndBranchesBitmap, SW_SHOW);
|
||||||
} else if (taseditor_config.branch_only_when_rec && movie_readonly)
|
} else if (taseditor_config.old_branching_controls && movie_readonly)
|
||||||
{
|
{
|
||||||
edit_mode = EDIT_MODE_BOOKMARKS;
|
edit_mode = EDIT_MODE_BOOKMARKS;
|
||||||
ShowWindow(hwndBranchesBitmap, SW_HIDE);
|
ShowWindow(hwndBranchesBitmap, SW_HIDE);
|
||||||
|
@ -531,6 +585,11 @@ int BOOKMARKS::FindItemUnderMouse()
|
||||||
}
|
}
|
||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int BOOKMARKS::GetSelectedSlot()
|
||||||
|
{
|
||||||
|
return selected_slot;
|
||||||
|
}
|
||||||
// ----------------------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------------------
|
||||||
void BOOKMARKS::GetDispInfo(NMLVDISPINFO* nmlvDispInfo)
|
void BOOKMARKS::GetDispInfo(NMLVDISPINFO* nmlvDispInfo)
|
||||||
{
|
{
|
||||||
|
@ -545,6 +604,11 @@ void BOOKMARKS::GetDispInfo(NMLVDISPINFO* nmlvDispInfo)
|
||||||
item.iImage = ((item.iItem + 1) % TOTAL_BOOKMARKS) + TOTAL_BOOKMARKS;
|
item.iImage = ((item.iItem + 1) % TOTAL_BOOKMARKS) + TOTAL_BOOKMARKS;
|
||||||
else
|
else
|
||||||
item.iImage = (item.iItem + 1) % TOTAL_BOOKMARKS;
|
item.iImage = (item.iItem + 1) % TOTAL_BOOKMARKS;
|
||||||
|
if (taseditor_config.old_branching_controls)
|
||||||
|
{
|
||||||
|
if ((item.iItem + 1) % TOTAL_BOOKMARKS == selected_slot)
|
||||||
|
item.iImage += BOOKMARKS_SELECTED;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case BOOKMARKS_COLUMN_FRAME:
|
case BOOKMARKS_COLUMN_FRAME:
|
||||||
|
@ -580,7 +644,7 @@ LONG BOOKMARKS::CustomDraw(NMLVCUSTOMDRAW* msg)
|
||||||
if (bookmarks_array[cell_y].flash_phase)
|
if (bookmarks_array[cell_y].flash_phase)
|
||||||
msg->clrText = bookmark_flash_colors[bookmarks_array[cell_y].flash_type][bookmarks_array[cell_y].flash_phase];
|
msg->clrText = bookmark_flash_colors[bookmarks_array[cell_y].flash_type][bookmarks_array[cell_y].flash_phase];
|
||||||
|
|
||||||
if (cell_x == BOOKMARKS_COLUMN_FRAME || (taseditor_config.branch_only_when_rec && movie_readonly && cell_x == BOOKMARKS_COLUMN_TIME))
|
if (cell_x == BOOKMARKS_COLUMN_FRAME || (taseditor_config.old_branching_controls && movie_readonly && cell_x == BOOKMARKS_COLUMN_TIME))
|
||||||
{
|
{
|
||||||
if (bookmarks_array[cell_y].not_empty)
|
if (bookmarks_array[cell_y].not_empty)
|
||||||
{
|
{
|
||||||
|
@ -650,9 +714,9 @@ LONG BOOKMARKS::CustomDraw(NMLVCUSTOMDRAW* msg)
|
||||||
|
|
||||||
void BOOKMARKS::LeftClick()
|
void BOOKMARKS::LeftClick()
|
||||||
{
|
{
|
||||||
if (column_clicked <= BOOKMARKS_COLUMN_FRAME || (taseditor_config.branch_only_when_rec && movie_readonly))
|
if (column_clicked <= BOOKMARKS_COLUMN_FRAME || (taseditor_config.old_branching_controls && movie_readonly))
|
||||||
command(COMMAND_JUMP, bookmark_leftclicked);
|
command(COMMAND_JUMP, bookmark_leftclicked);
|
||||||
else if (column_clicked == BOOKMARKS_COLUMN_TIME && (!taseditor_config.branch_only_when_rec || !movie_readonly))
|
else if (column_clicked == BOOKMARKS_COLUMN_TIME && (!taseditor_config.old_branching_controls || !movie_readonly))
|
||||||
command(COMMAND_DEPLOY, bookmark_leftclicked);
|
command(COMMAND_DEPLOY, bookmark_leftclicked);
|
||||||
}
|
}
|
||||||
void BOOKMARKS::RightClick()
|
void BOOKMARKS::RightClick()
|
||||||
|
@ -716,9 +780,9 @@ LRESULT APIENTRY BookmarksListWndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM
|
||||||
{
|
{
|
||||||
bookmarks.bookmark_leftclicked = (info.iItem + 1) % TOTAL_BOOKMARKS;
|
bookmarks.bookmark_leftclicked = (info.iItem + 1) % TOTAL_BOOKMARKS;
|
||||||
bookmarks.column_clicked = info.iSubItem;
|
bookmarks.column_clicked = info.iSubItem;
|
||||||
if (bookmarks.column_clicked <= BOOKMARKS_COLUMN_FRAME || (taseditor_config.branch_only_when_rec && movie_readonly))
|
if (bookmarks.column_clicked <= BOOKMARKS_COLUMN_FRAME || (taseditor_config.old_branching_controls && movie_readonly))
|
||||||
bookmarks.bookmarks_array[bookmarks.bookmark_leftclicked].flash_type = FLASH_TYPE_JUMP;
|
bookmarks.bookmarks_array[bookmarks.bookmark_leftclicked].flash_type = FLASH_TYPE_JUMP;
|
||||||
else if (bookmarks.column_clicked == BOOKMARKS_COLUMN_TIME && (!taseditor_config.branch_only_when_rec || !movie_readonly))
|
else if (bookmarks.column_clicked == BOOKMARKS_COLUMN_TIME && (!taseditor_config.old_branching_controls || !movie_readonly))
|
||||||
bookmarks.bookmarks_array[bookmarks.bookmark_leftclicked].flash_type = FLASH_TYPE_DEPLOY;
|
bookmarks.bookmarks_array[bookmarks.bookmark_leftclicked].flash_type = FLASH_TYPE_DEPLOY;
|
||||||
SetCapture(hWnd);
|
SetCapture(hWnd);
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,14 +16,17 @@ enum COMMANDS
|
||||||
COMMAND_SET = 0,
|
COMMAND_SET = 0,
|
||||||
COMMAND_JUMP = 1,
|
COMMAND_JUMP = 1,
|
||||||
COMMAND_DEPLOY = 2,
|
COMMAND_DEPLOY = 2,
|
||||||
COMMAND_DELETE = 3, // not implemented, probably useless
|
COMMAND_SELECT = 3,
|
||||||
|
COMMAND_DELETE = 4, // not implemented, probably useless
|
||||||
|
|
||||||
TOTAL_COMMANDS
|
TOTAL_COMMANDS
|
||||||
};
|
};
|
||||||
|
|
||||||
#define BOOKMARKSLIST_COLUMN_ICONS_WIDTH 14
|
#define BOOKMARKSLIST_COLUMN_ICONS_WIDTH 15
|
||||||
#define BOOKMARKSLIST_COLUMN_FRAMENUM_WIDTH 74
|
#define BOOKMARKSLIST_COLUMN_FRAMENUM_WIDTH 74
|
||||||
#define BOOKMARKSLIST_COLUMN_TIME_WIDTH 82
|
#define BOOKMARKSLIST_COLUMN_TIME_WIDTH 80
|
||||||
|
|
||||||
|
#define BOOKMARKS_SELECTED 20
|
||||||
|
|
||||||
#define ITEM_UNDER_MOUSE_NONE -2
|
#define ITEM_UNDER_MOUSE_NONE -2
|
||||||
#define ITEM_UNDER_MOUSE_CLOUD -1
|
#define ITEM_UNDER_MOUSE_CLOUD -1
|
||||||
|
@ -41,7 +44,7 @@ enum
|
||||||
#define BOOKMARKS_ID_LEN 10
|
#define BOOKMARKS_ID_LEN 10
|
||||||
#define TIME_DESC_LENGTH 9 // "HH:MM:SS"
|
#define TIME_DESC_LENGTH 9 // "HH:MM:SS"
|
||||||
|
|
||||||
#define DEFAULT_BOOKMARK 1
|
#define DEFAULT_SLOT 1
|
||||||
|
|
||||||
class BOOKMARKS
|
class BOOKMARKS
|
||||||
{
|
{
|
||||||
|
@ -74,7 +77,7 @@ public:
|
||||||
void MouseMove(int new_x, int new_y);
|
void MouseMove(int new_x, int new_y);
|
||||||
int FindItemUnderMouse();
|
int FindItemUnderMouse();
|
||||||
|
|
||||||
bool IsSafeToShowBookmarksData();
|
int GetSelectedSlot();
|
||||||
|
|
||||||
// saved vars
|
// saved vars
|
||||||
std::vector<BOOKMARK> bookmarks_array;
|
std::vector<BOOKMARK> bookmarks_array;
|
||||||
|
@ -99,6 +102,7 @@ private:
|
||||||
|
|
||||||
// not saved vars
|
// not saved vars
|
||||||
std::vector<int> commands;
|
std::vector<int> commands;
|
||||||
|
int selected_slot;
|
||||||
int check_flash_shedule;
|
int check_flash_shedule;
|
||||||
int mouse_x, mouse_y;
|
int mouse_x, mouse_y;
|
||||||
|
|
||||||
|
|
|
@ -212,6 +212,64 @@ void EDITOR::InputSetPattern(int start, int end, int joy, int button, int consec
|
||||||
greenzone.InvalidateAndCheck(history.RegisterChanges(MODTYPE_PATTERN, start, end, autofire_patterns_names[current_pattern].c_str(), consecutive_tag));
|
greenzone.InvalidateAndCheck(history.RegisterChanges(MODTYPE_PATTERN, start, end, autofire_patterns_names[current_pattern].c_str(), consecutive_tag));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void EDITOR::AdjustUp(int at)
|
||||||
|
{
|
||||||
|
if (at < 0)
|
||||||
|
return;
|
||||||
|
bool markers_changed = false;
|
||||||
|
// delete one frame
|
||||||
|
currMovieData.records.erase(currMovieData.records.begin() + at);
|
||||||
|
if (taseditor_config.bind_markers)
|
||||||
|
{
|
||||||
|
if (markers_manager.EraseMarker(at))
|
||||||
|
markers_changed = true;
|
||||||
|
}
|
||||||
|
// check if user deleted all frames
|
||||||
|
if (!currMovieData.getNumRecords())
|
||||||
|
playback.StartFromZero();
|
||||||
|
// reduce Piano Roll
|
||||||
|
piano_roll.UpdateItemCount();
|
||||||
|
// check and register changes
|
||||||
|
int result = history.RegisterChanges(MODTYPE_ADJUST_UP, at);
|
||||||
|
if (result >= 0)
|
||||||
|
{
|
||||||
|
greenzone.InvalidateAndCheck(result);
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
// check for special case: user deleted a bunch of empty frames the end of the movie
|
||||||
|
greenzone.InvalidateAndCheck(currMovieData.getNumRecords() - 1);
|
||||||
|
if (markers_changed)
|
||||||
|
history.RegisterMarkersChange(MODTYPE_MARKER_SHIFT, at);
|
||||||
|
}
|
||||||
|
if (markers_changed)
|
||||||
|
selection.must_find_current_marker = playback.must_find_current_marker = true;
|
||||||
|
}
|
||||||
|
void EDITOR::AdjustDown(int at)
|
||||||
|
{
|
||||||
|
if (at < 0)
|
||||||
|
return;
|
||||||
|
bool markers_changed = false;
|
||||||
|
// insert blank frame
|
||||||
|
currMovieData.insertEmpty(at, 1);
|
||||||
|
if (taseditor_config.bind_markers)
|
||||||
|
{
|
||||||
|
if (markers_manager.insertEmpty(at, 1))
|
||||||
|
markers_changed = true;
|
||||||
|
}
|
||||||
|
// check and register changes
|
||||||
|
int first_changes = history.RegisterChanges(MODTYPE_ADJUST_DOWN, at);
|
||||||
|
if (first_changes >= 0)
|
||||||
|
{
|
||||||
|
greenzone.InvalidateAndCheck(first_changes);
|
||||||
|
} else if (markers_changed)
|
||||||
|
{
|
||||||
|
history.RegisterMarkersChange(MODTYPE_MARKER_SHIFT, at);
|
||||||
|
piano_roll.RedrawList();
|
||||||
|
}
|
||||||
|
if (markers_changed)
|
||||||
|
selection.must_find_current_marker = playback.must_find_current_marker = true;
|
||||||
|
}
|
||||||
|
|
||||||
// following functions use current Selection to determine range of frames
|
// following functions use current Selection to determine range of frames
|
||||||
bool EDITOR::FrameColumnSet()
|
bool EDITOR::FrameColumnSet()
|
||||||
{
|
{
|
||||||
|
|
|
@ -12,6 +12,9 @@ public:
|
||||||
void InputToggle(int start, int end, int joy, int button, int consecutive_tag = 0);
|
void InputToggle(int start, int end, int joy, int button, int consecutive_tag = 0);
|
||||||
void InputSetPattern(int start, int end, int joy, int button, int consecutive_tag = 0);
|
void InputSetPattern(int start, int end, int joy, int button, int consecutive_tag = 0);
|
||||||
|
|
||||||
|
void AdjustUp(int at);
|
||||||
|
void AdjustDown(int at);
|
||||||
|
|
||||||
bool FrameColumnSet();
|
bool FrameColumnSet();
|
||||||
bool FrameColumnSetPattern();
|
bool FrameColumnSetPattern();
|
||||||
bool InputColumnSet(int joy, int button);
|
bool InputColumnSet(int joy, int button);
|
||||||
|
|
|
@ -28,6 +28,7 @@ extern TASEDITOR_PROJECT project;
|
||||||
extern PLAYBACK playback;
|
extern PLAYBACK playback;
|
||||||
extern BOOKMARKS bookmarks;
|
extern BOOKMARKS bookmarks;
|
||||||
extern PIANO_ROLL piano_roll;
|
extern PIANO_ROLL piano_roll;
|
||||||
|
extern EDITOR editor;
|
||||||
|
|
||||||
extern char lagFlag;
|
extern char lagFlag;
|
||||||
|
|
||||||
|
@ -74,7 +75,7 @@ void GREENZONE::CollectCurrentState()
|
||||||
{
|
{
|
||||||
// update greenzone upper limit if needed
|
// update greenzone upper limit if needed
|
||||||
if (greenZoneCount <= currFrameCounter)
|
if (greenZoneCount <= currFrameCounter)
|
||||||
greenZoneCount = currFrameCounter+1;
|
greenZoneCount = currFrameCounter + 1;
|
||||||
|
|
||||||
if ((int)savestates.size() < greenZoneCount)
|
if ((int)savestates.size() < greenZoneCount)
|
||||||
savestates.resize(greenZoneCount);
|
savestates.resize(greenZoneCount);
|
||||||
|
@ -87,10 +88,24 @@ void GREENZONE::CollectCurrentState()
|
||||||
if (currFrameCounter > 0)
|
if (currFrameCounter > 0)
|
||||||
{
|
{
|
||||||
// lagFlag indicates that lag was in previous frame
|
// lagFlag indicates that lag was in previous frame
|
||||||
|
int old_lagFlag = lag_history[currFrameCounter - 1];
|
||||||
if (lagFlag)
|
if (lagFlag)
|
||||||
lag_history[currFrameCounter-1] = 1;
|
lag_history[currFrameCounter - 1] = 1;
|
||||||
else
|
else
|
||||||
lag_history[currFrameCounter-1] = 0;
|
lag_history[currFrameCounter - 1] = 0;
|
||||||
|
// Auto-adjust Input due to lag
|
||||||
|
if (taseditor_config.adjust_input_due_to_lag)
|
||||||
|
{
|
||||||
|
if (old_lagFlag && !lagFlag)
|
||||||
|
{
|
||||||
|
// there's no more lag on previous frame - shift input up
|
||||||
|
editor.AdjustUp(currFrameCounter - 1);
|
||||||
|
} else if (!old_lagFlag && lagFlag)
|
||||||
|
{
|
||||||
|
// there's new lag on previous frame - shift input down
|
||||||
|
editor.AdjustDown(currFrameCounter - 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -410,31 +425,34 @@ void GREENZONE::InvalidateAndCheck(int after)
|
||||||
{
|
{
|
||||||
greenZoneCount = after+1;
|
greenZoneCount = after+1;
|
||||||
currMovieData.rerecordCount++;
|
currMovieData.rerecordCount++;
|
||||||
// either set playback cursor to the end of greenzone or run seeking to restore playback position
|
// either set Playback cursor to the end of Greenzone or run seeking to restore playback position
|
||||||
if (currFrameCounter >= greenZoneCount)
|
if (currFrameCounter >= greenZoneCount)
|
||||||
{
|
{
|
||||||
// remember the lost position
|
|
||||||
if ((playback.lost_position_frame < currFrameCounter + 1) || (playback.lost_position_frame > currFrameCounter + 1 && !playback.lost_position_must_be_fixed))
|
|
||||||
{
|
|
||||||
if (playback.lost_position_frame)
|
|
||||||
piano_roll.RedrawRow(playback.lost_position_frame - 1);
|
|
||||||
playback.lost_position_frame = currFrameCounter + 1;
|
|
||||||
playback.lost_position_must_be_fixed = true;
|
|
||||||
}
|
|
||||||
// auto-restore position if needed
|
// auto-restore position if needed
|
||||||
if (taseditor_config.restore_position)
|
if (taseditor_config.restore_position)
|
||||||
{
|
{
|
||||||
if (playback.pause_frame && playback.pause_frame_must_be_fixed)
|
if (playback.pause_frame && playback.pause_frame_must_be_fixed)
|
||||||
|
{
|
||||||
playback.jump(playback.pause_frame - 1);
|
playback.jump(playback.pause_frame - 1);
|
||||||
else
|
|
||||||
playback.jump(currFrameCounter);
|
|
||||||
} else
|
} else
|
||||||
{
|
{
|
||||||
|
playback.SetLostPosition(currFrameCounter);
|
||||||
|
playback.jump(currFrameCounter);
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
if (playback.pause_frame && playback.pause_frame_must_be_fixed)
|
||||||
|
{
|
||||||
|
playback.jump(playback.pause_frame - 1);
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
playback.SetLostPosition(currFrameCounter);
|
||||||
playback.jump(greenZoneCount-1);
|
playback.jump(greenZoneCount-1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
// redraw Piano Roll even if greenzone didn't change
|
// redraw Piano Roll even if greenzone didn't change
|
||||||
piano_roll.RedrawList();
|
piano_roll.RedrawList();
|
||||||
bookmarks.RedrawBookmarksList();
|
bookmarks.RedrawBookmarksList();
|
||||||
|
|
|
@ -102,7 +102,9 @@ char modCaptions[MODTYPES_TOTAL][20] = {" Initialization",
|
||||||
" LUA Marker Set",
|
" LUA Marker Set",
|
||||||
" LUA Marker Remove",
|
" LUA Marker Remove",
|
||||||
" LUA Marker Rename",
|
" LUA Marker Rename",
|
||||||
" LUA Change" };
|
" LUA Change",
|
||||||
|
" AdjustUp",
|
||||||
|
" AdjustDown" };
|
||||||
char LuaCaptionPrefix[6] = " LUA ";
|
char LuaCaptionPrefix[6] = " LUA ";
|
||||||
char joypadCaptions[4][5] = {"(1P)", "(2P)", "(3P)", "(4P)"};
|
char joypadCaptions[4][5] = {"(1P)", "(2P)", "(3P)", "(4P)"};
|
||||||
|
|
||||||
|
@ -489,6 +491,8 @@ int HISTORY::RegisterChanges(int mod_type, int start, int end, const char* comme
|
||||||
case MODTYPE_PASTE:
|
case MODTYPE_PASTE:
|
||||||
case MODTYPE_CLONE:
|
case MODTYPE_CLONE:
|
||||||
case MODTYPE_PATTERN:
|
case MODTYPE_PATTERN:
|
||||||
|
case MODTYPE_ADJUST_UP:
|
||||||
|
case MODTYPE_ADJUST_DOWN:
|
||||||
{
|
{
|
||||||
// for these changes user prefers to see frame of attempted change (selection beginning), not frame of actual differences
|
// for these changes user prefers to see frame of attempted change (selection beginning), not frame of actual differences
|
||||||
snap.jump_frame = start;
|
snap.jump_frame = start;
|
||||||
|
@ -568,6 +572,12 @@ int HISTORY::RegisterChanges(int mod_type, int start, int end, const char* comme
|
||||||
case MODTYPE_CLONE:
|
case MODTYPE_CLONE:
|
||||||
snap.inheritHotChanges_InsertSelection(&snapshots[real_pos]);
|
snap.inheritHotChanges_InsertSelection(&snapshots[real_pos]);
|
||||||
break;
|
break;
|
||||||
|
case MODTYPE_ADJUST_UP:
|
||||||
|
snap.inheritHotChanges_DeleteNum(&snapshots[real_pos], start, 1);
|
||||||
|
break;
|
||||||
|
case MODTYPE_ADJUST_DOWN:
|
||||||
|
snap.inheritHotChanges_InsertNum(&snapshots[real_pos], start, 1);
|
||||||
|
break;
|
||||||
case MODTYPE_SET:
|
case MODTYPE_SET:
|
||||||
case MODTYPE_UNSET:
|
case MODTYPE_UNSET:
|
||||||
case MODTYPE_CLEAR:
|
case MODTYPE_CLEAR:
|
||||||
|
|
|
@ -66,6 +66,8 @@ enum MOD_TYPES
|
||||||
MODTYPE_LUA_MARKER_REMOVE,
|
MODTYPE_LUA_MARKER_REMOVE,
|
||||||
MODTYPE_LUA_MARKER_RENAME,
|
MODTYPE_LUA_MARKER_RENAME,
|
||||||
MODTYPE_LUA_CHANGE,
|
MODTYPE_LUA_CHANGE,
|
||||||
|
MODTYPE_ADJUST_UP,
|
||||||
|
MODTYPE_ADJUST_DOWN,
|
||||||
|
|
||||||
MODTYPES_TOTAL
|
MODTYPES_TOTAL
|
||||||
};
|
};
|
||||||
|
|
|
@ -1188,7 +1188,7 @@ void PIANO_ROLL::GetDispInfo(NMLVDISPINFO* nmlvDispInfo)
|
||||||
if (item.iImage < 0)
|
if (item.iImage < 0)
|
||||||
{
|
{
|
||||||
// no bookmark at this frame
|
// no bookmark at this frame
|
||||||
if (item.iItem == playback.lost_position_frame - 1)
|
if (item.iItem == playback.GetLostPosition())
|
||||||
{
|
{
|
||||||
if (item.iItem == currFrameCounter)
|
if (item.iItem == currFrameCounter)
|
||||||
item.iImage = GREEN_BLUE_ARROW_IMAGE_ID;
|
item.iImage = GREEN_BLUE_ARROW_IMAGE_ID;
|
||||||
|
@ -1201,7 +1201,7 @@ void PIANO_ROLL::GetDispInfo(NMLVDISPINFO* nmlvDispInfo)
|
||||||
} else
|
} else
|
||||||
{
|
{
|
||||||
// bookmark at this frame
|
// bookmark at this frame
|
||||||
if (item.iItem == playback.lost_position_frame - 1)
|
if (item.iItem == playback.GetLostPosition())
|
||||||
item.iImage += BOOKMARKS_WITH_GREEN_ARROW;
|
item.iImage += BOOKMARKS_WITH_GREEN_ARROW;
|
||||||
else if (item.iItem == currFrameCounter)
|
else if (item.iItem == currFrameCounter)
|
||||||
item.iImage += BOOKMARKS_WITH_BLUE_ARROW;
|
item.iImage += BOOKMARKS_WITH_BLUE_ARROW;
|
||||||
|
|
|
@ -471,6 +471,21 @@ bool PLAYBACK::JumpToFrame(int index)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void PLAYBACK::SetLostPosition(int frame)
|
||||||
|
{
|
||||||
|
if ((lost_position_frame < frame + 1) || (lost_position_frame > frame + 1 && !lost_position_must_be_fixed))
|
||||||
|
{
|
||||||
|
if (lost_position_frame)
|
||||||
|
piano_roll.RedrawRow(lost_position_frame - 1);
|
||||||
|
lost_position_frame = frame + 1;
|
||||||
|
lost_position_must_be_fixed = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
int PLAYBACK::GetLostPosition()
|
||||||
|
{
|
||||||
|
return lost_position_frame - 1;
|
||||||
|
}
|
||||||
|
|
||||||
int PLAYBACK::GetFlashingPauseFrame()
|
int PLAYBACK::GetFlashingPauseFrame()
|
||||||
{
|
{
|
||||||
if (show_pauseframe)
|
if (show_pauseframe)
|
||||||
|
|
|
@ -39,13 +39,13 @@ public:
|
||||||
|
|
||||||
void StartFromZero();
|
void StartFromZero();
|
||||||
|
|
||||||
|
void SetLostPosition(int frame);
|
||||||
|
int GetLostPosition(); // actually returns lost_position_frame-1
|
||||||
|
|
||||||
int GetFlashingPauseFrame();
|
int GetFlashingPauseFrame();
|
||||||
void SetProgressbar(int a, int b);
|
void SetProgressbar(int a, int b);
|
||||||
void CancelSeeking();
|
void CancelSeeking();
|
||||||
|
|
||||||
int lastCursor; // but for currentCursor we use external variable currFrameCounter
|
|
||||||
int lost_position_frame;
|
|
||||||
bool lost_position_must_be_fixed; // for when Greenzone invalidates several times, but the end of current segment must remain the same
|
|
||||||
int pause_frame;
|
int pause_frame;
|
||||||
bool pause_frame_must_be_fixed; // for "Auto-restore last position"
|
bool pause_frame_must_be_fixed; // for "Auto-restore last position"
|
||||||
bool must_find_current_marker;
|
bool must_find_current_marker;
|
||||||
|
@ -61,6 +61,9 @@ private:
|
||||||
bool old_emu_paused, emu_paused;
|
bool old_emu_paused, emu_paused;
|
||||||
int old_pauseframe;
|
int old_pauseframe;
|
||||||
bool old_show_pauseframe, show_pauseframe;
|
bool old_show_pauseframe, show_pauseframe;
|
||||||
|
int lastCursor; // but for currentCursor we use external variable currFrameCounter
|
||||||
|
int lost_position_frame;
|
||||||
|
bool lost_position_must_be_fixed; // for when Greenzone invalidates several times, but the end of current segment must remain the same
|
||||||
bool old_rewind_button_state, rewind_button_state;
|
bool old_rewind_button_state, rewind_button_state;
|
||||||
bool old_forward_button_state, forward_button_state;
|
bool old_forward_button_state, forward_button_state;
|
||||||
bool old_rewind_full_button_state, rewind_full_button_state;
|
bool old_rewind_full_button_state, rewind_full_button_state;
|
||||||
|
|
|
@ -114,7 +114,7 @@ void RECORDER::update()
|
||||||
if (old_movie_readonly != movie_readonly || old_multitrack_recording_joypad != multitrack_recording_joypad)
|
if (old_movie_readonly != movie_readonly || old_multitrack_recording_joypad != multitrack_recording_joypad)
|
||||||
taseditor_window.UpdateCaption();
|
taseditor_window.UpdateCaption();
|
||||||
// update Bookmarks/Branches groupbox caption if needed
|
// update Bookmarks/Branches groupbox caption if needed
|
||||||
if (taseditor_config.branch_only_when_rec && old_movie_readonly != movie_readonly)
|
if (taseditor_config.old_branching_controls && old_movie_readonly != movie_readonly)
|
||||||
bookmarks.RedrawBookmarksCaption();
|
bookmarks.RedrawBookmarksCaption();
|
||||||
// update "Recording" checkbox state
|
// update "Recording" checkbox state
|
||||||
if (old_movie_readonly != movie_readonly)
|
if (old_movie_readonly != movie_readonly)
|
||||||
|
|
|
@ -690,11 +690,32 @@ void SNAPSHOT::inheritHotChanges_InsertSelection(SNAPSHOT* source_of_hotchanges)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
void SNAPSHOT::inheritHotChanges_InsertNum(SNAPSHOT* source_of_hotchanges, int start, int frames)
|
void SNAPSHOT::inheritHotChanges_DeleteNum(SNAPSHOT* source_of_hotchanges, int start, int frames)
|
||||||
{
|
{
|
||||||
int bytes = joysticks_per_frame[input_type] * HOTCHANGE_BYTES_PER_JOY;
|
int bytes = joysticks_per_frame[input_type] * HOTCHANGE_BYTES_PER_JOY;
|
||||||
// copy hot changes from source snapshot up to "start" and from "start+frames" to end
|
// copy hot changes from source snapshot up to "start" and from "start+frames" to end
|
||||||
if (source_of_hotchanges && source_of_hotchanges->has_hot_changes && source_of_hotchanges->input_type == input_type)
|
if (source_of_hotchanges && source_of_hotchanges->has_hot_changes && source_of_hotchanges->input_type == input_type)
|
||||||
|
{
|
||||||
|
int this_size = hot_changes.size(), source_size = source_of_hotchanges->hot_changes.size();
|
||||||
|
int bytes_to_copy = bytes * start;
|
||||||
|
int dest_pos = 0, source_pos = 0;
|
||||||
|
if (bytes_to_copy > source_size)
|
||||||
|
bytes_to_copy = source_size;
|
||||||
|
memcpy(&hot_changes[dest_pos], &source_of_hotchanges->hot_changes[source_pos], bytes_to_copy);
|
||||||
|
dest_pos += bytes_to_copy;
|
||||||
|
source_pos += bytes_to_copy + bytes * frames;
|
||||||
|
bytes_to_copy = this_size - dest_pos;
|
||||||
|
if (bytes_to_copy > source_size - source_pos)
|
||||||
|
bytes_to_copy = source_size - source_pos;
|
||||||
|
memcpy(&hot_changes[dest_pos], &source_of_hotchanges->hot_changes[source_pos], bytes_to_copy);
|
||||||
|
FadeHotChanges();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void SNAPSHOT::inheritHotChanges_InsertNum(SNAPSHOT* source_of_hotchanges, int start, int frames)
|
||||||
|
{
|
||||||
|
int bytes = joysticks_per_frame[input_type] * HOTCHANGE_BYTES_PER_JOY;
|
||||||
|
// copy hot changes from source snapshot up to "start", then make a gap, then copy from "start+frames" to end
|
||||||
|
if (source_of_hotchanges && source_of_hotchanges->has_hot_changes && source_of_hotchanges->input_type == input_type)
|
||||||
{
|
{
|
||||||
int this_size = hot_changes.size(), source_size = source_of_hotchanges->hot_changes.size();
|
int this_size = hot_changes.size(), source_size = source_of_hotchanges->hot_changes.size();
|
||||||
int bytes_to_copy = bytes * start;
|
int bytes_to_copy = bytes * start;
|
||||||
|
@ -710,7 +731,7 @@ void SNAPSHOT::inheritHotChanges_InsertNum(SNAPSHOT* source_of_hotchanges, int s
|
||||||
memcpy(&hot_changes[dest_pos], &source_of_hotchanges->hot_changes[source_pos], bytes_to_copy);
|
memcpy(&hot_changes[dest_pos], &source_of_hotchanges->hot_changes[source_pos], bytes_to_copy);
|
||||||
FadeHotChanges();
|
FadeHotChanges();
|
||||||
}
|
}
|
||||||
// now set filled lines on frames from start to start+frames
|
// fill the gap with max_hot lines on frames from "start" to "start+frames"
|
||||||
memset(&hot_changes[bytes * start], 0xFF, bytes * frames);
|
memset(&hot_changes[bytes * start], 0xFF, bytes * frames);
|
||||||
}
|
}
|
||||||
void SNAPSHOT::inheritHotChanges_PasteInsert(SNAPSHOT* source_of_hotchanges, SelectionFrames& inserted_set)
|
void SNAPSHOT::inheritHotChanges_PasteInsert(SNAPSHOT* source_of_hotchanges, SelectionFrames& inserted_set)
|
||||||
|
|
|
@ -49,6 +49,7 @@ public:
|
||||||
void inheritHotChanges(SNAPSHOT* source_of_hotchanges);
|
void inheritHotChanges(SNAPSHOT* source_of_hotchanges);
|
||||||
void inheritHotChanges_DeleteSelection(SNAPSHOT* source_of_hotchanges);
|
void inheritHotChanges_DeleteSelection(SNAPSHOT* source_of_hotchanges);
|
||||||
void inheritHotChanges_InsertSelection(SNAPSHOT* source_of_hotchanges);
|
void inheritHotChanges_InsertSelection(SNAPSHOT* source_of_hotchanges);
|
||||||
|
void inheritHotChanges_DeleteNum(SNAPSHOT* source_of_hotchanges, int start, int frames);
|
||||||
void inheritHotChanges_InsertNum(SNAPSHOT* source_of_hotchanges, int start, int frames);
|
void inheritHotChanges_InsertNum(SNAPSHOT* source_of_hotchanges, int start, int frames);
|
||||||
void inheritHotChanges_PasteInsert(SNAPSHOT* source_of_hotchanges, SelectionFrames& inserted_set);
|
void inheritHotChanges_PasteInsert(SNAPSHOT* source_of_hotchanges, SelectionFrames& inserted_set);
|
||||||
void fillHotChanges(SNAPSHOT& snap, int start = 0, int end = -1);
|
void fillHotChanges(SNAPSHOT& snap, int start = 0, int end = -1);
|
||||||
|
|
|
@ -267,8 +267,6 @@ void SPLICER::DeleteFrames()
|
||||||
markers_changed = true;
|
markers_changed = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (markers_changed)
|
|
||||||
selection.must_find_current_marker = playback.must_find_current_marker = true;
|
|
||||||
// check if user deleted all frames
|
// check if user deleted all frames
|
||||||
if (!currMovieData.getNumRecords())
|
if (!currMovieData.getNumRecords())
|
||||||
playback.StartFromZero();
|
playback.StartFromZero();
|
||||||
|
@ -286,6 +284,8 @@ void SPLICER::DeleteFrames()
|
||||||
if (markers_changed)
|
if (markers_changed)
|
||||||
history.RegisterMarkersChange(MODTYPE_MARKER_SHIFT, start_index);
|
history.RegisterMarkersChange(MODTYPE_MARKER_SHIFT, start_index);
|
||||||
}
|
}
|
||||||
|
if (markers_changed)
|
||||||
|
selection.must_find_current_marker = playback.must_find_current_marker = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void SPLICER::ClearFrames(SelectionFrames* current_selection)
|
void SPLICER::ClearFrames(SelectionFrames* current_selection)
|
||||||
|
|
|
@ -47,10 +47,11 @@ TASEDITOR_CONFIG::TASEDITOR_CONFIG()
|
||||||
columnset_by_keys = false;
|
columnset_by_keys = false;
|
||||||
superimpose = 0; // SUPERIMPOSE_UNCHECKED
|
superimpose = 0; // SUPERIMPOSE_UNCHECKED
|
||||||
branch_full_movie = true;
|
branch_full_movie = true;
|
||||||
branch_only_when_rec = false;
|
old_branching_controls = false;
|
||||||
view_branches_tree = false;
|
view_branches_tree = false;
|
||||||
branch_scr_hud = true;
|
branch_scr_hud = true;
|
||||||
restore_position = false;
|
restore_position = false;
|
||||||
|
adjust_input_due_to_lag = false;
|
||||||
greenzone_capacity = GREENZONE_CAPACITY_DEFAULT;
|
greenzone_capacity = GREENZONE_CAPACITY_DEFAULT;
|
||||||
undo_levels = UNDO_LEVELS_DEFAULT;
|
undo_levels = UNDO_LEVELS_DEFAULT;
|
||||||
autosave_period = AUTOSAVE_PERIOD_DEFAULT;
|
autosave_period = AUTOSAVE_PERIOD_DEFAULT;
|
||||||
|
|
|
@ -45,10 +45,11 @@ public:
|
||||||
bool columnset_by_keys;
|
bool columnset_by_keys;
|
||||||
int superimpose;
|
int superimpose;
|
||||||
bool branch_full_movie;
|
bool branch_full_movie;
|
||||||
bool branch_only_when_rec;
|
bool old_branching_controls;
|
||||||
bool view_branches_tree;
|
bool view_branches_tree;
|
||||||
bool branch_scr_hud;
|
bool branch_scr_hud;
|
||||||
bool restore_position;
|
bool restore_position;
|
||||||
|
bool adjust_input_due_to_lag;
|
||||||
int greenzone_capacity;
|
int greenzone_capacity;
|
||||||
int undo_levels;
|
int undo_levels;
|
||||||
int autosave_period;
|
int autosave_period;
|
||||||
|
|
|
@ -218,7 +218,7 @@ int TASEDITOR_LUA::getsuperimpose()
|
||||||
int TASEDITOR_LUA::getlostplayback()
|
int TASEDITOR_LUA::getlostplayback()
|
||||||
{
|
{
|
||||||
if (FCEUMOV_Mode(MOVIEMODE_TASEDITOR))
|
if (FCEUMOV_Mode(MOVIEMODE_TASEDITOR))
|
||||||
return playback.lost_position_frame - 1;
|
return playback.GetLostPosition();
|
||||||
else
|
else
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -74,6 +74,7 @@ LRESULT APIENTRY TASEDITOR_FORWARD_WndProc(HWND hWnd, UINT msg, WPARAM wParam, L
|
||||||
LRESULT APIENTRY TASEDITOR_FORWARD_FULL_WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
LRESULT APIENTRY TASEDITOR_FORWARD_FULL_WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
||||||
LRESULT APIENTRY CHECK_FOLLOW_CURSOR_WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
LRESULT APIENTRY CHECK_FOLLOW_CURSOR_WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
||||||
LRESULT APIENTRY CHECK_AUTORESTORE_PLAYBACK_WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
LRESULT APIENTRY CHECK_AUTORESTORE_PLAYBACK_WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
||||||
|
LRESULT APIENTRY CHECK_AUTOADJUSTINPUTDUETOLAG_WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
||||||
LRESULT APIENTRY IDC_RADIO_ALL_WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
LRESULT APIENTRY IDC_RADIO_ALL_WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
||||||
LRESULT APIENTRY IDC_RADIO_1P_WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
LRESULT APIENTRY IDC_RADIO_1P_WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
||||||
LRESULT APIENTRY IDC_RADIO_2P_WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
LRESULT APIENTRY IDC_RADIO_2P_WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
||||||
|
@ -100,6 +101,7 @@ WNDPROC
|
||||||
TASEDITOR_FORWARD_FULL_oldWndProc = 0,
|
TASEDITOR_FORWARD_FULL_oldWndProc = 0,
|
||||||
CHECK_FOLLOW_CURSOR_oldWndProc = 0,
|
CHECK_FOLLOW_CURSOR_oldWndProc = 0,
|
||||||
CHECK_AUTORESTORE_PLAYBACK_oldWndProc = 0,
|
CHECK_AUTORESTORE_PLAYBACK_oldWndProc = 0,
|
||||||
|
CHECK_AUTOADJUSTINPUTDUETOLAG_oldWndProc = 0,
|
||||||
IDC_RADIO_ALL_oldWndProc = 0,
|
IDC_RADIO_ALL_oldWndProc = 0,
|
||||||
IDC_RADIO_1P_oldWndProc = 0,
|
IDC_RADIO_1P_oldWndProc = 0,
|
||||||
IDC_RADIO_2P_oldWndProc = 0,
|
IDC_RADIO_2P_oldWndProc = 0,
|
||||||
|
@ -148,6 +150,7 @@ Window_items_struct window_items[TASEDITOR_WINDOW_TOTAL_ITEMS] = {
|
||||||
IDC_PROGRESS1, -1, 0, 0, 0, "", "", false, 0, 0,
|
IDC_PROGRESS1, -1, 0, 0, 0, "", "", false, 0, 0,
|
||||||
CHECK_FOLLOW_CURSOR, -1, 0, 0, 0, "The Piano Roll will follow Playback cursor movements", "", false, 0, 0,
|
CHECK_FOLLOW_CURSOR, -1, 0, 0, 0, "The Piano Roll will follow Playback cursor movements", "", false, 0, 0,
|
||||||
CHECK_AUTORESTORE_PLAYBACK, -1, 0, 0, 0, "Whenever you change input above Playback cursor, the cursor returns to where it was before the change (hotkey: Ctrl+Spacebar)", "", false, 0, 0,
|
CHECK_AUTORESTORE_PLAYBACK, -1, 0, 0, 0, "Whenever you change input above Playback cursor, the cursor returns to where it was before the change (hotkey: Ctrl+Spacebar)", "", false, 0, 0,
|
||||||
|
CHECK_AUTOADJUSTINPUTDUETOLAG, -1, 0, 0, 0, "TAS Editor will adjust Input when new lag frames appear or old lag frames disappear while emulating", "", false, 0, 0,
|
||||||
IDC_BOOKMARKSLIST, -1, 0, 0, 0, "Right click = set Bookmark, Left click = jump to Bookmark or load Branch", "", false, 0, 0,
|
IDC_BOOKMARKSLIST, -1, 0, 0, 0, "Right click = set Bookmark, Left click = jump to Bookmark or load Branch", "", false, 0, 0,
|
||||||
IDC_HISTORYLIST, -1, 0, 0, -1, "Click to revert the project back to that time", "", false, 0, 0,
|
IDC_HISTORYLIST, -1, 0, 0, -1, "Click to revert the project back to that time", "", false, 0, 0,
|
||||||
IDC_RADIO_ALL, -1, 0, 0, 0, "", "", false, 0, 0,
|
IDC_RADIO_ALL, -1, 0, 0, 0, "", "", false, 0, 0,
|
||||||
|
@ -271,6 +274,7 @@ void TASEDITOR_WINDOW::init()
|
||||||
TASEDITOR_FORWARD_FULL_oldWndProc = (WNDPROC)SetWindowLong(GetDlgItem(hwndTasEditor, TASEDITOR_FORWARD_FULL), GWL_WNDPROC, (LONG)TASEDITOR_FORWARD_FULL_WndProc);
|
TASEDITOR_FORWARD_FULL_oldWndProc = (WNDPROC)SetWindowLong(GetDlgItem(hwndTasEditor, TASEDITOR_FORWARD_FULL), GWL_WNDPROC, (LONG)TASEDITOR_FORWARD_FULL_WndProc);
|
||||||
CHECK_FOLLOW_CURSOR_oldWndProc = (WNDPROC)SetWindowLong(GetDlgItem(hwndTasEditor, CHECK_FOLLOW_CURSOR), GWL_WNDPROC, (LONG)CHECK_FOLLOW_CURSOR_WndProc);
|
CHECK_FOLLOW_CURSOR_oldWndProc = (WNDPROC)SetWindowLong(GetDlgItem(hwndTasEditor, CHECK_FOLLOW_CURSOR), GWL_WNDPROC, (LONG)CHECK_FOLLOW_CURSOR_WndProc);
|
||||||
CHECK_AUTORESTORE_PLAYBACK_oldWndProc = (WNDPROC)SetWindowLong(GetDlgItem(hwndTasEditor, CHECK_AUTORESTORE_PLAYBACK), GWL_WNDPROC, (LONG)CHECK_AUTORESTORE_PLAYBACK_WndProc);
|
CHECK_AUTORESTORE_PLAYBACK_oldWndProc = (WNDPROC)SetWindowLong(GetDlgItem(hwndTasEditor, CHECK_AUTORESTORE_PLAYBACK), GWL_WNDPROC, (LONG)CHECK_AUTORESTORE_PLAYBACK_WndProc);
|
||||||
|
CHECK_AUTOADJUSTINPUTDUETOLAG_oldWndProc = (WNDPROC)SetWindowLong(GetDlgItem(hwndTasEditor, CHECK_AUTOADJUSTINPUTDUETOLAG), GWL_WNDPROC, (LONG)CHECK_AUTOADJUSTINPUTDUETOLAG_WndProc);
|
||||||
IDC_RADIO_ALL_oldWndProc = (WNDPROC)SetWindowLong(GetDlgItem(hwndTasEditor, IDC_RADIO_ALL), GWL_WNDPROC, (LONG)IDC_RADIO_ALL_WndProc);
|
IDC_RADIO_ALL_oldWndProc = (WNDPROC)SetWindowLong(GetDlgItem(hwndTasEditor, IDC_RADIO_ALL), GWL_WNDPROC, (LONG)IDC_RADIO_ALL_WndProc);
|
||||||
IDC_RADIO_1P_oldWndProc = (WNDPROC)SetWindowLong(GetDlgItem(hwndTasEditor, IDC_RADIO_1P), GWL_WNDPROC, (LONG)IDC_RADIO_1P_WndProc);
|
IDC_RADIO_1P_oldWndProc = (WNDPROC)SetWindowLong(GetDlgItem(hwndTasEditor, IDC_RADIO_1P), GWL_WNDPROC, (LONG)IDC_RADIO_1P_WndProc);
|
||||||
IDC_RADIO_2P_oldWndProc = (WNDPROC)SetWindowLong(GetDlgItem(hwndTasEditor, IDC_RADIO_2P), GWL_WNDPROC, (LONG)IDC_RADIO_2P_WndProc);
|
IDC_RADIO_2P_oldWndProc = (WNDPROC)SetWindowLong(GetDlgItem(hwndTasEditor, IDC_RADIO_2P), GWL_WNDPROC, (LONG)IDC_RADIO_2P_WndProc);
|
||||||
|
@ -552,7 +556,8 @@ void TASEDITOR_WINDOW::UpdateCheckedItems()
|
||||||
{
|
{
|
||||||
// check option ticks
|
// check option ticks
|
||||||
CheckDlgButton(hwndTasEditor, CHECK_FOLLOW_CURSOR, taseditor_config.follow_playback?BST_CHECKED : BST_UNCHECKED);
|
CheckDlgButton(hwndTasEditor, CHECK_FOLLOW_CURSOR, taseditor_config.follow_playback?BST_CHECKED : BST_UNCHECKED);
|
||||||
CheckDlgButton(hwndTasEditor,CHECK_AUTORESTORE_PLAYBACK,taseditor_config.restore_position?BST_CHECKED:BST_UNCHECKED);
|
CheckDlgButton(hwndTasEditor, CHECK_AUTORESTORE_PLAYBACK, taseditor_config.restore_position?BST_CHECKED:BST_UNCHECKED);
|
||||||
|
CheckDlgButton(hwndTasEditor, CHECK_AUTOADJUSTINPUTDUETOLAG, taseditor_config.adjust_input_due_to_lag?BST_CHECKED:BST_UNCHECKED);
|
||||||
if (taseditor_config.superimpose == SUPERIMPOSE_UNCHECKED)
|
if (taseditor_config.superimpose == SUPERIMPOSE_UNCHECKED)
|
||||||
CheckDlgButton(hwndTasEditor, IDC_SUPERIMPOSE, BST_UNCHECKED);
|
CheckDlgButton(hwndTasEditor, IDC_SUPERIMPOSE, BST_UNCHECKED);
|
||||||
else if (taseditor_config.superimpose == SUPERIMPOSE_CHECKED)
|
else if (taseditor_config.superimpose == SUPERIMPOSE_CHECKED)
|
||||||
|
@ -568,7 +573,7 @@ void TASEDITOR_WINDOW::UpdateCheckedItems()
|
||||||
CheckMenuItem(hmenu, ID_VIEW_FOLLOWMARKERNOTECONTEXT, taseditor_config.follow_note_context?MF_CHECKED : MF_UNCHECKED);
|
CheckMenuItem(hmenu, ID_VIEW_FOLLOWMARKERNOTECONTEXT, taseditor_config.follow_note_context?MF_CHECKED : MF_UNCHECKED);
|
||||||
CheckMenuItem(hmenu, ID_VIEW_ENABLEHOTCHANGES, taseditor_config.enable_hot_changes?MF_CHECKED : MF_UNCHECKED);
|
CheckMenuItem(hmenu, ID_VIEW_ENABLEHOTCHANGES, taseditor_config.enable_hot_changes?MF_CHECKED : MF_UNCHECKED);
|
||||||
CheckMenuItem(hmenu, ID_CONFIG_BRANCHESRESTOREFULLMOVIE, taseditor_config.branch_full_movie?MF_CHECKED : MF_UNCHECKED);
|
CheckMenuItem(hmenu, ID_CONFIG_BRANCHESRESTOREFULLMOVIE, taseditor_config.branch_full_movie?MF_CHECKED : MF_UNCHECKED);
|
||||||
CheckMenuItem(hmenu, ID_CONFIG_BRANCHESWORKONLYWHENRECORDING, taseditor_config.branch_only_when_rec?MF_CHECKED : MF_UNCHECKED);
|
CheckMenuItem(hmenu, ID_CONFIG_OLDBRANCHINGCONTROLS, taseditor_config.old_branching_controls?MF_CHECKED : MF_UNCHECKED);
|
||||||
CheckMenuItem(hmenu, ID_CONFIG_HUDINBRANCHSCREENSHOTS, taseditor_config.branch_scr_hud?MF_CHECKED : MF_UNCHECKED);
|
CheckMenuItem(hmenu, ID_CONFIG_HUDINBRANCHSCREENSHOTS, taseditor_config.branch_scr_hud?MF_CHECKED : MF_UNCHECKED);
|
||||||
CheckMenuItem(hmenu, ID_CONFIG_BINDMARKERSTOINPUT, taseditor_config.bind_markers?MF_CHECKED : MF_UNCHECKED);
|
CheckMenuItem(hmenu, ID_CONFIG_BINDMARKERSTOINPUT, taseditor_config.bind_markers?MF_CHECKED : MF_UNCHECKED);
|
||||||
CheckMenuItem(hmenu, ID_CONFIG_EMPTYNEWMARKERNOTES, taseditor_config.empty_marker_notes?MF_CHECKED : MF_UNCHECKED);
|
CheckMenuItem(hmenu, ID_CONFIG_EMPTYNEWMARKERNOTES, taseditor_config.empty_marker_notes?MF_CHECKED : MF_UNCHECKED);
|
||||||
|
@ -1052,6 +1057,10 @@ BOOL CALLBACK WndprocTasEditor(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lPara
|
||||||
taseditor_config.restore_position ^= 1;
|
taseditor_config.restore_position ^= 1;
|
||||||
taseditor_window.UpdateCheckedItems();
|
taseditor_window.UpdateCheckedItems();
|
||||||
break;
|
break;
|
||||||
|
case CHECK_AUTOADJUSTINPUTDUETOLAG:
|
||||||
|
taseditor_config.adjust_input_due_to_lag ^= 1;
|
||||||
|
taseditor_window.UpdateCheckedItems();
|
||||||
|
break;
|
||||||
case ID_CONFIG_SETGREENZONECAPACITY:
|
case ID_CONFIG_SETGREENZONECAPACITY:
|
||||||
{
|
{
|
||||||
int new_capacity = taseditor_config.greenzone_capacity;
|
int new_capacity = taseditor_config.greenzone_capacity;
|
||||||
|
@ -1105,8 +1114,8 @@ BOOL CALLBACK WndprocTasEditor(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lPara
|
||||||
taseditor_config.branch_full_movie ^= 1;
|
taseditor_config.branch_full_movie ^= 1;
|
||||||
taseditor_window.UpdateCheckedItems();
|
taseditor_window.UpdateCheckedItems();
|
||||||
break;
|
break;
|
||||||
case ID_CONFIG_BRANCHESWORKONLYWHENRECORDING:
|
case ID_CONFIG_OLDBRANCHINGCONTROLS:
|
||||||
taseditor_config.branch_only_when_rec ^= 1;
|
taseditor_config.old_branching_controls ^= 1;
|
||||||
taseditor_window.UpdateCheckedItems();
|
taseditor_window.UpdateCheckedItems();
|
||||||
bookmarks.RedrawBookmarksCaption();
|
bookmarks.RedrawBookmarksCaption();
|
||||||
break;
|
break;
|
||||||
|
@ -1655,6 +1664,19 @@ LRESULT APIENTRY CHECK_AUTORESTORE_PLAYBACK_WndProc(HWND hWnd, UINT msg, WPARAM
|
||||||
}
|
}
|
||||||
return CallWindowProc(CHECK_AUTORESTORE_PLAYBACK_oldWndProc, hWnd, msg, wParam, lParam);
|
return CallWindowProc(CHECK_AUTORESTORE_PLAYBACK_oldWndProc, hWnd, msg, wParam, lParam);
|
||||||
}
|
}
|
||||||
|
LRESULT APIENTRY CHECK_AUTOADJUSTINPUTDUETOLAG_WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam)
|
||||||
|
{
|
||||||
|
switch(msg)
|
||||||
|
{
|
||||||
|
case WM_MBUTTONDOWN:
|
||||||
|
case WM_MBUTTONDBLCLK:
|
||||||
|
playback.MiddleButtonClick();
|
||||||
|
return 0;
|
||||||
|
case WM_KEYDOWN:
|
||||||
|
return 0; // disable Spacebar
|
||||||
|
}
|
||||||
|
return CallWindowProc(CHECK_AUTOADJUSTINPUTDUETOLAG_oldWndProc, hWnd, msg, wParam, lParam);
|
||||||
|
}
|
||||||
LRESULT APIENTRY IDC_RADIO_ALL_WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam)
|
LRESULT APIENTRY IDC_RADIO_ALL_WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam)
|
||||||
{
|
{
|
||||||
switch(msg)
|
switch(msg)
|
||||||
|
|
|
@ -51,17 +51,8 @@
|
||||||
#include "drivers/win/memview.h"
|
#include "drivers/win/memview.h"
|
||||||
#include "drivers/win/window.h"
|
#include "drivers/win/window.h"
|
||||||
#include "drivers/win/ntview.h"
|
#include "drivers/win/ntview.h"
|
||||||
|
#include "drivers/win/taseditor.h"
|
||||||
#include "./drivers/win/taseditor/taseditor_window.h"
|
|
||||||
#include "./drivers/win/taseditor/markers.h"
|
|
||||||
#include "./drivers/win/taseditor/selection.h"
|
|
||||||
#include "./drivers/win/taseditor/snapshot.h"
|
|
||||||
#include "./drivers/win/taseditor/bookmarks.h"
|
|
||||||
#include "./drivers/win/taseditor/playback.h"
|
|
||||||
extern bool Taseditor_rewind_now;
|
extern bool Taseditor_rewind_now;
|
||||||
extern BOOKMARKS bookmarks;
|
|
||||||
extern TASEDITOR_WINDOW taseditor_window;
|
|
||||||
extern PLAYBACK playback;
|
|
||||||
#endif // WIN32
|
#endif // WIN32
|
||||||
|
|
||||||
//it is easier to declare these input drivers extern here than include a bunch of files
|
//it is easier to declare these input drivers extern here than include a bunch of files
|
||||||
|
@ -699,8 +690,8 @@ struct EMUCMDTABLE FCEUI_CommandTable[]=
|
||||||
{ EMUCMD_SAVE_SLOT_7, EMUCMDTYPE_STATE, CommandSelectSaveSlot, 0, 0, "Savestate Slot 7", EMUCMDFLAG_TASEDITOR },
|
{ EMUCMD_SAVE_SLOT_7, EMUCMDTYPE_STATE, CommandSelectSaveSlot, 0, 0, "Savestate Slot 7", EMUCMDFLAG_TASEDITOR },
|
||||||
{ EMUCMD_SAVE_SLOT_8, EMUCMDTYPE_STATE, CommandSelectSaveSlot, 0, 0, "Savestate Slot 8", EMUCMDFLAG_TASEDITOR },
|
{ EMUCMD_SAVE_SLOT_8, EMUCMDTYPE_STATE, CommandSelectSaveSlot, 0, 0, "Savestate Slot 8", EMUCMDFLAG_TASEDITOR },
|
||||||
{ EMUCMD_SAVE_SLOT_9, EMUCMDTYPE_STATE, CommandSelectSaveSlot, 0, 0, "Savestate Slot 9", EMUCMDFLAG_TASEDITOR },
|
{ EMUCMD_SAVE_SLOT_9, EMUCMDTYPE_STATE, CommandSelectSaveSlot, 0, 0, "Savestate Slot 9", EMUCMDFLAG_TASEDITOR },
|
||||||
{ EMUCMD_SAVE_SLOT_NEXT, EMUCMDTYPE_STATE, CommandSelectSaveSlot, 0, 0, "Next Savestate Slot", 0 },
|
{ EMUCMD_SAVE_SLOT_NEXT, EMUCMDTYPE_STATE, CommandSelectSaveSlot, 0, 0, "Next Savestate Slot", EMUCMDFLAG_TASEDITOR },
|
||||||
{ EMUCMD_SAVE_SLOT_PREV, EMUCMDTYPE_STATE, CommandSelectSaveSlot, 0, 0, "Previous Savestate Slot", 0 },
|
{ EMUCMD_SAVE_SLOT_PREV, EMUCMDTYPE_STATE, CommandSelectSaveSlot, 0, 0, "Previous Savestate Slot", EMUCMDFLAG_TASEDITOR },
|
||||||
{ EMUCMD_SAVE_STATE, EMUCMDTYPE_STATE, CommandStateSave, 0, 0, "Save State", EMUCMDFLAG_TASEDITOR },
|
{ EMUCMD_SAVE_STATE, EMUCMDTYPE_STATE, CommandStateSave, 0, 0, "Save State", EMUCMDFLAG_TASEDITOR },
|
||||||
{ EMUCMD_SAVE_STATE_AS, EMUCMDTYPE_STATE, FCEUD_SaveStateAs, 0, 0, "Save State As...", 0 },
|
{ EMUCMD_SAVE_STATE_AS, EMUCMDTYPE_STATE, FCEUD_SaveStateAs, 0, 0, "Save State As...", 0 },
|
||||||
{ EMUCMD_SAVE_STATE_SLOT_0, EMUCMDTYPE_STATE, CommandStateSave, 0, 0, "Save State to Slot 0", EMUCMDFLAG_TASEDITOR },
|
{ EMUCMD_SAVE_STATE_SLOT_0, EMUCMDTYPE_STATE, CommandStateSave, 0, 0, "Save State to Slot 0", EMUCMDFLAG_TASEDITOR },
|
||||||
|
@ -857,7 +848,7 @@ static void CommandSelectSaveSlot(void)
|
||||||
if (FCEUMOV_Mode(MOVIEMODE_TASEDITOR))
|
if (FCEUMOV_Mode(MOVIEMODE_TASEDITOR))
|
||||||
{
|
{
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
bookmarks.command(COMMAND_JUMP, execcmd - EMUCMD_SAVE_SLOT_0);
|
Taseditor_EMUCMD(execcmd);
|
||||||
#endif
|
#endif
|
||||||
} else
|
} else
|
||||||
{
|
{
|
||||||
|
@ -875,10 +866,7 @@ static void CommandStateSave(void)
|
||||||
if (FCEUMOV_Mode(MOVIEMODE_TASEDITOR))
|
if (FCEUMOV_Mode(MOVIEMODE_TASEDITOR))
|
||||||
{
|
{
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
if (execcmd == EMUCMD_SAVE_STATE)
|
Taseditor_EMUCMD(execcmd);
|
||||||
bookmarks.command(COMMAND_SET);
|
|
||||||
else if(execcmd >= EMUCMD_SAVE_STATE_SLOT_0 && execcmd <= EMUCMD_SAVE_STATE_SLOT_9)
|
|
||||||
bookmarks.command(COMMAND_SET, execcmd - EMUCMD_SAVE_STATE_SLOT_0);
|
|
||||||
#endif
|
#endif
|
||||||
} else
|
} else
|
||||||
{
|
{
|
||||||
|
@ -899,10 +887,7 @@ static void CommandStateLoad(void)
|
||||||
if (FCEUMOV_Mode(MOVIEMODE_TASEDITOR))
|
if (FCEUMOV_Mode(MOVIEMODE_TASEDITOR))
|
||||||
{
|
{
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
if (execcmd == EMUCMD_LOAD_STATE)
|
Taseditor_EMUCMD(execcmd);
|
||||||
bookmarks.command(COMMAND_DEPLOY);
|
|
||||||
else if(execcmd >= EMUCMD_LOAD_STATE_SLOT_0 && execcmd <= EMUCMD_LOAD_STATE_SLOT_9)
|
|
||||||
bookmarks.command(COMMAND_DEPLOY, execcmd - EMUCMD_LOAD_STATE_SLOT_0);
|
|
||||||
#endif
|
#endif
|
||||||
} else
|
} else
|
||||||
{
|
{
|
||||||
|
@ -1141,7 +1126,7 @@ static void ReloadRom(void)
|
||||||
if (FCEUMOV_Mode(MOVIEMODE_TASEDITOR))
|
if (FCEUMOV_Mode(MOVIEMODE_TASEDITOR))
|
||||||
{
|
{
|
||||||
// load most recent project
|
// load most recent project
|
||||||
taseditor_window.LoadRecentProject(0);
|
Taseditor_EMUCMD(execcmd);
|
||||||
} else
|
} else
|
||||||
{
|
{
|
||||||
// load most recent ROM
|
// load most recent ROM
|
||||||
|
@ -1204,14 +1189,13 @@ static void TaseditorRestorePlayback(void)
|
||||||
{
|
{
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
if (FCEUMOV_Mode(MOVIEMODE_TASEDITOR))
|
if (FCEUMOV_Mode(MOVIEMODE_TASEDITOR))
|
||||||
playback.RestorePosition();
|
Taseditor_EMUCMD(execcmd);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static void TaseditorCancelSeeking(void)
|
static void TaseditorCancelSeeking(void)
|
||||||
{
|
{
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
if (FCEUMOV_Mode(MOVIEMODE_TASEDITOR))
|
if (FCEUMOV_Mode(MOVIEMODE_TASEDITOR))
|
||||||
playback.CancelSeeking();
|
Taseditor_EMUCMD(execcmd);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
|
@ -872,8 +872,6 @@
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<None Include="..\..\..\tasedit\psd\bmp\te_green_arrow.bmp" />
|
<None Include="..\..\..\tasedit\psd\bmp\te_green_arrow.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\bitmap20.bmp" />
|
<None Include="..\src\drivers\win\res\bitmap20.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\bitmap21.bmp" />
|
|
||||||
<None Include="..\src\drivers\win\res\bitmap22.bmp" />
|
|
||||||
<None Include="..\src\drivers\win\res\branch_spritesheet.bmp" />
|
<None Include="..\src\drivers\win\res\branch_spritesheet.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\icon3.ico" />
|
<None Include="..\src\drivers\win\res\icon3.ico" />
|
||||||
<None Include="..\src\drivers\win\res\icon4.ico" />
|
<None Include="..\src\drivers\win\res\icon4.ico" />
|
||||||
|
@ -882,25 +880,45 @@
|
||||||
<None Include="..\src\drivers\win\res\taseditor-icon.ico" />
|
<None Include="..\src\drivers\win\res\taseditor-icon.ico" />
|
||||||
<None Include="..\src\drivers\win\res\taseditor-icon32.ico" />
|
<None Include="..\src\drivers\win\res\taseditor-icon32.ico" />
|
||||||
<None Include="..\src\drivers\win\res\te_0.bmp" />
|
<None Include="..\src\drivers\win\res\te_0.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_0_selected.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_1.bmp" />
|
<None Include="..\src\drivers\win\res\te_1.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_10.bmp" />
|
<None Include="..\src\drivers\win\res\te_10.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_10_selected.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_11.bmp" />
|
<None Include="..\src\drivers\win\res\te_11.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_11_selected.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_12.bmp" />
|
<None Include="..\src\drivers\win\res\te_12.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_12_selected.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_13.bmp" />
|
<None Include="..\src\drivers\win\res\te_13.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_13_selected.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_14.bmp" />
|
<None Include="..\src\drivers\win\res\te_14.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_14_selected.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_15.bmp" />
|
<None Include="..\src\drivers\win\res\te_15.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_15_selected.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_16.bmp" />
|
<None Include="..\src\drivers\win\res\te_16.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_16_selected.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_17.bmp" />
|
<None Include="..\src\drivers\win\res\te_17.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_17_selected.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_18.bmp" />
|
<None Include="..\src\drivers\win\res\te_18.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_18_selected.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_19.bmp" />
|
<None Include="..\src\drivers\win\res\te_19.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_19_selected.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_1_selected.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_2.bmp" />
|
<None Include="..\src\drivers\win\res\te_2.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_2_selected.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_3.bmp" />
|
<None Include="..\src\drivers\win\res\te_3.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_3_selected.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_4.bmp" />
|
<None Include="..\src\drivers\win\res\te_4.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_4_selected.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_5.bmp" />
|
<None Include="..\src\drivers\win\res\te_5.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_5_selected.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_6.bmp" />
|
<None Include="..\src\drivers\win\res\te_6.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_6_selected.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_7.bmp" />
|
<None Include="..\src\drivers\win\res\te_7.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_7_selected.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_8.bmp" />
|
<None Include="..\src\drivers\win\res\te_8.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_8_selected.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_9.bmp" />
|
<None Include="..\src\drivers\win\res\te_9.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_9_selected.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_arrow.bmp" />
|
<None Include="..\src\drivers\win\res\te_arrow.bmp" />
|
||||||
<CustomBuild Include="..\src\drivers\win\help\fceux.chm">
|
<CustomBuild Include="..\src\drivers\win\help\fceux.chm">
|
||||||
<Command Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
|
<Command Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
|
||||||
|
@ -918,6 +936,66 @@
|
||||||
</CustomBuild>
|
</CustomBuild>
|
||||||
<None Include="..\src\drivers\win\res\te_green_arrow.bmp" />
|
<None Include="..\src\drivers\win\res\te_green_arrow.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_green_blue_arrow.bmp" />
|
<None Include="..\src\drivers\win\res\te_green_blue_arrow.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_0.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_0_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_0_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_1.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_10.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_10_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_10_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_11.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_11_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_11_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_12.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_12_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_12_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_13.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_13_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_13_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_14.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_14_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_14_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_15.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_15_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_15_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_16.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_16_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_16_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_17.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_17_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_17_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_18.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_18_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_18_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_19.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_19_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_19_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_1_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_1_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_2.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_2_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_2_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_3.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_3_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_3_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_4.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_4_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_4_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_5.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_5_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_5_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_6.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_6_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_6_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_7.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_7_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_7_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_8.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_8_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_8_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_9.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_9_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_9_playback.bmp" />
|
||||||
<None Include="..\src\pputile.inc" />
|
<None Include="..\src\pputile.inc" />
|
||||||
<None Include="ClassDiagram1.cd" />
|
<None Include="ClassDiagram1.cd" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
|
@ -1544,9 +1544,87 @@
|
||||||
<None Include="..\src\drivers\win\res\bitmap20.bmp" />
|
<None Include="..\src\drivers\win\res\bitmap20.bmp" />
|
||||||
<None Include="..\..\..\tasedit\psd\bmp\te_green_arrow.bmp" />
|
<None Include="..\..\..\tasedit\psd\bmp\te_green_arrow.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\te_green_arrow.bmp" />
|
<None Include="..\src\drivers\win\res\te_green_arrow.bmp" />
|
||||||
<None Include="..\src\drivers\win\res\bitmap21.bmp" />
|
|
||||||
<None Include="..\src\drivers\win\res\bitmap22.bmp" />
|
|
||||||
<None Include="..\src\drivers\win\res\te_green_blue_arrow.bmp" />
|
<None Include="..\src\drivers\win\res\te_green_blue_arrow.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_0.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_1.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_2.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_3.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_4.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_5.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_6.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_7.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_8.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_9.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_10.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_11.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_12.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_13.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_14.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_15.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_16.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_17.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_18.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_19.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_0_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_1_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_2_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_3_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_4_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_5_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_6_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_7_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_8_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_9_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_10_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_11_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_12_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_13_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_14_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_15_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_16_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_17_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_18_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_19_playback.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_0_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_1_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_2_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_3_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_4_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_5_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_6_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_7_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_8_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_9_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_10_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_11_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_12_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_13_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_14_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_15_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_16_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_17_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_18_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_piano_19_lostpos.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_0_selected.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_1_selected.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_2_selected.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_3_selected.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_4_selected.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_5_selected.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_6_selected.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_7_selected.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_8_selected.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_9_selected.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_10_selected.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_11_selected.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_12_selected.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_13_selected.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_14_selected.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_15_selected.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_16_selected.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_17_selected.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_18_selected.bmp" />
|
||||||
|
<None Include="..\src\drivers\win\res\te_19_selected.bmp" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<CustomBuild Include="..\src\auxlib.lua" />
|
<CustomBuild Include="..\src\auxlib.lua" />
|
||||||
|
|