MyGL
Loading...
Searching...
No Matches
Polygon Class Reference

Class for creating regular polygons of 3 or more sides. More...

#include <Polygon.hpp>

Inheritance diagram for Polygon:
AbstractShape

Public Member Functions

MYGL_EXPORT Polygon ()
 Creates a triangle of radius 10.
 
MYGL_EXPORT Polygon (unsigned int sides, int radius)
 Creates a n-sided regular polygon with the specified radius.
 
MYGL_EXPORT Polygon (unsigned int sides, int radius, int x, int y)
 Creates a n-sided regular polygon with the specified radius and places its center at (x, y)
 
MYGL_EXPORT ~Polygon () override
 Default destructor.
 
MYGL_EXPORT void setSides (unsigned int sides)
 Changes the number of sides of a polygon.
 
virtual MYGL_EXPORT void draw (const glm::mat4 &lookAt, const glm::mat4 &projection) const override
 Draws a polygon, this method is called by a window.
 
- Public Member Functions inherited from AbstractShape
MYGL_EXPORT AbstractShape ()
 Default constructor, Initializes a 10 * 10 grey object.
 
MYGL_EXPORT AbstractShape (int width, int height)
 Intializes a grey object which dimensions are width * height.
 
MYGL_EXPORT AbstractShape (int width, int height, int x, int y)
 Initializes a width * height object whose center is at (x, y);.
 
virtual MYGL_EXPORT ~AbstractShape ()
 Default destructor.
 
MYGL_EXPORT glm::vec2 getSize () const noexcept
 Returns the size of the shape.
 
virtual MYGL_EXPORT void setPosition (int x, int y, bool center=false)
 Moves the shape to (x,y)
 
virtual MYGL_EXPORT void setPosition (const glm::vec2 &pos, bool center=false)
 Moves the shape to a specified position.
 
virtual MYGL_EXPORT void setRelativePosition (int x, int y, const my::Camera &camera, bool center=false)
 Moves the shape to a certain position, relative to a camera's position.
 
virtual MYGL_EXPORT void setRelativePosition (const glm::vec2 &pos, const my::Camera &camera, bool center=false)
 Moves the shape to a certain position, relative to a camera's position.
 
virtual MYGL_EXPORT void move (float x, float y) noexcept
 Moves the shape relative to it's current position.
 
MYGL_EXPORT glm::vec2 getPosition () const noexcept
 Gives the current position of the shape's center.
 
MYGL_EXPORT void setScale (float x, float y) noexcept
 Sets the scale factor applied to the shape.
 
MYGL_EXPORT void scale (float x, float y) noexcept
 Modifies the scaling factor.
 
MYGL_EXPORT glm::vec2 getScale () const noexcept
 Gives the current scaling factor applied to the shape.
 
MYGL_EXPORT void setRotation (float angle)
 Sets the rotation applied to the shape.
 
MYGL_EXPORT void rotate (float angle)
 Rotates the shape.
 
MYGL_EXPORT float getRotation () const noexcept
 Returns the shapes's angle of rotation.
 
virtual MYGL_EXPORT void setColor (uint8_t r, uint8_t g, uint8_t b, uint8_t alpha=255) noexcept
 Sets the shape's color from its individual components (ints between 0 and 255)
 
virtual MYGL_EXPORT void setColor (const my::Color &color) noexcept
 Sets the shape's color from an existing color.
 
MYGL_EXPORT my::Color getColor () const noexcept
 Returns the shape's color.
 
MYGL_EXPORT void setOutlineThickness (unsigned int thickness)
 Sets the shape's outline's thickness.
 
MYGL_EXPORT void setOutlineColor (const my::Color &color) noexcept
 Sets the shape's outline color.
 
MYGL_EXPORT void setOutlineColor (uint8_t r, uint8_t g, uint8_t b, uint8_t alpha=255) noexcept
 Sets the shape's outline color from its individual components (ints between 0 and 255)
 
MYGL_EXPORT bool SATCollides (const AbstractShape &shape) const
 Tells wether 2 shapes are overlapping using the separating axis theorem (SAT)
 
MYGL_EXPORT bool BBoxCollides (const AbstractShape &shape) const noexcept
 Tells whether 2 shapes are overlapping using their bounding boxes.
 
virtual MYGL_EXPORT void setTexture (const my::Texture &texture)
 Attaches a texture to the shape.
 
MYGL_EXPORT void setTexture (const std::string &filename)
 Attaches a texture to the shape.
 
MYGL_EXPORT void setShader (const ShaderProgram &program)
 Sets the shader used to draw the shape.
 
MYGL_EXPORT void setOutlineShader (const ShaderProgram &program)
 Sets the shader used to draw the shape's outline.
 

Additional Inherited Members

- Static Public Attributes inherited from AbstractShape
static const ShaderProgramdefaultShader
 
- Protected Attributes inherited from AbstractShape
glm::vec2 m_position
 
glm::vec2 m_originalScale
 
glm::vec2 m_scaleFactor
 
float m_rotationAngle
 
bool m_updateMatrix
 
glm::mat4 m_model
 
my::Color m_color
 
float m_outlineThickness
 
my::Color m_outlineColor
 
glm::mat4 m_outlineModel
 
my::Texture m_texture
 
bool m_isTextured
 
my::ShaderProgram m_shader
 
my::ShaderProgram m_outlineShader
 
- Static Protected Attributes inherited from AbstractShape
static constexpr float pi = std::numbers::pi_v<float>
 
static my::ShaderProgram shader
 
static my::ShaderProgram texShader
 

Detailed Description

Class for creating regular polygons of 3 or more sides.

Definition at line 16 of file Polygon.hpp.

Constructor & Destructor Documentation

◆ Polygon() [1/2]

MYGL_EXPORT Polygon ( unsigned int sides,
int radius )

Creates a n-sided regular polygon with the specified radius.

Parameters
sidesThe number of sides (at least 3)
radiusThe polygon's radius

◆ Polygon() [2/2]

MYGL_EXPORT Polygon ( unsigned int sides,
int radius,
int x,
int y )

Creates a n-sided regular polygon with the specified radius and places its center at (x, y)

Parameters
sidesThe number of sides (at least 3)
radiusThe polygon's radius
xThe x coordinate of the center
yThe y coordinate of the center

Member Function Documentation

◆ draw()

virtual MYGL_EXPORT void draw ( const glm::mat4 & lookAt,
const glm::mat4 & projection ) const
overridevirtual

Draws a polygon, this method is called by a window.

Parameters
lookAtThe view matrix (usually provided by the window)
projectionThe projection matrix (also provided by the window)

Implements AbstractShape.

◆ setSides()

MYGL_EXPORT void setSides ( unsigned int sides)

Changes the number of sides of a polygon.

Parameters
sidesThe new number of sides

The documentation for this class was generated from the following file: