mirror of
https://github.com/libretro/scummvm.git
synced 2025-01-19 00:15:30 +00:00
003317e89d
svn-id: r38201
439 lines
18 KiB
C
439 lines
18 KiB
C
/***************************************************************************
|
|
gfx_driver.h Copyright (C) 2000 Christoph Reichenbach
|
|
|
|
This program may be modified and copied freely according to the terms of
|
|
the GNU general public license (GPL), as long as the above copyright
|
|
notice and the licensing information contained herein are preserved.
|
|
|
|
Please refer to www.gnu.org for licensing details.
|
|
|
|
This work is provided AS IS, without warranty of any kind, expressed or
|
|
implied, including but not limited to the warranties of merchantibility,
|
|
noninfringement, and fitness for a specific purpose. The author will not
|
|
be held liable for any damage caused by this work or derivatives of it.
|
|
|
|
By using this source code, you agree to the licensing terms as stated
|
|
above.
|
|
|
|
|
|
Please contact the maintainer for bug reports or inquiries.
|
|
|
|
Current Maintainer:
|
|
|
|
Christoph Reichenbach (CR) <jameson@linuxgames.com>
|
|
|
|
***************************************************************************/
|
|
|
|
#ifndef _SCI_GFX_DRIVER_H_
|
|
#define _SCI_GFX_DRIVER_H_
|
|
|
|
#include "sci/include/gfx_system.h"
|
|
#include "sci/include/uinput.h"
|
|
|
|
|
|
typedef enum {
|
|
GFX_BUFFER_FRONT = 0,
|
|
GFX_BUFFER_BACK = 1,
|
|
GFX_BUFFER_STATIC = 2
|
|
} gfx_buffer_t;
|
|
|
|
|
|
/* graphics driver hints */
|
|
#define GFX_CAPABILITY_SHADING (1<<0)
|
|
#define GFX_CAPABILITY_MOUSE_POINTER (1<<1)
|
|
#define GFX_CAPABILITY_COLOR_MOUSE_POINTER (1<<2)
|
|
#define GFX_CAPABILITY_PIXMAP_REGISTRY (1<<3)
|
|
#define GFX_CAPABILITY_SCALEABLE_PIXMAPS (1<<4)
|
|
#define GFX_CAPABILITY_STIPPLED_LINES (1<<6)
|
|
#define GFX_CAPABILITY_MOUSE_SUPPORT (1<<7)
|
|
#define GFX_CAPABILITY_POINTER_PIXMAP_REGISTRY (1<<8)
|
|
#define GFX_CAPABILITY_FINE_LINES (1<<9)
|
|
#define GFX_CAPABILITY_WINDOWED (1<<10)
|
|
#define GFX_CAPABILITY_KEYTRANSLATE (1<<11)
|
|
|
|
#define GFX_DEBUG_POINTER (1<<0)
|
|
#define GFX_DEBUG_UPDATES (1<<1)
|
|
#define GFX_DEBUG_PIXMAPS (1<<2)
|
|
#define GFX_DEBUG_BASIC (1<<3) /* Basic geometric ops (lines, boxes, etc) */
|
|
|
|
/* Principial graphics driver architecture
|
|
** ---------------------------------------
|
|
**
|
|
** All graphics drivers must provide
|
|
** - One visual front buffer (the actually visible thing)
|
|
** - Two dynamic back buffers:
|
|
** + visual
|
|
** + priority
|
|
** - Two static buffers (containing the background image and picviews):
|
|
** + visual
|
|
** + priority
|
|
**
|
|
** The control buffer is handled outside the graphics driver architecture.
|
|
** Graphics are drawn by first setting the static buffers, then updating
|
|
** the back buffers (from the static buffers), adding all picviews and other
|
|
** widgets, and finally updating the front buffer.
|
|
**
|
|
** All coordinates refer to the scaled coordinate system.
|
|
** Invalid parameters should produce an error message.
|
|
** Support for some valid parameter values is optional (like different line
|
|
** modes). If an unsupported but valid parameter is specified, the function
|
|
** must use a reasonable default value.
|
|
*/
|
|
|
|
#define SCI_GFX_DRIVER_VERSION 0
|
|
#define SCI_GFX_DRIVER_MAGIC 0xf001337
|
|
|
|
typedef struct _gfx_driver { /* Graphics driver */
|
|
|
|
const char *name; /* Graphics driver name. Unique identifier, should consist of
|
|
** lower-case (where applicable) alphanumerics
|
|
*/
|
|
|
|
const char *version; /* Free-form version description (for informative purposes
|
|
** only)
|
|
*/
|
|
|
|
int sci_driver_magic; /* SCI_GFX_DRIVER_MAGIC */
|
|
int sci_driver_version; /* SCI_GFX_DRIVER_VERSION */
|
|
|
|
gfx_mode_t *mode; /* Currently active mode, NULL if no mode is active */
|
|
|
|
int pointer_x, pointer_y; /* Mouse pointer position */
|
|
|
|
int capabilities; /* The driver's capabilities: A list of flags that may
|
|
** be pre-defined or set after a successful initialization.
|
|
*/
|
|
/* Capability flags:
|
|
**
|
|
** The words MUST, SHOULD and MAY are to be interpreted as described in
|
|
** the IETF RFC 1123.
|
|
**
|
|
** GFX_CAPABILITY_SHADING: draw_filled_rect() supports drawing shaded
|
|
** rectangles.
|
|
** GFX_CAPABILITY_MOUSE_POINTER: The driver has built-in support for mouse
|
|
** pointers (monochrome or colored).
|
|
** GFX_CAPABILITY_COLOR_MOUSE_POINTER: The driver has built-in support for
|
|
** colored mouse pointers.
|
|
** GFX_CAPABILITY_PIXMAP_REGISTRY: System provides a pixmap registry. The
|
|
** invoking functions will assume that all pixmaps MUST be registered;
|
|
** if this flag is not set, it assumes that pixmaps MUST NOT be
|
|
** registered. Note that this excludes pointer pixmaps (see below)
|
|
** GFX_CAPABILITY_POINTER_PIXMAP_REGISTRY: The system provides a pixmap
|
|
** registry which mouse pointers have to be registered in explicitly.
|
|
** This MUST be used only if the registry is identical to the 'normal' pixmap
|
|
** registry. Otherwise, it MUST be handled manually by the driver,
|
|
** unless pointer support is disabled completely.
|
|
** GFX_CAPABILITY_SCALEABLE_PIXMAPS: Pixmap scaling is fully supported.
|
|
** If this capability is flag is set, all pixmaps passed to the driver
|
|
** will be unscaled.
|
|
** GFX_CAPABILITY_STIPPLED_LINES: The driver is able to draw stippled lines
|
|
** horizontally and vertically (xl = 0 or yl = 0).
|
|
** GFX_CAPABILITY_MOUSE_SUPPORT: There is some support for mouse (or similar)
|
|
** input. Note that this flag may be disabled by external code after
|
|
** initialization time, if no support for mouse pointer /drawing/ is
|
|
** available.
|
|
** GFX_CAPABILITY_FINE_LINES: Should be set IFF the driver supports drawing
|
|
** fine (width 1) lines
|
|
** GFX_CAPABILITY_WINDOWED: Driver runs in a window and supports a debug
|
|
** console running on stdin/stdout
|
|
** GFX_CAPABILITY_KEYTRANSLATE: The driver's input layer automatically
|
|
** handles 'shifted' keys (i.e. turning shift-'a' to 'A' etc.).
|
|
** Drivers only need to handle this if they desire to support
|
|
** non-US keyboard layouts, usually by localisation methods
|
|
** provided by the underlying windowing or operating system.
|
|
*/
|
|
|
|
unsigned int debug_flags; /* Driver debug flags */
|
|
|
|
|
|
/*** Initialization ***/
|
|
|
|
int (*set_parameter) (struct _gfx_driver *drv, char *attribute, char *value);
|
|
/* Sets a driver-specific parameter
|
|
** Parameters: (gfx_driver_t *) drv: Pointer to the affected driver
|
|
** (char *) attribute: Name of the attribute/parameter to set
|
|
** (char *) value: The value to set, or NULL to query the value
|
|
** Returns : (int) GFX_OK or GFX_FATAL, which signals a fatal error
|
|
** condition.
|
|
** This function should make extensive use of sciprintf() to signal invalid
|
|
** values or unapplicable attributes.
|
|
** Note that it may be called either before initialization (to interpret
|
|
** config file or command line parameters) or afterwars (from the command
|
|
** console).
|
|
*/
|
|
|
|
int (*init_specific) (struct _gfx_driver *drv, int xres, int yres,
|
|
int bytespp);
|
|
/* Attempts to initialize a specific graphics mode
|
|
** Parameters: (gfx_driver_t *) drv: The affected driver
|
|
** (int x int) xres, yres: Horizontal and vertical scaling
|
|
** factors
|
|
** (int) bytespp: Any of GFX_COLOR_MODE_*. GFX_COLOR_MODE_INDEX
|
|
** implies color index mode.
|
|
** Returns : (int) GFX_OK on success, GFX_ERROR if the mode could not be
|
|
** set, or GFX_FATAL if the graphics target is unuseable.
|
|
** The scaling factors apply to the standard SCI resolution of 320x200 pixels
|
|
** and is used for internal representation of graphical data. The physical
|
|
** resolution set by the graphics driver may be different for practical
|
|
** reasons.
|
|
** Must also set drv->mode, preferably with the gfx_new_mode() function
|
|
** specified in gfx_tools.h.
|
|
*/
|
|
|
|
int (*init) (struct _gfx_driver *drv);
|
|
/* Initialize any graphics mode
|
|
** Parameters: (gfx_driver_t *) drv: The affected driver
|
|
** Returns : (int) GFX_OK on success, GFX_FATAL otherwise.
|
|
** This function attempts to set /any/ graphics mode, starting with the one
|
|
** most 'natural' to the graphics target. Target implementors have relatively
|
|
** free reign in choosing the heuristics used to determine the resulting
|
|
** mode.
|
|
** Must also set drv->mode, preferably with the gfx_new_mode() function
|
|
** specified in gfx_tools.h.
|
|
*/
|
|
|
|
void (*exit) (struct _gfx_driver *drv);
|
|
/* Uninitializes the current graphics mode
|
|
** Paramters: (gfx_driver_t *) drv: The driver to uninitialize
|
|
** Return : (void)
|
|
** This function frees all memory allocated by the graphics driver,
|
|
** including mode and palette information, uninstalls all console commands
|
|
** introduced by preceeding init() or init_specific() commands, and does any
|
|
** clean-up work (like closing visuals or returning to text mode) required by
|
|
** the graphics infrastructure used.
|
|
*/
|
|
|
|
|
|
/*** Drawing operations ***/
|
|
|
|
int (*draw_line) (struct _gfx_driver *drv,
|
|
point_t start, point_t end,
|
|
gfx_color_t color,
|
|
gfx_line_mode_t line_mode, gfx_line_style_t line_style);
|
|
/* Draws a single line to the back buffer.
|
|
** Parameters: (gfx_driver_t *) drv: The driver affected
|
|
** (point_t) start: Starting point of the line to draw
|
|
** (point_t) end: End point of the line to draw
|
|
** (gfx_color_t *) color: The color to draw with
|
|
** (int) line_mode: Any of the line modes
|
|
** (int) line_style: Any of the line styles
|
|
** Returns : (int) GFX_OK or GFX_FATAL
|
|
** Note that color.priority is relevant and must be drawn if
|
|
** (color.mask & GFX_MASK_PRIORITY).
|
|
** Support for line modes other than GFX_LINE_MODE_FAST is optional.
|
|
** For non-fine lines, the coordinates provided describe the upper left
|
|
** corner of the pixels of the line to draw.
|
|
** line_style support is optional, if GFX_CAPABILITY_STIPPLED_LINES is not
|
|
** set.
|
|
*/
|
|
|
|
int (*draw_filled_rect) (struct _gfx_driver *drv, rect_t rect,
|
|
gfx_color_t color1, gfx_color_t color2,
|
|
gfx_rectangle_fill_t shade_mode);
|
|
/* Draws a single filled and possibly shaded rectangle to the back buffer.
|
|
** Parameters: (gfx_driver_t *) drv: The driver affected
|
|
** (rect_t *) rect: The rectangle to draw
|
|
** (gfx_color_t *) color1, color2: The colors to draw with
|
|
** (int) shade_mode: Any of GFX_SHADE_*.
|
|
** Returns : (int) GFX_OK or GFX_FATAL
|
|
** Note that color.priority is relevant and must be drawn if
|
|
** (color.mask & GFX_MASK_PRIORITY).
|
|
** color2 is relevant only if shade_mode is not GFX_SHADE_FLAT.
|
|
** Support for shade modes other than GFX_SHADE_FLAT is optional.
|
|
*/
|
|
|
|
/*** Pixmap operations ***/
|
|
|
|
int (*register_pixmap) (struct _gfx_driver *drv, gfx_pixmap_t *pxm);
|
|
/* Registers a pixmap with the driver.
|
|
** Parameters: (gfx_driver_t *) drv: The driver
|
|
** (gfx_pixmap_t *) pxm: The pixmap to register
|
|
** Returns : GFX_OK or GFX_FATAL
|
|
** This function may be NULL if GFX_CAPABILITY_PIXMAP_REGISTRY is not
|
|
** set.
|
|
** pxm->internal may be used to store any handle or meta information.
|
|
*/
|
|
|
|
int (*unregister_pixmap) (struct _gfx_driver *drv, gfx_pixmap_t *pxm);
|
|
/* Unregisters a pixmap previously registered with register_pixmap()
|
|
** Parameters: (gfx_driver_t *) drv: The driver
|
|
** (gfx_pixmap_t *) pxm: The pixmap to register
|
|
** Returns : (int) GFX_OK or GFX_FATAL, or GFX_ERROR if pxm was
|
|
** not registered
|
|
** Just like register_pixmap(), this function may be NULL unless
|
|
** GFX_CAPABILITY_PIXMAP_REGISTRY is set.
|
|
*/
|
|
|
|
int (*draw_pixmap) (struct _gfx_driver *drv, gfx_pixmap_t *pxm, int priority,
|
|
rect_t src, rect_t dest, gfx_buffer_t buffer);
|
|
/* Draws part of a pixmap to the static or back buffer
|
|
** Parameters: (gfx_driver_t *) drv: The affected driver
|
|
** (gfx_pixmap_t *) pxm: The pixmap to draw
|
|
** (int) priority: The priority to draw with, or GFX_NO_PRIORITY
|
|
** to draw on top of everything without setting the
|
|
** priority back buffer
|
|
** (rect_t) src: The pixmap-relative source rectangle
|
|
** (rect_t) dest: The destination rectangle
|
|
** (int) buffer: One of GFX_BUFFER_STATIC and GFX_BUFFER_BACK
|
|
** Returns : (int) GFX_OK or GFX_FATAL, or GFX_ERROR if pxm was not
|
|
** (but should have been) registered.
|
|
** dest.xl and dest.yl must be evaluated and used for scaling if
|
|
** GFX_CAPABILITY_SCALEABLE_PIXMAPS is supported.
|
|
*/
|
|
|
|
int (*grab_pixmap) (struct _gfx_driver *drv, rect_t src, gfx_pixmap_t *pxm,
|
|
gfx_map_mask_t map);
|
|
/* Grabs an image from the visual or priority back buffer
|
|
** Parameters: (gfx_driver_t *) drv: The affected driver
|
|
** (rect_t) src: The rectangle to grab
|
|
** (gfx_pixmap_t *) pxm: The pixmap structure the data is to
|
|
** be written to
|
|
** (int) map: GFX_MASK_VISUAL or GFX_MASK_PRIORITY
|
|
** Returns : (int) GFX_OK, GFX_FATAL, or GFX_ERROR for invalid map values
|
|
** pxm may be assumed to be empty and pre-allocated with an appropriate
|
|
** memory size.
|
|
** This function is now mandatory.
|
|
*/
|
|
|
|
|
|
/*** Buffer operations ***/
|
|
|
|
int (*update) (struct _gfx_driver *drv, rect_t src, point_t dest,
|
|
gfx_buffer_t buffer);
|
|
/* Updates the front buffer or the back buffers
|
|
** Parameters: (gfx_driver_t *) drv: The affected driver
|
|
** (rect_t) src: Source rectangle
|
|
** (point_t) dest: Destination point
|
|
** (int) buffer: One of GFX_BUFFER_FRONT or GFX_BUFFER_BACK
|
|
** Returns : (int) GFX_OK, GFX_ERROR or GFX_FATAL
|
|
** This function updates either the visual front buffer, or the two back
|
|
** buffers, by copying the specified source region to the destination
|
|
** region.
|
|
** For heuristical reasons, it may be assumed that the x and y fields of
|
|
** src and dest will be identical in /most/ cases.
|
|
** If they aren't, the priority map will not be required to be copied.
|
|
*/
|
|
|
|
int (*set_static_buffer) (struct _gfx_driver *drv, gfx_pixmap_t *pic,
|
|
gfx_pixmap_t *priority);
|
|
/* Sets the contents of the static visual and priority buffers
|
|
** Parameters: (gfx_driver_t *) drv: The affected driver
|
|
** (gfx_pixmap_t *) pic: The image defining the new content
|
|
** of the visual back buffer
|
|
** (gfx_pixmap_t *) priority: The priority map containing
|
|
** the new content of the priority back buffer
|
|
** in the index buffer
|
|
** Returns : (int) GFX_OK or GFX_FATAL
|
|
** pic and priority may be modified or written to freely. They may also be
|
|
** used as the actual static buffers, since they are not freed and re-
|
|
** allocated between calls to set_static_buffer() and update(), unless
|
|
** exit() was called in between.
|
|
** Note that later version of the driver interface may disallow modifying
|
|
** pic and priority.
|
|
** pic and priority are always scaled to the appropriate resolution, even
|
|
** if GFX_CAPABILITY_SCALEABLE_PIXMAPS is set.
|
|
*/
|
|
|
|
|
|
/*** Mouse pointer operations ***/
|
|
|
|
int (*set_pointer) (struct _gfx_driver *drv, gfx_pixmap_t *pointer);
|
|
/* Sets a new mouse pointer.
|
|
** Parameters: (gfx_driver_t *) drv: The driver to modify
|
|
** (gfx_pixmap_t *) pointer: The pointer to set, or NULL to set
|
|
** no pointer
|
|
** Returns : (int) GFX_OK or GFX_FATAL
|
|
** This function may be NULL if GFX_CAPABILITY_MOUSE_POINTER is not set.
|
|
** If pointer is not NULL, it will have been scaled to the appropriate
|
|
** size and registered as a pixmap (if neccessary) beforehand.
|
|
** If this function is called for a target that supports only two-color
|
|
** pointers, the image is a color index image, where only color index values
|
|
** 0, 1, and GFX_COLOR_INDEX_TRANSPARENT are used.
|
|
*/
|
|
|
|
|
|
/*** Palette operations ***/
|
|
|
|
int (*set_palette) (struct _gfx_driver *drv, int index, byte red, byte green,
|
|
byte blue);
|
|
/* Manipulates a palette index in the hardware palette
|
|
** Parameters: (gfx_driver_t *) drv: The driver affected
|
|
** (int) index: The index of the palette entry to modify
|
|
** (int x int x int) red, green, blue: The RGB intensities to
|
|
** set for the specified index. The minimum
|
|
** intensity is 0, maximum is 0xff.
|
|
** Returns : (int) GFX_OK, GFX_ERROR or GFX_FATAL
|
|
** This function does not need to update mode->palette, as this is done
|
|
** by the calling code.
|
|
** set_palette() is only required for targets supporting color index mode.
|
|
*/
|
|
|
|
|
|
/*** Event management ***/
|
|
|
|
sci_event_t (*get_event) (struct _gfx_driver *drv);
|
|
/* Returns the next event in the event queue for this driver
|
|
** Parameters: (gfx_driver_t *) drv: The driver to query
|
|
** Returns : (sci_event_t) The oldest event still in the driver's event
|
|
** queue, or the null event if there is none.
|
|
*/
|
|
|
|
int (*usec_sleep) (struct _gfx_driver *drv, long usecs);
|
|
/* Sleeps the specified amount of microseconds, or until the mouse moves
|
|
** Parameters: (gfx_driver_t *) drv: The relevant driver
|
|
** (long) usecs: Amount of microseconds to sleep
|
|
** Returns : (int) GFX_OK or GFX_FATAL
|
|
** This function returns when the specified amount of microseconds has
|
|
** elapsed, or when the mouse pointer has been moved and needs to be redrawn.
|
|
** Only targets that can handle colored mouse pointers may choose to handle
|
|
** all mouse management internally.
|
|
*/
|
|
|
|
void *state; /* Reserved for internal use */
|
|
|
|
} gfx_driver_t;
|
|
|
|
|
|
|
|
gfx_driver_t *
|
|
gfx_find_driver(char *, char *name);
|
|
/* Attempts to match a graphics driver to a name
|
|
** Parameters: (char *) path: The path to search in
|
|
** (char *) name: The name of the graphics driver to look for
|
|
** or NULL for the default driver
|
|
** Returns : (gfx_driver_t *) The resulting driver, or NULL if none
|
|
** was found
|
|
*/
|
|
|
|
const char *
|
|
gfx_get_driver_name(int nr);
|
|
/* Retreives the name of the driver with the specified number
|
|
** Parameters: (int) nr: Number of the driver
|
|
** (char *) The driver's name
|
|
** Note that this function only makes sense within a loop or if nr=0, since
|
|
** the result value is valid iff nr >= 0 AND there does not exist an nr'
|
|
** with 0 <= nr' < nr so that gfx_get_driver_name(nr') == NULL.
|
|
*/
|
|
|
|
/*** Utility functions for set_parameter implementations */
|
|
|
|
int
|
|
string_truep(char *value);
|
|
/* Tests whether a string expresses truth
|
|
** Parameters: (char *) value: The value to test
|
|
** Returns : non-zero iff 'value' contans a string expressing something
|
|
** along the lines of "yes"
|
|
*/
|
|
|
|
int
|
|
string_falsep(char *value);
|
|
/* Tests whether a string expresses falsehood
|
|
** Parameters: (char *) value: The value to test
|
|
** Returns : non-zero iff 'value' contans a string expressing something
|
|
** along the lines of "no"
|
|
*/
|
|
|
|
|
|
|
|
#endif /* !_SCI_GFX_DRIVER_H_ */
|