5#ifndef JPP_I_VIDEO_DRIVER_HPP_INCLUDED
6#define JPP_I_VIDEO_DRIVER_HPP_INCLUDED
8#include <jimcpp/core/engine/rect.hpp>
9#include <jimcpp/core/engine/SColor.hpp>
10#include <jimcpp/core/engine/ITexture.hpp>
11#include <jimcpp/core/engine/irrArray.hpp>
12#include <jimcpp/core/engine/matrix4.hpp>
13#include <jimcpp/core/engine/plane3d.hpp>
14#include <jimcpp/core/engine/dimension2d.hpp>
15#include <jimcpp/core/engine/position2d.hpp>
16#include <jimcpp/core/engine/IMeshBuffer.hpp>
17#include <jimcpp/core/engine/triangle3d.hpp>
18#include <jimcpp/core/engine/EDriverTypes.hpp>
19#include <jimcpp/core/engine/EDriverFeatures.hpp>
20#include <jimcpp/core/engine/SExposedVideoData.hpp>
21#include <jimcpp/core/engine/SOverrideMaterial.hpp>
28 class SAttributeReadWriteOptions;
36 class IMeshManipulator;
43 class S3DVertex2TCoords;
44 class S3DVertexTangents;
48 class IMaterialRenderer;
49 class IGPUProgrammingServices;
69#if _JPP_MATERIAL_MAX_TEXTURES_>4
72#if _JPP_MATERIAL_MAX_TEXTURES_>5
75#if _JPP_MATERIAL_MAX_TEXTURES_>6
78#if _JPP_MATERIAL_MAX_TEXTURES_>7
124 ECBF_ALL = ECBF_COLOR|ECBF_DEPTH|ECBF_STENCIL
135 const c8*
const FogTypeNames[] =
184 return beginScene(flag, color, 1.f, 0, videoData, sourceRect);
493 bool zeroTexels =
false)
const =0;
510 bool zeroTexels =
false)
const =0;
542 f32 clearDepth = 1.f,
u8 clearStencil = 0) = 0;
574 f32 clearDepth = 1.f,
u8 clearStencil = 0) = 0;
618 const void* indexList,
u32 primCount,
621 E_INDEX_TYPE iType=EIT_16BIT) =0;
644 const void* indexList,
u32 primCount,
647 E_INDEX_TYPE iType=EIT_16BIT) =0;
659 u32 vertexCount,
const u16* indexList,
u32 triangleCount)
674 u32 vertexCount,
const u16* indexList,
u32 triangleCount)
689 u32 vertexCount,
const u16* indexList,
u32 triangleCount)
704 u32 vertexCount,
const u16* indexList,
u32 triangleCount)
719 u32 vertexCount,
const u16* indexList,
u32 triangleCount)
734 u32 vertexCount,
const u16* indexList,
u32 triangleCount)
816 SColor color=
SColor(255,255,255,255),
bool useAlphaChannelOfTexture=
false) =0;
845 bool useAlphaChannelOfTexture=
false) =0;
868 bool useAlphaChannelOfTexture=
false) =0;
882 const video::SColor *
const colors=0,
bool useAlphaChannelOfTexture=
false) =0;
959 s32 vertexCount=10) =0;
1033 f32 start=50.0f,
f32 end=100.0f,
f32 density=0.01f,
1034 bool pixelFog=
false,
bool rangeFog=
false) =0;
1039 bool& pixelFog,
bool& rangeFog) = 0;
1180 for (
u32 i = 1; i < imageArray.size(); ++i)
1181 imageArray[i]->
drop();
1183 return (imageArray.size() > 0) ? imageArray[0] : 0;
1198 for (
u32 i = 1; i < imageArray.size(); ++i)
1199 imageArray[i]->
drop();
1201 return (imageArray.size() > 0) ? imageArray[0] : 0;
1245 bool deleteMemory =
true) = 0;
1414 flag |= ECBF_STENCIL;
Base class of most objects of the Jimcpp Engine.
Definition IReferenceCounted.hpp:46
bool drop() const
Drops the object. Decrements the reference counter by one.
Definition IReferenceCounted.hpp:126
4x4 matrix. Mostly used as transformation matrix for 3d calculations.
Definition matrix4.hpp:49
Axis aligned bounding box in 3d dimensional space.
Definition aabbox3d.hpp:22
Self reallocating template array (like stl vector) with additional features.
Definition irrArray.hpp:23
Provides a generic interface for attributes and their values and the possibility to serialize them.
Definition IAttributes.hpp:42
Interface providing read access to a file.
Definition IReadFile.hpp:19
Interface providing write access to a file.
Definition IWriteFile.hpp:18
class holding data describing options
Definition IAttributeExchangingObject.hpp:35
Class for holding a mesh with a single material.
Definition IMeshBuffer.hpp:41
An interface for easy manipulation of meshes.
Definition IMeshManipulator.hpp:30
Class which holds the geometry of an object.
Definition IMesh.hpp:72
Scene node interface.
Definition ISceneNode.hpp:43
Interface making it possible to create and use programs running on the GPU.
Definition IGPUProgrammingServices.hpp:29
Class which is able to create a image from a file.
Definition IImageLoader.hpp:29
Interface for writing software image data.
Definition IImageWriter.hpp:26
Interface for software image data.
Definition IImage.hpp:26
void setMipMapsData(void *data, bool ownForeignMemory, bool deleteMemory)
Set mipmaps data.
Definition IImage.hpp:277
Interface for material rendering.
Definition IMaterialRenderer.hpp:26
Interface of a Render Target.
Definition IRenderTarget.hpp:31
Interface of a Video Driver dependent Texture.
Definition ITexture.hpp:186
Interface to driver which is able to perform 2d and 3d graphics functions.
Definition IVideoDriver.hpp:152
virtual void updateAllOcclusionQueries(bool block=true)=0
Update all occlusion queries. Retrieves results from GPU.
virtual void removeOcclusionQuery(scene::ISceneNode *node)=0
Remove occlusion query.
void drawIndexedTriangleList(const S3DVertex2TCoords *vertices, u32 vertexCount, const u16 *indexList, u32 triangleCount)
Draws an indexed triangle list.
Definition IVideoDriver.hpp:673
virtual ECOLOR_FORMAT getColorFormat() const =0
Get the current color format of the color buffer.
virtual E_DRIVER_TYPE getDriverType() const =0
Get type of video driver.
virtual void drawPixel(u32 x, u32 y, const SColor &color)=0
Draws a pixel.
virtual ITexture * addTextureCubemap(const jpp::u32 sideLen, const io::path &name, ECOLOR_FORMAT format=ECF_A8R8G8B8)=0
Creates an empty cubemap texture of specified size.
virtual void enableClipPlane(u32 index, bool enable)=0
Enable or disable a clipping plane.
virtual JPP_DEPRECATED IImage * createImage(IImage *imageToCopy, const core::position2d< s32 > &pos, const core::dimension2d< u32 > &size)=0
Creates a software image from a part of another image.
virtual bool getTextureCreationFlag(E_TEXTURE_CREATION_FLAG flag) const =0
Returns if a texture creation flag is enabled or disabled.
virtual void removeRenderTarget(IRenderTarget *renderTarget)=0
Remove render target.
virtual IImageWriter * getImageWriter(u32 n)=0
Retrieve the given image writer.
virtual void setMinHardwareBufferVertexCount(u32 count)=0
Set the minimum number of vertices for which a hw buffer will be created.
virtual void drawMeshBufferNormals(const scene::IMeshBuffer *mb, f32 length=10.f, SColor color=0xffffffff)=0
Draws normals of a mesh buffer.
void drawIndexedTriangleFan(const S3DVertex2TCoords *vertices, u32 vertexCount, const u16 *indexList, u32 triangleCount)
Draws an indexed triangle fan.
Definition IVideoDriver.hpp:718
JPP_DEPRECATED void clearBuffers(bool backBuffer, bool depthBuffer, bool stencilBuffer, SColor color)
Clear the color, depth and/or stencil buffers.
Definition IVideoDriver.hpp:1403
virtual ITexture * addTexture(const io::path &name, IImage *image)=0
Creates a texture from an IImage.
virtual void enableMaterial2D(bool enable=true)=0
Enable the 2d override material.
virtual void removeAllTextures()=0
Removes all textures from the texture cache and deletes them.
virtual void removeTexture(ITexture *texture)=0
Removes a texture from the texture cache and deletes it.
virtual void runAllOcclusionQueries(bool visible=false)=0
Run all occlusion queries. Draws all meshes stored in queries.
virtual video::ITexture * findTexture(const io::path &filename)=0
Check if the image is already loaded.
virtual JPP_DEPRECATED IImage * createImage(ECOLOR_FORMAT format, IImage *imageToCopy)=0
Creates a software image by converting it to given format from another image.
virtual void renameTexture(ITexture *texture, const io::path &newName)=0
Renames a texture.
virtual void clearBuffers(u16 flag, SColor color=SColor(255, 0, 0, 0), f32 depth=1.f, u8 stencil=0)=0
Clear the color, depth and/or stencil buffers.
virtual void draw3DLine(const core::vector3df &start, const core::vector3df &end, SColor color=SColor(255, 255, 255, 255))=0
Draws a 3d line.
virtual void setMaterial(const SMaterial &material)=0
Sets a material.
bool setRenderTarget(ITexture *texture, bool clearBackBuffer, bool clearZBuffer, SColor color=SColor(255, 0, 0, 0))
Definition IVideoDriver.hpp:579
virtual void draw2DLine(const core::position2d< s32 > &start, const core::position2d< s32 > &end, SColor color=SColor(255, 255, 255, 255))=0
Draws a 2d line.
virtual void removeAllHardwareBuffers()=0
Remove all hardware buffers.
virtual void removeAllOcclusionQueries()=0
Remove all occlusion queries.
JPP_DEPRECATED ITexture * addTexture(const io::path &name, IImage *image, void *mipmapData)
Creates a texture from an IImage.
Definition IVideoDriver.hpp:333
virtual const c8 * getMaterialRendererName(u32 idx) const =0
Get name of a material renderer.
virtual bool setRenderTargetEx(IRenderTarget *target, u16 clearFlag, SColor clearColor=SColor(255, 0, 0, 0), f32 clearDepth=1.f, u8 clearStencil=0)=0
Set a render target.
virtual void addExternalImageLoader(IImageLoader *loader)=0
Adds an external image loader to the engine.
virtual bool endScene()=0
Presents the rendered image to the screen.
IImage * createImageFromFile(io::IReadFile *file)
Creates a software image from a file.
Definition IVideoDriver.hpp:1194
virtual IMaterialRenderer * getMaterialRenderer(u32 idx) const =0
Get access to a material renderer by index.
virtual u32 getOcclusionQueryResult(const scene::ISceneNode *node) const =0
Return query result.
virtual void draw3DTriangle(const core::triangle3df &triangle, SColor color=SColor(255, 255, 255, 255))=0
Draws a 3d triangle.
void clearZBuffer()
Clears the ZBuffer.
Definition IVideoDriver.hpp:1426
virtual ITexture * getTexture(io::IReadFile *file)=0
Get access to a named texture.
virtual void drawMeshBuffer(const scene::IMeshBuffer *mb)=0
Draws a mesh buffer.
virtual void drawStencilShadow(bool clearStencilBuffer=false, video::SColor leftUpEdge=video::SColor(255, 0, 0, 0), video::SColor rightUpEdge=video::SColor(255, 0, 0, 0), video::SColor leftDownEdge=video::SColor(255, 0, 0, 0), video::SColor rightDownEdge=video::SColor(255, 0, 0, 0))=0
Fills the stencil shadow with color.
virtual void draw2DImage(const video::ITexture *texture, const core::position2d< s32 > &destPos, bool useAlphaChannelOfTexture=false)=0
Draws a 2d image without any special effects.
virtual s32 getFPS() const =0
Returns current frames per second value.
virtual void removeHardwareBuffer(const scene::IMeshBuffer *mb)=0
Remove hardware buffer.
virtual IImage * createScreenShot(video::ECOLOR_FORMAT format=video::ECF_UNKNOWN, video::E_RENDER_TARGET target=video::ERT_FRAME_BUFFER)=0
Make a screenshot of the last rendered frame.
virtual void removeAllRenderTargets()=0
Remove all render targets.
virtual SOverrideMaterial & getOverrideMaterial()=0
Get the global Material, which might override local materials.
void drawIndexedTriangleFan(const S3DVertexTangents *vertices, u32 vertexCount, const u16 *indexList, u32 triangleCount)
Draws an indexed triangle fan.
Definition IVideoDriver.hpp:733
virtual IImage * createImageFromData(ECOLOR_FORMAT format, const core::dimension2d< u32 > &size, void *data, bool ownForeignMemory=false, bool deleteMemory=true)=0
Creates a software image from a byte array.
virtual void draw2DVertexPrimitiveList(const void *vertices, u32 vertexCount, const void *indexList, u32 primCount, E_VERTEX_TYPE vType=EVT_STANDARD, scene::E_PRIMITIVE_TYPE pType=scene::EPT_TRIANGLES, E_INDEX_TYPE iType=EIT_16BIT)=0
Draws a vertex primitive list in 2d.
virtual void draw2DPolygon(core::position2d< s32 > center, f32 radius, video::SColor color=SColor(100, 255, 255, 255), s32 vertexCount=10)=0
Draws a non filled concyclic regular 2d polygon.
virtual void swapMaterialRenderers(u32 idx1, u32 idx2, bool swapNames=true)=0
Swap the material renderers used for certain id's.
virtual void turnLightOn(s32 lightIndex, bool turnOn)=0
virtual SMaterial & getMaterial2D()=0
Get the 2d override material for altering its values.
virtual IImage * createImage(ECOLOR_FORMAT format, const core::dimension2d< u32 > &size)=0
Creates an empty software image.
virtual core::array< IImage * > createImagesFromFile(const io::path &filename, E_TEXTURE_TYPE *type=0)=0
Creates a software images from a file.
virtual const core::matrix4 & getTransform(E_TRANSFORMATION_STATE state) const =0
Returns the transformation set by setTransform.
virtual bool queryFeature(E_VIDEO_DRIVER_FEATURE feature) const =0
Queries the features of the driver.
virtual void draw3DBox(const core::aabbox3d< f32 > &box, SColor color=SColor(255, 255, 255, 255))=0
Draws a 3d axis aligned box.
virtual void disableFeature(E_VIDEO_DRIVER_FEATURE feature, bool flag=true)=0
Disable a feature of the driver.
virtual ITexture * getTexture(const io::path &filename)=0
Get access to a named texture.
virtual u32 getImageLoaderCount() const =0
Retrieve the number of image loaders.
virtual const SLight & getDynamicLight(u32 idx) const =0
Returns light data which was previously set by IVideoDriver::addDynamicLight().
virtual void makeColorKeyTexture(video::ITexture *texture, core::position2d< s32 > colorKeyPixelPos, bool zeroTexels=false) const =0
Sets a boolean alpha channel on the texture based on the color at a position.
virtual void setTextureCreationFlag(E_TEXTURE_CREATION_FLAG flag, bool enabled=true)=0
Enables or disables a texture creation flag.
virtual u32 getTextureCount() const =0
Returns amount of textures currently loaded.
virtual u32 getPrimitiveCountDrawn(u32 mode=0) const =0
Returns amount of primitives (mostly triangles) which were drawn in the last frame.
virtual void draw2DImage(const video::ITexture *texture, const core::position2d< s32 > &destPos, const core::rect< s32 > &sourceRect, const core::rect< s32 > *clipRect=0, SColor color=SColor(255, 255, 255, 255), bool useAlphaChannelOfTexture=false)=0
Draws a 2d image using a color.
virtual bool setRenderTarget(ITexture *texture, u16 clearFlag=ECBF_COLOR|ECBF_DEPTH, SColor clearColor=SColor(255, 0, 0, 0), f32 clearDepth=1.f, u8 clearStencil=0)=0
Sets a new render target.
virtual void makeColorKeyTexture(video::ITexture *texture, video::SColor color, bool zeroTexels=false) const =0
Sets a boolean alpha channel on the texture based on a color key.
virtual void getFog(SColor &color, E_FOG_TYPE &fogType, f32 &start, f32 &end, f32 &density, bool &pixelFog, bool &rangeFog)=0
Gets the fog mode.
virtual const core::dimension2d< u32 > & getScreenSize() const =0
Get the size of the screen or render window.
virtual bool needsTransparentRenderPass(const jpp::video::SMaterial &material) const =0
Used by some SceneNodes to check if a material should be rendered in the transparent render pass.
virtual bool writeImageToFile(IImage *image, const io::path &filename, u32 param=0)=0
Writes the provided image to a file.
virtual void drawVertexPrimitiveList(const void *vertices, u32 vertexCount, const void *indexList, u32 primCount, E_VERTEX_TYPE vType=EVT_STANDARD, scene::E_PRIMITIVE_TYPE pType=scene::EPT_TRIANGLES, E_INDEX_TYPE iType=EIT_16BIT)=0
Draws a vertex primitive list.
virtual ITexture * addTexture(const core::dimension2d< u32 > &size, const io::path &name, ECOLOR_FORMAT format=ECF_A8R8G8B8)=0
Creates an empty texture of specified size.
virtual scene::IMeshManipulator * getMeshManipulator()=0
Returns a pointer to the mesh manipulator.
virtual u32 getImageWriterCount() const =0
Retrieve the number of image writers.
virtual void setFog(SColor color=SColor(0, 255, 255, 255), E_FOG_TYPE fogType=EFT_FOG_LINEAR, f32 start=50.0f, f32 end=100.0f, f32 density=0.01f, bool pixelFog=false, bool rangeFog=false)=0
Sets the fog mode.
virtual void setViewPort(const core::rect< s32 > &area)=0
Sets a new viewport.
virtual void convertColor(const void *sP, ECOLOR_FORMAT sF, s32 sN, void *dP, ECOLOR_FORMAT dF) const =0
Color conversion convenience function.
virtual void addExternalImageWriter(IImageWriter *writer)=0
Adds an external image writer to the engine.
virtual u32 getDynamicLightCount() const =0
Returns amount of dynamic lights currently set.
virtual u32 getMaterialRendererCount() const =0
Get amount of currently available material renderers.
virtual core::stringc getVendorInfo()=0
Get the graphics card vendor name.
virtual void deleteAllDynamicLights()=0
Deletes all dynamic lights which were previously added with addDynamicLight().
virtual void draw2DRectangle(SColor color, const core::rect< s32 > &pos, const core::rect< s32 > *clip=0)=0
Draws a 2d rectangle.
virtual void OnResize(const core::dimension2d< u32 > &size)=0
Event handler for resize events. Only used by the engine internally.
virtual u32 getMaximalDynamicLightAmount() const =0
Returns the maximal amount of dynamic lights the device can handle.
virtual const SExposedVideoData & getExposedVideoData()=0
Returns driver and operating system specific data about the IVideoDriver.
virtual const io::IAttributes & getDriverAttributes() const =0
Get attributes of the actual video driver.
virtual bool beginScene(u16 clearFlag=(u16)(ECBF_COLOR|ECBF_DEPTH), SColor clearColor=SColor(255, 0, 0, 0), f32 clearDepth=1.f, u8 clearStencil=0, const SExposedVideoData &videoData=SExposedVideoData(), core::rect< s32 > *sourceRect=0)=0
Applications must call this method before performing any rendering.
virtual core::array< IImage * > createImagesFromFile(io::IReadFile *file, E_TEXTURE_TYPE *type=0)=0
Creates a software images from a file.
virtual bool setClipPlane(u32 index, const core::plane3df &plane, bool enable=false)=0
Set or unset a clipping plane.
virtual bool queryTextureFormat(ECOLOR_FORMAT format) const =0
Check if the driver supports creating textures with the given color format.
virtual bool checkDriverReset()=0
Check if the driver was recently reset.
virtual s32 addDynamicLight(const SLight &light)=0
virtual void drawStencilShadowVolume(const core::array< core::vector3df > &triangles, bool zfail=true, u32 debugDataVisible=0)=0
Draws a shadow volume into the stencil buffer.
virtual bool writeImageToFile(IImage *image, io::IWriteFile *file, u32 param=0)=0
Writes the provided image to a file.
virtual ITexture * addRenderTargetTextureCubemap(const jpp::u32 sideLen, const io::path &name="rt", const ECOLOR_FORMAT format=ECF_UNKNOWN)=0
Adds a new render target texture with 6 sides for a cubemap map to the texture cache.
virtual void runOcclusionQuery(scene::ISceneNode *node, bool visible=false)=0
Run occlusion query. Draws mesh stored in query.
virtual s32 addMaterialRenderer(IMaterialRenderer *renderer, const c8 *name=0)=0
Adds a new material renderer to the video device.
virtual ITexture * getTextureByIndex(u32 index)=0
Returns a texture by index.
void drawIndexedTriangleList(const S3DVertex *vertices, u32 vertexCount, const u16 *indexList, u32 triangleCount)
Draws an indexed triangle list.
Definition IVideoDriver.hpp:658
virtual io::IAttributes * createAttributesFromMaterial(const video::SMaterial &material, io::SAttributeReadWriteOptions *options=0)=0
Creates material attributes list from a material.
virtual void draw2DRectangleOutline(const core::recti &pos, SColor color=SColor(255, 255, 255, 255))=0
Draws the outline of a 2D rectangle.
virtual void makeNormalMapTexture(video::ITexture *texture, f32 amplitude=1.0f) const =0
Creates a normal map from a height map texture.
virtual void addOcclusionQuery(scene::ISceneNode *node, const scene::IMesh *mesh=0)=0
Create occlusion query.
virtual void draw2DImage(const video::ITexture *texture, const core::rect< s32 > &destRect, const core::rect< s32 > &sourceRect, const core::rect< s32 > *clipRect=0, const video::SColor *const colors=0, bool useAlphaChannelOfTexture=false)=0
Draws a part of the texture into the rectangle. Note that colors must be an array of 4 colors if used...
virtual IImage * createImage(ITexture *texture, const core::position2d< s32 > &pos, const core::dimension2d< u32 > &size)=0
Creates a software image from a part of a texture.
virtual void draw2DImageBatch(const video::ITexture *texture, const core::position2d< s32 > &pos, const core::array< core::rect< s32 > > &sourceRects, const core::array< s32 > &indices, s32 kerningWidth=0, const core::rect< s32 > *clipRect=0, SColor color=SColor(255, 255, 255, 255), bool useAlphaChannelOfTexture=false)=0
Draws a set of 2d images, using a color and the alpha channel of the texture.
virtual const wchar_t * getName() const =0
Gets name of this video driver.
virtual IRenderTarget * addRenderTarget()=0
Create render target.
virtual const core::dimension2d< u32 > & getCurrentRenderTargetSize() const =0
Get the size of the current render target.
virtual void fillMaterialStructureFromAttributes(video::SMaterial &outMaterial, io::IAttributes *attributes)=0
Fills an SMaterial class from attributes.
IImage * createImageFromFile(const io::path &filename)
Creates a software image from a file.
Definition IVideoDriver.hpp:1176
virtual u32 getMaximalPrimitiveCount() const =0
Returns the maximum amount of primitives.
virtual void setAmbientLight(const SColorf &color)=0
Only used by the engine internally.
virtual void setMaterialRendererName(u32 idx, const c8 *name)=0
Sets the name of a material renderer.
virtual void setAllowZWriteOnTransparent(bool flag)=0
Only used by the engine internally.
virtual void updateOcclusionQuery(scene::ISceneNode *node, bool block=true)=0
Update occlusion query. Retrieves results from GPU.
void drawIndexedTriangleList(const S3DVertexTangents *vertices, u32 vertexCount, const u16 *indexList, u32 triangleCount)
Draws an indexed triangle list.
Definition IVideoDriver.hpp:688
bool beginScene(bool backBuffer, bool zBuffer, SColor color=SColor(255, 0, 0, 0), const SExposedVideoData &videoData=SExposedVideoData(), core::rect< s32 > *sourceRect=0)
Alternative beginScene implementation. Can't clear stencil buffer, but otherwise identical to other b...
Definition IVideoDriver.hpp:173
virtual void setTransform(E_TRANSFORMATION_STATE state, const core::matrix4 &mat)=0
Sets transformation matrices.
virtual const core::rect< s32 > & getViewPort() const =0
Gets the area of the current viewport.
void drawIndexedTriangleFan(const S3DVertex *vertices, u32 vertexCount, const u16 *indexList, u32 triangleCount)
Draws an indexed triangle fan.
Definition IVideoDriver.hpp:703
virtual ITexture * addRenderTargetTexture(const core::dimension2d< u32 > &size, const io::path &name="rt", const ECOLOR_FORMAT format=ECF_UNKNOWN)=0
Adds a new render target texture to the texture cache.
virtual void draw2DImageBatch(const video::ITexture *texture, const core::array< core::position2d< s32 > > &positions, const core::array< core::rect< s32 > > &sourceRects, const core::rect< s32 > *clipRect=0, SColor color=SColor(255, 255, 255, 255), bool useAlphaChannelOfTexture=false)=0
Draws a set of 2d images, using a color and the alpha channel of the texture.
virtual IGPUProgrammingServices * getGPUProgrammingServices()=0
Gets the IGPUProgrammingServices interface.
virtual IImageLoader * getImageLoader(u32 n)=0
Retrieve the given image loader.
virtual ITexture * addTextureCubemap(const io::path &name, IImage *imagePosX, IImage *imageNegX, IImage *imagePosY, IImage *imageNegY, IImage *imagePosZ, IImage *imageNegZ)=0
Creates a cubemap texture from loaded IImages.
virtual void draw2DRectangle(const core::rect< s32 > &pos, SColor colorLeftUp, SColor colorRightUp, SColor colorLeftDown, SColor colorRightDown, const core::rect< s32 > *clip=0)=0
Draws a 2d rectangle with a gradient.
virtual core::dimension2du getMaxTextureSize() const =0
Get the maximum texture size supported.
Vertex with two texture coordinates.
Definition S3DVertex.hpp:116
Vertex with a tangent and binormal vector.
Definition S3DVertex.hpp:199
standard vertex used by the Jimcpp engine.
Definition S3DVertex.hpp:45
Class representing a 32 bit ARGB color.
Definition SColor.hpp:317
Class representing a color with four floats.
Definition SColor.hpp:574
class for holding data describing a driver and operating system specific data.
Definition SExposedVideoData.hpp:26
class for holding data describing a dynamic point light.
Definition SLight.hpp:43
Class for holding parameters for a material renderer.
Definition SMaterial.hpp:304
Definition SOverrideMaterial.hpp:16
E_PRIMITIVE_TYPE
Enumeration for all primitive types there are.
Definition EPrimitiveTypes.hpp:15
@ EPT_TRIANGLES
Explicitly set all vertices for each triangle.
Definition EPrimitiveTypes.hpp:37
@ EPT_TRIANGLE_FAN
Definition EPrimitiveTypes.hpp:34
E_RENDER_TARGET
Special render targets, which usually map to dedicated hardware.
Definition IVideoDriver.hpp:92
@ ERT_STEREO_RIGHT_BUFFER
Render target is the right color buffer (left is the main buffer)
Definition IVideoDriver.hpp:102
@ ERT_AUX_BUFFER1
Auxiliary buffer 1.
Definition IVideoDriver.hpp:108
@ ERT_STEREO_LEFT_BUFFER
Render target is the main color frame buffer.
Definition IVideoDriver.hpp:100
@ ERT_AUX_BUFFER4
Auxiliary buffer 4.
Definition IVideoDriver.hpp:114
@ ERT_RENDER_TEXTURE
Render target is a render texture.
Definition IVideoDriver.hpp:96
@ ERT_AUX_BUFFER2
Auxiliary buffer 2.
Definition IVideoDriver.hpp:110
@ ERT_STEREO_BOTH_BUFFERS
Render to both stereo buffers at once.
Definition IVideoDriver.hpp:104
@ ERT_FRAME_BUFFER
Render target is the main color frame buffer.
Definition IVideoDriver.hpp:94
@ ERT_AUX_BUFFER3
Auxiliary buffer 3.
Definition IVideoDriver.hpp:112
@ ERT_MULTI_RENDER_TEXTURES
Multi-Render target textures.
Definition IVideoDriver.hpp:98
@ ERT_AUX_BUFFER0
Auxiliary buffer 0.
Definition IVideoDriver.hpp:106
E_VERTEX_TYPE
Enumeration for all vertex types there are.
Definition S3DVertex.hpp:19
@ EVT_STANDARD
Standard vertex type used by the Jimcpp engine, video::S3DVertex.
Definition S3DVertex.hpp:21
@ EVT_2TCOORDS
Vertex with two texture coordinates, video::S3DVertex2TCoords.
Definition S3DVertex.hpp:25
@ EVT_TANGENTS
Vertex with a tangent and binormal vector, video::S3DVertexTangents.
Definition S3DVertex.hpp:31
E_TRANSFORMATION_STATE
enumeration for geometry transformation states
Definition IVideoDriver.hpp:54
@ ETS_VIEW
View transformation.
Definition IVideoDriver.hpp:56
@ ETS_WORLD
World transformation.
Definition IVideoDriver.hpp:58
@ ETS_COUNT
Only used internally.
Definition IVideoDriver.hpp:86
@ ETS_PROJECTION
Projection transformation.
Definition IVideoDriver.hpp:60
@ ETS_TEXTURE_2
Texture transformation.
Definition IVideoDriver.hpp:66
@ ETS_TEXTURE_3
Texture transformation.
Definition IVideoDriver.hpp:68
@ ETS_TEXTURE_0
Texture transformation.
Definition IVideoDriver.hpp:62
@ ETS_TEXTURE_1
Texture transformation.
Definition IVideoDriver.hpp:64
ECOLOR_FORMAT
An enum for the color format of textures used by the Jimcpp Engine.
Definition SColor.hpp:21
@ ECF_UNKNOWN
Unknown color format:
Definition SColor.hpp:132
@ ECF_A8R8G8B8
Definition SColor.hpp:38
E_CLEAR_BUFFER_FLAG
Enum for the flags of clear buffer.
Definition IVideoDriver.hpp:119
E_DRIVER_TYPE
An enum for all types of drivers the Jimcpp Engine supports.
Definition EDriverTypes.hpp:17
E_TEXTURE_CREATION_FLAG
Enumeration flags used to tell the video driver with setTextureCreationFlag in which format textures ...
Definition ITexture.hpp:23
E_VIDEO_DRIVER_FEATURE
enumeration for querying features of the video driver.
Definition EDriverFeatures.hpp:15
E_TEXTURE_TYPE
Enumeration describing the type of ITexture.
Definition ITexture.hpp:168
E_FOG_TYPE
Enum for the types of fog distributions to choose from.
Definition IVideoDriver.hpp:129
As of Jimcpp 1.6, position2d is a synonym for vector2d.
Definition vector3d.hpp:11
signed int s32
32 bit signed variable.
Definition irrTypes.hpp:72
unsigned char u8
8 bit unsigned variable.
Definition irrTypes.hpp:24
unsigned int u32
32 bit unsigned variable.
Definition irrTypes.hpp:64
unsigned short u16
16 bit unsigned variable.
Definition irrTypes.hpp:46
float f32
32 bit floating point variable.
Definition irrTypes.hpp:110
char c8
8 bit character variable.
Definition irrTypes.hpp:37