Mercurial > sdl-ios-xcode
annotate src/video/cybergfx/SDL_cgxvideo.h @ 3846:66fb40445587 SDL-ryan-multiple-audio-device
Removed distinction between "available" and "init" in audio backends, since
both had to be checked for success as a pair at the higher level and several
of the Available methods were just always-succeed placeholders anyhow. Now
the availability check is done in the init code, and the higher level tries
all possible drivers until one manages to initialize successfully.
author | Ryan C. Gordon <icculus@icculus.org> |
---|---|
date | Tue, 17 Oct 2006 09:09:21 +0000 |
parents | c121d94672cb |
children |
rev | line source |
---|---|
0 | 1 /* |
2 SDL - Simple DirectMedia Layer | |
1312
c9b51268668f
Updated copyright information and removed rcs id lines (problematic in branch merges)
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
3 Copyright (C) 1997-2006 Sam Lantinga |
0 | 4 |
5 This library is free software; you can redistribute it and/or | |
1312
c9b51268668f
Updated copyright information and removed rcs id lines (problematic in branch merges)
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
6 modify it under the terms of the GNU Lesser General Public |
0 | 7 License as published by the Free Software Foundation; either |
1312
c9b51268668f
Updated copyright information and removed rcs id lines (problematic in branch merges)
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
8 version 2.1 of the License, or (at your option) any later version. |
0 | 9 |
10 This library is distributed in the hope that it will be useful, | |
11 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
1312
c9b51268668f
Updated copyright information and removed rcs id lines (problematic in branch merges)
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
13 Lesser General Public License for more details. |
0 | 14 |
1312
c9b51268668f
Updated copyright information and removed rcs id lines (problematic in branch merges)
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
15 You should have received a copy of the GNU Lesser General Public |
c9b51268668f
Updated copyright information and removed rcs id lines (problematic in branch merges)
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
16 License along with this library; if not, write to the Free Software |
c9b51268668f
Updated copyright information and removed rcs id lines (problematic in branch merges)
Sam Lantinga <slouken@libsdl.org>
parents:
769
diff
changeset
|
17 Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA |
0 | 18 |
19 Sam Lantinga | |
252
e8157fcb3114
Updated the source with the correct e-mail address
Sam Lantinga <slouken@libsdl.org>
parents:
21
diff
changeset
|
20 slouken@libsdl.org |
0 | 21 */ |
1402
d910939febfa
Use consistent identifiers for the various platforms we support.
Sam Lantinga <slouken@libsdl.org>
parents:
1361
diff
changeset
|
22 #include "SDL_config.h" |
0 | 23 |
24 #ifndef _SDL_cgxvideo_h | |
25 #define _SDL_cgxvideo_h | |
26 | |
27 | |
28 #include <exec/exec.h> | |
29 #include <cybergraphx/cybergraphics.h> | |
30 #include <graphics/scale.h> | |
31 #include <graphics/gfx.h> | |
32 #include <intuition/intuition.h> | |
255
dcb5e869f8b5
Updated Amiga port by Gabriele Greco
Sam Lantinga <slouken@libsdl.org>
parents:
252
diff
changeset
|
33 #if defined(__SASC) || defined(STORMC4_WOS) |
0 | 34 #include <proto/exec.h> |
35 #include <proto/cybergraphics.h> | |
36 #include <proto/graphics.h> | |
37 #include <proto/intuition.h> | |
38 #include <proto/console.h> | |
39 #else | |
40 #include <inline/exec.h> | |
41 #include <inline/cybergraphics.h> | |
42 #include <inline/graphics.h> | |
43 #include <inline/intuition.h> | |
44 #include <inline/console.h> | |
45 #endif | |
46 | |
47 #include "SDL_mouse.h" | |
1361
19418e4422cb
New configure-based build system. Still work in progress, but much improved
Sam Lantinga <slouken@libsdl.org>
parents:
1358
diff
changeset
|
48 #include "../SDL_sysvideo.h" |
1338
604d73db6802
Removed uses of stdlib.h and string.h
Sam Lantinga <slouken@libsdl.org>
parents:
1312
diff
changeset
|
49 #include "mydebug.h" |
0 | 50 |
51 #define USE_CGX_WRITELUTPIXEL | |
52 | |
53 /* Hidden "this" pointer for the video functions */ | |
54 #define _THIS SDL_VideoDevice *this | |
55 | |
56 /* Private display data */ | |
1895
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
57 struct SDL_PrivateVideoData |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
58 { |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
59 struct Screen *Public_Display; /* Used for events and window management */ |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
60 struct Screen *GFX_Display; /* Used for graphics and colormap stuff */ |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
61 Uint32 SDL_VisualUnused; /* The visual used by our window */ |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
62 struct Window *SDL_Window; /* Shared by both displays (no X security?) */ |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
63 unsigned char *BlankCursor; /* The invisible cursor */ |
0 | 64 |
1895
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
65 char *SDL_windowid; /* Flag: true if we have been passed a window */ |
21
75a95f82bc1f
Updated the Amiga OS port of SDL (thanks Gabriele)
Sam Lantinga <slouken@lokigames.com>
parents:
0
diff
changeset
|
66 |
0 | 67 /* The variables used for displaying graphics */ |
1895
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
68 Uint8 *Ximage; /* The X image for our window */ |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
69 int swap_pixels; /* Flag: true if display is swapped endian */ |
0 | 70 |
71 /* Support for internal mouse warping */ | |
1895
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
72 struct |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
73 { |
0 | 74 int x; |
75 int y; | |
76 } mouse_last; | |
1895
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
77 struct |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
78 { |
0 | 79 int numerator; |
80 int denominator; | |
81 int threshold; | |
82 } mouse_accel; | |
83 int mouse_relative; | |
84 | |
85 /* The current list of available video modes */ | |
86 SDL_Rect **modelist; | |
87 | |
88 /* available visuals of interest to us, sorted deepest first */ | |
1895
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
89 struct |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
90 { |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
91 Uint32 visual; |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
92 int depth; /* number of significant bits/pixel */ |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
93 int bpp; /* pixel quantum in bits */ |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
94 } visuals[5]; /* at most entries for 8, 15, 16, 24 */ |
0 | 95 int nvisuals; |
96 | |
1895
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
97 Uint32 vis; /* current visual in use */ |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
98 int depth; /* current visual depth (not bpp) */ |
0 | 99 int BytesPerPixel; |
1895
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
100 int currently_fullscreen, same_format, dbuffer; |
0 | 101 |
102 /* Automatic mode switching support (entering/leaving fullscreen) */ | |
103 Uint32 switch_waiting; | |
104 Uint32 switch_time; | |
105 | |
106 /* Prevent too many XSync() calls */ | |
107 int blit_queued; | |
108 | |
109 /* Colormap handling */ | |
110 LONG Pens; | |
1895
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
111 Sint32 *XPixels; /* A list of pixels that have been allocated, the size depends on the screen format */ |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
112 struct ScreenBuffer *SB[2]; |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
113 struct RastPort *RP; |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
114 short *iconcolors; /* List of colors used by the icon */ |
0 | 115 }; |
116 | |
117 /* Old variable names */ | |
118 #define local_X11 (this->hidden->local_X11) | |
119 #define SDL_Display (this->hidden->Public_Display) | |
120 #define GFX_Display (this->hidden->GFX_Display) | |
121 #define SDL_Screen DefaultScreen(this->hidden->Public_Display) | |
122 | |
123 #define SDL_Visual (this->hidden->vis) | |
124 | |
125 #define SDL_Root RootWindow(SDL_Display, SDL_Screen) | |
126 #define WMwindow (this->hidden->WMwindow) | |
127 #define FSwindow (this->hidden->FSwindow) | |
128 #define SDL_Window (this->hidden->SDL_Window) | |
129 #define WM_DELETE_WINDOW (this->hidden->WM_DELETE_WINDOW) | |
130 #define SDL_BlankCursor (this->hidden->BlankCursor) | |
21
75a95f82bc1f
Updated the Amiga OS port of SDL (thanks Gabriele)
Sam Lantinga <slouken@lokigames.com>
parents:
0
diff
changeset
|
131 #define SDL_windowid (this->hidden->SDL_windowid) |
0 | 132 #define SDL_Ximage (this->hidden->Ximage) |
133 #define SDL_GC (this->hidden->gc) | |
134 #define swap_pixels (this->hidden->swap_pixels) | |
135 #define mouse_last (this->hidden->mouse_last) | |
136 #define mouse_accel (this->hidden->mouse_accel) | |
137 #define mouse_relative (this->hidden->mouse_relative) | |
138 #define SDL_modelist (this->hidden->modelist) | |
139 #define SDL_RastPort (this->hidden->RP) | |
140 #define saved_mode (this->hidden->saved_mode) | |
141 #define saved_view (this->hidden->saved_view) | |
142 #define currently_fullscreen (this->hidden->currently_fullscreen) | |
143 #define blit_queued (this->hidden->blit_queued) | |
144 #define SDL_DisplayColormap (this->hidden->GFX_Display->ViewPort.ColorMap) | |
145 #define SDL_XPixels (this->hidden->XPixels) | |
146 #define SDL_iconcolors (this->hidden->iconcolors) | |
147 | |
21
75a95f82bc1f
Updated the Amiga OS port of SDL (thanks Gabriele)
Sam Lantinga <slouken@lokigames.com>
parents:
0
diff
changeset
|
148 /* Used to get the X cursor from a window-manager specific cursor */ |
75a95f82bc1f
Updated the Amiga OS port of SDL (thanks Gabriele)
Sam Lantinga <slouken@lokigames.com>
parents:
0
diff
changeset
|
149 // extern Cursor SDL_GetWMXCursor(WMcursor *cursor); |
75a95f82bc1f
Updated the Amiga OS port of SDL (thanks Gabriele)
Sam Lantinga <slouken@lokigames.com>
parents:
0
diff
changeset
|
150 |
1895
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
151 extern int CGX_CreateWindow(_THIS, SDL_Surface * screen, |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
152 int w, int h, int bpp, Uint32 flags); |
0 | 153 extern int CGX_ResizeWindow(_THIS, |
1895
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
154 SDL_Surface * screen, int w, int h, Uint32 flags); |
0 | 155 |
1895
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
156 extern void CGX_DestroyWindow(_THIS, SDL_Surface * screen); |
0 | 157 |
158 extern struct Library *CyberGfxBase; | |
159 extern struct IntuitionBase *IntuitionBase; | |
160 extern struct GfxBase *GfxBase; | |
161 extern struct ExecBase *SysBase; | |
162 extern struct DosLibrary *DOSBase; | |
163 | |
164 struct private_hwdata | |
165 { | |
1895
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
166 struct BitMap *bmap; |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
167 APTR lock; |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
168 struct SDL_VideoDevice *videodata; |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
169 APTR mask; |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
170 int allocated; |
0 | 171 }; |
172 | |
1895
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
173 int CGX_CheckHWBlit(_THIS, SDL_Surface * src, SDL_Surface * dst); |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
174 int CGX_FillHWRect(_THIS, SDL_Surface * dst, SDL_Rect * dstrect, |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
175 Uint32 color); |
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
176 int CGX_SetHWColorKey(_THIS, SDL_Surface * surface, Uint32 key); |
0 | 177 #endif /* _SDL_x11video_h */ |
1895
c121d94672cb
SDL 1.2 is moving to a branch, and SDL 1.3 is becoming the head.
Sam Lantinga <slouken@libsdl.org>
parents:
1545
diff
changeset
|
178 /* vi: set ts=4 sw=4 expandtab: */ |