/* NSColor.h The colorful color class Copyright (C) 1996, 1998 Free Software Foundation, Inc. Author: Scott Christley Date: 1996 This file is part of the GNUstep GUI Library. This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This library 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 Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with this library; see the file COPYING.LIB. If not, see or write to the Free Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #ifndef _GNUstep_H_NSColor #define _GNUstep_H_NSColor #import #include #include @class NSString; @class NSDictionary; @class NSPasteboard; @class NSImage; @class NSColorSpace; typedef enum _NSControlTint { NSDefaultControlTint, NSBlueControlTint, NSGraphiteControlTint = 6, NSClearControlTint } NSControlTint; typedef enum _NSControlSize { NSRegularControlSize, NSSmallControlSize, NSMiniControlSize } NSControlSize; /* * NSColor is an abstract super class of the class cluster of the real colour classes. * For each colour space exists a specific subclass that implements the behaviour for * this colour space. * The colour spaces NSDeviceBlackColorSpace and NSCalibratedBlackColorSpace * are no longer supported by this class. They were not in the old OpenStep * specification, and are not used in the new Apple specification. The names are * used as synonyms to NSDeviceWhiteColorSpace and NSCalibratedWhiteColorSpace. */ @interface NSColor : NSObject { } // // Creating an NSColor from Component Values // + (NSColor *)colorWithCalibratedHue:(float)hue saturation:(float)saturation brightness:(float)brightness alpha:(float)alpha; + (NSColor *)colorWithCalibratedRed:(float)red green:(float)green blue:(float)blue alpha:(float)alpha; + (NSColor *)colorWithCalibratedWhite:(float)white alpha:(float)alpha; + (NSColor *)colorWithCatalogName:(NSString *)listName colorName:(NSString *)colorName; + (NSColor *)colorWithDeviceCyan:(float)cyan magenta:(float)magenta yellow:(float)yellow black:(float)black alpha:(float)alpha; + (NSColor *)colorWithDeviceHue:(float)hue saturation:(float)saturation brightness:(float)brightness alpha:(float)alpha; + (NSColor *)colorWithDeviceRed:(float)red green:(float)green blue:(float)blue alpha:(float)alpha; + (NSColor *)colorWithDeviceWhite:(float)white alpha:(float)alpha; // // Creating an NSColor With Preset Components // + (NSColor *)blackColor; + (NSColor *)blueColor; + (NSColor *)brownColor; + (NSColor *)clearColor; + (NSColor *)cyanColor; + (NSColor *)darkGrayColor; + (NSColor *)grayColor; + (NSColor *)greenColor; + (NSColor *)lightGrayColor; + (NSColor *)magentaColor; + (NSColor *)orangeColor; + (NSColor *)purpleColor; + (NSColor *)redColor; + (NSColor *)whiteColor; + (NSColor *)yellowColor; // // Ignoring Alpha Components // + (BOOL)ignoresAlpha; + (void)setIgnoresAlpha:(BOOL)flag; // // Retrieving a Set of Components // - (void)getCyan:(float *)cyan magenta:(float *)magenta yellow:(float *)yellow black:(float *)black alpha:(float *)alpha; - (void)getHue:(float *)hue saturation:(float *)saturation brightness:(float *)brightness alpha:(float *)alpha; - (void)getRed:(float *)red green:(float *)green blue:(float *)blue alpha:(float *)alpha; - (void)getWhite:(float *)white alpha:(float *)alpha; // // Retrieving Individual Components // - (float)alphaComponent; - (float)blackComponent; - (float)blueComponent; - (float)brightnessComponent; - (NSString *)catalogNameComponent; - (NSString *)colorNameComponent; - (float)cyanComponent; - (float)greenComponent; - (float)hueComponent; - (NSString *)localizedCatalogNameComponent; - (NSString *)localizedColorNameComponent; - (float)magentaComponent; - (float)redComponent; - (float)saturationComponent; - (float)whiteComponent; - (float)yellowComponent; // // Converting to Another Color Space // - (NSString *)colorSpaceName; - (NSColor *)colorUsingColorSpaceName:(NSString *)colorSpace; - (NSColor *)colorUsingColorSpaceName:(NSString *)colorSpace device:(NSDictionary *)deviceDescription; #if OS_API_VERSION(MAC_OS_X_VERSION_10_4, GS_API_LATEST) // + (NSColor *)colorWithCIColor:(CIColor *)color; + (NSColor *)colorWithColorSpace:(NSColorSpace *)space components:(const float *)comp count:(int)number; - (NSColorSpace *)colorSpace; - (NSColor *)colorUsingColorSpace:(NSColorSpace *)space; - (void)getComponents:(float *)components; - (int)numberOfComponents; #endif // // Changing the Color // - (NSColor *)blendedColorWithFraction:(float)fraction ofColor:(NSColor *)aColor; - (NSColor *)colorWithAlphaComponent:(float)alpha; // // Copying and Pasting // + (NSColor *)colorFromPasteboard:(NSPasteboard *)pasteBoard; - (void)writeToPasteboard:(NSPasteboard *)pasteBoard; // // Drawing // - (void)drawSwatchInRect:(NSRect)rect; - (void)set; #if OS_API_VERSION(MAC_OS_X_VERSION_10_3, GS_API_LATEST) - (void)setFill; - (void)setStroke; #endif #if OS_API_VERSION(GS_API_MACOSX, GS_API_LATEST) // // Changing the color // - (NSColor*) highlightWithLevel: (float)level; - (NSColor*) shadowWithLevel: (float)level; + (NSColor*)colorWithPatternImage:(NSImage*)image; + (NSColor*)colorForControlTint:(NSControlTint)controlTint; #if OS_API_VERSION(MAC_OS_X_VERSION_10_3, GS_API_LATEST) + (NSControlTint)currentControlTint; #endif // // System colors stuff. // #if OS_API_VERSION(MAC_OS_X_VERSION_10_2, GS_API_LATEST) + (NSColor*) alternateSelectedControlColor; + (NSColor*) alternateSelectedControlTextColor; #endif + (NSColor*) controlBackgroundColor; + (NSColor*) controlColor; + (NSColor*) controlHighlightColor; + (NSColor*) controlLightHighlightColor; + (NSColor*) controlShadowColor; + (NSColor*) controlDarkShadowColor; + (NSColor*) controlTextColor; + (NSColor*) disabledControlTextColor; + (NSColor*) gridColor; + (NSColor*) headerColor; + (NSColor*) headerTextColor; + (NSColor*) highlightColor; + (NSColor*) keyboardFocusIndicatorColor; + (NSColor*) knobColor; + (NSColor*) scrollBarColor; + (NSColor*) secondarySelectedControlColor; + (NSColor*) selectedControlColor; + (NSColor*) selectedControlTextColor; + (NSColor*) selectedKnobColor; + (NSColor*) selectedMenuItemColor; + (NSColor*) selectedMenuItemTextColor; + (NSColor*) selectedTextBackgroundColor; + (NSColor*) selectedTextColor; + (NSColor*) shadowColor; + (NSColor*) textBackgroundColor; + (NSColor*) textColor; + (NSColor*) windowBackgroundColor; + (NSColor*) windowFrameColor; + (NSColor*) windowFrameTextColor; #if OS_API_VERSION(MAC_OS_X_VERSION_10_3, GS_API_LATEST) + (NSArray*) controlAlternatingRowBackgroundColors; #endif // Pattern colour - (NSImage*) patternImage; #endif @end APPKIT_EXPORT NSString *NSSystemColorsDidChangeNotification; #if OS_API_VERSION(GS_API_NONE, GS_API_NONE) @interface NSCoder (NSCoderAdditions) // // Converting an Archived NXColor to an NSColor // - (NSColor *)decodeNXColor; @end #endif #endif // _GNUstep_H_NSColor