tasedit delete capability

This commit is contained in:
zeromus 2008-06-28 22:38:11 +00:00
parent 0b1030a820
commit e8da728db3
1 changed files with 28 additions and 4 deletions

View File

@ -235,15 +235,36 @@ static void InsertFrames()
currMovieData.records.reserve(currMovieData.records.size()+frames); currMovieData.records.reserve(currMovieData.records.size()+frames);
//insert frames before each selection //insert frames before each selection
int ctr=0; for(TSelectionFrames::reverse_iterator it(selectionFrames.rbegin()); it != selectionFrames.rend(); it++)
for(TSelectionFrames::iterator it(selectionFrames.begin()); it != selectionFrames.end(); it++)
{ {
currMovieData.insertEmpty(*it+ctr,1); currMovieData.insertEmpty(*it,1);
ctr++;
} }
InvalidateGreenZone(*selectionFrames.begin()); InvalidateGreenZone(*selectionFrames.begin());
UpdateTasEdit();
RedrawList();
}
//delete frames at the currently selected positions.
static void DeleteFrames()
{
//this is going to be _really_ slow.
//insert frames before each selection
int ctr=0;
for(TSelectionFrames::reverse_iterator it(selectionFrames.rbegin()); it != selectionFrames.rend(); it++)
{
currMovieData.records.erase(currMovieData.records.begin()+*it);
}
InvalidateGreenZone(*selectionFrames.begin());
//in the particular case of deletion, we need to make sure we reset currFrameCounter to something reasonable
//why not the current green zone max?
currFrameCounter = currMovieData.greenZoneCount-1;
UpdateTasEdit();
RedrawList(); RedrawList();
} }
@ -510,6 +531,9 @@ BOOL CALLBACK WndprocTasEdit(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lPar
case WM_COMMAND: case WM_COMMAND:
switch(LOWORD(wParam)) switch(LOWORD(wParam))
{ {
case MENU_DELETEFRAMES:
DeleteFrames();
break;
case MENU_INSERTFRAMES: case MENU_INSERTFRAMES:
InsertFrames(); InsertFrames();
break; break;