libs-gui/Source/NSCachedImageRep.m
Eric Wasylishen 346f604cb7 * Source/NSWindow.m: Remove unnecessary FIXMEs related to
user space scale factor
* Source/NSAppliation.m: Correct app icon sizing which was
mixing up window frame coordinates and user space coordinates
* Source/NSCachedImageRep.m: Add NSUnscaledWindowMask to the
window used internally


git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/gui/trunk@32897 72102866-910b-0410-8b05-ffd578937521
2011-04-19 08:23:01 +00:00

245 lines
6 KiB
Objective-C

/** <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 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 <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.
*/
// for fabs()
#include <math.h>
#import "config.h"
#import <Foundation/NSString.h>
#import <Foundation/NSException.h>
#import <Foundation/NSUserDefaults.h>
#import "AppKit/NSAffineTransform.h"
#import "AppKit/NSBitmapImageRep.h"
#import "AppKit/NSCachedImageRep.h"
#import "AppKit/NSView.h"
#import "AppKit/NSWindow.h"
#import "AppKit/PSOperators.h"
@interface GSCacheW : NSWindow
@end
@implementation GSCacheW
- (void) _initDefaults
{
[super _initDefaults];
[self setExcludedFromWindowsMenu: YES];
[self setAutodisplay: NO];
[self setReleasedWhenClosed: NO];
[self setMiniwindowImage: nil];
}
- (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 | NSUnscaledWindowMask
backing: NSBackingStoreRetained
defer: NO];
self = [self initWithWindow: win rect: frame];
RELEASE(win);
if (!self)
return nil;
[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
{
self = [super init];
if (!self)
return nil;
_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 | NSUnscaledWindowMask
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
{
/*
FIXME: Horrible hack to get drawing on a scaled or rotated
context correct. We need another interface with the backend
to do it properly.
*/
NSGraphicsContext *ctxt = GSCurrentContext();
NSAffineTransform *transform;
NSAffineTransformStruct ts;
// Is there anything to draw?
if (NSIsEmptyRect(_rect))
return YES;
transform = [ctxt GSCurrentCTM];
ts = [transform transformStruct];
if (fabs(ts.m11 - 1.0) < 0.01 && fabs(ts.m12) < 0.01
&& fabs(ts.m21) < 0.01 && fabs(ts.m22 - 1.0) < 0.01)
{
PScomposite(NSMinX(_rect), NSMinY(_rect), NSWidth(_rect), NSHeight(_rect),
[_window gState], 0, 0, NSCompositeSourceOver);
}
else
{
NSView *view = [_window contentView];
NSBitmapImageRep *rep;
[view lockFocus];
rep = [[NSBitmapImageRep alloc] initWithFocusedViewRect: _rect];
[view unlockFocus];
[rep draw];
RELEASE(rep);
}
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 (!self)
return nil;
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