| 
							- /*
 -   ==============================================================================
 - 
 -    This file is part of the JUCE library - "Jules' Utility Class Extensions"
 -    Copyright 2004-11 by Raw Material Software Ltd.
 - 
 -   ------------------------------------------------------------------------------
 - 
 -    JUCE can be redistributed and/or modified under the terms of the GNU General
 -    Public License (Version 2), as published by the Free Software Foundation.
 -    A copy of the license is included in the JUCE distribution, or can be found
 -    online 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.rawmaterialsoftware.com/juce for more information.
 - 
 -   ==============================================================================
 - */
 - 
 - #include "jucer_Application.h"
 - #include "jucer_AppearanceSettings.h"
 - 
 - namespace AppearanceColours
 - {
 -     struct ColourInfo
 -     {
 -         const char* name;
 -         uint32 colourID;
 -         bool mustBeOpaque;
 -         bool applyToEditorOnly;
 -     };
 - 
 -     static const ColourInfo colours[] =
 -     {
 -         { "Main Window Bkgd",   mainBackgroundColourId, true, false },
 -         { "Treeview Highlight", treeviewHighlightColourId, false, false },
 - 
 -         { "Code Background",    CodeEditorComponent::backgroundColourId, true, false },
 -         { "Line Number Bkgd",   CodeEditorComponent::lineNumberBackgroundId, false, false },
 -         { "Line Numbers",       CodeEditorComponent::lineNumberTextId, false, false },
 -         { "Plain Text",         CodeEditorComponent::defaultTextColourId, false, false },
 -         { "Selected Text Bkgd", CodeEditorComponent::highlightColourId, false, false },
 -         { "Caret",              CaretComponent::caretColourId, false, true }
 -     };
 - }
 - 
 - //==============================================================================
 - AppearanceSettings::AppearanceSettings (bool updateAppWhenChanged)
 -     : settings ("COLOUR_SCHEME")
 - {
 -     IntrojucerLookAndFeel lf;
 - 
 -     for (int i = 0; i < sizeof (AppearanceColours::colours) / sizeof (AppearanceColours::colours[0]); ++i)
 -         getColourValue (AppearanceColours::colours[i].name) = lf.findColour (AppearanceColours::colours[i].colourID).toString();
 - 
 -     CodeDocument doc;
 -     CPlusPlusCodeTokeniser tokeniser;
 -     CodeEditorComponent editor (doc, &tokeniser);
 - 
 -     const CodeEditorComponent::ColourScheme cs (editor.getColourScheme());
 - 
 -     for (int i = cs.types.size(); --i >= 0;)
 -     {
 -         CodeEditorComponent::ColourScheme::TokenType& t = cs.types.getReference(i);
 -         getColourValue (t.name) = t.colour.toString();
 -     }
 - 
 -     getCodeFontValue() = getDefaultCodeFont().toString();
 - 
 -     if (updateAppWhenChanged)
 -         settings.addListener (this);
 - }
 - 
 - File AppearanceSettings::getSchemesFolder()
 - {
 -     File f (getGlobalProperties().getFile().getSiblingFile ("Schemes"));
 -     f.createDirectory();
 -     return f;
 - }
 - 
 - void AppearanceSettings::writeDefaultSchemeFile (const String& xmlString, const String& name)
 - {
 -     const File file (getSchemesFolder().getChildFile (name).withFileExtension (getSchemeFileSuffix()));
 - 
 -     AppearanceSettings settings (false);
 - 
 -     ScopedPointer<XmlElement> xml (XmlDocument::parse (xmlString));
 -     if (xml != nullptr)
 -         settings.readFromXML (*xml);
 - 
 -     settings.writeToFile (file);
 - }
 - 
 - void AppearanceSettings::refreshPresetSchemeList()
 - {
 -     writeDefaultSchemeFile (BinaryData::colourscheme_dark_xml,  "Default (Dark)");
 -     writeDefaultSchemeFile (BinaryData::colourscheme_light_xml, "Default (Light)");
 - 
 -     Array<File> newSchemes;
 -     getSchemesFolder().findChildFiles (newSchemes, File::findFiles, false, String ("*") + getSchemeFileSuffix());
 - 
 -     if (newSchemes != presetSchemeFiles)
 -     {
 -         presetSchemeFiles.swapWithArray (newSchemes);
 -         commandManager->commandStatusChanged();
 -     }
 - }
 - 
 - StringArray AppearanceSettings::getPresetSchemes()
 - {
 -     StringArray s;
 -     for (int i = 0; i < presetSchemeFiles.size(); ++i)
 -         s.add (presetSchemeFiles.getReference(i).getFileNameWithoutExtension());
 - 
 -     return s;
 - }
 - 
 - void AppearanceSettings::selectPresetScheme (int index)
 - {
 -     readFromFile (presetSchemeFiles [index]);
 - }
 - 
 - bool AppearanceSettings::readFromXML (const XmlElement& xml)
 - {
 -     if (xml.hasTagName (settings.getType().toString()))
 -     {
 -         const ValueTree newSettings (ValueTree::fromXml (xml));
 - 
 -         // we'll manually copy across the new properties to the existing tree so that
 -         // any open editors will be kept up to date..
 -         settings.copyPropertiesFrom (newSettings, nullptr);
 - 
 -         for (int i = settings.getNumChildren(); --i >= 0;)
 -         {
 -             ValueTree c (settings.getChild (i));
 - 
 -             const ValueTree newValue (newSettings.getChildWithProperty (Ids::name, c.getProperty (Ids::name)));
 - 
 -             if (newValue.isValid())
 -                 c.copyPropertiesFrom (newValue, nullptr);
 -         }
 - 
 -         return true;
 -     }
 - 
 -     return false;
 - }
 - 
 - bool AppearanceSettings::readFromFile (const File& file)
 - {
 -     const ScopedPointer<XmlElement> xml (XmlDocument::parse (file));
 -     return xml != nullptr && readFromXML (*xml);
 - }
 - 
 - bool AppearanceSettings::writeToFile (const File& file) const
 - {
 -     const ScopedPointer<XmlElement> xml (settings.createXml());
 -     return xml != nullptr && xml->writeToFile (file, String::empty);
 - }
 - 
 - Font AppearanceSettings::getDefaultCodeFont()
 - {
 -     return Font (Font::getDefaultMonospacedFontName(), Font::getDefaultStyle(), 13.0f);
 - }
 - 
 - StringArray AppearanceSettings::getColourNames() const
 - {
 -     StringArray s;
 - 
 -     for (int i = 0; i < settings.getNumChildren(); ++i)
 -     {
 -         const ValueTree c (settings.getChild(i));
 - 
 -         if (c.hasType ("COLOUR"))
 -             s.add (c [Ids::name]);
 -     }
 - 
 -     return s;
 - }
 - 
 - void AppearanceSettings::updateColourScheme()
 - {
 -     applyToLookAndFeel (LookAndFeel::getDefaultLookAndFeel());
 -     JucerApplication::getApp().mainWindowList.sendLookAndFeelChange();
 - }
 - 
 - void AppearanceSettings::applyToLookAndFeel (LookAndFeel& lf) const
 - {
 -     for (int i = 0; i < sizeof (AppearanceColours::colours) / sizeof (AppearanceColours::colours[0]); ++i)
 -     {
 -         Colour col;
 -         if (getColour (AppearanceColours::colours[i].name, col))
 -         {
 -             if (AppearanceColours::colours[i].mustBeOpaque)
 -                 col = Colours::white.overlaidWith (col);
 - 
 -             if (! AppearanceColours::colours[i].applyToEditorOnly)
 -                 lf.setColour (AppearanceColours::colours[i].colourID, col);
 -         }
 -     }
 - 
 -     lf.setColour (ScrollBar::thumbColourId,
 -                   getScrollbarColourForBackground (lf.findColour (mainBackgroundColourId)));
 - }
 - 
 - void AppearanceSettings::applyToCodeEditor (CodeEditorComponent& editor) const
 - {
 -     CodeEditorComponent::ColourScheme cs (editor.getColourScheme());
 - 
 -     for (int i = cs.types.size(); --i >= 0;)
 -     {
 -         CodeEditorComponent::ColourScheme::TokenType& t = cs.types.getReference(i);
 -         getColour (t.name, t.colour);
 -     }
 - 
 -     editor.setColourScheme (cs);
 -     editor.setFont (getCodeFont());
 - 
 -     for (int i = 0; i < sizeof (AppearanceColours::colours) / sizeof (AppearanceColours::colours[0]); ++i)
 -     {
 -         if (AppearanceColours::colours[i].applyToEditorOnly)
 -         {
 -             Colour col;
 -             if (getColour (AppearanceColours::colours[i].name, col))
 -                 editor.setColour (AppearanceColours::colours[i].colourID, col);
 -         }
 -     }
 - 
 -     editor.setColour (ScrollBar::thumbColourId,
 -                       getScrollbarColourForBackground (editor.findColour (CodeEditorComponent::backgroundColourId)));
 - }
 - 
 - Font AppearanceSettings::getCodeFont() const
 - {
 -     const String fontString (settings [Ids::font].toString());
 - 
 -     if (fontString.isEmpty())
 -         return getDefaultCodeFont();
 - 
 -     return Font::fromString (fontString);
 - }
 - 
 - Value AppearanceSettings::getCodeFontValue()
 - {
 -     return settings.getPropertyAsValue (Ids::font, nullptr);
 - }
 - 
 - Value AppearanceSettings::getColourValue (const String& colourName)
 - {
 -     ValueTree c (settings.getChildWithProperty (Ids::name, colourName));
 - 
 -     if (! c.isValid())
 -     {
 -         c = ValueTree ("COLOUR");
 -         c.setProperty (Ids::name, colourName, nullptr);
 -         settings.addChild (c, -1, nullptr);
 -     }
 - 
 -     return c.getPropertyAsValue (Ids::colour, nullptr);
 - }
 - 
 - bool AppearanceSettings::getColour (const String& name, Colour& result) const
 - {
 -     const ValueTree colour (settings.getChildWithProperty (Ids::name, name));
 - 
 -     if (colour.isValid())
 -     {
 -         result = Colour::fromString (colour [Ids::colour].toString());
 -         return true;
 -     }
 - 
 -     return false;
 - }
 - 
 - Colour AppearanceSettings::getScrollbarColourForBackground (const Colour& background)
 - {
 -     return background.contrasting().withAlpha (0.13f);
 - }
 - 
 - //==============================================================================
 - struct AppearanceEditor
 - {
 -     class FontScanPanel   : public Component,
 -                             private Timer
 -     {
 -     public:
 -         FontScanPanel()
 -         {
 -             fontsToScan = Font::findAllTypefaceNames();
 -             startTimer (1);
 -         }
 - 
 -         void paint (Graphics& g)
 -         {
 -             g.fillAll (Colours::darkgrey);
 - 
 -             g.setFont (14.0f);
 -             g.setColour (Colours::white);
 -             g.drawFittedText ("Scanning for fonts..", getLocalBounds(), Justification::centred, 2);
 - 
 -             const int size = 30;
 -             getLookAndFeel().drawSpinningWaitAnimation (g, Colours::white, (getWidth() - size) / 2, getHeight() / 2 - 50, size, size);
 -         }
 - 
 -         void timerCallback()
 -         {
 -             repaint();
 - 
 -             if (fontsToScan.size() == 0)
 -             {
 -                 getAppSettings().monospacedFontNames = fontsFound;
 -                 DialogWindow* w = findParentComponentOfClass<DialogWindow>();
 - 
 -                 if (w != nullptr)
 -                     w->setContentOwned (new EditorPanel(), false);
 -             }
 -             else
 -             {
 -                 if (isMonospacedTypeface (fontsToScan[0]))
 -                     fontsFound.add (fontsToScan[0]);
 - 
 -                 fontsToScan.remove (0);
 -             }
 -         }
 - 
 -         // A rather hacky trick to select only the fixed-pitch fonts..
 -         // This is unfortunately a bit slow, but will work on all platforms.
 -         static bool isMonospacedTypeface (const String& name)
 -         {
 -             const Font font (name, 20.0f, Font::plain);
 - 
 -             const int width = font.getStringWidth ("....");
 - 
 -             return width == font.getStringWidth ("WWWW")
 -                 && width == font.getStringWidth ("0000")
 -                 && width == font.getStringWidth ("1111")
 -                 && width == font.getStringWidth ("iiii");
 -         }
 - 
 -         StringArray fontsToScan, fontsFound;
 -     };
 - 
 -     //==============================================================================
 -     class EditorPanel  : public Component,
 -                          private Button::Listener
 -     {
 -     public:
 -         EditorPanel()
 -             : loadButton ("Load Scheme..."),
 -               saveButton ("Save Scheme...")
 -         {
 -             rebuildProperties();
 -             addAndMakeVisible (&panel);
 - 
 -             loadButton.setColour (TextButton::buttonColourId, Colours::darkgrey.withAlpha (0.5f));
 -             saveButton.setColour (TextButton::buttonColourId, Colours::darkgrey.withAlpha (0.5f));
 -             loadButton.setColour (TextButton::textColourOffId, Colours::white);
 -             saveButton.setColour (TextButton::textColourOffId, Colours::white);
 - 
 -             addAndMakeVisible (&loadButton);
 -             addAndMakeVisible (&saveButton);
 - 
 -             loadButton.addListener (this);
 -             saveButton.addListener (this);
 -         }
 - 
 -         void rebuildProperties()
 -         {
 -             AppearanceSettings& scheme = getAppSettings().appearance;
 - 
 -             Array <PropertyComponent*> props;
 -             Value fontValue (scheme.getCodeFontValue());
 -             props.add (FontNameValueSource::createProperty  ("Code Editor Font", fontValue));
 -             props.add (FontSizeValueSource::createProperty  ("Font Size", fontValue));
 - 
 -             const StringArray colourNames (scheme.getColourNames());
 - 
 -             for (int i = 0; i < colourNames.size(); ++i)
 -                 props.add (new ColourPropertyComponent (nullptr, colourNames[i],
 -                                                         scheme.getColourValue (colourNames[i]),
 -                                                         Colours::white, false));
 - 
 -             panel.clear();
 -             panel.addProperties (props);
 -         }
 - 
 -         void resized()
 -         {
 -             Rectangle<int> r (getLocalBounds());
 -             panel.setBounds (r.removeFromTop (getHeight() - 28).reduced (4, 2));
 -             loadButton.setBounds (r.removeFromLeft (getWidth() / 2).reduced (10, 4));
 -             saveButton.setBounds (r.reduced (10, 3));
 -         }
 - 
 -     private:
 -         PropertyPanel panel;
 -         TextButton loadButton, saveButton;
 - 
 -         void buttonClicked (Button* b)
 -         {
 -             if (b == &loadButton)
 -                 loadScheme();
 -             else
 -                 saveScheme();
 -         }
 - 
 -         void saveScheme()
 -         {
 -             FileChooser fc ("Select a file in which to save this colour-scheme...",
 -                             getAppSettings().appearance.getSchemesFolder()
 -                                 .getNonexistentChildFile ("Scheme", AppearanceSettings::getSchemeFileSuffix()),
 -                             AppearanceSettings::getSchemeFileWildCard());
 - 
 -             if (fc.browseForFileToSave (true))
 -             {
 -                 File file (fc.getResult().withFileExtension (AppearanceSettings::getSchemeFileSuffix()));
 -                 getAppSettings().appearance.writeToFile (file);
 -                 getAppSettings().appearance.refreshPresetSchemeList();
 -             }
 -         }
 - 
 -         void loadScheme()
 -         {
 -             FileChooser fc ("Please select a colour-scheme file to load...",
 -                             getAppSettings().appearance.getSchemesFolder(),
 -                             AppearanceSettings::getSchemeFileWildCard());
 - 
 -             if (fc.browseForFileToOpen())
 -             {
 -                 if (getAppSettings().appearance.readFromFile (fc.getResult()))
 -                     rebuildProperties();
 -             }
 -         }
 - 
 -         JUCE_DECLARE_NON_COPYABLE (EditorPanel);
 -     };
 - 
 -     //==============================================================================
 -     class FontNameValueSource   : public ValueSourceFilter
 -     {
 -     public:
 -         FontNameValueSource (const Value& source)  : ValueSourceFilter (source) {}
 - 
 -         var getValue() const
 -         {
 -             return Font::fromString (sourceValue.toString()).getTypefaceName();
 -         }
 - 
 -         void setValue (const var& newValue)
 -         {
 -             Font font (Font::fromString (sourceValue.toString()));
 -             font.setTypefaceName (newValue.toString().isEmpty() ? Font::getDefaultMonospacedFontName()
 -                                                                 : newValue.toString());
 -             sourceValue = font.toString();
 -         }
 - 
 -         static ChoicePropertyComponent* createProperty (const String& title, const Value& value)
 -         {
 -             StringArray fontNames = getAppSettings().monospacedFontNames;
 - 
 -             Array<var> values;
 -             values.add (Font::getDefaultMonospacedFontName());
 -             values.add (var());
 - 
 -             for (int i = 0; i < fontNames.size(); ++i)
 -                 values.add (fontNames[i]);
 - 
 -             StringArray names;
 -             names.add ("<Default Monospaced>");
 -             names.add (String::empty);
 -             names.addArray (getAppSettings().monospacedFontNames);
 - 
 -             return new ChoicePropertyComponent (Value (new FontNameValueSource (value)),
 -                                                 title, names, values);
 -         }
 -     };
 - 
 -     //==============================================================================
 -     class FontSizeValueSource   : public ValueSourceFilter
 -     {
 -     public:
 -         FontSizeValueSource (const Value& source)  : ValueSourceFilter (source) {}
 - 
 -         var getValue() const
 -         {
 -             return Font::fromString (sourceValue.toString()).getHeight();
 -         }
 - 
 -         void setValue (const var& newValue)
 -         {
 -             sourceValue = Font::fromString (sourceValue.toString()).withHeight (newValue).toString();
 -         }
 - 
 -         static PropertyComponent* createProperty (const String& title, const Value& value)
 -         {
 -             return new SliderPropertyComponent (Value (new FontSizeValueSource (value)),
 -                                                 title, 5.0, 40.0, 0.1, 0.5);
 -         }
 -     };
 - };
 - 
 - void AppearanceSettings::showEditorWindow (ScopedPointer<Component>& ownerPointer)
 - {
 -     if (ownerPointer != nullptr)
 -     {
 -         ownerPointer->toFront (true);
 -     }
 -     else
 -     {
 -         Component* content;
 -         if (getAppSettings().monospacedFontNames.size() == 0)
 -             content = new AppearanceEditor::FontScanPanel();
 -         else
 -             content = new AppearanceEditor::EditorPanel();
 - 
 -         const int width = 350;
 -         new FloatingToolWindow ("Appearance Settings",
 -                                 "colourSchemeEditorPos",
 -                                 content, ownerPointer,
 -                                 width, 500,
 -                                 width, 200, width, 1000);
 -     }
 - }
 - 
 - //==============================================================================
 - IntrojucerLookAndFeel::IntrojucerLookAndFeel()
 - {
 -     setColour (mainBackgroundColourId, Colour::greyLevel (0.8f));
 -     setColour (treeviewHighlightColourId, Colour (0x401111ee));
 - }
 - 
 - Rectangle<int> IntrojucerLookAndFeel::getPropertyComponentContentPosition (PropertyComponent& component)
 - {
 -     if (component.findParentComponentOfClass<AppearanceEditor::EditorPanel>() != nullptr)
 -         return component.getLocalBounds().reduced (1).removeFromRight (component.getWidth() / 2);
 - 
 -     return LookAndFeel::getPropertyComponentContentPosition (component);
 - }
 - 
 - int IntrojucerLookAndFeel::getTabButtonOverlap (int tabDepth)                          { return -1; }
 - int IntrojucerLookAndFeel::getTabButtonSpaceAroundImage()                              { return 1; }
 - int IntrojucerLookAndFeel::getTabButtonBestWidth (TabBarButton& button, int tabDepth)  { return 120; }
 - 
 - void IntrojucerLookAndFeel::createTabTextLayout (const TabBarButton& button, const Rectangle<int>& textArea, GlyphArrangement& textLayout)
 - {
 -     Font font (textArea.getHeight() * 0.5f);
 -     font.setUnderline (button.hasKeyboardFocus (false));
 - 
 -     textLayout.addFittedText (font, button.getButtonText().trim(),
 -                               (float) textArea.getX(), (float) textArea.getY(), (float) textArea.getWidth(), (float) textArea.getHeight(),
 -                               Justification::centred, 1);
 - }
 - 
 - Colour IntrojucerLookAndFeel::getTabBackgroundColour (TabBarButton& button)
 - {
 -     const Colour normalBkg (button.findColour (mainBackgroundColourId));
 -     Colour bkg (normalBkg.contrasting (0.15f));
 -     if (button.isFrontTab())
 -         bkg = bkg.overlaidWith (Colours::yellow.withAlpha (0.5f));
 - 
 -     return bkg;
 - }
 - 
 - void IntrojucerLookAndFeel::drawTabButton (TabBarButton& button, Graphics& g, bool isMouseOver, bool isMouseDown)
 - {
 -     const Rectangle<int> activeArea (button.getActiveArea());
 - 
 -     const Colour bkg (getTabBackgroundColour (button));
 - 
 -     g.setGradientFill (ColourGradient (bkg.brighter (0.1f), 0, (float) activeArea.getY(),
 -                                        bkg.darker (0.1f), 0, (float) activeArea.getBottom(), false));
 -     g.fillRect (activeArea);
 - 
 -     g.setColour (button.findColour (mainBackgroundColourId).darker (0.3f));
 -     g.drawRect (activeArea);
 - 
 -     GlyphArrangement textLayout;
 -     createTabTextLayout (button, button.getTextArea(), textLayout);
 - 
 -     const float alpha = button.isEnabled() ? ((isMouseOver || isMouseDown) ? 1.0f : 0.8f) : 0.3f;
 -     g.setColour (bkg.contrasting().withMultipliedAlpha (alpha));
 -     textLayout.draw (g);
 - }
 - 
 - Rectangle<int> IntrojucerLookAndFeel::getTabButtonExtraComponentBounds (const TabBarButton& button, Rectangle<int>& textArea, Component& comp)
 - {
 -     GlyphArrangement textLayout;
 -     createTabTextLayout (button, textArea, textLayout);
 -     const int textWidth = (int) textLayout.getBoundingBox (0, -1, false).getWidth();
 -     const int extraSpace = jmax (0, textArea.getWidth() - (textWidth + comp.getWidth())) / 2;
 - 
 -     textArea.removeFromRight (extraSpace);
 -     textArea.removeFromLeft (extraSpace);
 -     return textArea.removeFromRight (comp.getWidth());
 - }
 - 
 - void IntrojucerLookAndFeel::drawStretchableLayoutResizerBar (Graphics& g, int /*w*/, int /*h*/, bool /*isVerticalBar*/, bool isMouseOver, bool isMouseDragging)
 - {
 -     if (isMouseOver || isMouseDragging)
 -         g.fillAll (Colours::yellow.withAlpha (0.4f));
 - }
 - 
 - void IntrojucerLookAndFeel::drawScrollbar (Graphics& g, ScrollBar& scrollbar, int x, int y, int width, int height,
 -                                            bool isScrollbarVertical, int thumbStartPosition, int thumbSize,
 -                                            bool isMouseOver, bool isMouseDown)
 - {
 -     Path thumbPath;
 - 
 -     if (thumbSize > 0)
 -     {
 -         const float thumbIndent = (isScrollbarVertical ? width : height) * 0.25f;
 -         const float thumbIndentx2 = thumbIndent * 2.0f;
 - 
 -         if (isScrollbarVertical)
 -             thumbPath.addRoundedRectangle (x + thumbIndent, thumbStartPosition + thumbIndent,
 -                                            width - thumbIndentx2, thumbSize - thumbIndentx2, (width - thumbIndentx2) * 0.5f);
 -         else
 -             thumbPath.addRoundedRectangle (thumbStartPosition + thumbIndent, y + thumbIndent,
 -                                            thumbSize - thumbIndentx2, height - thumbIndentx2, (height - thumbIndentx2) * 0.5f);
 -     }
 - 
 -     Colour thumbCol (scrollbar.findColour (ScrollBar::thumbColourId, true));
 - 
 -     if (isMouseOver || isMouseDown)
 -         thumbCol = thumbCol.withMultipliedAlpha (2.0f);
 - 
 -     g.setColour (thumbCol);
 -     g.fillPath (thumbPath);
 - 
 -     g.setColour (thumbCol.contrasting ((isMouseOver  || isMouseDown) ? 0.2f : 0.1f));
 -     g.strokePath (thumbPath, PathStrokeType (1.0f));
 - }
 - 
 - static Range<float> getBrightnessRange (const Image& im)
 - {
 -     float minB = 1.0f, maxB = 0;
 -     const int w = im.getWidth();
 -     const int h = im.getHeight();
 - 
 -     for (int y = 0; y < h; ++y)
 -     {
 -         for (int x = 0; x < w; ++x)
 -         {
 -             const float b = im.getPixelAt (x, y).getBrightness();
 -             minB = jmin (minB, b);
 -             maxB = jmax (maxB, b);
 -         }
 -     }
 - 
 -     return Range<float> (minB, maxB);
 - }
 - 
 - void IntrojucerLookAndFeel::fillWithBackgroundTexture (Graphics& g)
 - {
 -     const Colour bkg (findColour (mainBackgroundColourId));
 - 
 -     if (backgroundTextureBaseColour != bkg)
 -     {
 -         backgroundTextureBaseColour = bkg;
 - 
 -         const Image original (ImageCache::getFromMemory (BinaryData::background_tile_png,
 -                                                          BinaryData::background_tile_pngSize));
 -         const int w = original.getWidth();
 -         const int h = original.getHeight();
 - 
 -         backgroundTexture = Image (Image::RGB, w, h, false);
 - 
 -         const Range<float> brightnessRange (getBrightnessRange (original));
 -         const float brightnessOffset = (brightnessRange.getStart() + brightnessRange.getEnd()) / 2.0f;
 -         const float brightnessScale = 0.025f / brightnessRange.getLength();
 -         const float bkgB = bkg.getBrightness();
 - 
 -         for (int y = 0; y < h; ++y)
 -         {
 -             for (int x = 0; x < w; ++x)
 -             {
 -                 const float b = (original.getPixelAt (x, y).getBrightness() - brightnessOffset) * brightnessScale;
 -                 backgroundTexture.setPixelAt (x, y, bkg.withBrightness (jlimit (0.0f, 1.0f, bkgB + b)));
 -             }
 -         }
 -     }
 - 
 -     g.setTiledImageFill (backgroundTexture, 0, 0, 1.0f);
 -     g.fillAll();
 - }
 - 
 - void IntrojucerLookAndFeel::fillWithBackgroundTexture (Component& c, Graphics& g)
 - {
 -     dynamic_cast<IntrojucerLookAndFeel&> (c.getLookAndFeel()).fillWithBackgroundTexture (g);
 - }
 - 
 - void IntrojucerLookAndFeel::drawConcertinaPanelHeader (Graphics& g, const Rectangle<int>& area,
 -                                                        bool isMouseOver, bool isMouseDown,
 -                                                        ConcertinaPanel& concertina, Component& panel)
 - {
 -     const Colour bkg (findColour (mainBackgroundColourId));
 - 
 -     g.setGradientFill (ColourGradient (Colours::white.withAlpha (isMouseOver ? 0.4f : 0.2f), 0, area.getY(),
 -                                        Colours::darkgrey.withAlpha (0.2f), 0, area.getBottom(), false));
 - 
 -     g.fillAll();
 -     g.setColour (bkg.contrasting().withAlpha (0.04f));
 -     g.fillRect (area.withHeight (1));
 -     g.fillRect (area.withTop (area.getBottom() - 1));
 - 
 -     g.setColour (bkg.contrasting());
 -     g.setFont (Font (area.getHeight() * 0.6f).boldened());
 -     g.drawFittedText (panel.getName(), 4, 0, area.getWidth() - 6, area.getHeight(), Justification::centredLeft, 1);
 - }
 
 
  |