123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151 |
- /*
- ==============================================================================
- 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.
- ==============================================================================
- */
- //==============================================================================
- static Typeface::Ptr getTypefaceForFontFromLookAndFeel (const Font& font)
- {
- return LookAndFeel::getDefaultLookAndFeel().getTypefaceForFont (font);
- }
- typedef Typeface::Ptr (*GetTypefaceForFont) (const Font&);
- extern GetTypefaceForFont juce_getTypefaceForFont;
- //==============================================================================
- LookAndFeel::LookAndFeel()
- : useNativeAlertWindows (false)
- {
- /* if this fails it means you're trying to create a LookAndFeel object before
- the static Colours have been initialised. That ain't gonna work. It probably
- means that you're using a static LookAndFeel object and that your compiler has
- decided to intialise it before the Colours class.
- */
- jassert (Colours::white == Colour (0xffffffff));
- juce_getTypefaceForFont = getTypefaceForFontFromLookAndFeel;
- }
- LookAndFeel::~LookAndFeel()
- {
- masterReference.clear();
- }
- //==============================================================================
- Colour LookAndFeel::findColour (int colourID) const noexcept
- {
- const ColourSetting c = { colourID, Colour() };
- const int index = colours.indexOf (c);
- if (index >= 0)
- return colours.getReference (index).colour;
- jassertfalse;
- return Colours::black;
- }
- void LookAndFeel::setColour (int colourID, Colour newColour) noexcept
- {
- const ColourSetting c = { colourID, newColour };
- const int index = colours.indexOf (c);
- if (index >= 0)
- colours.getReference (index).colour = newColour;
- else
- colours.add (c);
- }
- bool LookAndFeel::isColourSpecified (const int colourID) const noexcept
- {
- const ColourSetting c = { colourID, Colour() };
- return colours.contains (c);
- }
- //==============================================================================
- LookAndFeel& LookAndFeel::getDefaultLookAndFeel() noexcept
- {
- return Desktop::getInstance().getDefaultLookAndFeel();
- }
- void LookAndFeel::setDefaultLookAndFeel (LookAndFeel* newDefaultLookAndFeel) noexcept
- {
- Desktop::getInstance().setDefaultLookAndFeel (newDefaultLookAndFeel);
- }
- //==============================================================================
- Typeface::Ptr LookAndFeel::getTypefaceForFont (const Font& font)
- {
- if (defaultSans.isNotEmpty() && font.getTypefaceName() == Font::getDefaultSansSerifFontName())
- {
- Font f (font);
- f.setTypefaceName (defaultSans);
- return Typeface::createSystemTypefaceFor (f);
- }
- return Font::getDefaultTypefaceForFont (font);
- }
- void LookAndFeel::setDefaultSansSerifTypefaceName (const String& newName)
- {
- if (defaultSans != newName)
- {
- Typeface::clearTypefaceCache();
- defaultSans = newName;
- }
- }
- //==============================================================================
- MouseCursor LookAndFeel::getMouseCursorFor (Component& component)
- {
- MouseCursor m (component.getMouseCursor());
- Component* parent = component.getParentComponent();
- while (parent != nullptr && m == MouseCursor::ParentCursor)
- {
- m = parent->getMouseCursor();
- parent = parent->getParentComponent();
- }
- return m;
- }
- LowLevelGraphicsContext* LookAndFeel::createGraphicsContext (const Image& imageToRenderOn, const Point<int>& origin,
- const RectangleList<int>& initialClip)
- {
- return new LowLevelGraphicsSoftwareRenderer (imageToRenderOn, origin, initialClip);
- }
- //==============================================================================
- void LookAndFeel::setUsingNativeAlertWindows (bool shouldUseNativeAlerts)
- {
- useNativeAlertWindows = shouldUseNativeAlerts;
- }
- bool LookAndFeel::isUsingNativeAlertWindows()
- {
- #if JUCE_LINUX
- return false; // not available currently..
- #else
- return useNativeAlertWindows;
- #endif
- }
|