Qt TAS selection and splicer operation in work.
This commit is contained in:
parent
39f90e04e7
commit
4acf8ab61b
|
@ -262,6 +262,7 @@ class TasEditorWindow : public QDialog
|
||||||
|
|
||||||
friend class RECORDER;
|
friend class RECORDER;
|
||||||
friend class SPLICER;
|
friend class SPLICER;
|
||||||
|
friend class SELECTION;
|
||||||
};
|
};
|
||||||
|
|
||||||
extern TASEDITOR_PROJECT *project;
|
extern TASEDITOR_PROJECT *project;
|
||||||
|
|
|
@ -165,7 +165,9 @@ void SELECTION::updateHistoryLogSize()
|
||||||
std::vector<RowsSelection> new_selections_history(new_history_size);
|
std::vector<RowsSelection> new_selections_history(new_history_size);
|
||||||
int pos = historyCursorPos, source_pos = historyCursorPos;
|
int pos = historyCursorPos, source_pos = historyCursorPos;
|
||||||
if (pos >= new_history_size)
|
if (pos >= new_history_size)
|
||||||
|
{
|
||||||
pos = new_history_size - 1;
|
pos = new_history_size - 1;
|
||||||
|
}
|
||||||
int new_history_cursor_pos = pos;
|
int new_history_cursor_pos = pos;
|
||||||
// copy old "undo" snapshots
|
// copy old "undo" snapshots
|
||||||
while (pos >= 0)
|
while (pos >= 0)
|
||||||
|
@ -180,7 +182,9 @@ void SELECTION::updateHistoryLogSize()
|
||||||
int i = (num_redo_snapshots <= space_available) ? num_redo_snapshots : space_available;
|
int i = (num_redo_snapshots <= space_available) ? num_redo_snapshots : space_available;
|
||||||
int new_history_total_items = new_history_cursor_pos + i + 1;
|
int new_history_total_items = new_history_cursor_pos + i + 1;
|
||||||
for (; i > 0; i--)
|
for (; i > 0; i--)
|
||||||
|
{
|
||||||
new_selections_history[new_history_cursor_pos + i] = rowsSelectionHistory[(historyStartPos + historyCursorPos + i) % historySize];
|
new_selections_history[new_history_cursor_pos + i] = rowsSelectionHistory[(historyStartPos + historyCursorPos + i) % historySize];
|
||||||
|
}
|
||||||
// finish
|
// finish
|
||||||
rowsSelectionHistory = new_selections_history;
|
rowsSelectionHistory = new_selections_history;
|
||||||
historySize = new_history_size;
|
historySize = new_history_size;
|
||||||
|
@ -194,7 +198,9 @@ void SELECTION::redrawMarkerData()
|
||||||
// redraw Marker num
|
// redraw Marker num
|
||||||
char new_text[MAX_NOTE_LEN] = {0};
|
char new_text[MAX_NOTE_LEN] = {0};
|
||||||
if (displayedMarkerNumber <= 9999) // if there's too many digits in the number then don't show the word "Marker" before the number
|
if (displayedMarkerNumber <= 9999) // if there's too many digits in the number then don't show the word "Marker" before the number
|
||||||
|
{
|
||||||
strcpy(new_text, lowerMarkerText);
|
strcpy(new_text, lowerMarkerText);
|
||||||
|
}
|
||||||
char num[16];
|
char num[16];
|
||||||
sprintf( num, "%i", displayedMarkerNumber);
|
sprintf( num, "%i", displayedMarkerNumber);
|
||||||
strcat(new_text, num);
|
strcat(new_text, num);
|
||||||
|
@ -214,13 +220,19 @@ void SELECTION::jumpToPreviousMarker(int speed)
|
||||||
while (speed > 0)
|
while (speed > 0)
|
||||||
{
|
{
|
||||||
for (index--; index >= 0; index--)
|
for (index--; index >= 0; index--)
|
||||||
|
{
|
||||||
if (markersManager->getMarkerAtFrame(index)) break;
|
if (markersManager->getMarkerAtFrame(index)) break;
|
||||||
|
}
|
||||||
speed--;
|
speed--;
|
||||||
}
|
}
|
||||||
if (index >= 0)
|
if (index >= 0)
|
||||||
|
{
|
||||||
jumpToFrame(index); // jump to the Marker
|
jumpToFrame(index); // jump to the Marker
|
||||||
|
}
|
||||||
else
|
else
|
||||||
|
{
|
||||||
jumpToFrame(0); // jump to the beginning of Piano Roll
|
jumpToFrame(0); // jump to the beginning of Piano Roll
|
||||||
|
}
|
||||||
}
|
}
|
||||||
void SELECTION::jumpToNextMarker(int speed)
|
void SELECTION::jumpToNextMarker(int speed)
|
||||||
{
|
{
|
||||||
|
@ -232,19 +244,25 @@ void SELECTION::jumpToNextMarker(int speed)
|
||||||
while (speed > 0)
|
while (speed > 0)
|
||||||
{
|
{
|
||||||
for (++index; index <= last_frame; ++index)
|
for (++index; index <= last_frame; ++index)
|
||||||
|
{
|
||||||
if (markersManager->getMarkerAtFrame(index)) break;
|
if (markersManager->getMarkerAtFrame(index)) break;
|
||||||
|
}
|
||||||
speed--;
|
speed--;
|
||||||
}
|
}
|
||||||
if (index <= last_frame)
|
if (index <= last_frame)
|
||||||
|
{
|
||||||
jumpToFrame(index); // jump to Marker
|
jumpToFrame(index); // jump to Marker
|
||||||
|
}
|
||||||
else
|
else
|
||||||
|
{
|
||||||
jumpToFrame(last_frame); // jump to the end of Piano Roll
|
jumpToFrame(last_frame); // jump to the end of Piano Roll
|
||||||
|
}
|
||||||
}
|
}
|
||||||
void SELECTION::jumpToFrame(int frame)
|
void SELECTION::jumpToFrame(int frame)
|
||||||
{
|
{
|
||||||
clearAllRowsSelection();
|
clearAllRowsSelection();
|
||||||
setRowSelection(frame);
|
setRowSelection(frame);
|
||||||
//pianoRoll.followSelection();
|
//pianoRoll.followSelection(); FIXME
|
||||||
}
|
}
|
||||||
// ----------------------------------------------------------
|
// ----------------------------------------------------------
|
||||||
void SELECTION::save(EMUFILE *os, bool really_save)
|
void SELECTION::save(EMUFILE *os, bool really_save)
|
||||||
|
@ -345,8 +363,10 @@ void SELECTION::saveSelection(RowsSelection& selection, EMUFILE *os)
|
||||||
if (selection.size())
|
if (selection.size())
|
||||||
{
|
{
|
||||||
for(RowsSelection::iterator it(selection.begin()); it != selection.end(); it++)
|
for(RowsSelection::iterator it(selection.begin()); it != selection.end(); it++)
|
||||||
|
{
|
||||||
write32le(*it, os);
|
write32le(*it, os);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
bool SELECTION::loadSelection(RowsSelection& selection, EMUFILE *is)
|
bool SELECTION::loadSelection(RowsSelection& selection, EMUFILE *is)
|
||||||
{
|
{
|
||||||
|
@ -369,51 +389,91 @@ bool SELECTION::skipLoadSelection(EMUFILE *is)
|
||||||
}
|
}
|
||||||
// ----------------------------------------------------------
|
// ----------------------------------------------------------
|
||||||
// used to track selection
|
// used to track selection
|
||||||
//void SELECTION::noteThatItemRangeChanged(NMLVODSTATECHANGE* info)
|
void SELECTION::noteThatItemRangeChanged(int startItem, int endItem, int newValue )
|
||||||
//{
|
{
|
||||||
// bool ON = !(info->uOldState & LVIS_SELECTED) && (info->uNewState & LVIS_SELECTED);
|
int oldValue = 0;
|
||||||
// bool OFF = (info->uOldState & LVIS_SELECTED) && !(info->uNewState & LVIS_SELECTED);
|
std::map <int, int>::iterator it;
|
||||||
//
|
|
||||||
// if (ON)
|
if ( selList.size() > 0 )
|
||||||
// for(int i = info->iFrom; i <= info->iTo; ++i)
|
{
|
||||||
// getCurrentRowsSelection().insert(i);
|
it = selList.find(startItem);
|
||||||
// else
|
|
||||||
// for(int i = info->iFrom; i <= info->iTo; ++i)
|
if ( it != selList.end() )
|
||||||
// getCurrentRowsSelection().erase(i);
|
{
|
||||||
//
|
oldValue = it->second;
|
||||||
// splicer->mustRedrawInfoAboutSelection = true;
|
}
|
||||||
//}
|
}
|
||||||
//void SELECTION::noteThatItemChanged(NMLISTVIEW* info)
|
bool ON = !oldValue && newValue;
|
||||||
//{
|
bool OFF = oldValue && !newValue;
|
||||||
// int item = info->iItem;
|
|
||||||
//
|
if (ON)
|
||||||
// bool ON = !(info->uOldState & LVIS_SELECTED) && (info->uNewState & LVIS_SELECTED);
|
{
|
||||||
// bool OFF = (info->uOldState & LVIS_SELECTED) && !(info->uNewState & LVIS_SELECTED);
|
for(int i = startItem; i <= endItem; ++i)
|
||||||
//
|
{
|
||||||
// //if the item is -1, apply the change to all items
|
getCurrentRowsSelection().insert(i);
|
||||||
// if (item == -1)
|
}
|
||||||
// {
|
}
|
||||||
// if (OFF)
|
else
|
||||||
// {
|
{
|
||||||
// // clear all (actually add new empty Selection to history)
|
for(int i = startItem; i <= endItem; ++i)
|
||||||
// if (getCurrentRowsSelection().size() && trackSelectionChanges)
|
{
|
||||||
// addNewSelectionToHistory();
|
getCurrentRowsSelection().erase(i);
|
||||||
// } else if (ON)
|
}
|
||||||
// {
|
}
|
||||||
// // select all
|
|
||||||
// for(int i = currMovieData.getNumRecords() - 1; i >= 0; i--)
|
splicer->mustRedrawInfoAboutSelection = true;
|
||||||
// getCurrentRowsSelection().insert(i);
|
}
|
||||||
// }
|
void SELECTION::noteThatItemChanged(int item, int newValue )
|
||||||
// } else
|
{
|
||||||
// {
|
int oldValue = 0;
|
||||||
// if (ON)
|
std::map <int, int>::iterator it;
|
||||||
// getCurrentRowsSelection().insert(item);
|
|
||||||
// else if (OFF)
|
if ( selList.size() > 0 )
|
||||||
// getCurrentRowsSelection().erase(item);
|
{
|
||||||
// }
|
it = selList.find(item);
|
||||||
//
|
|
||||||
// splicer->mustRedrawInfoAboutSelection = true;
|
if ( it != selList.end() )
|
||||||
//}
|
{
|
||||||
|
oldValue = it->second;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
bool ON = !oldValue && newValue;
|
||||||
|
bool OFF = oldValue && !newValue;
|
||||||
|
|
||||||
|
//if the item is -1, apply the change to all items
|
||||||
|
if (item == -1)
|
||||||
|
{
|
||||||
|
if (OFF)
|
||||||
|
{
|
||||||
|
// clear all (actually add new empty Selection to history)
|
||||||
|
if (getCurrentRowsSelection().size() && trackSelectionChanges)
|
||||||
|
{
|
||||||
|
addNewSelectionToHistory();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (ON)
|
||||||
|
{
|
||||||
|
// select all
|
||||||
|
for(int i = currMovieData.getNumRecords() - 1; i >= 0; i--)
|
||||||
|
{
|
||||||
|
getCurrentRowsSelection().insert(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (ON)
|
||||||
|
{
|
||||||
|
getCurrentRowsSelection().insert(item);
|
||||||
|
}
|
||||||
|
else if (OFF)
|
||||||
|
{
|
||||||
|
getCurrentRowsSelection().erase(item);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
splicer->mustRedrawInfoAboutSelection = true;
|
||||||
|
}
|
||||||
// ----------------------------------------------------------
|
// ----------------------------------------------------------
|
||||||
void SELECTION::addNewSelectionToHistory()
|
void SELECTION::addNewSelectionToHistory()
|
||||||
{
|
{
|
||||||
|
@ -481,61 +541,118 @@ void SELECTION::redo()
|
||||||
// ----------------------------------------------------------
|
// ----------------------------------------------------------
|
||||||
bool SELECTION::isRowSelected(int index)
|
bool SELECTION::isRowSelected(int index)
|
||||||
{
|
{
|
||||||
|
std::map <int, int>::iterator it;
|
||||||
/*
|
/*
|
||||||
if (CurrentSelection().find(frame) == CurrentSelection().end())
|
if (CurrentSelection().find(frame) == CurrentSelection().end())
|
||||||
return false;
|
return false;
|
||||||
return true;
|
return true;
|
||||||
*/
|
*/
|
||||||
return false; // ListView_GetItemState(pianoRoll.hwndList, index, LVIS_SELECTED) != 0;
|
//return false; // ListView_GetItemState(pianoRoll.hwndList, index, LVIS_SELECTED) != 0;
|
||||||
|
it = selList.find(index);
|
||||||
|
|
||||||
|
if ( it != selList.end() )
|
||||||
|
{
|
||||||
|
return it->second ? true : false;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void SELECTION::clearAllRowsSelection()
|
void SELECTION::clearAllRowsSelection()
|
||||||
{
|
{
|
||||||
|
if ( selList.size() > 0 )
|
||||||
|
{
|
||||||
|
noteThatItemChanged(-1, 0);
|
||||||
|
}
|
||||||
//ListView_SetItemState(pianoRoll.hwndList, -1, 0, LVIS_SELECTED);
|
//ListView_SetItemState(pianoRoll.hwndList, -1, 0, LVIS_SELECTED);
|
||||||
|
selList.clear();
|
||||||
}
|
}
|
||||||
void SELECTION::clearSingleRowSelection(int index)
|
void SELECTION::clearSingleRowSelection(int index)
|
||||||
{
|
{
|
||||||
|
if ( selList.size() == 0 )
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
std::map <int, int>::iterator it;
|
||||||
//ListView_SetItemState(pianoRoll.hwndList, index, 0, LVIS_SELECTED);
|
//ListView_SetItemState(pianoRoll.hwndList, index, 0, LVIS_SELECTED);
|
||||||
|
|
||||||
|
it = selList.find(index);
|
||||||
|
|
||||||
|
if ( it != selList.end() )
|
||||||
|
{
|
||||||
|
noteThatItemChanged(index, 1);
|
||||||
|
it->second = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
void SELECTION::clearRegionOfRowsSelection(int start, int end)
|
void SELECTION::clearRegionOfRowsSelection(int start, int end)
|
||||||
{
|
{
|
||||||
|
if ( selList.size() == 0 )
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
//for (int i = start; i < end; ++i)
|
//for (int i = start; i < end; ++i)
|
||||||
// ListView_SetItemState(pianoRoll.hwndList, i, 0, LVIS_SELECTED);
|
// ListView_SetItemState(pianoRoll.hwndList, i, 0, LVIS_SELECTED);
|
||||||
|
|
||||||
|
for (int i = start; i < end; ++i)
|
||||||
|
{
|
||||||
|
selList[i] = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void SELECTION::selectAllRows()
|
void SELECTION::selectAllRows(void)
|
||||||
{
|
{
|
||||||
|
noteThatItemChanged(-1, 1);
|
||||||
|
|
||||||
|
for (size_t i = 0; i < currMovieData.records.size(); ++i)
|
||||||
|
{
|
||||||
|
selList[i] = 1;
|
||||||
|
}
|
||||||
//ListView_SetItemState(pianoRoll.hwndList, -1, LVIS_SELECTED, LVIS_SELECTED);
|
//ListView_SetItemState(pianoRoll.hwndList, -1, LVIS_SELECTED, LVIS_SELECTED);
|
||||||
}
|
}
|
||||||
void SELECTION::setRowSelection(int index)
|
void SELECTION::setRowSelection(int index)
|
||||||
{
|
{
|
||||||
|
noteThatItemChanged(index, 1);
|
||||||
|
selList[index] = 1;
|
||||||
//ListView_SetItemState(pianoRoll.hwndList, index, LVIS_SELECTED, LVIS_SELECTED);
|
//ListView_SetItemState(pianoRoll.hwndList, index, LVIS_SELECTED, LVIS_SELECTED);
|
||||||
|
printf("Set Row Selection:%i\n", index);
|
||||||
}
|
}
|
||||||
void SELECTION::setRegionOfRowsSelection(int start, int end)
|
void SELECTION::setRegionOfRowsSelection(int start, int end)
|
||||||
{
|
{
|
||||||
//for (int i = start; i < end; ++i)
|
//for (int i = start; i < end; ++i)
|
||||||
// ListView_SetItemState(pianoRoll.hwndList, i, LVIS_SELECTED, LVIS_SELECTED);
|
// ListView_SetItemState(pianoRoll.hwndList, i, LVIS_SELECTED, LVIS_SELECTED);
|
||||||
|
noteThatItemRangeChanged(start, end, 1);
|
||||||
|
|
||||||
|
for (int i = start; i < end; ++i)
|
||||||
|
{
|
||||||
|
selList[i] = 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void SELECTION::setRegionOfRowsSelectionUsingPattern(int start, int end)
|
void SELECTION::setRegionOfRowsSelectionUsingPattern(int start, int end)
|
||||||
{
|
{
|
||||||
//int pattern_offset = 0, current_pattern = taseditorConfig.currentPattern;
|
int pattern_offset = 0, current_pattern = taseditorConfig->currentPattern;
|
||||||
//for (int i = start; i <= end; ++i)
|
for (int i = start; i <= end; ++i)
|
||||||
//{
|
{
|
||||||
// // skip lag frames
|
// skip lag frames
|
||||||
// if (taseditorConfig.autofirePatternSkipsLag && greenzone.lagLog.getLagInfoAtFrame(i) == LAGGED_YES)
|
if (taseditorConfig->autofirePatternSkipsLag && greenzone->lagLog.getLagInfoAtFrame(i) == LAGGED_YES)
|
||||||
// continue;
|
{
|
||||||
// if (editor.patterns[current_pattern][pattern_offset])
|
continue;
|
||||||
// {
|
}
|
||||||
// ListView_SetItemState(pianoRoll.hwndList, i, LVIS_SELECTED, LVIS_SELECTED);
|
if (tasWin->patterns[current_pattern][pattern_offset])
|
||||||
// } else
|
{
|
||||||
// {
|
selList[i] = 1;
|
||||||
// ListView_SetItemState(pianoRoll.hwndList, i, 0, LVIS_SELECTED);
|
//ListView_SetItemState(pianoRoll.hwndList, i, LVIS_SELECTED, LVIS_SELECTED);
|
||||||
// }
|
}
|
||||||
// pattern_offset++;
|
else
|
||||||
// if (pattern_offset >= (int)editor.patterns[current_pattern].size())
|
{
|
||||||
// pattern_offset -= editor.patterns[current_pattern].size();
|
selList[i] = 0;
|
||||||
//}
|
//ListView_SetItemState(pianoRoll.hwndList, i, 0, LVIS_SELECTED);
|
||||||
|
}
|
||||||
|
pattern_offset++;
|
||||||
|
if (pattern_offset >= (int)tasWin->patterns[current_pattern].size())
|
||||||
|
{
|
||||||
|
pattern_offset -= tasWin->patterns[current_pattern].size();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
void SELECTION::selectAllRowsBetweenMarkers()
|
void SELECTION::selectAllRowsBetweenMarkers()
|
||||||
{
|
{
|
||||||
|
@ -548,15 +665,23 @@ void SELECTION::selectAllRowsBetweenMarkers()
|
||||||
{
|
{
|
||||||
upper_border = center = *getCurrentRowsSelection().begin();
|
upper_border = center = *getCurrentRowsSelection().begin();
|
||||||
lower_border = *getCurrentRowsSelection().rbegin();
|
lower_border = *getCurrentRowsSelection().rbegin();
|
||||||
} else lower_border = upper_border = center = currFrameCounter;
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
lower_border = upper_border = center = currFrameCounter;
|
||||||
|
}
|
||||||
|
|
||||||
// find Markers
|
// find Markers
|
||||||
// searching up starting from center-0
|
// searching up starting from center-0
|
||||||
for (upper_marker = center; upper_marker >= 0; upper_marker--)
|
for (upper_marker = center; upper_marker >= 0; upper_marker--)
|
||||||
|
{
|
||||||
if (markersManager->getMarkerAtFrame(upper_marker)) break;
|
if (markersManager->getMarkerAtFrame(upper_marker)) break;
|
||||||
|
}
|
||||||
// searching down starting from center+1
|
// searching down starting from center+1
|
||||||
for (lower_marker = center+1; lower_marker < movie_size; ++lower_marker)
|
for (lower_marker = center+1; lower_marker < movie_size; ++lower_marker)
|
||||||
|
{
|
||||||
if (markersManager->getMarkerAtFrame(lower_marker)) break;
|
if (markersManager->getMarkerAtFrame(lower_marker)) break;
|
||||||
|
}
|
||||||
|
|
||||||
clearAllRowsSelection();
|
clearAllRowsSelection();
|
||||||
|
|
||||||
|
@ -568,47 +693,56 @@ void SELECTION::selectAllRowsBetweenMarkers()
|
||||||
}
|
}
|
||||||
|
|
||||||
// selecting circle: 1-2-3-4-1-2-3-4...
|
// selecting circle: 1-2-3-4-1-2-3-4...
|
||||||
//if (upper_border > upper_marker+1 || lower_border < lower_marker-1 || lower_border > lower_marker)
|
if (upper_border > upper_marker+1 || lower_border < lower_marker-1 || lower_border > lower_marker)
|
||||||
//{
|
{
|
||||||
// // 1 - default: select all between Markers, not including lower Marker
|
// 1 - default: select all between Markers, not including lower Marker
|
||||||
// if (upper_marker < 0) upper_marker = 0;
|
if (upper_marker < 0) upper_marker = 0;
|
||||||
// for (int i = upper_marker; i < lower_marker; ++i)
|
for (int i = upper_marker; i < lower_marker; ++i)
|
||||||
// {
|
{
|
||||||
// ListView_SetItemState(pianoRoll.hwndList, i, LVIS_SELECTED, LVIS_SELECTED);
|
//ListView_SetItemState(pianoRoll.hwndList, i, LVIS_SELECTED, LVIS_SELECTED);
|
||||||
// }
|
selList[i] = 1;
|
||||||
//} else if (upper_border == upper_marker && lower_border == lower_marker-1)
|
}
|
||||||
//{
|
}
|
||||||
// // 2 - selected all between Markers and upper Marker selected too: select all between Markers, not including Markers
|
else if (upper_border == upper_marker && lower_border == lower_marker-1)
|
||||||
// for (int i = upper_marker+1; i < lower_marker; ++i)
|
{
|
||||||
// {
|
// 2 - selected all between Markers and upper Marker selected too: select all between Markers, not including Markers
|
||||||
// ListView_SetItemState(pianoRoll.hwndList, i, LVIS_SELECTED, LVIS_SELECTED);
|
for (int i = upper_marker+1; i < lower_marker; ++i)
|
||||||
// }
|
{
|
||||||
//} else if (upper_border == upper_marker+1 && lower_border == lower_marker-1)
|
//ListView_SetItemState(pianoRoll.hwndList, i, LVIS_SELECTED, LVIS_SELECTED);
|
||||||
//{
|
selList[i] = 1;
|
||||||
// // 3 - selected all between Markers, nut including Markers: select all between Markers, not including upper Marker
|
}
|
||||||
// if (lower_marker >= movie_size) lower_marker = movie_size - 1;
|
}
|
||||||
// for (int i = upper_marker+1; i <= lower_marker; ++i)
|
else if (upper_border == upper_marker+1 && lower_border == lower_marker-1)
|
||||||
// {
|
{
|
||||||
// ListView_SetItemState(pianoRoll.hwndList, i, LVIS_SELECTED, LVIS_SELECTED);
|
// 3 - selected all between Markers, nut including Markers: select all between Markers, not including upper Marker
|
||||||
// }
|
if (lower_marker >= movie_size) lower_marker = movie_size - 1;
|
||||||
//} else if (upper_border == upper_marker+1 && lower_border == lower_marker)
|
for (int i = upper_marker+1; i <= lower_marker; ++i)
|
||||||
//{
|
{
|
||||||
// // 4 - selected all between Markers and lower Marker selected too: select all bertween Markers, including Markers
|
//ListView_SetItemState(pianoRoll.hwndList, i, LVIS_SELECTED, LVIS_SELECTED);
|
||||||
// if (upper_marker < 0) upper_marker = 0;
|
selList[i] = 1;
|
||||||
// if (lower_marker >= movie_size) lower_marker = movie_size - 1;
|
}
|
||||||
// for (int i = upper_marker; i <= lower_marker; ++i)
|
}
|
||||||
// {
|
else if (upper_border == upper_marker+1 && lower_border == lower_marker)
|
||||||
// ListView_SetItemState(pianoRoll.hwndList, i, LVIS_SELECTED, LVIS_SELECTED);
|
{
|
||||||
// }
|
// 4 - selected all between Markers and lower Marker selected too: select all bertween Markers, including Markers
|
||||||
//} else
|
if (upper_marker < 0) upper_marker = 0;
|
||||||
//{
|
if (lower_marker >= movie_size) lower_marker = movie_size - 1;
|
||||||
// // return to 1
|
for (int i = upper_marker; i <= lower_marker; ++i)
|
||||||
// if (upper_marker < 0) upper_marker = 0;
|
{
|
||||||
// for (int i = upper_marker; i < lower_marker; ++i)
|
//ListView_SetItemState(pianoRoll.hwndList, i, LVIS_SELECTED, LVIS_SELECTED);
|
||||||
// {
|
selList[i] = 1;
|
||||||
// ListView_SetItemState(pianoRoll.hwndList, i, LVIS_SELECTED, LVIS_SELECTED);
|
}
|
||||||
// }
|
}
|
||||||
//}
|
else
|
||||||
|
{
|
||||||
|
// return to 1
|
||||||
|
if (upper_marker < 0) upper_marker = 0;
|
||||||
|
for (int i = upper_marker; i < lower_marker; ++i)
|
||||||
|
{
|
||||||
|
//ListView_SetItemState(pianoRoll.hwndList, i, LVIS_SELECTED, LVIS_SELECTED);
|
||||||
|
selList[i] = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
void SELECTION::reselectClipboard()
|
void SELECTION::reselectClipboard()
|
||||||
{
|
{
|
||||||
|
@ -625,42 +759,50 @@ void SELECTION::reselectClipboard()
|
||||||
void SELECTION::transposeVertically(int shift)
|
void SELECTION::transposeVertically(int shift)
|
||||||
{
|
{
|
||||||
if (!shift) return;
|
if (!shift) return;
|
||||||
//RowsSelection* current_selection = getCopyOfCurrentRowsSelection();
|
RowsSelection* current_selection = getCopyOfCurrentRowsSelection();
|
||||||
//if (current_selection->size())
|
if (current_selection->size())
|
||||||
//{
|
{
|
||||||
// clearAllRowsSelection();
|
clearAllRowsSelection();
|
||||||
// int pos;
|
int pos;
|
||||||
// if (shift > 0)
|
if (shift > 0)
|
||||||
// {
|
{
|
||||||
// int movie_size = currMovieData.getNumRecords();
|
int movie_size = currMovieData.getNumRecords();
|
||||||
// RowsSelection::reverse_iterator current_selection_rend(current_selection->rend());
|
RowsSelection::reverse_iterator current_selection_rend(current_selection->rend());
|
||||||
// for(RowsSelection::reverse_iterator it(current_selection->rbegin()); it != current_selection_rend; it++)
|
for(RowsSelection::reverse_iterator it(current_selection->rbegin()); it != current_selection_rend; it++)
|
||||||
// {
|
{
|
||||||
// pos = (*it) + shift;
|
pos = (*it) + shift;
|
||||||
// if (pos < movie_size)
|
if (pos < movie_size)
|
||||||
// ListView_SetItemState(pianoRoll.hwndList, pos, LVIS_SELECTED, LVIS_SELECTED);
|
{
|
||||||
// }
|
//ListView_SetItemState(pianoRoll.hwndList, pos, LVIS_SELECTED, LVIS_SELECTED);
|
||||||
// } else
|
selList[pos] = 1;
|
||||||
// {
|
}
|
||||||
// RowsSelection::iterator current_selection_end(current_selection->end());
|
}
|
||||||
// for(RowsSelection::iterator it(current_selection->begin()); it != current_selection_end; it++)
|
}
|
||||||
// {
|
else
|
||||||
// pos = (*it) + shift;
|
{
|
||||||
// if (pos >= 0)
|
RowsSelection::iterator current_selection_end(current_selection->end());
|
||||||
// ListView_SetItemState(pianoRoll.hwndList, pos, LVIS_SELECTED, LVIS_SELECTED);
|
for(RowsSelection::iterator it(current_selection->begin()); it != current_selection_end; it++)
|
||||||
// }
|
{
|
||||||
// }
|
pos = (*it) + shift;
|
||||||
//}
|
if (pos >= 0)
|
||||||
|
{
|
||||||
|
//ListView_SetItemState(pianoRoll.hwndList, pos, LVIS_SELECTED, LVIS_SELECTED);
|
||||||
|
selList[pos] = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void SELECTION::enforceRowsSelectionToList()
|
void SELECTION::enforceRowsSelectionToList()
|
||||||
{
|
{
|
||||||
trackSelectionChanges = false;
|
trackSelectionChanges = false;
|
||||||
clearAllRowsSelection();
|
clearAllRowsSelection();
|
||||||
//for(RowsSelection::reverse_iterator it(getCurrentRowsSelection().rbegin()); it != getCurrentRowsSelection().rend(); it++)
|
for(RowsSelection::reverse_iterator it(getCurrentRowsSelection().rbegin()); it != getCurrentRowsSelection().rend(); it++)
|
||||||
//{
|
{
|
||||||
// ListView_SetItemState(pianoRoll.hwndList, *it, LVIS_SELECTED, LVIS_SELECTED);
|
//ListView_SetItemState(pianoRoll.hwndList, *it, LVIS_SELECTED, LVIS_SELECTED);
|
||||||
//}
|
selList[*it] = 1;
|
||||||
|
}
|
||||||
trackSelectionChanges = true;
|
trackSelectionChanges = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <set>
|
#include <set>
|
||||||
|
#include <map>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
typedef std::set<int> RowsSelection;
|
typedef std::set<int> RowsSelection;
|
||||||
|
|
||||||
|
@ -29,8 +30,8 @@ public:
|
||||||
bool loadSelection(RowsSelection& selection, EMUFILE *is);
|
bool loadSelection(RowsSelection& selection, EMUFILE *is);
|
||||||
bool skipLoadSelection(EMUFILE *is);
|
bool skipLoadSelection(EMUFILE *is);
|
||||||
|
|
||||||
//void noteThatItemRangeChanged(NMLVODSTATECHANGE* info);
|
void noteThatItemRangeChanged(int startItem, int endItem, int newValue);
|
||||||
//void noteThatItemChanged(NMLISTVIEW* info);
|
void noteThatItemChanged(int itemIndex, int value);
|
||||||
|
|
||||||
void addNewSelectionToHistory();
|
void addNewSelectionToHistory();
|
||||||
void addCurrentSelectionToHistory();
|
void addCurrentSelectionToHistory();
|
||||||
|
@ -95,4 +96,5 @@ private:
|
||||||
|
|
||||||
RowsSelection tempRowsSelection;
|
RowsSelection tempRowsSelection;
|
||||||
|
|
||||||
|
std::map <int, int> selList;
|
||||||
};
|
};
|
||||||
|
|
|
@ -74,16 +74,19 @@ void SPLICER::update(void)
|
||||||
int size = selection->getCurrentRowsSelectionSize();
|
int size = selection->getCurrentRowsSelectionSize();
|
||||||
if (size)
|
if (size)
|
||||||
{
|
{
|
||||||
char new_text[128];
|
|
||||||
strcpy(new_text, selectionText);
|
|
||||||
char num[16];
|
char num[16];
|
||||||
|
char new_text[128];
|
||||||
|
//strcpy(new_text, selectionText);
|
||||||
|
|
||||||
|
new_text[0] = 0;
|
||||||
// rows
|
// rows
|
||||||
if (size > 1)
|
if (size > 1)
|
||||||
{
|
{
|
||||||
sprintf( num, "%i", size);
|
sprintf( num, "%i", size);
|
||||||
strcat(new_text, num);
|
strcat(new_text, num);
|
||||||
strcat(new_text, numTextRows);
|
strcat(new_text, numTextRows);
|
||||||
} else
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
strcat(new_text, numTextRow);
|
strcat(new_text, numTextRow);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue