mirror of
https://github.com/SFML/SFML.git
synced 2025-01-20 00:05:13 +08:00
8293de5c50
+ added missing Font functions * using alias template parameter for DrawableImpl now git-svn-id: https://sfml.svn.sourceforge.net/svnroot/sfml/branches/sfml2@1337 4e206d99-4929-0410-ac5d-dfc041789085
335 lines
8.5 KiB
D
335 lines
8.5 KiB
D
/*
|
|
* DSFML - SFML Library wrapper for the D programming language.
|
|
* Copyright (C) 2010 Andreas Hollandt
|
|
*
|
|
* This software is provided 'as-is', without any express or
|
|
* implied warranty. In no event will the authors be held
|
|
* liable for any damages arising from the use of this software.
|
|
*
|
|
* Permission is granted to anyone to use this software for any purpose,
|
|
* including commercial applications, and to alter it and redistribute
|
|
* it freely, subject to the following restrictions:
|
|
*
|
|
* 1. The origin of this software must not be misrepresented;
|
|
* you must not claim that you wrote the original software.
|
|
* If you use this software in a product, an acknowledgment
|
|
* in the product documentation would be appreciated but
|
|
* is not required.
|
|
*
|
|
* 2. Altered source versions must be plainly marked as such,
|
|
* and must not be misrepresented as being the original software.
|
|
*
|
|
* 3. This notice may not be removed or altered from any
|
|
* source distribution.
|
|
*/
|
|
|
|
|
|
module dsfml.graphics.renderimage;
|
|
|
|
import dsfml.system.common,
|
|
dsfml.system.exception,
|
|
dsfml.system.stringutil,
|
|
dsfml.system.vector2;
|
|
|
|
import dsfml.graphics.idrawable,
|
|
dsfml.graphics.image,
|
|
dsfml.graphics.color,
|
|
dsfml.graphics.rect,
|
|
dsfml.graphics.shader,
|
|
dsfml.graphics.view;
|
|
|
|
|
|
/**
|
|
* Target for 2D rendering into an image that can be reused in a sprite
|
|
*/
|
|
class RenderImage : DSFMLObject
|
|
{
|
|
private:
|
|
Image _image = null;
|
|
View _view = null;
|
|
View _defaultView = null;
|
|
|
|
package:
|
|
this(void* ptr)
|
|
{
|
|
super(ptr, true);
|
|
}
|
|
|
|
public:
|
|
|
|
/**
|
|
* Construct a new renderimage
|
|
*
|
|
* Params:
|
|
* width = Width of the renderimage
|
|
* height = Height of the renderimage
|
|
* depthBuffer = Do you want a depth-buffer attached? (useful only if you're doing 3D OpenGL on the renderimage)
|
|
*/
|
|
this(uint width, uint height, bool depthBuffer = false)
|
|
{
|
|
super(sfRenderImage_Create(width, height, depthBuffer));
|
|
}
|
|
|
|
override void dispose()
|
|
{
|
|
sfRenderImage_Destroy(m_ptr);
|
|
}
|
|
|
|
/**
|
|
* Return the width of the rendering region of a renderimage
|
|
*
|
|
* Returns:
|
|
* Width in pixels
|
|
*/
|
|
uint getWidth()
|
|
{
|
|
return sfRenderImage_GetWidth(m_ptr);
|
|
}
|
|
|
|
/**
|
|
* Return the height of the rendering region of a renderimage
|
|
*
|
|
* Returns:
|
|
* Height in pixels
|
|
*/
|
|
uint getHeight()
|
|
{
|
|
return sfRenderImage_GetHeight(m_ptr);
|
|
}
|
|
|
|
/**
|
|
* Activate or deactivate a renderimage as the current target for rendering
|
|
*
|
|
* Params:
|
|
* active = true to activate, false to deactivate
|
|
* Returns:
|
|
* true if operation was successful, false otherwise
|
|
*/
|
|
bool setActive(bool active)
|
|
{
|
|
return sfRenderImage_SetActive(m_ptr, active);
|
|
}
|
|
|
|
/**
|
|
* Make sure that what has been drawn so far is rendered
|
|
*
|
|
* Use this function if you use OpenGL rendering commands, and you want to make sure that things will appear on top
|
|
* of all the SFML objects that have been drawn so far. This is needed because SFML doesn't use immediate rendering,
|
|
* it first accumulates drawables into a queue and trigger the actual rendering afterwards.
|
|
*
|
|
* You don't need to call this function if you're not dealing with OpenGL directly.
|
|
*/
|
|
void flush()
|
|
{
|
|
sfRenderImage_Flush(m_ptr);
|
|
}
|
|
|
|
/**
|
|
* Update the contents of the target image
|
|
*/
|
|
void display()
|
|
{
|
|
sfRenderImage_Display(m_ptr);
|
|
}
|
|
|
|
/**
|
|
* Draw something on a renderimage
|
|
*
|
|
* Params:
|
|
* drawable = object to draw
|
|
*/
|
|
void draw(IDrawable drawable)
|
|
{
|
|
drawable.render(this);
|
|
}
|
|
|
|
/**
|
|
*
|
|
* Params:
|
|
* drawable = Object to draw
|
|
* shader = Shader to use
|
|
*/
|
|
void drawWithShader(IDrawable drawable, Shader shader)
|
|
{
|
|
drawable.renderWithShader(this, shader);
|
|
}
|
|
|
|
/**
|
|
* Clear the renderimage with the given color
|
|
*
|
|
* Params:
|
|
* color = Fill color
|
|
*/
|
|
void clear(Color color)
|
|
{
|
|
sfRenderImage_Clear(m_ptr, color);
|
|
}
|
|
|
|
/**
|
|
* Change the current active view of a renderimage
|
|
*
|
|
* Params:
|
|
* view = Pointer to the new view
|
|
*/
|
|
void setView(View view)
|
|
{
|
|
if (_view !is null)
|
|
{
|
|
_view.setHandled(false);
|
|
}
|
|
|
|
sfRenderImage_SetView(m_ptr, view.getNativePointer);
|
|
|
|
_view = view;
|
|
_view.setHandled(true);
|
|
}
|
|
|
|
/**
|
|
* Get the current active view rectangle
|
|
*
|
|
* Returns:
|
|
* current view rectangle, in global coordinates
|
|
*/
|
|
View getView()
|
|
{
|
|
if (_view is null)
|
|
{
|
|
void* cView = sfRenderImage_GetView(m_ptr);
|
|
_view = new View(cView, true);
|
|
}
|
|
return _view;
|
|
}
|
|
|
|
/**
|
|
* Get the default view
|
|
*
|
|
* Returns:
|
|
* default view
|
|
*/
|
|
View getDefaultView()
|
|
{
|
|
if (_defaultView is null)
|
|
{
|
|
void* cView = sfRenderImage_GetDefaultView(m_ptr);
|
|
_defaultView = new View(cView, true);
|
|
}
|
|
return _defaultView;
|
|
}
|
|
|
|
|
|
IntRect getViewport() // TODO: is there a need to accept other Views than the currently assigned one?
|
|
{
|
|
return sfRenderImage_GetViewport(m_ptr, _view.getNativePointer);
|
|
}
|
|
|
|
/**
|
|
* Convert a point in image coordinates into view coordinates
|
|
*
|
|
* Params:
|
|
* imageX = X coordinate of the point to convert, relative to the image
|
|
* imageY = Y coordinate of the point to convert, relative to the image
|
|
* targetView = Target view to convert the point to (pass NULL to use the current view)
|
|
*
|
|
* Returns:
|
|
* Converted point
|
|
*/
|
|
Vector2f convertCoords(uint imageX, uint imageY, View targetView = null)
|
|
{
|
|
Vector2f vec;
|
|
sfRenderImage_ConvertCoords(m_ptr, imageX, imageY, &vec.x, &vec.y, targetView is null ? null : targetView.getNativePointer);
|
|
return vec;
|
|
}
|
|
|
|
/**
|
|
* Get the target image
|
|
*
|
|
* Returns:
|
|
* target image
|
|
*/
|
|
Image getImage()
|
|
{
|
|
if (_image is null)
|
|
{
|
|
void* cImage = sfRenderImage_GetImage(m_ptr);
|
|
_image = new Image(cImage);
|
|
}
|
|
return _image;
|
|
}
|
|
|
|
/**
|
|
* Check whether the system supports render images or not
|
|
*
|
|
* Returns:
|
|
* true if the RenderImage class can be used
|
|
*/
|
|
bool isAvailable()
|
|
{
|
|
return sfRenderImage_IsAvailable();
|
|
}
|
|
|
|
private:
|
|
extern (C)
|
|
{
|
|
static
|
|
{
|
|
void* function(uint, uint, bool) sfRenderImage_Create;
|
|
void function(void*) sfRenderImage_Destroy;
|
|
uint function(void*) sfRenderImage_GetWidth;
|
|
uint function(void*) sfRenderImage_GetHeight;
|
|
bool function(void*, bool) sfRenderImage_SetActive;
|
|
void function(void*) sfRenderImage_Flush;
|
|
void function(void*) sfRenderImage_Display;
|
|
|
|
void function(void*, void*) sfRenderImage_DrawSprite;
|
|
void function(void*, void*) sfRenderImage_DrawShape;
|
|
void function(void*, void*) sfRenderImage_DrawText;
|
|
|
|
void function(void*, void*, void*) sfRenderImage_DrawSpriteWithShader;
|
|
void function(void*, void*, void*) sfRenderImage_DrawShapeWithShader;
|
|
void function(void*, void*, void*) sfRenderImage_DrawTextWithShader;
|
|
|
|
void function(void*, Color) sfRenderImage_Clear;
|
|
void function(void*, void*) sfRenderImage_SetView;
|
|
void* function(void*) sfRenderImage_GetView;
|
|
void* function(void*) sfRenderImage_GetDefaultView;
|
|
IntRect function(void*, void*) sfRenderImage_GetViewport;
|
|
void function(void*, uint, uint, float*, float*, void*) sfRenderImage_ConvertCoords;
|
|
void* function(void*) sfRenderImage_GetImage;
|
|
bool function() sfRenderImage_IsAvailable;
|
|
}
|
|
}
|
|
|
|
static this()
|
|
{
|
|
debug
|
|
DllLoader dll = DllLoader.load("csfml-graphics-d");
|
|
else
|
|
DllLoader dll = DllLoader.load("csfml-graphics");
|
|
|
|
mixin(loadFromSharedLib("sfRenderImage_Create"));
|
|
mixin(loadFromSharedLib("sfRenderImage_Destroy"));
|
|
mixin(loadFromSharedLib("sfRenderImage_GetWidth"));
|
|
mixin(loadFromSharedLib("sfRenderImage_GetHeight"));
|
|
mixin(loadFromSharedLib("sfRenderImage_SetActive"));
|
|
mixin(loadFromSharedLib("sfRenderImage_Flush"));
|
|
mixin(loadFromSharedLib("sfRenderImage_Display"));
|
|
/*
|
|
mixin(loadFromSharedLib("sfRenderImage_DrawSprite"));
|
|
mixin(loadFromSharedLib("sfRenderImage_DrawShape"));
|
|
mixin(loadFromSharedLib("sfRenderImage_DrawText"));
|
|
|
|
mixin(loadFromSharedLib("sfRenderImage_DrawSpriteWithShader"));
|
|
mixin(loadFromSharedLib("sfRenderImage_DrawShapeWithShader"));
|
|
mixin(loadFromSharedLib("sfRenderImage_DrawTextWithShader"));
|
|
*/
|
|
|
|
mixin(loadFromSharedLib("sfRenderImage_Clear"));
|
|
mixin(loadFromSharedLib("sfRenderImage_SetView"));
|
|
mixin(loadFromSharedLib("sfRenderImage_GetView"));
|
|
mixin(loadFromSharedLib("sfRenderImage_GetDefaultView"));
|
|
mixin(loadFromSharedLib("sfRenderImage_GetViewport"));
|
|
mixin(loadFromSharedLib("sfRenderImage_ConvertCoords"));
|
|
mixin(loadFromSharedLib("sfRenderImage_GetImage"));
|
|
mixin(loadFromSharedLib("sfRenderImage_IsAvailable"));
|
|
}
|
|
} |