| 
							- /*
 -   ==============================================================================
 - 
 -    This file is part of the JUCE library.
 -    Copyright (c) 2015 - ROLI 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 "../JuceDemoHeader.h"
 - 
 - //==============================================================================
 - class ImagesDemo  : public Component,
 -                     public FileBrowserListener
 - {
 - public:
 -     ImagesDemo()
 -         : imagesWildcardFilter ("*.jpeg;*.jpg;*.png;*.gif", "*", "Image File Filter"),
 -           directoryThread ("Image File Scanner Thread"),
 -           imageList (&imagesWildcardFilter, directoryThread),
 -           fileTree (imageList),
 -           resizerBar (&stretchableManager, 1, false)
 -     {
 -         setOpaque (true);
 -         imageList.setDirectory (File::getSpecialLocation (File::userPicturesDirectory), true, true);
 -         directoryThread.startThread (1);
 - 
 -         fileTree.addListener (this);
 -         fileTree.setColour (TreeView::backgroundColourId, Colours::lightgrey.withAlpha (0.6f));
 -         addAndMakeVisible (fileTree);
 - 
 -         addAndMakeVisible (resizerBar);
 - 
 -         addAndMakeVisible (imagePreview);
 - 
 -         // we have to set up our StretchableLayoutManager so it know the limits and preferred sizes of it's contents
 -         stretchableManager.setItemLayout (0,            // for the fileTree
 -                                           -0.1, -0.9,   // must be between 50 pixels and 90% of the available space
 -                                           -0.3);        // and its preferred size is 30% of the total available space
 - 
 -         stretchableManager.setItemLayout (1,            // for the resize bar
 -                                           5, 5, 5);     // hard limit to 5 pixels
 - 
 -         stretchableManager.setItemLayout (2,            // for the imagePreview
 -                                           -0.1, -0.9,   // size must be between 50 pixels and 90% of the available space
 -                                           -0.7);        // and its preferred size is 70% of the total available space
 -     }
 - 
 -     ~ImagesDemo()
 -     {
 -         fileTree.removeListener (this);
 -     }
 - 
 -     void paint (Graphics& g) override
 -     {
 -         fillStandardDemoBackground (g);
 -     }
 - 
 -     void resized() override
 -     {
 -         Rectangle<int> r (getLocalBounds().reduced (4));
 - 
 -         // make a list of two of our child components that we want to reposition
 -         Component* comps[] = { &fileTree, &resizerBar, &imagePreview };
 - 
 -         // this will position the 3 components, one above the other, to fit
 -         // vertically into the rectangle provided.
 -         stretchableManager.layOutComponents (comps, 3,
 -                                              r.getX(), r.getY(), r.getWidth(), r.getHeight(),
 -                                              true, true);
 -     }
 - 
 - private:
 -     WildcardFileFilter imagesWildcardFilter;
 -     TimeSliceThread directoryThread;
 -     DirectoryContentsList imageList;
 -     FileTreeComponent fileTree;
 - 
 -     ImageComponent imagePreview;
 - 
 -     StretchableLayoutManager stretchableManager;
 -     StretchableLayoutResizerBar resizerBar;
 - 
 -     void selectionChanged() override
 -     {
 -         // we're only really interested in when the selection changes, regardless of if it was
 -         // clicked or not so we'll only override this method
 -         const File selectedFile (fileTree.getSelectedFile());
 - 
 -         if (selectedFile.existsAsFile())
 -             imagePreview.setImage (ImageCache::getFromFile (selectedFile));
 - 
 -         // the image cahce is a handly way to load images from files or directly from memory and
 -         // will keep them hanging around for a few seconds in case they are requested elsewhere
 -     }
 - 
 -     void fileClicked (const File&, const MouseEvent&) override {}
 -     void fileDoubleClicked (const File&) override {}
 -     void browserRootChanged (const File&) override {}
 - 
 -     JUCE_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR (ImagesDemo)
 - };
 - 
 - 
 - // This static object will register this demo type in a global list of demos..
 - static JuceDemoType<ImagesDemo> demo ("20 Graphics: Image formats");
 
 
  |