2002-12-01 07:56:17 +00:00
|
|
|
/*******************************************************************************
|
2002-12-29 06:50:19 +00:00
|
|
|
This file is Part of the ZEngine Library for 2D game development.
|
|
|
|
Copyright (C) 2002, 2003 James Turk
|
2002-12-01 07:56:17 +00:00
|
|
|
|
2002-12-29 06:50:19 +00:00
|
|
|
Licensed under a BSD-style license.
|
2002-12-01 07:56:17 +00:00
|
|
|
|
2002-12-29 06:50:19 +00:00
|
|
|
The maintainer of this library is James Turk (james@conceptofzero.net)
|
|
|
|
and the home of this Library is http://www.zengine.sourceforge.net
|
2002-12-01 07:56:17 +00:00
|
|
|
*******************************************************************************/
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\file ZE_ZImage.h
|
|
|
|
\brief Definition file for ZImage.
|
|
|
|
|
|
|
|
Definition file for ZImage, the OpenGL version of the ZImage class for ZEngine.
|
2003-08-07 05:54:45 +00:00
|
|
|
<br>$Id: ZE_ZImage.h,v 1.22 2003/08/07 05:54:45 cozman Exp $<br>
|
2003-05-07 20:34:50 +00:00
|
|
|
\author James Turk
|
2002-12-01 07:56:17 +00:00
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef __ze_zimage_h__
|
|
|
|
#define __ze_zimage_h__
|
|
|
|
|
2003-02-10 04:02:38 +00:00
|
|
|
#include "ZE_ZEngine.h"
|
2002-12-01 07:56:17 +00:00
|
|
|
|
|
|
|
namespace ZE
|
|
|
|
{
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief ZImage class for basic Image use.
|
|
|
|
|
|
|
|
ZImage image drawing class, class wraps common features of SDL_Surface. Inherited from ZObject.
|
|
|
|
**/
|
2003-02-10 04:02:38 +00:00
|
|
|
class ZImage
|
2002-12-01 07:56:17 +00:00
|
|
|
{
|
|
|
|
protected:
|
2003-02-10 04:02:38 +00:00
|
|
|
//! Pointer to ZEngine Object
|
|
|
|
ZEngine* rEngine;
|
2003-08-01 21:57:32 +00:00
|
|
|
//! Stored texture.
|
|
|
|
SDL_Surface *rImage;
|
|
|
|
//! Stored alpha value for drawing texture.
|
|
|
|
Uint8 rAlpha;
|
2003-08-02 01:18:45 +00:00
|
|
|
#if (GFX_BACKEND == ZE_OGL)
|
2002-12-02 05:18:52 +00:00
|
|
|
//! Texture lower X, used internally for flip.
|
|
|
|
GLfloat rTexMinX;
|
|
|
|
//! Texture lower Y, used internally for flip
|
|
|
|
GLfloat rTexMinY;
|
2002-12-01 07:56:17 +00:00
|
|
|
//! Texture X width ratio, used internally by OpenGL.
|
|
|
|
GLfloat rTexMaxX;
|
|
|
|
//! Texture Y width ratio, used internally by OpenGL.
|
|
|
|
GLfloat rTexMaxY;
|
|
|
|
//! Texture ID for OpenGL.
|
|
|
|
unsigned int rTexID;
|
|
|
|
//! Current draw width of Texture.
|
2003-08-07 05:54:45 +00:00
|
|
|
GLfloat rWidth;
|
2002-12-01 07:56:17 +00:00
|
|
|
//! Current draw height of Texture.
|
2003-08-07 05:54:45 +00:00
|
|
|
GLfloat rHeight;
|
2003-08-01 21:57:32 +00:00
|
|
|
#endif //GFX_BACKEND == OGL
|
2002-12-01 07:56:17 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Default Constructor.
|
|
|
|
|
|
|
|
Default Constructor, initializes variables.
|
|
|
|
**/
|
|
|
|
ZImage();
|
|
|
|
|
2003-01-18 22:22:37 +00:00
|
|
|
/*!
|
|
|
|
\brief Copy constructor for ZImage.
|
|
|
|
|
|
|
|
Creates one ZImage using another.
|
|
|
|
\param rhs A previously created ZImage to copy.
|
|
|
|
**/
|
2003-01-24 02:47:06 +00:00
|
|
|
ZImage(const ZImage &rhs);
|
2003-01-18 22:22:37 +00:00
|
|
|
|
2002-12-01 07:56:17 +00:00
|
|
|
/*!
|
|
|
|
\brief Constructor to Construct from File.
|
|
|
|
|
|
|
|
Constructor is same as calling ZImage::Open() on passed filename.
|
|
|
|
\param filename File to open as rImage.
|
|
|
|
**/
|
2003-06-11 00:15:07 +00:00
|
|
|
ZImage(std::string filename);
|
2002-12-01 07:56:17 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Constructor to Construct from SDL_Surface*.
|
|
|
|
|
|
|
|
Constructor is same as calling ZImage::Attach() on passed SDL_Surface*.
|
|
|
|
\param surface SDL_Surface* to use as rImage.
|
|
|
|
**/
|
|
|
|
ZImage(SDL_Surface *surface);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Constructor to Construct from part of an SDL_Surface*.
|
|
|
|
|
2003-02-10 04:55:48 +00:00
|
|
|
Constructor is same as calling ZImage::OpenFromImage with an SDL_Surface*.
|
2002-12-01 07:56:17 +00:00
|
|
|
|
|
|
|
\param img Image to take new image from.
|
|
|
|
\param x X Coordinate in source of top left corner.
|
|
|
|
\param y Y Coordinate in source of top left corner.
|
|
|
|
\param w Width of new image.
|
|
|
|
\param h Height of new image.
|
|
|
|
**/
|
|
|
|
ZImage(SDL_Surface *img, Sint16 x, Sint16 y, Sint16 w, Sint16 h);
|
|
|
|
|
2003-02-10 04:55:48 +00:00
|
|
|
/*!
|
|
|
|
\brief Constructor to Construct from part of another ZImage.
|
|
|
|
|
|
|
|
Constructor is same as calling ZImage::OpenFromImage with a ZImage.
|
|
|
|
|
|
|
|
\param img Image to take new image from.
|
|
|
|
\param x X Coordinate in source of top left corner.
|
|
|
|
\param y Y Coordinate in source of top left corner.
|
|
|
|
\param w Width of new image.
|
|
|
|
\param h Height of new image.
|
|
|
|
**/
|
|
|
|
ZImage(const ZImage &img, Sint16 x, Sint16 y, Sint16 w, Sint16 h);
|
|
|
|
|
2002-12-01 07:56:17 +00:00
|
|
|
/*!
|
|
|
|
\brief Destructor, frees memory.
|
|
|
|
|
|
|
|
Destructor calls ZImage::Release().
|
|
|
|
**/
|
2003-02-10 04:40:16 +00:00
|
|
|
virtual ~ZImage();
|
2002-12-01 07:56:17 +00:00
|
|
|
|
|
|
|
///////////////////////
|
|
|
|
//Opening and Closing//
|
|
|
|
///////////////////////
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Opens a file.
|
|
|
|
|
|
|
|
Open a file using ZEngine. Loads into rImage member of class.
|
|
|
|
\param filename File to open as rImage.
|
|
|
|
**/
|
2003-06-11 00:15:07 +00:00
|
|
|
void Open(std::string filename);
|
2002-12-01 07:56:17 +00:00
|
|
|
|
|
|
|
/*!
|
2003-02-10 04:55:48 +00:00
|
|
|
\brief Cuts part of an existing image to create a new image.
|
2002-12-01 07:56:17 +00:00
|
|
|
|
|
|
|
Cut part of an SDL_Surface to create a new Image.
|
|
|
|
|
2003-02-10 04:55:48 +00:00
|
|
|
\param img SDL_Surface* to take new image from.
|
2002-12-01 07:56:17 +00:00
|
|
|
\param x X Coordinate in source of top left corner.
|
|
|
|
\param y Y Coordinate in source of top left corner.
|
|
|
|
\param w Width of new image.
|
|
|
|
\param h Height of new image.
|
|
|
|
**/
|
|
|
|
void OpenFromImage(SDL_Surface *img, Sint16 x, Sint16 y, Sint16 w, Sint16 h);
|
|
|
|
|
2003-02-10 04:55:48 +00:00
|
|
|
/*!
|
|
|
|
\brief Cuts part of an existing ZImage to create a new image.
|
|
|
|
|
|
|
|
Cut part of another ZImage to create a new Image.
|
|
|
|
|
|
|
|
\param img ZImage to take new image from.
|
|
|
|
\param x X Coordinate in source of top left corner.
|
|
|
|
\param y Y Coordinate in source of top left corner.
|
|
|
|
\param w Width of new image.
|
|
|
|
\param h Height of new image.
|
|
|
|
**/
|
|
|
|
void OpenFromImage(const ZImage &img, Sint16 x, Sint16 y, Sint16 w, Sint16 h);
|
|
|
|
|
2002-12-01 07:56:17 +00:00
|
|
|
/*!
|
|
|
|
\brief Attach an existing surface to class.
|
|
|
|
|
|
|
|
Attach a pointer to instance of ZImage. (NOTE: Should not be used on a surface that is owned elsewhere.)
|
|
|
|
\param surface SDL_Surface* to use as rImage.
|
|
|
|
**/
|
|
|
|
void Attach(SDL_Surface *surface);
|
|
|
|
|
2002-12-29 07:22:01 +00:00
|
|
|
/*!
|
2002-12-27 18:56:17 +00:00
|
|
|
\brief Reattach a preloaded texture that has been lost.
|
|
|
|
|
|
|
|
Attach loaded textures which have been lost due to loss of focus, should be called when ZEngine::ImagesNeedReload is true.
|
|
|
|
**/
|
|
|
|
void Reload();
|
|
|
|
|
2002-12-01 07:56:17 +00:00
|
|
|
/*!
|
|
|
|
\brief Releases image.
|
|
|
|
|
|
|
|
Frees memory via call to SDL_FreeSurface for the image.
|
|
|
|
**/
|
|
|
|
void Release();
|
|
|
|
|
|
|
|
////////////
|
|
|
|
//Graphics//
|
|
|
|
////////////
|
|
|
|
|
|
|
|
/*!
|
2003-01-25 19:56:05 +00:00
|
|
|
\brief Set alpha value (translucency) of image.
|
|
|
|
|
|
|
|
Set translucency value 0-255 (0 is transparent, 255 = opaque).
|
|
|
|
\since 0.8.2
|
|
|
|
\param alpha Number 0-255 setting translucency for image.
|
|
|
|
**/
|
|
|
|
void SetAlpha(Uint8 alpha);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Set Color Key (transparent color) of image.
|
2002-12-01 07:56:17 +00:00
|
|
|
|
|
|
|
Set color which will not be drawn in image.
|
|
|
|
\param red Red component of colorkey (0-255).
|
|
|
|
\param green Green component of colorkey (0-255).
|
|
|
|
\param blue Blue component of colorkey (0-255).
|
|
|
|
**/
|
|
|
|
void SetColorKey(Uint8 red, Uint8 green, Uint8 blue);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Draw Image to Screen.
|
|
|
|
|
|
|
|
Draw Image to screen at specified location.
|
|
|
|
\param x X coord to draw Image to.
|
|
|
|
\param y Y coord to draw Image to.
|
|
|
|
**/
|
2003-02-10 05:15:33 +00:00
|
|
|
void Draw(int x, int y) const;
|
|
|
|
|
2003-08-02 01:18:45 +00:00
|
|
|
#if (GFX_BACKEND == ZE_OGL)
|
2003-02-10 05:15:33 +00:00
|
|
|
/*!
|
|
|
|
\brief Draw Image to Screen.
|
|
|
|
|
|
|
|
Draw Image to screen at specified location.
|
|
|
|
\since 0.8.3
|
|
|
|
\param x X coord to draw Image to.
|
|
|
|
\param y Y coord to draw Image to.
|
|
|
|
**/
|
2003-01-16 05:45:58 +00:00
|
|
|
void Draw(float x, float y) const;
|
2002-12-02 00:36:35 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Draw Image rotated to screen.
|
|
|
|
|
|
|
|
Image is rotated about it's own center by specified angle, then drawn to screen.
|
|
|
|
\param x X coord to draw Image to.
|
|
|
|
\param y Y coord to draw Image to.
|
|
|
|
\param angle Angle in degrees to rotate image.
|
|
|
|
**/
|
2003-01-16 05:45:58 +00:00
|
|
|
void DrawRotated(int x, int y, float angle) const;
|
2002-12-01 07:56:17 +00:00
|
|
|
|
2003-02-10 05:15:33 +00:00
|
|
|
/*!
|
|
|
|
\brief Draw Image rotated to screen.
|
|
|
|
|
|
|
|
Image is rotated about it's own center by specified angle, then drawn to screen.
|
2003-02-10 05:26:17 +00:00
|
|
|
\since 0.8.3
|
2003-02-10 05:15:33 +00:00
|
|
|
\param x X coord to draw Image to.
|
|
|
|
\param y Y coord to draw Image to.
|
|
|
|
\param angle Angle in degrees to rotate image.
|
|
|
|
**/
|
|
|
|
void DrawRotated(float x, float y, float angle) const;
|
|
|
|
|
2003-08-01 21:57:32 +00:00
|
|
|
/*!
|
|
|
|
\brief Flip image over one or both axes.
|
|
|
|
|
|
|
|
Flip image vertical and/or horizontal.
|
|
|
|
\param horizontal Boolean, true will flip image horizontally.
|
|
|
|
\param vertical Boolean, true will flip image vertically.
|
|
|
|
**/
|
|
|
|
void Flip(bool horizontal, bool vertical);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Stretch the image by a certain X and Y factor.
|
|
|
|
|
|
|
|
Stretch image using a factor to multiply width and height by.
|
|
|
|
\param xFactor Stretch factor for width. [newWidth = oldWidth * xStretch]
|
|
|
|
\param yFactor Stretch factor for height. [newHeight = oldHeight * yStretch]
|
|
|
|
**/
|
|
|
|
void Stretch(float xFactor, float yFactor);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Resizes an image, stretching to new size.
|
|
|
|
|
|
|
|
Stretch image to new width and height.
|
|
|
|
\param width New width to stretch image to.
|
|
|
|
\param height New height to stretch image to.
|
|
|
|
**/
|
2003-08-07 05:54:45 +00:00
|
|
|
void Resize(float width, float height);
|
2003-08-01 21:57:32 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief OpenGL related bind call.
|
|
|
|
|
|
|
|
OpenGL related bind call, only available in case you want to bind image in 3D.
|
|
|
|
Draw uses this but the average user should never need to call this.
|
|
|
|
**/
|
|
|
|
void Bind() const;
|
|
|
|
#endif //GFX_BACKEND == OGL
|
|
|
|
|
2002-12-01 07:56:17 +00:00
|
|
|
/////////////
|
|
|
|
//Accessors//
|
|
|
|
/////////////
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Check if file is loaded.
|
|
|
|
|
2002-12-27 18:56:17 +00:00
|
|
|
Check if surface is a valid GL texture. (does not detect surface loss)
|
2002-12-01 07:56:17 +00:00
|
|
|
\return Loaded or Unloaded state of data.
|
|
|
|
**/
|
2003-01-16 05:45:58 +00:00
|
|
|
bool IsLoaded() const;
|
2002-12-01 07:56:17 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Get SDL_Surface.
|
|
|
|
Get SDL_Surface pointer to actual image data.
|
|
|
|
\return SDL_Surface* of rImage.
|
|
|
|
**/
|
2003-01-16 05:45:58 +00:00
|
|
|
SDL_Surface *Surface() const;
|
2002-12-01 07:56:17 +00:00
|
|
|
|
2003-08-07 05:54:45 +00:00
|
|
|
#if (GFX_BACKEND == ZE_OGL)
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Get Width.
|
|
|
|
|
|
|
|
Get Current Width of Image.
|
|
|
|
\return Image Width.
|
|
|
|
**/
|
|
|
|
float Width() const;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Get Height.
|
|
|
|
|
|
|
|
Get Current Height of Image.
|
|
|
|
\return Image Height.
|
|
|
|
**/
|
|
|
|
float Height() const;
|
|
|
|
|
|
|
|
#elif (GFX_BACKEND == ZE_SDL)
|
2002-12-01 07:56:17 +00:00
|
|
|
/*!
|
|
|
|
\brief Get Width.
|
|
|
|
|
|
|
|
Get Current Width of Image.
|
|
|
|
\return Image Width.
|
|
|
|
**/
|
2003-01-16 05:45:58 +00:00
|
|
|
int Width() const;
|
2002-12-01 07:56:17 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Get Height.
|
|
|
|
|
|
|
|
Get Current Height of Image.
|
|
|
|
\return Image Height.
|
|
|
|
**/
|
2003-01-16 05:45:58 +00:00
|
|
|
int Height() const;
|
2003-08-07 05:54:45 +00:00
|
|
|
#endif //GFX_BACKEND
|
2003-01-25 19:56:05 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Get Alpha component.
|
|
|
|
|
|
|
|
Get current alpha value of image.
|
|
|
|
\since 0.8.2
|
|
|
|
\return Image Alpha.
|
|
|
|
**/
|
|
|
|
Uint8 Alpha() const;
|
2002-12-01 07:56:17 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|