2024-04-20 15:57:49 +00:00
|
|
|
/*
|
|
|
|
* Descent 3
|
|
|
|
* Copyright (C) 2024 Parallax Software
|
|
|
|
*
|
|
|
|
* This program 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, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program 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/>.
|
|
|
|
*/
|
|
|
|
|
2024-04-16 03:43:29 +00:00
|
|
|
#ifndef REND_D3D_H
|
|
|
|
#define REND_D3D_H
|
|
|
|
|
|
|
|
#include "renderer.h"
|
|
|
|
#include "3d.h"
|
|
|
|
|
|
|
|
class oeApplication;
|
|
|
|
|
|
|
|
// Starts up glide
|
2024-04-16 18:56:40 +00:00
|
|
|
int d3d_Init(oeApplication *app, renderer_preferred_state *pref_state);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Closes down glide
|
|
|
|
void d3d_Close();
|
|
|
|
|
|
|
|
// The main drawing function...draws a flat/textured/gouraud polygon
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_DrawPolygon(int, g3Point **, int, int);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_SetFlatColor(ddgr_color color);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Ends a frame
|
|
|
|
void d3d_EndFrame();
|
|
|
|
|
|
|
|
// Flips the screen
|
|
|
|
void d3d_Flip();
|
|
|
|
|
|
|
|
// Does setup for a new frame
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_BeginFrame(int, int, int, int, int);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Tells glide what kind of texturing (linear/perspective) we want
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_SetTextureType(texture_type);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Sets the lighting state of glide
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_SetLightingState(light_state state);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Sets the glide color model (either rgb or mono)
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_SetColorModel(color_model state);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Sets the state of bilinear filtering for our textures
|
2024-05-24 03:05:05 +00:00
|
|
|
void d3d_SetFiltering(int8_t state);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Sets the state of zbuffering to on or off
|
2024-05-24 03:05:05 +00:00
|
|
|
void d3d_SetZBufferState(int8_t state);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Sets the near/far z values for zbuffering
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_SetZValues(float nearz, float farz);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Sets a bitmap as a lightmap to rendered on top of the next texture map
|
|
|
|
// a -1 value indicates no lighting map
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_SetLightingMap(int handle);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Clears the display to a specified color
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_ClearScreen(ddgr_color color);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Fills a rectangle on the display
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_FillRect(ddgr_color color, int x1, int y1, int x2, int y2);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Sets a pixel on the display
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_SetPixel(ddgr_color color, int x, int y);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Sets the near and far plane of fog
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_SetFogBorders(float nearz, float farz);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Sets the fog state to on or off
|
2024-05-24 03:05:05 +00:00
|
|
|
void d3d_SetFogState(int8_t state);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Draws a 2d line
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_DrawLine(int x1, int y1, int x2, int y2);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// sets fog color
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_SetFogColor(ddgr_color fogcolor);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// sets the alpha type
|
2024-05-24 03:05:05 +00:00
|
|
|
void d3d_SetAlphaType(int8_t);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Sets the constant alpha value
|
2024-05-24 03:07:26 +00:00
|
|
|
void d3d_SetAlphaValue(uint8_t val);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Sets the overall alpha scale factor (all alpha values are scaled by this value)
|
|
|
|
// usefull for motion blur effect
|
|
|
|
void d3d_SetAlphaFactor(float val);
|
|
|
|
|
|
|
|
// Returns the current Alpha factor
|
|
|
|
float d3d_GetAlphaFactor(void);
|
|
|
|
|
|
|
|
// Sets the glide wrapping type
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_SetWrapType(wrap_type val);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Takes a screenshot of the frontbuffer and puts it into the passed bitmap handle
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_Screenshot(int bm_handle);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Sets write mask for depth buffer
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_SetZBufferWriteMask(int state);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Locks the linear frame buffer for application access
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_GetLFBLock(renderer_lfb *lfb);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Releases the previous LFB lock
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_ReleaseLFBLock(renderer_lfb *lfb);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_GetProjectionParameters(int *width, int *height);
|
2024-04-16 03:43:29 +00:00
|
|
|
float d3d_GetAspectRatio();
|
|
|
|
|
|
|
|
// Draws a line using the states set by the renderer lib
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_DrawSpecialLine(g3Point *p0, g3Point *p1);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
2024-05-24 03:05:05 +00:00
|
|
|
void d3d_SetMipState(int8_t);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Sets up a some global preferences for glide
|
2024-04-16 18:56:40 +00:00
|
|
|
int d3d_SetPreferredState(renderer_preferred_state *pref_state);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Sets the gamma correction value
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_SetGammaValue(float val);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Gets the current state of the renderer
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_GetRenderState(rendering_state *rstate);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Sets the resolution that glide uses
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_SetResolution(int width, int height);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Sets the coplanar z bias for rendered polygons
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_SetCoplanarPolygonOffset(float factor);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Creates a on the video card if needed
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_PreUploadTextureToCard(int handle, int map_type);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Evicts local texture memory
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_FreePreUploadedTexture(int handle, int map_type);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Returns a string describing the passed in error
|
2024-04-28 04:39:29 +00:00
|
|
|
const char *d3d_ErrorString(int error);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Takes a screenshot of the frontbuffer and puts it into the passed bitmap handle
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_Screenshot(int bm_handle);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Returns 1 if the renderer supports bumpmapping
|
2024-04-16 18:56:40 +00:00
|
|
|
int d3d_SupportsBumpmapping();
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Clears the zbuffer
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_ClearZBuffer();
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Clears the texture cache
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_ResetCache();
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Creates or destroys a linear framebuffer lock
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_GetLFBLock(renderer_lfb *lfb);
|
|
|
|
void d3d_ReleaseLFBLock(renderer_lfb *lfb);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Takes a bitmap and blits it to the screen using linear frame buffer stuff
|
|
|
|
// X and Y are the destination X,Y
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_CopyBitmapToFramebuffer(int bm_handle, int x, int y);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
// Gets a renderer ready for a framebuffer copy, or stops a framebuffer copy
|
2024-04-16 18:56:40 +00:00
|
|
|
void d3d_SetFrameBufferCopyState(bool state);
|
2024-04-16 03:43:29 +00:00
|
|
|
|
|
|
|
#if defined(WIN32)
|
|
|
|
// returns directdraw object
|
|
|
|
void *d3d_DirectDrawObj(void **frontsurf, void **backsurf);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// returns rendering statistics for the frame
|
|
|
|
void d3d_GetStatistics(tRendererStats *stats);
|
|
|
|
|
|
|
|
#endif
|