123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549 |
- /**
- * Copyright (c) 2006-2016 LOVE Development Team
- *
- * 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.
- **/
- #ifndef LOVE_GRAPHICS_OPENGL_GRAPHICS_H
- #define LOVE_GRAPHICS_OPENGL_GRAPHICS_H
- // STD
- #include <stack>
- #include <vector>
- // OpenGL
- #include "OpenGL.h"
- // LOVE
- #include "graphics/Graphics.h"
- #include "graphics/Color.h"
- #include "image/Image.h"
- #include "image/ImageData.h"
- #include "window/Window.h"
- #include "video/VideoStream.h"
- #include "Font.h"
- #include "Image.h"
- #include "graphics/Quad.h"
- #include "graphics/Texture.h"
- #include "SpriteBatch.h"
- #include "ParticleSystem.h"
- #include "Canvas.h"
- #include "Shader.h"
- #include "Mesh.h"
- #include "Text.h"
- #include "Video.h"
- namespace love
- {
- namespace graphics
- {
- namespace opengl
- {
- class Graphics : public love::graphics::Graphics
- {
- public:
- struct OptionalColorf
- {
- float r, g, b, a;
- bool enabled;
- };
- Graphics();
- virtual ~Graphics();
- // Implements Module.
- const char *getName() const;
- virtual void setViewportSize(int width, int height);
- virtual bool setMode(int width, int height);
- virtual void unSetMode();
- virtual void setActive(bool active);
- virtual bool isActive() const;
- void setDebug(bool enable);
- /**
- * Resets the current color, background color,
- * line style, and so forth. (This will be called
- * when the game reloads.
- **/
- void reset();
- /**
- * Clears the screen to a specific color.
- **/
- void clear(Colorf c);
- /**
- * Clears each active canvas to a different color.
- **/
- void clear(const std::vector<OptionalColorf> &colors);
- /**
- * Discards the contents of the screen.
- **/
- void discard(const std::vector<bool> &colorbuffers, bool stencil);
- /**
- * Flips buffers. (Rendered geometry is presented on screen).
- **/
- void present();
- /**
- * Gets the width of the current graphics viewport.
- **/
- int getWidth() const;
- /**
- * Gets the height of the current graphics viewport.
- **/
- int getHeight() const;
- /**
- * True if a graphics viewport is set.
- **/
- bool isCreated() const;
- /**
- * Scissor defines a box such that everything outside that box is discarded and not drawn.
- * Scissoring is automatically enabled.
- * @param x The x-coordinate of the top-left corner.
- * @param y The y-coordinate of the top-left corner.
- * @param width The width of the box.
- * @param height The height of the box.
- **/
- void setScissor(int x, int y, int width, int height);
- void intersectScissor(int x, int y, int width, int height);
- /**
- * Clears any scissor that has been created.
- **/
- void setScissor();
- /**
- * Gets the current scissor box.
- * @return Whether the scissor is enabled.
- */
- bool getScissor(int &x, int &y, int &width, int &height) const;
- /**
- * Enables or disables drawing to the stencil buffer. When enabled, the
- * color buffer is disabled.
- **/
- void drawToStencilBuffer(StencilAction action, int value);
- void stopDrawToStencilBuffer();
- /**
- * Sets whether stencil testing is enabled.
- **/
- void setStencilTest(CompareMode compare, int value);
- void setStencilTest();
- void getStencilTest(CompareMode &compare, int &value);
- /**
- * Clear the stencil buffer in the active Canvas(es.)
- **/
- void clearStencil();
- /**
- * Creates an Image object with padding and/or optimization.
- **/
- Image *newImage(const std::vector<love::image::ImageData *> &data, const Image::Flags &flags);
- Image *newImage(const std::vector<love::image::CompressedImageData *> &cdata, const Image::Flags &flags);
- Quad *newQuad(Quad::Viewport v, double sw, double sh);
- /**
- * Creates a Font object.
- **/
- Font *newFont(love::font::Rasterizer *data, const Texture::Filter &filter = Texture::getDefaultFilter());
- SpriteBatch *newSpriteBatch(Texture *texture, int size, Mesh::Usage usage);
- ParticleSystem *newParticleSystem(Texture *texture, int size);
- Canvas *newCanvas(int width, int height, Canvas::Format format = Canvas::FORMAT_NORMAL, int msaa = 0);
- Shader *newShader(const Shader::ShaderSource &source);
- Mesh *newMesh(const std::vector<Vertex> &vertices, Mesh::DrawMode drawmode, Mesh::Usage usage);
- Mesh *newMesh(int vertexcount, Mesh::DrawMode drawmode, Mesh::Usage usage);
- Mesh *newMesh(const std::vector<Mesh::AttribFormat> &vertexformat, int vertexcount, Mesh::DrawMode drawmode, Mesh::Usage usage);
- Mesh *newMesh(const std::vector<Mesh::AttribFormat> &vertexformat, const void *data, size_t datasize, Mesh::DrawMode drawmode, Mesh::Usage usage);
- Text *newText(Font *font, const std::vector<Font::ColoredString> &text = {});
- Video *newVideo(love::video::VideoStream *stream);
- bool isGammaCorrect() const;
- /**
- * Sets the foreground color.
- * @param c The new foreground color.
- **/
- void setColor(Colorf c);
- /**
- * Gets current color.
- **/
- Colorf getColor() const;
- /**
- * Sets the background Color.
- **/
- void setBackgroundColor(Colorf c);
- /**
- * Gets the current background color.
- **/
- Colorf getBackgroundColor() const;
- void setFont(Font *font);
- Font *getFont();
- void setShader(Shader *shader);
- void setShader();
- Shader *getShader() const;
- void setCanvas(Canvas *canvas);
- void setCanvas(const std::vector<Canvas *> &canvases);
- void setCanvas(const std::vector<StrongRef<Canvas>> &canvases);
- void setCanvas();
- std::vector<Canvas *> getCanvas() const;
- /**
- * Sets the enabled color components when rendering.
- **/
- void setColorMask(ColorMask mask);
- /**
- * Gets the current color mask.
- **/
- ColorMask getColorMask() const;
- /**
- * Sets the current blend mode.
- **/
- void setBlendMode(BlendMode mode, BlendAlpha alphamode);
- /**
- * Gets the current blend mode.
- **/
- BlendMode getBlendMode(BlendAlpha &alphamode) const;
- /**
- * Sets the default filter for images, canvases, and fonts.
- **/
- void setDefaultFilter(const Texture::Filter &f);
- /**
- * Gets the default filter for images, canvases, and fonts.
- **/
- const Texture::Filter &getDefaultFilter() const;
- /**
- * Default Image mipmap filter mode and sharpness values.
- **/
- void setDefaultMipmapFilter(Texture::FilterMode filter, float sharpness);
- void getDefaultMipmapFilter(Texture::FilterMode *filter, float *sharpness) const;
- /**
- * Sets the line width.
- * @param width The new width of the line.
- **/
- void setLineWidth(float width);
- /**
- * Sets the line style.
- * @param style LINE_ROUGH or LINE_SMOOTH.
- **/
- void setLineStyle(LineStyle style);
- /**
- * Sets the line style.
- * @param style LINE_ROUGH or LINE_SMOOTH.
- **/
- void setLineJoin(LineJoin style);
- /**
- * Gets the line width.
- **/
- float getLineWidth() const;
- /**
- * Gets the line style.
- **/
- LineStyle getLineStyle() const;
- /**
- * Gets the line style.
- **/
- LineJoin getLineJoin() const;
- /**
- * Sets the size of points.
- **/
- void setPointSize(float size);
- /**
- * Gets the point size.
- **/
- float getPointSize() const;
- /**
- * Sets whether graphics will be drawn as wireframe lines instead of filled
- * triangles (has no effect for drawn points.)
- * This should only be used as a debugging tool. The wireframe lines do not
- * behave the same as regular love.graphics lines.
- **/
- void setWireframe(bool enable);
- /**
- * Gets whether wireframe drawing mode is enabled.
- **/
- bool isWireframe() const;
- /**
- * Draws text at the specified coordinates, with rotation and
- * scaling along both axes.
- * @param x The x-coordinate.
- * @param y The y-coordinate.
- * @param angle The amount of rotation.
- * @param sx The scale factor along the x-axis. (1 = normal).
- * @param sy The scale factor along the y-axis. (1 = normal).
- * @param ox The origin offset along the x-axis.
- * @param oy The origin offset along the y-axis.
- * @param kx Shear along the x-axis.
- * @param ky Shear along the y-axis.
- **/
- void print(const std::vector<Font::ColoredString> &str, float x, float y, float angle, float sx, float sy, float ox, float oy, float kx, float ky);
- /**
- * Draw formatted text on screen at the specified coordinates.
- *
- * @param str A string of text.
- * @param x The x-coordinate.
- * @param y The y-coordinate.
- * @param wrap The maximum width of the text area.
- * @param align Where to align the text.
- * @param angle The amount of rotation.
- * @param sx The scale factor along the x-axis. (1 = normal).
- * @param sy The scale factor along the y-axis. (1 = normal).
- * @param ox The origin offset along the x-axis.
- * @param oy The origin offset along the y-axis.
- * @param kx Shear along the x-axis.
- * @param ky Shear along the y-axis.
- **/
- void printf(const std::vector<Font::ColoredString> &str, float x, float y, float wrap, Font::AlignMode align, float angle, float sx, float sy, float ox, float oy, float kx, float ky);
- /**
- * Draws a point at (x,y).
- * @param x Point along x-axis.
- * @param y Point along y-axis.
- **/
- void points(const float *coords, const uint8 *colors, size_t numpoints);
- /**
- * Draws a series of lines connecting the given vertices.
- * @param coords Vertex components (x1, y1, ..., xn, yn). If x1,y1 == xn,yn the line will be drawn closed.
- * @param count Number of items in the array, i.e. count = 2 * n
- **/
- void polyline(const float *coords, size_t count);
- /**
- * Draws a rectangle.
- * @param x Position along x-axis for top-left corner.
- * @param y Position along y-axis for top-left corner.
- * @param w The width of the rectangle.
- * @param h The height of the rectangle.
- **/
- void rectangle(DrawMode mode, float x, float y, float w, float h);
- /**
- * Variant of rectangle that draws a rounded rectangle.
- * @param mode The mode of drawing (line/filled).
- * @param x X-coordinate of top-left corner
- * @param y Y-coordinate of top-left corner
- * @param w The width of the rectangle.
- * @param h The height of the rectangle.
- * @param rx The radius of the corners on the x axis
- * @param ry The radius of the corners on the y axis
- * @param points The number of points to use per corner
- **/
- void rectangle(DrawMode mode, float x, float y, float w, float h, float rx, float ry, int points = 10);
- /**
- * Draws a circle using the specified arguments.
- * @param mode The mode of drawing (line/filled).
- * @param x X-coordinate.
- * @param y Y-coordinate.
- * @param radius Radius of the circle.
- * @param points Number of points to use to draw the circle.
- **/
- void circle(DrawMode mode, float x, float y, float radius, int points = 10);
- /**
- * Draws an ellipse using the specified arguments.
- * @param mode The mode of drawing (line/filled).
- * @param x X-coordinate of center
- * @param y Y-coordinate of center
- * @param a Radius in x-direction
- * @param b Radius in y-direction
- * @param points Number of points to use to draw the circle.
- **/
- void ellipse(DrawMode mode, float x, float y, float a, float b, int points = 10);
- /**
- * Draws an arc using the specified arguments.
- * @param drawmode The mode of drawing (line/filled).
- * @param arcmode The type of arc.
- * @param x X-coordinate.
- * @param y Y-coordinate.
- * @param radius Radius of the arc.
- * @param angle1 The angle at which the arc begins.
- * @param angle2 The angle at which the arc terminates.
- * @param points Number of points to use to draw the arc.
- **/
- void arc(DrawMode drawmode, ArcMode arcmode, float x, float y, float radius, float angle1, float angle2, int points = 10);
- /**
- * Draws a polygon with an arbitrary number of vertices.
- * @param mode The type of drawing (line/filled).
- * @param coords Vertex components (x1, y1, x2, y2, etc.)
- * @param count Coord array size
- **/
- void polygon(DrawMode mode, const float *coords, size_t count);
- /**
- * Creates a screenshot of the view and saves it to the default folder.
- * @param image The love.image module.
- * @param copyAlpha If the alpha channel should be copied or set to full opacity (255).
- **/
- love::image::ImageData *newScreenshot(love::image::Image *image, bool copyAlpha = true);
- /**
- * Returns system-dependent renderer information.
- * Returned strings can vary greatly between systems! Do not rely on it for
- * anything!
- **/
- RendererInfo getRendererInfo() const;
- /**
- * Returns performance-related statistics.
- **/
- Stats getStats() const;
- /**
- * Gets the system-dependent numeric limit for the specified parameter.
- **/
- double getSystemLimit(SystemLimit limittype) const;
- /**
- * Gets whether a graphics feature is supported on this system.
- **/
- bool isSupported(Support feature) const;
- void push(StackType type = STACK_TRANSFORM);
- void pop();
- void rotate(float r);
- void scale(float x, float y = 1.0f);
- void translate(float x, float y);
- void shear(float kx, float ky);
- void origin();
- private:
- struct DisplayState
- {
- Colorf color = Colorf(255.0, 255.0, 255.0, 255.0);
- Colorf backgroundColor = Colorf(0.0, 0.0, 0.0, 255.0);
- BlendMode blendMode = BLEND_ALPHA;
- BlendAlpha blendAlphaMode = BLENDALPHA_MULTIPLY;
- float lineWidth = 1.0f;
- LineStyle lineStyle = LINE_SMOOTH;
- LineJoin lineJoin = LINE_JOIN_MITER;
- float pointSize = 1.0f;
- bool scissor = false;
- ScissorRect scissorRect = ScissorRect();
- // Stencil.
- CompareMode stencilCompare = COMPARE_ALWAYS;
- int stencilTestValue = 0;
- StrongRef<Font> font;
- StrongRef<Shader> shader;
- std::vector<StrongRef<Canvas>> canvases;
- ColorMask colorMask = ColorMask(true, true, true, true);
- bool wireframe = false;
- Texture::Filter defaultFilter = Texture::Filter();
- Texture::FilterMode defaultMipmapFilter = Texture::FILTER_NEAREST;
- float defaultMipmapSharpness = 0.0f;
- };
- void restoreState(const DisplayState &s);
- void restoreStateChecked(const DisplayState &s);
- void checkSetDefaultFont();
- StrongRef<love::window::Window> currentWindow;
- StrongRef<Font> defaultFont;
- std::vector<double> pixelSizeStack; // stores current size of a pixel (needed for line drawing)
- QuadIndices *quadIndices;
- int width;
- int height;
- bool created;
- bool active;
- bool writingToStencil;
- std::vector<DisplayState> states;
- std::vector<StackType> stackTypes; // Keeps track of the pushed stack types.
- static const size_t MAX_USER_STACK_DEPTH = 64;
- }; // Graphics
- } // opengl
- } // graphics
- } // love
- #endif // LOVE_GRAPHICS_OPENGL_GRAPHICS_H
|