/*******************************************************************************
This file is Part of the ZEngine Library for SDL Game Development.
Copyright (C) 2002 ConceptOfZero.net
Licensed under the BSD License, see licensing.txt.
The maintainer of this library is James Turk (james@conceptofzero.net)
and the home of this Library is http://www.conceptofzero.net/
*******************************************************************************/
/*!
\par File Header:
File: ZE_ZImage.cpp
Description: Implementation source file for core ZEngine Image or Texture Object.
Author(s): James Turk, Gamer Tazar
$Id: ZE_ZImage.cpp,v 1.5 2002/12/02 05:18:52 cozman Exp $
\file ZE_ZImage.cpp
\brief Source file for ZImage.
Implementation of ZImage, the Image class for ZEngine.
**/
#include "ZE_ZImage.h"
namespace ZE
{
ZImage::ZImage()
{
rImage = NULL;
Release();
}
ZImage::ZImage(string filename)
{
rImage = NULL;
Open(filename);
}
ZImage::ZImage(SDL_Surface *surface)
{
rImage = NULL;
Attach(surface);
}
ZImage::ZImage(SDL_Surface *img, Sint16 x, Sint16 y, Sint16 w, Sint16 h)
{
rImage = NULL;
OpenFromImage(img,x,y,w,h);
}
ZImage::~ZImage()
{
Release();
}
void ZImage::Open(string filename)
{
SDL_Surface *image;
Release();
image = rEngine->LoadImage(filename.c_str());
Attach(image);
}
void ZImage::OpenFromImage(SDL_Surface *image, Sint16 x, Sint16 y, Sint16 w, Sint16 h)
{
SDL_Surface *screen = rEngine->Display();
SDL_Surface *cutImg = NULL;
SDL_Rect rect;
SDL_VideoInfo *videoInfo;
Release();
//either set hardware or software surface//
videoInfo = const_cast(SDL_GetVideoInfo());
rect.x = x;
rect.y = y;
rect.w = w;
rect.h = h;
if(!image)
LogError("Invalid Parameter to ZImage::OpenFromImage.");
cutImg = SDL_CreateRGBSurface(0, rect.w, rect.h, rEngine->BPP(),
screen->format->Rmask, screen->format->Gmask, screen->format->Bmask, screen->format->Amask);
if(!cutImg)
LogError(FormatStr("SDL_CreateRGBSurface failed in ZImage::OpenFromImage."));
SDL_BlitSurface(image,&rect,cutImg,NULL);
Attach(cutImg);
}
void ZImage::Attach(SDL_Surface *surface)
{
GLfloat coord[4];
if(surface)
{
rWidth = surface->w;
rHeight = surface->h;
rTexID = SDL_GL_LoadTexture(surface,coord);
rTexMinX = coord[0];
rTexMinY = coord[1];
rTexMaxX = coord[2];
rTexMaxY = coord[3];
rImage = surface;
}
else
LogError("Invalid surface passed to ZImage::Attach.");
}
void ZImage::Release()
{
if(glIsTexture(rTexID))
glDeleteTextures(1,&rTexID);
rTexMinX = rTexMinY = rTexMaxX = rTexMaxY = 0.0f;
rTexID = rWidth = rHeight = 0;
FreeImage(rImage);
}
void ZImage::SetColorKey(Uint8 red, Uint8 green, Uint8 blue)
{
SDL_Surface *temp=NULL;
Uint32 color = SDL_MapRGB(rEngine->Display()->format,red,green,blue);
if(rImage)
{
if(SDL_SetColorKey(rImage, SDL_SRCCOLORKEY, color) < 0)
LogError("Invalid Call to SDL_SetColorKey.");
else
{
//surface conversion//
temp = rImage;
rImage = SDL_DisplayFormatAlpha(temp);
if(rImage)
{
FreeImage(temp);
Attach(rImage); //Rebind new image.
}
else //can't convert
{
LogError("Surface conversion failed.");
rImage = temp;
}
}
}
else
LogError("ZImage not initialized in ZImage::SetColorKey.");
}
void ZImage::Flip(bool horizontal, bool vertical)
{
GLfloat temp;
if(horizontal)
{
temp = rTexMinX;
rTexMinX = rTexMaxX;
rTexMaxX = temp;
}
if(vertical)
{
temp = rTexMinY;
rTexMinY = rTexMaxY;
rTexMaxY = temp;
}
}
void ZImage::Stretch(float xFactor, float yFactor)
{
rWidth = static_cast(xFactor*rWidth);
rHeight = static_cast(yFactor*rHeight);
}
void ZImage::Resize(unsigned int width, unsigned int height)
{
rWidth = width;
rHeight = height;
}
void ZImage::Bind()
{
glBindTexture(GL_TEXTURE_2D, rTexID);
}
void ZImage::Draw(float x, float y)
{
Bind();
glBegin(GL_TRIANGLE_STRIP);
glTexCoord2f(rTexMinX,rTexMinY); glVertex2f(x,y);
glTexCoord2f(rTexMaxX,rTexMinY); glVertex2f(x+rWidth,y);
glTexCoord2f(rTexMinX,rTexMaxY); glVertex2f(x,y+rHeight);
glTexCoord2f(rTexMaxX,rTexMaxY); glVertex2f(x+rWidth,y+rHeight);
glEnd();
}
void ZImage::DrawRotated(int x, int y, float angle)
{
float cX,cY; //center variables
cX = rWidth/2.0f;
cY = rHeight/2.0f;
glPushMatrix();
glTranslatef(x+cX,y+cY,0);
glRotatef(angle,0,0,1.0f);
Bind();
glBegin(GL_TRIANGLE_STRIP);
glTexCoord2f(0.0f,0.0f); glVertex2f(-cX, -cY);
glTexCoord2f(rTexMaxX,0.0f); glVertex2f(-cX+rWidth, -cY);
glTexCoord2f(0.0f,rTexMaxY); glVertex2f(-cX, -cY+rHeight);
glTexCoord2f(rTexMaxX,rTexMaxY); glVertex2f(-cX+rWidth, -cY+rHeight);
glEnd();
glPopMatrix();
}
bool ZImage::IsLoaded()
{
return glIsTexture(rTexID) == GL_TRUE;
}
SDL_Surface* ZImage::Surface()
{
return rImage;
}
int ZImage::Width()
{
return rWidth;
}
int ZImage::Height()
{
return rHeight;
}
}