libs-gui/Source/NSCachedImageRep.m

199 lines
4.9 KiB
Mathematica
Raw Normal View History

/** <title>NSCachedImageRep</title>
<abstract>Cached image representation.</abstract>
Copyright (C) 1996 Free Software Foundation, Inc.
Author: Adam Fedor <fedor@gnu.org>
Date: Feb 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 3 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 <http://www.gnu.org/licenses/> or write to the
Free Software Foundation, 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA.
*/
/*
Keeps a representation of an image in an off-screen window. If the
message initFromWindow:rect: is sent with a nil window, one is created
using the rect information.
*/
#include "config.h"
#include <Foundation/NSString.h>
#include <Foundation/NSException.h>
#include <Foundation/NSUserDefaults.h>
#include "AppKit/NSCachedImageRep.h"
#include "AppKit/NSView.h"
#include "AppKit/NSWindow.h"
#include "AppKit/PSOperators.h"
@interface GSCacheW : NSWindow
@end
@implementation GSCacheW
- (void) _initDefaults
{
[super _initDefaults];
[self setExcludedFromWindowsMenu: YES];
[self setAutodisplay: NO];
[self setReleasedWhenClosed: NO];
}
- (void) display
{
}
- (void) displayIfNeeded
{
}
- (void) setViewsNeedDisplay: (BOOL)f
{
}
@end
/**<p>Todo Description </p>
*/
@implementation NSCachedImageRep
/** <p>Initializes and returns a new NSCachedImageRep with size
and depth specified by <var>aSize</var> and <var>aDepth</var> respectively.
If seperate is YES, the image will gets its own unique cache without
sharing it with other images. </p>
*/
- (id) initWithSize: (NSSize)aSize
depth: (NSWindowDepth)aDepth
separate: (BOOL)separate
alpha: (BOOL)alpha
{
NSWindow *win;
NSRect frame;
// FIXME: Only create new window when separate is YES
frame.origin = NSMakePoint(0,0);
frame.size = aSize;
win = [[GSCacheW alloc] initWithContentRect: frame
styleMask: NSBorderlessWindowMask
backing: NSBackingStoreRetained
defer: NO];
self = [self initWithWindow: win rect: frame];
RELEASE(win);
[self setAlpha: alpha];
[self setBitsPerSample: NSBitsPerSampleFromDepth(aDepth)];
return self;
}
/** <p>Initializes and returns a new NSCachedImageRep into a NSWindow
<var>aWindow</var>. The image will be draw into the rectange aRect of
this window. aWindow is retained.</p>
<p>See Also: -rect -window</p>
*/
- (id) initWithWindow: (NSWindow *)aWindow rect: (NSRect)aRect
{
[super init];
_window = RETAIN(aWindow);
_rect = aRect;
/* Either win or rect must be non-NULL. If rect is empty, we get the
frame info from the window. If win is nil we create it from the
rect information. */
if (NSIsEmptyRect(_rect))
{
if (!_window)
{
[NSException raise: NSInvalidArgumentException
format: @"Must specify either window or rect when "
@"creating NSCachedImageRep"];
}
_rect = [_window frame];
}
if (!_window)
_window = [[GSCacheW alloc] initWithContentRect: _rect
styleMask: NSBorderlessWindowMask
backing: NSBackingStoreRetained
defer: NO];
[self setSize: _rect.size];
[self setAlpha: NO];
[self setOpaque: YES];
[self setPixelsHigh: _rect.size.height];
[self setPixelsWide: _rect.size.width];
return self;
}
- (void) dealloc
{
RELEASE(_window);
[super dealloc];
}
/** <p>Returns the rectangle where the image is cached.</p>
<p>See Also: -initWithWindow:rect:</p>
*/
- (NSRect) rect
{
return _rect;
}
/** <p>Returns the NSWindow where the image is cached.</p>
<p>See Also: -initWithWindow:rect:</p>
*/
- (NSWindow *) window
{
return _window;
}
- (BOOL) draw
{
PScomposite(NSMinX(_rect), NSMinY(_rect), NSWidth(_rect), NSHeight(_rect),
[_window gState], 0, 0, NSCompositeSourceOver);
return YES;
}
// NSCoding protocol
- (void) encodeWithCoder: (NSCoder*)aCoder
{
[super encodeWithCoder: aCoder];
if ([aCoder allowsKeyedCoding] == NO)
{
[aCoder encodeObject: _window];
[aCoder encodeRect: _rect];
}
}
- (id) initWithCoder: (NSCoder*)aDecoder
{
self = [super initWithCoder: aDecoder];
if ([aDecoder allowsKeyedCoding] == NO)
{
[aDecoder decodeValueOfObjCType: @encode(id) at: &_window];
_rect = [aDecoder decodeRect];
}
return self;
}
// NSCopying protocol
- (id) copyWithZone: (NSZone *)zone
{
// Cached images should not be copied
return nil;
}
@end