|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416 |
- /*
- ==============================================================================
-
- This file is part of the JUCE library.
- Copyright (c) 2013 - Raw Material Software Ltd.
-
- Permission is granted to use this software under the terms of either:
- a) the GPL v2 (or any later version)
- b) the Affero GPL v3
-
- Details of these licenses can be found at: www.gnu.org/licenses
-
- JUCE is distributed in the hope that it will be useful, but WITHOUT ANY
- WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
- A PARTICULAR PURPOSE. See the GNU General Public License for more details.
-
- ------------------------------------------------------------------------------
-
- To release a closed-source product which uses JUCE, commercial licenses are
- available: visit www.juce.com for more information.
-
- ==============================================================================
- */
-
- #include "MainHostWindow.h"
- #include "InternalFilters.h"
-
-
- //==============================================================================
- class MainHostWindow::PluginListWindow : public DocumentWindow
- {
- public:
- PluginListWindow (MainHostWindow& owner_, AudioPluginFormatManager& formatManager)
- : DocumentWindow ("Available Plugins", Colours::white,
- DocumentWindow::minimiseButton | DocumentWindow::closeButton),
- owner (owner_)
- {
- const File deadMansPedalFile (owner.appProperties.getUserSettings()
- ->getFile().getSiblingFile ("RecentlyCrashedPluginsList"));
-
- setContentOwned (new PluginListComponent (formatManager,
- owner.knownPluginList,
- deadMansPedalFile,
- owner.appProperties.getUserSettings()), true);
-
- setOpaque (true);
- setResizable (true, false);
- setResizeLimits (300, 400, 800, 1500);
- setTopLeftPosition (60, 60);
-
- restoreWindowStateFromString (owner.appProperties.getUserSettings()->getValue ("listWindowPos"));
- setUsingNativeTitleBar (true);
- setVisible (true);
- }
-
- ~PluginListWindow()
- {
- owner.appProperties.getUserSettings()->setValue ("listWindowPos", getWindowStateAsString());
-
- clearContentComponent();
- }
-
- void closeButtonPressed()
- {
- owner.pluginListWindow = nullptr;
- }
-
- private:
- MainHostWindow& owner;
-
- JUCE_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR (PluginListWindow)
- };
-
- //==============================================================================
- MainHostWindow::MainHostWindow (AudioPluginFormatManager& fm, FilterGraph& graph, ApplicationProperties& ap)
- : DocumentWindow ("Juce Patchbay", Colours::lightgrey, DocumentWindow::allButtons),
- formatManager (fm),
- appProperties (ap),
- closed (false)
- {
- LookAndFeel::setDefaultLookAndFeel (&lookAndFeel);
-
- setOpaque (true);
- setResizable (true, false);
- setResizeLimits (500, 400, 10000, 10000);
- centreWithSize (800, 600);
-
- setContentOwned (new GraphDocumentComponent (graph), false);
- setUsingNativeTitleBar (true);
-
- restoreWindowStateFromString (appProperties.getUserSettings()->getValue ("mainWindowPos"));
-
- setVisible (true);
-
- ScopedPointer<XmlElement> savedPluginList (appProperties.getUserSettings()->getXmlValue ("pluginList"));
-
- if (savedPluginList != nullptr)
- knownPluginList.recreateFromXml (*savedPluginList);
-
- pluginSortMethod = (KnownPluginList::SortMethod) appProperties.getUserSettings()
- ->getIntValue ("pluginSortMethod", KnownPluginList::sortByManufacturer);
-
- knownPluginList.addChangeListener (this);
-
- addKeyListener (commandManager.getKeyMappings());
-
- //Process::setPriority (Process::HighPriority);
-
- #if JUCE_MAC
- setMacMainMenu (this);
- #else
- setMenuBar (this);
- #endif
-
- commandManager.setFirstCommandTarget (this);
- commandManager.registerAllCommandsForTarget (this);
-
- menuItemsChanged();
- }
-
- MainHostWindow::~MainHostWindow()
- {
- pluginListWindow = nullptr;
-
- #if JUCE_MAC
- setMacMainMenu (nullptr);
- #else
- setMenuBar (nullptr);
- #endif
-
- knownPluginList.removeChangeListener (this);
-
- appProperties.getUserSettings()->setValue ("mainWindowPos", getWindowStateAsString());
- clearContentComponent();
-
- LookAndFeel::setDefaultLookAndFeel (nullptr);
- }
-
- void MainHostWindow::closeButtonPressed()
- {
- getGraphEditor()->closeAllCurrentlyOpenWindows();
-
- closed = true;
- }
-
- void MainHostWindow::changeListenerCallback (ChangeBroadcaster*)
- {
- menuItemsChanged();
-
- // save the plugin list every time it gets chnaged, so that if we're scanning
- // and it crashes, we've still saved the previous ones
- ScopedPointer<XmlElement> savedPluginList (knownPluginList.createXml());
-
- if (savedPluginList != nullptr)
- {
- appProperties.getUserSettings()->setValue ("pluginList", savedPluginList);
- appProperties.saveIfNeeded();
- }
- }
-
- StringArray MainHostWindow::getMenuBarNames()
- {
- const char* const names[] = { "File", "Plugins", "Options", nullptr };
-
- return StringArray (names);
- }
-
- PopupMenu MainHostWindow::getMenuForIndex (int topLevelMenuIndex, const String& /*menuName*/)
- {
- PopupMenu menu;
-
- if (topLevelMenuIndex == 0)
- {
- // "File" menu
- menu.addCommandItem (&commandManager, CommandIDs::open);
-
- RecentlyOpenedFilesList recentFiles;
- recentFiles.restoreFromString (appProperties.getUserSettings()
- ->getValue ("recentFilterGraphFiles"));
-
- PopupMenu recentFilesMenu;
- recentFiles.createPopupMenuItems (recentFilesMenu, 100, true, true);
- menu.addSubMenu ("Open recent file", recentFilesMenu);
-
- menu.addCommandItem (&commandManager, CommandIDs::save);
- menu.addCommandItem (&commandManager, CommandIDs::saveAs);
- }
- else if (topLevelMenuIndex == 1)
- {
- // "Plugins" menu
- PopupMenu pluginsMenu;
- addPluginsToMenu (pluginsMenu);
- menu.addSubMenu ("Create plugin", pluginsMenu);
- menu.addSeparator();
- menu.addItem (250, "Delete all plugins");
- }
- else if (topLevelMenuIndex == 2)
- {
- // "Options" menu
-
- menu.addCommandItem (&commandManager, CommandIDs::showPluginListEditor);
-
- PopupMenu sortTypeMenu;
- sortTypeMenu.addItem (200, "List plugins in default order", true, pluginSortMethod == KnownPluginList::defaultOrder);
- sortTypeMenu.addItem (201, "List plugins in alphabetical order", true, pluginSortMethod == KnownPluginList::sortAlphabetically);
- sortTypeMenu.addItem (202, "List plugins by category", true, pluginSortMethod == KnownPluginList::sortByCategory);
- sortTypeMenu.addItem (203, "List plugins by manufacturer", true, pluginSortMethod == KnownPluginList::sortByManufacturer);
- sortTypeMenu.addItem (204, "List plugins based on the directory structure", true, pluginSortMethod == KnownPluginList::sortByFileSystemLocation);
- menu.addSubMenu ("Plugin menu type", sortTypeMenu);
- }
-
- return menu;
- }
-
- void MainHostWindow::menuItemSelected (int menuItemID, int /*topLevelMenuIndex*/)
- {
- GraphDocumentComponent* const graphEditor = getGraphEditor();
-
- if (menuItemID == 250)
- {
- if (graphEditor != nullptr)
- graphEditor->graph.clearKeepingInternals();
- }
- else if (menuItemID >= 100 && menuItemID < 200)
- {
- RecentlyOpenedFilesList recentFiles;
- recentFiles.restoreFromString (appProperties.getUserSettings()
- ->getValue ("recentFilterGraphFiles"));
-
- if (graphEditor != nullptr && graphEditor->graph.saveIfNeededAndUserAgrees() == FileBasedDocument::savedOk)
- graphEditor->graph.loadFrom (recentFiles.getFile (menuItemID - 100), true);
- }
- else if (menuItemID >= 200 && menuItemID < 210)
- {
- if (menuItemID == 200) pluginSortMethod = KnownPluginList::defaultOrder;
- else if (menuItemID == 201) pluginSortMethod = KnownPluginList::sortAlphabetically;
- else if (menuItemID == 202) pluginSortMethod = KnownPluginList::sortByCategory;
- else if (menuItemID == 203) pluginSortMethod = KnownPluginList::sortByManufacturer;
- else if (menuItemID == 204) pluginSortMethod = KnownPluginList::sortByFileSystemLocation;
-
- appProperties.getUserSettings()->setValue ("pluginSortMethod", (int) pluginSortMethod);
-
- menuItemsChanged();
- }
- else
- {
- createPlugin (getChosenType (menuItemID),
- proportionOfWidth (0.3f + Random::getSystemRandom().nextFloat() * 0.6f),
- proportionOfHeight (0.3f + Random::getSystemRandom().nextFloat() * 0.6f));
- }
- }
-
- void MainHostWindow::createPlugin (const PluginDescription* desc, int x, int y)
- {
- GraphDocumentComponent* const graphEditor = getGraphEditor();
-
- if (graphEditor != nullptr)
- graphEditor->createNewPlugin (desc, x, y);
- }
-
- void MainHostWindow::addPluginsToMenu (PopupMenu& m) const
- {
- knownPluginList.addToMenu (m, pluginSortMethod);
- }
-
- const PluginDescription* MainHostWindow::getChosenType (const int menuID) const
- {
- return knownPluginList.getType (knownPluginList.getIndexChosenByMenu (menuID));
- }
-
- //==============================================================================
- ApplicationCommandTarget* MainHostWindow::getNextCommandTarget()
- {
- return findFirstTargetParentComponent();
- }
-
- void MainHostWindow::getAllCommands (Array <CommandID>& commands)
- {
- // this returns the set of all commands that this target can perform..
- const CommandID ids[] = { CommandIDs::open,
- CommandIDs::save,
- CommandIDs::saveAs,
- CommandIDs::showPluginListEditor
- };
-
- commands.addArray (ids, numElementsInArray (ids));
- }
-
- void MainHostWindow::getCommandInfo (const CommandID commandID, ApplicationCommandInfo& result)
- {
- const String category ("General");
-
- switch (commandID)
- {
- case CommandIDs::open:
- result.setInfo ("Open...",
- "Opens a filter graph file",
- category, 0);
- result.defaultKeypresses.add (KeyPress ('o', ModifierKeys::commandModifier, 0));
- break;
-
- case CommandIDs::save:
- result.setInfo ("Save",
- "Saves the current graph to a file",
- category, 0);
- result.defaultKeypresses.add (KeyPress ('s', ModifierKeys::commandModifier, 0));
- break;
-
- case CommandIDs::saveAs:
- result.setInfo ("Save As...",
- "Saves a copy of the current graph to a file",
- category, 0);
- result.defaultKeypresses.add (KeyPress ('s', ModifierKeys::shiftModifier | ModifierKeys::commandModifier, 0));
- break;
-
- case CommandIDs::showPluginListEditor:
- result.setInfo ("Edit the list of available plug-Ins...", String::empty, category, 0);
- result.addDefaultKeypress ('p', ModifierKeys::commandModifier);
- break;
-
- default:
- break;
- }
- }
-
- bool MainHostWindow::perform (const InvocationInfo& info)
- {
- GraphDocumentComponent* const graphEditor = getGraphEditor();
-
- switch (info.commandID)
- {
- case CommandIDs::open:
- if (graphEditor != nullptr && graphEditor->graph.saveIfNeededAndUserAgrees() == FileBasedDocument::savedOk)
- graphEditor->graph.loadFromUserSpecifiedFile (true);
-
- break;
-
- case CommandIDs::save:
- if (graphEditor != nullptr)
- graphEditor->graph.save (true, true);
- break;
-
- case CommandIDs::saveAs:
- if (graphEditor != nullptr)
- graphEditor->graph.saveAs (File::nonexistent, true, true, true);
- break;
-
- case CommandIDs::showPluginListEditor:
- if (pluginListWindow == nullptr)
- pluginListWindow = new PluginListWindow (*this, formatManager);
-
- pluginListWindow->toFront (true);
- break;
-
- default:
- return false;
- }
-
- return true;
- }
-
- bool MainHostWindow::isInterestedInFileDrag (const StringArray&)
- {
- return true;
- }
-
- void MainHostWindow::fileDragEnter (const StringArray&, int, int)
- {
- }
-
- void MainHostWindow::fileDragMove (const StringArray&, int, int)
- {
- }
-
- void MainHostWindow::fileDragExit (const StringArray&)
- {
- }
-
- void MainHostWindow::filesDropped (const StringArray& files, int x, int y)
- {
- GraphDocumentComponent* const graphEditor = getGraphEditor();
-
- if (graphEditor != nullptr)
- {
- if (files.size() == 1 && File (files[0]).hasFileExtension (filenameSuffix))
- {
- if (graphEditor->graph.saveIfNeededAndUserAgrees() == FileBasedDocument::savedOk)
- graphEditor->graph.loadFrom (File (files[0]), true);
- }
- else
- {
- OwnedArray <PluginDescription> typesFound;
- knownPluginList.scanAndAddDragAndDroppedFiles (formatManager, files, typesFound);
-
- Point<int> pos (graphEditor->getLocalPoint (this, Point<int> (x, y)));
-
- for (int i = 0; i < jmin (5, typesFound.size()); ++i)
- createPlugin (typesFound.getUnchecked(i), pos.getX(), pos.getY());
- }
- }
- }
-
- GraphDocumentComponent* MainHostWindow::getGraphEditor() const
- {
- return dynamic_cast <GraphDocumentComponent*> (getContentComponent());
- }
-
- MidiKeyboardState* MainHostWindow::getMidiState() noexcept
- {
- return getGraphEditor()->getMidiState();
- }
-
- bool MainHostWindow::wasClosedByUser() const noexcept
- {
- return closed;
- }
|