|
- /*
- ==============================================================================
-
- This file is part of the JUCE library.
- Copyright (c) 2017 - ROLI Ltd.
-
- JUCE is an open source library subject to commercial or open-source
- licensing.
-
- By using JUCE, you agree to the terms of both the JUCE 5 End-User License
- Agreement and JUCE 5 Privacy Policy (both updated and effective as of the
- 27th April 2017).
-
- End User License Agreement: www.juce.com/juce-5-licence
- Privacy Policy: www.juce.com/juce-5-privacy-policy
-
- Or: You may also use this code under the terms of the GPL v3 (see
- www.gnu.org/licenses).
-
- JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
- EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
- DISCLAIMED.
-
- ==============================================================================
- */
-
-
- #pragma once
-
-
- class ZoneLayoutComponent : public Component,
- public MPESetupComponent::Listener
- {
- public:
- //==============================================================================
- ZoneLayoutComponent (const ZoneColourPicker& zoneColourPicker)
- : colourPicker (zoneColourPicker)
- {}
-
- //==============================================================================
- void paint (Graphics& g) override
- {
- paintBackground (g);
-
- if (legacyModeEnabled)
- paintLegacyMode (g);
- else
- paintZones (g);
- }
-
- //==============================================================================
- void zoneAdded (MPEZone newZone) override
- {
- zoneLayout.addZone (newZone);
- repaint();
- }
-
- void allZonesCleared() override
- {
- zoneLayout.clearAllZones();
- repaint();
- }
-
- void legacyModeChanged (bool legacyModeShouldBeEnabled, int pitchbendRange, Range<int> channelRange) override
- {
- legacyModeEnabled = legacyModeShouldBeEnabled;
- legacyModePitchbendRange = pitchbendRange;
- legacyModeChannelRange = channelRange;
- repaint();
- }
-
- void voiceStealingEnabledChanged (bool) override { /* not interested in this change */ }
- void numberOfVoicesChanged (int) override { /* not interested in this change */ }
-
- private:
- //==============================================================================
- void paintBackground (Graphics& g)
- {
- g.setColour (Colours::black);
- float channelWidth = getChannelRectangleWidth();
-
- for (int i = 0; i < numMidiChannels; ++i)
- {
- float x = float (i) * channelWidth;
- Rectangle<int> channelArea ((int) x, 0, (int) channelWidth, getHeight());
-
- Line<float> line (x, 0.0f, x, float (getHeight()));
- g.drawLine (line);
- g.drawText (String (i + 1), channelArea.reduced (4, 4), Justification::topLeft, false);
- }
- }
-
- //==============================================================================
- void paintZones (Graphics& g)
- {
- float channelWidth = getChannelRectangleWidth();
-
- for (int i = 0; i < zoneLayout.getNumZones(); ++i)
- {
- MPEZone zone = *zoneLayout.getZoneByIndex (i);
- Colour zoneColour = colourPicker.getColourForZoneIndex (i);
-
- Rectangle<int> zoneRect (int (getChannelRectangleWidth() * (zone.getMasterChannel() - 1)), 0,
- int (getChannelRectangleWidth() * (zone.getNumNoteChannels() + 1)), getHeight());
- zoneRect.removeFromTop (20);
-
- g.setColour (zoneColour.withAlpha (0.3f));
- g.fillRect (zoneRect.withWidth ((int) channelWidth));
-
- g.setColour (zoneColour);
- g.drawRect (zoneRect, 3);
- g.drawText ("<>" + String (zone.getPerNotePitchbendRange()), zoneRect.withTrimmedLeft ((int) channelWidth).reduced (4, 4), Justification::bottomLeft, false);
-
- g.setColour (Colours::black);
- g.drawText ("ZONE " + String (i + 1), zoneRect.reduced (4, 4), Justification::topLeft, false);
- g.drawText ("<>" + String (zone.getMasterPitchbendRange()), zoneRect.reduced (4, 4), Justification::bottomLeft, false);
- }
- }
-
- //==============================================================================
- void paintLegacyMode (Graphics& g)
- {
- int startChannel = legacyModeChannelRange.getStart() - 1;
- int numChannels = legacyModeChannelRange.getEnd() - startChannel - 1;
-
-
- Rectangle<int> zoneRect (int (getChannelRectangleWidth() * startChannel), 0,
- int (getChannelRectangleWidth() * numChannels), getHeight());
-
- zoneRect.removeFromTop (20);
-
- g.setColour (Colours::white);
- g.drawRect (zoneRect, 3);
- g.drawText ("LGCY", zoneRect.reduced (4, 4), Justification::topLeft, false);
- g.drawText ("<>" + String (legacyModePitchbendRange), zoneRect.reduced (4, 4), Justification::bottomLeft, false);
- }
-
- //==============================================================================
- float getChannelRectangleWidth() const noexcept
- {
- return float (getWidth()) / numMidiChannels;
- }
-
- //==============================================================================
- MPEZoneLayout zoneLayout;
- const ZoneColourPicker& colourPicker;
-
- bool legacyModeEnabled = false;
- int legacyModePitchbendRange = 48;
- Range<int> legacyModeChannelRange = { 1, 17 };
- const int numMidiChannels = 16;
- };
|