netsurf/riscos/tinct.h

155 lines
4.4 KiB

/*
* Copyright 2005 Richard Wilson <info@tinct.net>
*
* This file is part of NetSurf, http://www.netsurf-browser.org/
*
* NetSurf is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; version 2 of the License.
*
* NetSurf 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
/*
* Complete details on using Tinct are available from http://www.tinct.net.
*/
/** \file
* Tinct SWI numbers and flags for version 0.11
*/
#ifndef _NETSURF_RISCOS_TINCT_H_
#define _NETSURF_RISCOS_TINCT_H_
/**
* Plots an alpha-blended sprite at the specified coordinates.
*
* -> R2 Sprite pointer
* R3 X coordinate
* R4 Y coordinate
* R7 Flag word
*/
#define Tinct_PlotAlpha 0x57240
/**
* Plots a scaled alpha-blended sprite at the specified coordinates.
*
* -> R2 Sprite pointer
* R3 X coordinate
* R4 Y coordinate
* R5 Scaled sprite width
* R6 Scaled sprite height
* R7 Flag word
*/
#define Tinct_PlotScaledAlpha 0x57241
/**
* Plots a sprite at the specified coordinates with a constant 0xff value for
* the alpha channel, ie without a mask.
*
* -> R2 Sprite pointer
* R3 X coordinate
* R4 Y coordinate
* R7 Flag word
*/
#define Tinct_Plot 0x57242
/**
* Plots a scaled sprite at the specified coordinates with a constant 0xff value
* for the alpha channel, ie without a mask.
*
* -> R2 Sprite pointer
* R3 X coordinate
* R4 Y coordinate
* R5 Scaled sprite width
* R6 Scaled sprite height
* R7 Flag word
*/
#define Tinct_PlotScaled 0x57243
/**
* Converts a paletted sprite into its 32bpp equivalent. Sufficient memory must
* have previously been allocated for the sprite (44 + width * height * 4).
* As sprites with 16bpp or 32bpp do not have palettes, conversion cannot be
* performed on these variants. All sprites must be supplied with a full palette,
* eg 8bpp must have 256 palette entries.
*
* -> R2 Source sprite pointer
* R3 Destination sprite pointer
*/
#define Tinct_ConvertSprite 0x57244
/**
* Returns the features available to the caller by specifying bits in the flag
* word. The features available are unique for each mode, although the current
* version of Tinct supports the same subset of features for all modes.
*
* -> R0 Feature to test for, or 0 for all features
* <- R0 Features available
*/
#define Tinct_AvailableFeatures 0x57245
/**
* Compresses an image using a fast algorithm. Sufficient memory must have been
* previously allocated for the maximum possible compressed size. This value is
* equal to 28 + (width * height * 4) * 33 / 32.
*
* -> R0 Source sprite pointer
* R2 Output data buffer
* R3 Output bytes available
* R7 Flag word (currently 0)
* <- R0 Size of compressed data
*/
#define Tinct_Compress 0x57246
/**
* Decompresses an image previously compressed. Sufficient memory must have been
* previously allocated for the decompressed data (44 + width * height * 4) where
* width and height are available at +0 and +4 of the compressed data respectively.
*
* -> R0 Input data buffer
* R2 Output data buffer
* R7 Flag word (currently 0)
* <- R0 Size of decompressed data
*/
#define Tinct_Decompress 0x57247
/* Plotting flags
*/
#define tinct_READ_SCREEN_BASE 0x01 /** <-- Use when hardware scrolling */
#define tinct_BILINEAR_FILTER 0x02 /** <-- Perform bi-linear filtering */
#define tinct_DITHER 0x04 /** <-- Perform dithering */
#define tinct_ERROR_DIFFUSE 0x08 /** <-- Perform error diffusion */
#define tinct_DITHER_INVERTED 0x0C /** <-- Perform dithering with inverted pattern */
#define tinct_FILL_HORIZONTALLY 0x10 /** <-- Horizontally fill clipping region with image */
#define tinct_FILL_VERTICALLY 0x20 /** <-- Vertically fill clipping region with image */
#define tinct_FORCE_PALETTE_READ 0x40 /** <-- Use after a palette change when out of the desktop */
#define tinct_USE_OS_SPRITE_OP 0x80 /** <-- Use when printing */
/* Compression flags
*/
#define tinct_OPAQUE_IMAGE 0x01 /** <-- Image is opaque, compress further */
/* Shifts
*/
#define tinct_BACKGROUND_SHIFT 0x08
/* Sprite mode
*/
#define tinct_SPRITE_MODE (os_mode)0x301680b5
#endif