Added 4 pads support; also now current frame is shown by blue line; minor cleanups.
This commit is contained in:
parent
1de5077bcb
commit
790af32e1b
|
@ -48,34 +48,27 @@ static void GetDispInfo(NMLVDISPINFO* nmlvDispInfo)
|
||||||
{
|
{
|
||||||
switch(item.iSubItem)
|
switch(item.iSubItem)
|
||||||
{
|
{
|
||||||
case 0:
|
case COLUMN_ARROW:
|
||||||
if(item.iImage == I_IMAGECALLBACK && item.iItem == currFrameCounter)
|
if(item.iImage == I_IMAGECALLBACK && item.iItem == currFrameCounter)
|
||||||
item.iImage = 0;
|
item.iImage = 0;
|
||||||
else
|
else
|
||||||
item.iImage = -1;
|
item.iImage = -1;
|
||||||
break;
|
break;
|
||||||
case 1:
|
case COLUMN_FRAMENUM:
|
||||||
|
case COLUMN_FRAMENUM2:
|
||||||
U32ToDecStr(item.pszText,item.iItem);
|
U32ToDecStr(item.pszText,item.iItem);
|
||||||
break;
|
break;
|
||||||
case 2:
|
case COLUMN_JOYPAD1_A: case COLUMN_JOYPAD1_B: case COLUMN_JOYPAD1_S: case COLUMN_JOYPAD1_T:
|
||||||
case 3:
|
case COLUMN_JOYPAD1_U: case COLUMN_JOYPAD1_D: case COLUMN_JOYPAD1_L: case COLUMN_JOYPAD1_R:
|
||||||
case 4:
|
case COLUMN_JOYPAD2_A: case COLUMN_JOYPAD2_B: case COLUMN_JOYPAD2_S: case COLUMN_JOYPAD2_T:
|
||||||
case 5:
|
case COLUMN_JOYPAD2_U: case COLUMN_JOYPAD2_D: case COLUMN_JOYPAD2_L: case COLUMN_JOYPAD2_R:
|
||||||
case 6:
|
case COLUMN_JOYPAD3_A: case COLUMN_JOYPAD3_B: case COLUMN_JOYPAD3_S: case COLUMN_JOYPAD3_T:
|
||||||
case 7:
|
case COLUMN_JOYPAD3_U: case COLUMN_JOYPAD3_D: case COLUMN_JOYPAD3_L: case COLUMN_JOYPAD3_R:
|
||||||
case 8:
|
case COLUMN_JOYPAD4_A: case COLUMN_JOYPAD4_B: case COLUMN_JOYPAD4_S: case COLUMN_JOYPAD4_T:
|
||||||
case 9:
|
case COLUMN_JOYPAD4_U: case COLUMN_JOYPAD4_D: case COLUMN_JOYPAD4_L: case COLUMN_JOYPAD4_R:
|
||||||
case 10:
|
|
||||||
case 11:
|
|
||||||
case 12:
|
|
||||||
case 13:
|
|
||||||
case 14:
|
|
||||||
case 15:
|
|
||||||
case 16:
|
|
||||||
case 17:
|
|
||||||
{
|
{
|
||||||
int joy = (item.iSubItem - 2)/8;
|
int joy = (item.iSubItem - COLUMN_JOYPAD1_A) / NUM_JOYPAD_BUTTONS;
|
||||||
int bit = (item.iSubItem - 2)%8;
|
int bit = (item.iSubItem - COLUMN_JOYPAD1_A) % NUM_JOYPAD_BUTTONS;
|
||||||
uint8 data = currMovieData.records[item.iItem].joysticks[joy];
|
uint8 data = currMovieData.records[item.iItem].joysticks[joy];
|
||||||
if(data & (1<<bit))
|
if(data & (1<<bit))
|
||||||
{
|
{
|
||||||
|
@ -96,6 +89,7 @@ static void GetDispInfo(NMLVDISPINFO* nmlvDispInfo)
|
||||||
|
|
||||||
static LONG CustomDraw(NMLVCUSTOMDRAW* msg)
|
static LONG CustomDraw(NMLVCUSTOMDRAW* msg)
|
||||||
{
|
{
|
||||||
|
int cell_x, cell_y;
|
||||||
switch(msg->nmcd.dwDrawStage)
|
switch(msg->nmcd.dwDrawStage)
|
||||||
{
|
{
|
||||||
case CDDS_PREPAINT:
|
case CDDS_PREPAINT:
|
||||||
|
@ -104,15 +98,57 @@ static LONG CustomDraw(NMLVCUSTOMDRAW* msg)
|
||||||
return CDRF_NOTIFYSUBITEMDRAW;
|
return CDRF_NOTIFYSUBITEMDRAW;
|
||||||
case CDDS_SUBITEMPREPAINT:
|
case CDDS_SUBITEMPREPAINT:
|
||||||
SelectObject(msg->nmcd.hdc,debugSystem->hFixedFont);
|
SelectObject(msg->nmcd.hdc,debugSystem->hFixedFont);
|
||||||
if((msg->iSubItem-2)/8==0)
|
cell_x = msg->iSubItem;
|
||||||
if((int)msg->nmcd.dwItemSpec < currMovieData.greenZoneCount &&
|
cell_y = msg->nmcd.dwItemSpec;
|
||||||
!currMovieData.savestates[msg->nmcd.dwItemSpec].empty())
|
if(cell_x == 1 || cell_x == 34)
|
||||||
msg->clrTextBk = RGB(192,255,192);
|
{
|
||||||
else {}
|
// frame number
|
||||||
else if((int)msg->nmcd.dwItemSpec < currMovieData.greenZoneCount &&
|
if(cell_y < currMovieData.greenZoneCount && !currMovieData.savestates[cell_y].empty())
|
||||||
!currMovieData.savestates[msg->nmcd.dwItemSpec].empty())
|
{
|
||||||
msg->clrTextBk = RGB(144,192,144);
|
if (cell_y == currFrameCounter)
|
||||||
else msg->clrTextBk = RGB(192,192,192);
|
{
|
||||||
|
// current frame
|
||||||
|
msg->clrTextBk = RGB(217,254,253);
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
// TODO: redline for lag frames
|
||||||
|
// green zone frame
|
||||||
|
msg->clrTextBk = RGB(220,255,220);
|
||||||
|
}
|
||||||
|
} else msg->clrTextBk = RGB(255,255,255);
|
||||||
|
} else if((cell_x - COLUMN_JOYPAD1_A) / NUM_JOYPAD_BUTTONS == 0 || (cell_x - COLUMN_JOYPAD1_A) / NUM_JOYPAD_BUTTONS == 2)
|
||||||
|
{
|
||||||
|
// pad 1 or 3
|
||||||
|
if(cell_y < currMovieData.greenZoneCount && !currMovieData.savestates[cell_y].empty())
|
||||||
|
{
|
||||||
|
if (cell_y == currFrameCounter)
|
||||||
|
{
|
||||||
|
// current frame
|
||||||
|
msg->clrTextBk = RGB(195,255,250);
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
// TODO: redline for lag frames
|
||||||
|
// green zone frame
|
||||||
|
msg->clrTextBk = RGB(195,255,195);
|
||||||
|
}
|
||||||
|
} else msg->clrTextBk = RGB(240,240,240);
|
||||||
|
} else if((cell_x - COLUMN_JOYPAD1_A) / NUM_JOYPAD_BUTTONS == 1 || (cell_x - COLUMN_JOYPAD1_A) / NUM_JOYPAD_BUTTONS == 3)
|
||||||
|
{
|
||||||
|
// pad 2 or 4
|
||||||
|
if(cell_y < currMovieData.greenZoneCount && !currMovieData.savestates[cell_y].empty())
|
||||||
|
{
|
||||||
|
if (cell_y == currFrameCounter)
|
||||||
|
{
|
||||||
|
// current frame
|
||||||
|
msg->clrTextBk = RGB(170,220,218);
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
// TODO: redline for lag frames
|
||||||
|
// green zone frame
|
||||||
|
msg->clrTextBk = RGB(170,220,170);
|
||||||
|
}
|
||||||
|
} else msg->clrTextBk = RGB(220,220,220);
|
||||||
|
}
|
||||||
return CDRF_DODEFAULT;
|
return CDRF_DODEFAULT;
|
||||||
default:
|
default:
|
||||||
return CDRF_DODEFAULT;
|
return CDRF_DODEFAULT;
|
||||||
|
@ -139,7 +175,6 @@ void UpdateTasEdit()
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//update the number of items
|
//update the number of items
|
||||||
int currLVItemCount = ListView_GetItemCount(hwndList);
|
int currLVItemCount = ListView_GetItemCount(hwndList);
|
||||||
if(currMovieData.getNumRecords() != currLVItemCount)
|
if(currMovieData.getNumRecords() != currLVItemCount)
|
||||||
|
@ -198,7 +233,7 @@ enum ECONTEXTMENU
|
||||||
void ShowMenu(ECONTEXTMENU which, POINT& pt)
|
void ShowMenu(ECONTEXTMENU which, POINT& pt)
|
||||||
{
|
{
|
||||||
HMENU sub = GetSubMenu(hrmenu,(int)which);
|
HMENU sub = GetSubMenu(hrmenu,(int)which);
|
||||||
TrackPopupMenu(sub,TPM_RIGHTBUTTON,pt.x,pt.y,0,hwndTasEdit,0);
|
TrackPopupMenu(sub,0,pt.x,pt.y,TPM_RIGHTBUTTON,hwndTasEdit,0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void StrayClickMenu(LPNMITEMACTIVATE info)
|
void StrayClickMenu(LPNMITEMACTIVATE info)
|
||||||
|
@ -331,15 +366,15 @@ void DoubleClick(LPNMITEMACTIVATE info)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
//if the icon or frame columns were double clicked:
|
//if the icon or frame columns were double clicked:
|
||||||
if(info->iSubItem == 0 || info->iSubItem == 1)
|
if(info->iSubItem == COLUMN_ARROW || info->iSubItem == COLUMN_FRAMENUM || info->iSubItem == COLUMN_FRAMENUM2)
|
||||||
{
|
{
|
||||||
JumpToFrame(index);
|
JumpToFrame(index);
|
||||||
}
|
}
|
||||||
else //if an input column was clicked:
|
else if(info->iSubItem >= COLUMN_JOYPAD1_A && info->iSubItem <= COLUMN_JOYPAD4_R)
|
||||||
{
|
{
|
||||||
//toggle the bit
|
//toggle the bit
|
||||||
int joy = (info->iSubItem - 2)/8;
|
int joy = (info->iSubItem - COLUMN_JOYPAD1_A) / NUM_JOYPAD_BUTTONS;
|
||||||
int bit = (info->iSubItem - 2)%8;
|
int bit = (info->iSubItem - COLUMN_JOYPAD1_A) % NUM_JOYPAD_BUTTONS;
|
||||||
|
|
||||||
if (info->uKeyFlags&(LVKF_SHIFT|LVKF_CONTROL))
|
if (info->uKeyFlags&(LVKF_SHIFT|LVKF_CONTROL))
|
||||||
{
|
{
|
||||||
|
@ -348,7 +383,6 @@ void DoubleClick(LPNMITEMACTIVATE info)
|
||||||
{
|
{
|
||||||
currMovieData.records[*it].toggleBit(joy,bit);
|
currMovieData.records[*it].toggleBit(joy,bit);
|
||||||
}
|
}
|
||||||
|
|
||||||
index=*selectionFrames.begin();
|
index=*selectionFrames.begin();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -362,8 +396,7 @@ void DoubleClick(LPNMITEMACTIVATE info)
|
||||||
InvalidateGreenZone(index);
|
InvalidateGreenZone(index);
|
||||||
|
|
||||||
// If the change is in the past, move to it.
|
// If the change is in the past, move to it.
|
||||||
if(index < currFrameCounter &&
|
if(index < currFrameCounter && index < currMovieData.greenZoneCount)
|
||||||
index < currMovieData.greenZoneCount)
|
|
||||||
{
|
{
|
||||||
JumpToFrame(index);
|
JumpToFrame(index);
|
||||||
}
|
}
|
||||||
|
@ -442,8 +475,9 @@ static void DeleteFrames()
|
||||||
//the column set operation, for setting a button for a span of selected values
|
//the column set operation, for setting a button for a span of selected values
|
||||||
static void ColumnSet(int column)
|
static void ColumnSet(int column)
|
||||||
{
|
{
|
||||||
int joy = (column-2)/8;
|
int joy = (column - COLUMN_JOYPAD1_A) / NUM_JOYPAD_BUTTONS;
|
||||||
int button = (column-2)%8;
|
if (joy < 0 || joy >= NUM_JOYPADS) return;
|
||||||
|
int button = (column - COLUMN_JOYPAD1_A) % NUM_JOYPAD_BUTTONS;
|
||||||
|
|
||||||
//inspect the selected frames. count the set and unset rows
|
//inspect the selected frames. count the set and unset rows
|
||||||
int set=0, unset=0;
|
int set=0, unset=0;
|
||||||
|
@ -524,14 +558,14 @@ static bool Copy()
|
||||||
cframe=*it;
|
cframe=*it;
|
||||||
|
|
||||||
int cjoy=0;
|
int cjoy=0;
|
||||||
for (int joy=0; joy<2; ++joy)
|
for (int joy=0; joy<NUM_JOYPADS; ++joy)
|
||||||
{
|
{
|
||||||
while (currMovieData.records[*it].joysticks[joy] && cjoy<joy)
|
while (currMovieData.records[*it].joysticks[joy] && cjoy<joy)
|
||||||
{
|
{
|
||||||
clipString << '|';
|
clipString << '|';
|
||||||
++cjoy;
|
++cjoy;
|
||||||
}
|
}
|
||||||
for (int bit=0; bit<8; ++bit)
|
for (int bit=0; bit<NUM_JOYPAD_BUTTONS; ++bit)
|
||||||
{
|
{
|
||||||
if (currMovieData.records[*it].joysticks[joy] & (1<<bit))
|
if (currMovieData.records[*it].joysticks[joy] & (1<<bit))
|
||||||
{
|
{
|
||||||
|
@ -639,7 +673,7 @@ static bool Paste()
|
||||||
++joy;
|
++joy;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
for (int bit=0; bit<8; ++bit)
|
for (int bit=0; bit<NUM_JOYPAD_BUTTONS; ++bit)
|
||||||
{
|
{
|
||||||
if (*frame==MovieRecord::mnemonics[bit])
|
if (*frame==MovieRecord::mnemonics[bit])
|
||||||
{
|
{
|
||||||
|
@ -694,13 +728,13 @@ void Branch()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ---------------------------------------------------------------------------------
|
||||||
//The subclass wndproc for the listview header
|
//The subclass wndproc for the listview header
|
||||||
static LRESULT APIENTRY HeaderWndProc(HWND hWnd,UINT msg,WPARAM wParam,LPARAM lParam)
|
static LRESULT APIENTRY HeaderWndProc(HWND hWnd,UINT msg,WPARAM wParam,LPARAM lParam)
|
||||||
{
|
{
|
||||||
switch(msg)
|
switch(msg)
|
||||||
{
|
{
|
||||||
case WM_LBUTTONDOWN:
|
case WM_LBUTTONDOWN:
|
||||||
{
|
{
|
||||||
//perform hit test
|
//perform hit test
|
||||||
HD_HITTESTINFO info;
|
HD_HITTESTINFO info;
|
||||||
|
@ -752,45 +786,29 @@ static void InitDialog()
|
||||||
//setup columns
|
//setup columns
|
||||||
LVCOLUMN lvc;
|
LVCOLUMN lvc;
|
||||||
int colidx=0;
|
int colidx=0;
|
||||||
|
// arrow column - it's kinda obsolete now
|
||||||
lvc.mask = LVCF_WIDTH;
|
lvc.mask = LVCF_WIDTH;
|
||||||
lvc.cx = 12;
|
lvc.cx = 12;
|
||||||
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
||||||
|
// frame number column
|
||||||
lvc.mask = LVCF_WIDTH | LVCF_TEXT;
|
lvc.mask = LVCF_WIDTH | LVCF_TEXT;
|
||||||
lvc.cx = 95;
|
lvc.cx = 95;
|
||||||
lvc.pszText = "Frame#";
|
lvc.pszText = "Frame#";
|
||||||
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
||||||
|
// pads columns
|
||||||
lvc.cx = 20;
|
lvc.cx = 20;
|
||||||
lvc.pszText = "A";
|
char buttonNames[NUM_JOYPAD_BUTTONS][2] = {"A", "B", "S", "T", "U", "D", "L", "R"};
|
||||||
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
for (int joy = 0; joy < NUM_JOYPADS; ++joy)
|
||||||
lvc.pszText = "B";
|
{
|
||||||
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
for (int btn = 0; btn < NUM_JOYPAD_BUTTONS; ++btn)
|
||||||
lvc.pszText = "S";
|
{
|
||||||
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
lvc.pszText = buttonNames[btn];
|
||||||
lvc.pszText = "T";
|
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
||||||
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
}
|
||||||
lvc.pszText = "U";
|
}
|
||||||
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
// frame number column again
|
||||||
lvc.pszText = "D";
|
lvc.cx = 95;
|
||||||
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
lvc.pszText = "Frame#";
|
||||||
lvc.pszText = "L";
|
|
||||||
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
|
||||||
lvc.pszText = "R";
|
|
||||||
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
|
||||||
lvc.pszText = "A";
|
|
||||||
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
|
||||||
lvc.pszText = "B";
|
|
||||||
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
|
||||||
lvc.pszText = "S";
|
|
||||||
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
|
||||||
lvc.pszText = "T";
|
|
||||||
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
|
||||||
lvc.pszText = "U";
|
|
||||||
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
|
||||||
lvc.pszText = "D";
|
|
||||||
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
|
||||||
lvc.pszText = "L";
|
|
||||||
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
|
||||||
lvc.pszText = "R";
|
|
||||||
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
ListView_InsertColumn(hwndList, colidx++, &lvc);
|
||||||
//-----------------------------
|
//-----------------------------
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,43 @@
|
||||||
#include "movie.h"
|
#include "movie.h"
|
||||||
|
|
||||||
|
#define NUM_JOYPADS 4
|
||||||
|
#define NUM_JOYPAD_BUTTONS 8
|
||||||
|
#define COLUMN_ARROW 0
|
||||||
|
#define COLUMN_FRAMENUM 1
|
||||||
|
#define COLUMN_JOYPAD1_A 2
|
||||||
|
#define COLUMN_JOYPAD1_B 3
|
||||||
|
#define COLUMN_JOYPAD1_S 4
|
||||||
|
#define COLUMN_JOYPAD1_T 5
|
||||||
|
#define COLUMN_JOYPAD1_U 6
|
||||||
|
#define COLUMN_JOYPAD1_D 7
|
||||||
|
#define COLUMN_JOYPAD1_L 8
|
||||||
|
#define COLUMN_JOYPAD1_R 9
|
||||||
|
#define COLUMN_JOYPAD2_A 10
|
||||||
|
#define COLUMN_JOYPAD2_B 11
|
||||||
|
#define COLUMN_JOYPAD2_S 12
|
||||||
|
#define COLUMN_JOYPAD2_T 13
|
||||||
|
#define COLUMN_JOYPAD2_U 14
|
||||||
|
#define COLUMN_JOYPAD2_D 15
|
||||||
|
#define COLUMN_JOYPAD2_L 16
|
||||||
|
#define COLUMN_JOYPAD2_R 17
|
||||||
|
#define COLUMN_JOYPAD3_A 18
|
||||||
|
#define COLUMN_JOYPAD3_B 19
|
||||||
|
#define COLUMN_JOYPAD3_S 20
|
||||||
|
#define COLUMN_JOYPAD3_T 21
|
||||||
|
#define COLUMN_JOYPAD3_U 22
|
||||||
|
#define COLUMN_JOYPAD3_D 23
|
||||||
|
#define COLUMN_JOYPAD3_L 24
|
||||||
|
#define COLUMN_JOYPAD3_R 25
|
||||||
|
#define COLUMN_JOYPAD4_A 26
|
||||||
|
#define COLUMN_JOYPAD4_B 27
|
||||||
|
#define COLUMN_JOYPAD4_S 28
|
||||||
|
#define COLUMN_JOYPAD4_T 29
|
||||||
|
#define COLUMN_JOYPAD4_U 30
|
||||||
|
#define COLUMN_JOYPAD4_D 31
|
||||||
|
#define COLUMN_JOYPAD4_L 32
|
||||||
|
#define COLUMN_JOYPAD4_R 33
|
||||||
|
#define COLUMN_FRAMENUM2 34
|
||||||
|
|
||||||
void DoTasEdit();
|
void DoTasEdit();
|
||||||
void UpdateTasEdit();
|
void UpdateTasEdit();
|
||||||
void CreateProject(MovieData data);
|
void CreateProject(MovieData data);
|
||||||
|
|
Loading…
Reference in New Issue