99 lines
3.6 KiB
C
99 lines
3.6 KiB
C
/* Grafx2 - The Ultimate 256-color bitmap paint program
|
||
|
||
Copyright 2007 Adrien Destugues
|
||
Copyright 1996-2001 Sunset Design (Guillaume Dorme & Karl Maritaud)
|
||
|
||
Grafx2 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.
|
||
|
||
Grafx2 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 Grafx2; if not, see <http://www.gnu.org/licenses/>
|
||
*/
|
||
//////////////////////////////////////////////////////////////////////////////
|
||
///@file loadsave.h
|
||
/// Saving and loading different picture formats.
|
||
/// Also handles showing the preview in fileselectors.
|
||
//////////////////////////////////////////////////////////////////////////////
|
||
|
||
void Pixel_load_in_current_screen (word x_pos, word y_pos, byte color);
|
||
void Pixel_load_in_preview (word x_pos, word y_pos, byte color);
|
||
void Pixel_load_in_brush (word x_pos, word y_pos, byte color);
|
||
|
||
void Get_full_filename(char * filename, byte is_colorix_format);
|
||
|
||
///
|
||
/// High-level picture loading function.
|
||
/// Handles loading an image or a brush, or previewing only.
|
||
/// @param image true if the fileselector is the one for loading images (not brush)
|
||
void Load_image(byte image);
|
||
|
||
///
|
||
/// High-level picture saving function.
|
||
/// @param image true if the image should be saved (instead of the brush)
|
||
void Save_image(byte image);
|
||
|
||
/// Data for an image file format.
|
||
typedef struct {
|
||
byte Identifier; ///< Identifier for this format in enum :FILE_FORMATS
|
||
char *Label; ///< Five-letter label
|
||
Func_action Test; ///< Function which tests if the file is of this format
|
||
Func_action Load; ///< Function which loads an image of this format
|
||
Func_action Save; ///< Function which saves an image of this format
|
||
byte Backup_done; ///< Boolean, true if this format saves all the image, and considers it backed up. Set false for formats which only save the palette.
|
||
byte Comment; ///< This file format allows a text comment
|
||
char *Default_extension; ///< Default file extension
|
||
char *Extensions; ///< List of semicolon-separated file extensions
|
||
} T_Format;
|
||
|
||
/// Array of the known file formats
|
||
extern T_Format File_formats[];
|
||
|
||
///
|
||
/// Function which attempts to save backups of the images (main and spare),
|
||
/// called in case of SIGSEGV.
|
||
void Image_emergency_backup(void);
|
||
|
||
/// Pixel ratio of last loaded image: one of :PIXEL_SIMPLE, :PIXEL_WIDE or :PIXEL_TALL
|
||
extern enum PIXEL_RATIO Ratio_of_loaded_image;
|
||
|
||
T_Format * Get_fileformat(byte format);
|
||
|
||
// -- File formats
|
||
|
||
#ifndef __no_pnglib__
|
||
#define NB_KNOWN_FORMATS 19 ///< Total number of known file formats.
|
||
#else
|
||
// Without pnglib
|
||
#define NB_KNOWN_FORMATS 18 ///< Total number of known file formats.
|
||
#endif
|
||
|
||
// This is here and not in fileformats.c because the emergency save uses it...
|
||
#pragma pack(1)
|
||
typedef struct
|
||
{
|
||
byte Filler1[6];
|
||
word Width;
|
||
word Height;
|
||
byte Filler2[118];
|
||
T_Palette Palette;
|
||
} T_IMG_Header;
|
||
#pragma pack()
|
||
|
||
// Donn<6E>es pour la gestion du chargement en 24b
|
||
#define FORMAT_24B 0x100
|
||
typedef void (* Func_24b_display) (short,short,byte,byte,byte);
|
||
extern int Image_24b;
|
||
|
||
extern T_Components * Buffer_image_24b;
|
||
extern Func_24b_display Pixel_load_24b;
|
||
|
||
void Pixel_load_in_24b_preview(short x_pos,short y_pos,byte r,byte g,byte b);
|
||
extern enum PIXEL_RATIO Ratio_of_loaded_image;
|