comparison view/PaneStack.cpp @ 1362:d79e21855aef

Add mechanism for saving/loading colour maps by name/id rather than by numerical index, for future compatibility when adding to or changing the supported colour maps. Add two new colour maps (and one old one). Write out backward-compatible numerical indices for use when reloading in older versions. Also add a mechanism to invert the colour map, though I don't think it turns out useful enough to include in the UI.
author Chris Cannam
date Thu, 18 Oct 2018 13:21:56 +0100
parents a34a2a25907c
children c8a6fd3f9dff
comparison
equal deleted inserted replaced
1361:2e3b3fadba27 1362:d79e21855aef
284 } 284 }
285 285
286 void 286 void
287 PaneStack::deletePane(Pane *pane) 287 PaneStack::deletePane(Pane *pane)
288 { 288 {
289 cerr << "PaneStack::deletePane(" << pane << ")" << endl; 289 #ifdef DEBUG_PANE_STACK
290 SVCERR << "PaneStack::deletePane(" << pane << ")" << endl;
291 #endif
290 292
291 std::vector<PaneRec>::iterator i; 293 std::vector<PaneRec>::iterator i;
292 bool found = false; 294 bool found = false;
293 295
294 QWidget *stack = 0; 296 QWidget *stack = 0;
320 } 322 }
321 323
322 emit paneAboutToBeDeleted(pane); 324 emit paneAboutToBeDeleted(pane);
323 unlinkAlignmentViews(); 325 unlinkAlignmentViews();
324 326
325 cerr << "PaneStack::deletePane: about to delete parent " << pane->parent() << " of pane " << pane << endl; 327 #ifdef DEBUG_PANE_STACK
328 SVCERR << "PaneStack::deletePane: about to delete parent " << pane->parent() << " of pane " << pane << endl;
329 #endif
326 330
327 // The property stack associated with the parent was initially 331 // The property stack associated with the parent was initially
328 // created with the same parent as it, so it would be deleted when 332 // created with the same parent as it, so it would be deleted when
329 // we delete the pane's parent in a moment -- but it may have been 333 // we delete the pane's parent in a moment -- but it may have been
330 // reparented depending on the layout. We'd better delete it 334 // reparented depending on the layout. We'd better delete it
351 } 355 }
352 356
353 void 357 void
354 PaneStack::showOrHidePaneAccessories() 358 PaneStack::showOrHidePaneAccessories()
355 { 359 {
356 cerr << "PaneStack::showOrHidePaneAccessories: count == " << getPaneCount() << endl; 360 #ifdef DEBUG_PANE_STACK
361 SVCERR << "PaneStack::showOrHidePaneAccessories: count == " << getPaneCount() << endl;
362 #endif
357 363
358 bool multi = (getPaneCount() > 1); 364 bool multi = (getPaneCount() > 1);
359 for (std::vector<PaneRec>::iterator i = m_panes.begin(); 365 for (std::vector<PaneRec>::iterator i = m_panes.begin();
360 i != m_panes.end(); ++i) { 366 i != m_panes.end(); ++i) {
361 i->xButton->setVisible(multi && m_showAccessories); 367 i->xButton->setVisible(multi && m_showAccessories);
405 ++i; 411 ++i;
406 } 412 }
407 413
408 relinkAlignmentViews(); 414 relinkAlignmentViews();
409 415
410 cerr << "WARNING: PaneStack::hidePane(" << pane << "): Pane not found in visible panes" << endl; 416 SVCERR << "WARNING: PaneStack::hidePane(" << pane << "): Pane not found in visible panes" << endl;
411 } 417 }
412 418
413 void 419 void
414 PaneStack::showPane(Pane *pane) 420 PaneStack::showPane(Pane *pane)
415 { 421 {
431 ++i; 437 ++i;
432 } 438 }
433 439
434 relinkAlignmentViews(); 440 relinkAlignmentViews();
435 441
436 cerr << "WARNING: PaneStack::showPane(" << pane << "): Pane not found in hidden panes" << endl; 442 SVCERR << "WARNING: PaneStack::showPane(" << pane << "): Pane not found in hidden panes" << endl;
437 } 443 }
438 444
439 void 445 void
440 PaneStack::setCurrentPane(Pane *pane) // may be null 446 PaneStack::setCurrentPane(Pane *pane) // may be null
441 { 447 {
470 476
471 if (found || pane == 0) { 477 if (found || pane == 0) {
472 m_currentPane = pane; 478 m_currentPane = pane;
473 emit currentPaneChanged(m_currentPane); 479 emit currentPaneChanged(m_currentPane);
474 } else { 480 } else {
475 cerr << "WARNING: PaneStack::setCurrentPane(" << pane << "): pane is not a visible pane in this stack" << endl; 481 SVCERR << "WARNING: PaneStack::setCurrentPane(" << pane << "): pane is not a visible pane in this stack" << endl;
476 } 482 }
477 } 483 }
478 484
479 void 485 void
480 PaneStack::setCurrentLayer(Pane *pane, Layer *layer) // may be null 486 PaneStack::setCurrentLayer(Pane *pane, Layer *layer) // may be null