annotate widgets/SubdividingMenu.h @ 1553:76e4302a3fc2

Fix note numbering - ensure stable across whole track (as it used to be, but without scanning all notes in paint in order to do that)
author Chris Cannam
date Fri, 22 Nov 2019 14:12:50 +0000
parents edfc38ade098
children
rev   line source
Chris@151 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@151 2
Chris@151 3 /*
Chris@151 4 Sonic Visualiser
Chris@151 5 An audio file viewer and annotation editor.
Chris@151 6 Centre for Digital Music, Queen Mary, University of London.
Chris@182 7 This file copyright 2006 QMUL.
Chris@151 8
Chris@151 9 This program is free software; you can redistribute it and/or
Chris@151 10 modify it under the terms of the GNU General Public License as
Chris@151 11 published by the Free Software Foundation; either version 2 of the
Chris@151 12 License, or (at your option) any later version. See the file
Chris@151 13 COPYING included with this distribution for more information.
Chris@151 14 */
Chris@151 15
Chris@1347 16 #ifndef SV_SUBDIVIDING_MENU_H
Chris@1347 17 #define SV_SUBDIVIDING_MENU_H
Chris@151 18
Chris@151 19 #include <QMenu>
Chris@151 20
Chris@151 21 #include <QString>
Chris@151 22 #include <set>
Chris@151 23 #include <map>
Chris@151 24
Chris@151 25 /**
Chris@151 26 * A menu that divides its entries into submenus, alphabetically. For
Chris@151 27 * menus that may contain a very large or small number of named items
Chris@151 28 * (e.g. plugins).
Chris@151 29 *
Chris@151 30 * The menu needs to be told, before any of the actions are added,
Chris@151 31 * what the set of entry strings will be, so it can determine a
Chris@151 32 * reasonable categorisation. Do this by calling the setEntries()
Chris@152 33 * method. If it isn't practical to do this in advance, then add the
Chris@152 34 * entries and call entriesAdded() afterwards instead.
Chris@151 35 */
Chris@151 36
Chris@151 37 class SubdividingMenu : public QMenu
Chris@151 38 {
Chris@222 39 Q_OBJECT
Chris@222 40
Chris@151 41 public:
Chris@807 42 SubdividingMenu(int lowerLimit = 0, int upperLimit = 0,
Chris@152 43 QWidget *parent = 0);
Chris@807 44 SubdividingMenu(const QString &title, int lowerLimit = 0,
Chris@807 45 int upperLimit = 0, QWidget *parent = 0);
Chris@151 46 virtual ~SubdividingMenu();
Chris@151 47
Chris@151 48 void setEntries(const std::set<QString> &entries);
Chris@152 49 void entriesAdded();
Chris@151 50
Chris@151 51 // Action names and strings passed to addAction and addMenu must
Chris@151 52 // appear in the set previously given to setEntries. If you want
Chris@151 53 // to use a different string, use the two-argument method and pass
Chris@151 54 // the entry string (used to determine which submenu the action
Chris@151 55 // ends up on) as the first argument.
Chris@151 56
Chris@151 57 virtual void addAction(QAction *);
Chris@151 58 virtual QAction *addAction(const QString &);
Chris@151 59 virtual void addAction(const QString &entry, QAction *);
Chris@151 60
Chris@151 61 virtual void addMenu(QMenu *);
Chris@151 62 virtual QMenu *addMenu(const QString &);
Chris@151 63 virtual void addMenu(const QString &entry, QMenu *);
Chris@151 64
Chris@151 65 protected:
Chris@151 66 std::map<QString, QMenu *> m_nameToChunkMenuMap;
Chris@152 67
Chris@807 68 int m_lowerLimit;
Chris@807 69 int m_upperLimit;
Chris@152 70
Chris@152 71 bool m_entriesSet;
Chris@152 72 std::map<QString, QObject *> m_pendingEntries;
Chris@151 73 };
Chris@151 74
Chris@151 75 #endif
Chris@151 76