/* ============================================================================== 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. ============================================================================== */ #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::grey); 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 { g.fillAll (Colours::white); } void resized() override { auto 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 demo ("20 Graphics: Image formats");