libs-back/Headers/opal/OpalGState.h
Fred Kiefer 78b3ef9b31 Started cleanup of opal backend.
git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/back/trunk@37167 72102866-910b-0410-8b05-ffd578937521
2013-09-29 07:30:20 +00:00

82 lines
2.6 KiB
Objective-C

/*
OpalGState.h
Copyright (C) 2013 Free Software Foundation, Inc.
Author: Ivan Vucica <ivan@vucica.net>
Date: June 2013
This file is part of GNUstep.
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.
*/
#import <CoreGraphics/CoreGraphics.h>
#import "gsc/GSGState.h"
@class OpalSurface;
@interface OpalGState : GSGState
{
OpalSurface * _opalSurface;
/** When a surface's gstate is being switched away from,
we store the current gstate in _opGState.
When a surface's gstate is being switched back to,
if _opGState is not nil, we apply the stored gstate.
To facilitate OpalGState class instance copying, we
also store a copy of the gstate inside _opGState when
gstate's -copyWithZone: is being run. This is because
the same _opalSurface should be used in both new and
old OpalGState.
The same is done in Cairo backend, with one key
difference: since all graphics state operations in
Cairo are done directly on cairo_t and are unrelated
to the surface, Opal mixes the concepts of a gstate
and a surface into a context. Hence, when gstate is
switched, it's OpalContext's duty to apply the stored
copy of a gstate from _opGState. No such trickery
is needed with Cairo, as Cairo backend can simply
have a different cairo_t with the same surface.
**/
OPGStateRef _opGState;
}
@end
@interface OpalGState (InitializationMethods)
- (void) DPSinitgraphics;
- (void) GSSetSurface: (OpalSurface *)opalSurface
: (int)x
: (int)y;
- (void) GSCurrentSurface: (OpalSurface **)surface
: (int *)x
: (int *)y;
@end
@interface OpalGState (Accessors)
- (CGContextRef) CGContext;
- (OPGStateRef) OPGState;
- (void) setOPGState: (OPGStateRef) opGState;
@end
@interface OpalGState (NonrequiredMethods)
- (void) DPSgsave;
- (void) DPSgrestore;
@end