SDL3_gfx 1.0.0
Graphics primitives and surface functions for SDL3
|
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <string.h>
#include "SDL3_gfxPrimitives.h"
#include "SDL3_rotozoom.h"
#include "SDL3_gfxPrimitives_font.h"
Go to the source code of this file.
Macros | |
#define | AAlevels 256 |
#define | AAbits 8 |
#define | DEFAULT_ELLIPSE_OVERSCAN 4 |
Internal function to draw ellipse or filled ellipse with blending. | |
Functions | |
bool | pixel (SDL_Renderer *renderer, Sint16 x, Sint16 y) |
Draw pixel in currently set color. | |
bool | pixelColor (SDL_Renderer *renderer, Sint16 x, Sint16 y, Uint32 color) |
Draw pixel with blending enabled if a<255. | |
bool | pixelRGBA (SDL_Renderer *renderer, Sint16 x, Sint16 y, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw pixel with blending enabled if a<255. | |
bool | pixelRGBAWeight (SDL_Renderer *renderer, Sint16 x, Sint16 y, Uint8 r, Uint8 g, Uint8 b, Uint8 a, Uint32 weight) |
Draw pixel with blending enabled and using alpha weight on color. | |
bool | hline (SDL_Renderer *renderer, Sint16 x1, Sint16 x2, Sint16 y) |
Draw horizontal line in currently set color. | |
bool | hlineColor (SDL_Renderer *renderer, Sint16 x1, Sint16 x2, Sint16 y, Uint32 color) |
Draw horizontal line with blending. | |
bool | hlineRGBA (SDL_Renderer *renderer, Sint16 x1, Sint16 x2, Sint16 y, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw horizontal line with blending. | |
bool | vline (SDL_Renderer *renderer, Sint16 x, Sint16 y1, Sint16 y2) |
Draw vertical line in currently set color. | |
bool | vlineColor (SDL_Renderer *renderer, Sint16 x, Sint16 y1, Sint16 y2, Uint32 color) |
Draw vertical line with blending. | |
bool | vlineRGBA (SDL_Renderer *renderer, Sint16 x, Sint16 y1, Sint16 y2, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw vertical line with blending. | |
bool | rectangleColor (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Uint32 color) |
Draw rectangle with blending. | |
bool | rectangleRGBA (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw rectangle with blending. | |
bool | roundedRectangleColor (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Sint16 rad, Uint32 color) |
Draw rounded-corner rectangle with blending. | |
bool | roundedRectangleRGBA (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Sint16 rad, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw rounded-corner rectangle with blending. | |
bool | roundedBoxColor (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Sint16 rad, Uint32 color) |
Draw rounded-corner box (filled rectangle) with blending. | |
bool | roundedBoxRGBA (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Sint16 rad, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw rounded-corner box (filled rectangle) with blending. | |
bool | boxColor (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Uint32 color) |
Draw box (filled rectangle) with blending. | |
bool | boxRGBA (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw box (filled rectangle) with blending. | |
bool | line (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2) |
Draw line with alpha blending using the currently set color. | |
bool | lineColor (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Uint32 color) |
Draw line with alpha blending. | |
bool | lineRGBA (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw line with alpha blending. | |
int | _aalineRGBA (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Uint8 r, Uint8 g, Uint8 b, Uint8 a, int draw_endpoint) |
Internal function to draw anti-aliased line with alpha blending and endpoint control. | |
bool | aalineColor (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Uint32 color) |
Draw anti-aliased line with alpha blending. | |
bool | aalineRGBA (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw anti-aliased line with alpha blending. | |
bool | circleColor (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 rad, Uint32 color) |
Draw circle with blending. | |
bool | circleRGBA (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 rad, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw circle with blending. | |
bool | arcColor (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 rad, Sint16 start, Sint16 end, Uint32 color) |
Arc with blending. | |
bool | arcRGBA (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 rad, Sint16 start, Sint16 end, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Arc with blending. | |
bool | aacircleColor (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 rad, Uint32 color) |
Draw anti-aliased circle with blending. | |
bool | aacircleRGBA (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 rad, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw anti-aliased circle with blending. | |
int | _drawQuadrants (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 dx, Sint16 dy, Sint32 f) |
Internal function to draw pixels or lines in 4 quadrants. | |
bool | _ellipseRGBA (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 rx, Sint16 ry, Uint8 r, Uint8 g, Uint8 b, Uint8 a, Sint32 f) |
bool | ellipseColor (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 rx, Sint16 ry, Uint32 color) |
Draw ellipse with blending. | |
bool | ellipseRGBA (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 rx, Sint16 ry, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw ellipse with blending. | |
bool | filledCircleColor (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 rad, Uint32 color) |
Draw filled circle with blending. | |
bool | filledCircleRGBA (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 rad, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw filled circle with blending. | |
bool | aaellipseColor (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 rx, Sint16 ry, Uint32 color) |
Draw anti-aliased ellipse with blending. | |
bool | aaellipseRGBA (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 rx, Sint16 ry, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw anti-aliased ellipse with blending. | |
bool | filledEllipseColor (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 rx, Sint16 ry, Uint32 color) |
Draw filled ellipse with blending. | |
bool | filledEllipseRGBA (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 rx, Sint16 ry, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw filled ellipse with blending. | |
bool | _pieRGBA (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 rad, Sint16 start, Sint16 end, Uint8 r, Uint8 g, Uint8 b, Uint8 a, Uint8 filled) |
Internal float (low-speed) pie-calc implementation by drawing polygons. | |
bool | pieColor (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 rad, Sint16 start, Sint16 end, Uint32 color) |
Draw pie (outline) with alpha blending. | |
bool | pieRGBA (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 rad, Sint16 start, Sint16 end, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw pie (outline) with alpha blending. | |
bool | filledPieColor (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 rad, Sint16 start, Sint16 end, Uint32 color) |
Draw filled pie with alpha blending. | |
bool | filledPieRGBA (SDL_Renderer *renderer, Sint16 x, Sint16 y, Sint16 rad, Sint16 start, Sint16 end, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw filled pie with alpha blending. | |
bool | trigonColor (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Sint16 x3, Sint16 y3, Uint32 color) |
Draw trigon (triangle outline) with alpha blending. | |
bool | trigonRGBA (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Sint16 x3, Sint16 y3, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw trigon (triangle outline) with alpha blending. | |
bool | aatrigonColor (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Sint16 x3, Sint16 y3, Uint32 color) |
Draw anti-aliased trigon (triangle outline) with alpha blending. | |
bool | aatrigonRGBA (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Sint16 x3, Sint16 y3, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw anti-aliased trigon (triangle outline) with alpha blending. | |
bool | filledTrigonColor (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Sint16 x3, Sint16 y3, Uint32 color) |
Draw filled trigon (triangle) with alpha blending. | |
bool | filledTrigonRGBA (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Sint16 x3, Sint16 y3, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw filled trigon (triangle) with alpha blending. | |
bool | polygonColor (SDL_Renderer *renderer, const Sint16 *vx, const Sint16 *vy, int n, Uint32 color) |
Draw polygon with alpha blending. | |
bool | polygon (SDL_Renderer *renderer, const Sint16 *vx, const Sint16 *vy, int n) |
Draw polygon with the currently set color and blend mode. | |
bool | polygonRGBA (SDL_Renderer *renderer, const Sint16 *vx, const Sint16 *vy, int n, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw polygon with alpha blending. | |
bool | aapolygonColor (SDL_Renderer *renderer, const Sint16 *vx, const Sint16 *vy, int n, Uint32 color) |
Draw anti-aliased polygon with alpha blending. | |
bool | aapolygonRGBA (SDL_Renderer *renderer, const Sint16 *vx, const Sint16 *vy, int n, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw anti-aliased polygon with alpha blending. | |
int | _gfxPrimitivesCompareInt (const void *a, const void *b) |
Internal helper qsort callback functions used in filled polygon drawing. | |
int | filledPolygonRGBAMT (SDL_Renderer *renderer, const Sint16 *vx, const Sint16 *vy, int n, Uint8 r, Uint8 g, Uint8 b, Uint8 a, int **polyInts, int *polyAllocated) |
Draw filled polygon with alpha blending (multi-threaded capable). | |
bool | filledPolygonColor (SDL_Renderer *renderer, const Sint16 *vx, const Sint16 *vy, int n, Uint32 color) |
Draw filled polygon with alpha blending. | |
bool | filledPolygonRGBA (SDL_Renderer *renderer, const Sint16 *vx, const Sint16 *vy, int n, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw filled polygon with alpha blending. | |
bool | _HLineTextured (SDL_Renderer *renderer, Sint16 x1, Sint16 x2, Sint16 y, SDL_Texture *texture, int texture_w, int texture_h, int texture_dx, int texture_dy) |
Internal function to draw a textured horizontal line. | |
bool | texturedPolygonMT (SDL_Renderer *renderer, const Sint16 *vx, const Sint16 *vy, int n, SDL_Surface *texture, int texture_dx, int texture_dy, int **polyInts, int *polyAllocated) |
Draws a polygon filled with the given texture (Multi-Threading Capable). | |
bool | texturedPolygon (SDL_Renderer *renderer, const Sint16 *vx, const Sint16 *vy, int n, SDL_Surface *texture, int texture_dx, int texture_dy) |
Draws a polygon filled with the given texture. | |
void | gfxPrimitivesSetFont (const void *fontdata, Uint32 cw, Uint32 ch) |
Sets or resets the current global font data. | |
void | gfxPrimitivesSetFontRotation (Uint32 rotation) |
Sets current global font character rotation steps. | |
bool | characterRGBA (SDL_Renderer *renderer, Sint16 x, Sint16 y, char c, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw a character of the currently set font. | |
bool | characterColor (SDL_Renderer *renderer, Sint16 x, Sint16 y, char c, Uint32 color) |
Draw a character of the currently set font. | |
bool | stringColor (SDL_Renderer *renderer, Sint16 x, Sint16 y, const char *s, Uint32 color) |
Draw a string in the currently set font. | |
bool | stringRGBA (SDL_Renderer *renderer, Sint16 x, Sint16 y, const char *s, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw a string in the currently set font. | |
double | _evaluateBezier (double *data, int ndata, double t) |
Internal function to calculate bezier interpolator of data array with ndata values at position 't'. | |
bool | bezierColor (SDL_Renderer *renderer, const Sint16 *vx, const Sint16 *vy, int n, int s, Uint32 color) |
Draw a bezier curve with alpha blending. | |
bool | bezierRGBA (SDL_Renderer *renderer, const Sint16 *vx, const Sint16 *vy, int n, int s, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw a bezier curve with alpha blending. | |
bool | thickLineColor (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Uint8 width, Uint32 color) |
Draw a thick line with alpha blending. | |
bool | thickLineRGBA (SDL_Renderer *renderer, Sint16 x1, Sint16 y1, Sint16 x2, Sint16 y2, Uint8 width, Uint8 r, Uint8 g, Uint8 b, Uint8 a) |
Draw a thick line with alpha blending. | |
#define AAbits 8 |
Definition at line 834 of file SDL3_gfxPrimitives.c.
#define AAlevels 256 |
Definition at line 833 of file SDL3_gfxPrimitives.c.
#define DEFAULT_ELLIPSE_OVERSCAN 4 |
Internal function to draw ellipse or filled ellipse with blending.
renderer | The renderer to draw on. |
x | X coordinate of the center of the ellipse. |
y | Y coordinate of the center of the ellipse. |
rx | Horizontal radius in pixels of the ellipse. |
ry | Vertical radius in pixels of the ellipse. |
r | The red value of the ellipse to draw. |
g | The green value of the ellipse to draw. |
b | The blue value of the ellipse to draw. |
a | The alpha value of the ellipse to draw. |
f | Flag indicating if the ellipse should be filled (1) or not (0). |
Definition at line 1506 of file SDL3_gfxPrimitives.c.
int _aalineRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a, | ||
int | draw_endpoint ) |
Internal function to draw anti-aliased line with alpha blending and endpoint control.
This implementation of the Wu antialiasing code is based on Mike Abrash's DDJ article which was reprinted as Chapter 42 of his Graphics Programming Black Book, but has been optimized to work with SDL and utilizes 32-bit fixed-point arithmetic by A. Schiffler. The endpoint control allows the supression to draw the last pixel useful for rendering continous aa-lines with alpha<255.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point of the aa-line. |
y1 | Y coordinate of the first point of the aa-line. |
x2 | X coordinate of the second point of the aa-line. |
y2 | Y coordinate of the second point of the aa-line. |
r | The red value of the aa-line to draw. |
g | The green value of the aa-line to draw. |
b | The blue value of the aa-line to draw. |
a | The alpha value of the aa-line to draw. |
draw_endpoint | Flag indicating if the endpoint should be drawn; draw if non-zero. |
Definition at line 859 of file SDL3_gfxPrimitives.c.
int _drawQuadrants | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | dx, | ||
Sint16 | dy, | ||
Sint32 | f ) |
Internal function to draw pixels or lines in 4 quadrants.
renderer | The renderer to draw on. |
x | X coordinate of the center of the quadrant. |
y | Y coordinate of the center of the quadrant. |
dx | X offset in pixels of the corners of the quadrant. |
dy | Y offset in pixels of the corners of the quadrant. |
f | Flag indicating if the quadrant should be filled (1) or not (0). |
Definition at line 1452 of file SDL3_gfxPrimitives.c.
bool _ellipseRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | rx, | ||
Sint16 | ry, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a, | ||
Sint32 | f ) |
Definition at line 1507 of file SDL3_gfxPrimitives.c.
double _evaluateBezier | ( | double * | data, |
int | ndata, | ||
double | t ) |
Internal function to calculate bezier interpolator of data array with ndata values at position 't'.
data | Array of values. |
ndata | Size of array. |
t | Position for which to calculate interpolated value. t should be between [0, ndata]. |
Definition at line 3550 of file SDL3_gfxPrimitives.c.
int _gfxPrimitivesCompareInt | ( | const void * | a, |
const void * | b ) |
Internal helper qsort callback functions used in filled polygon drawing.
a | The surface to draw on. |
b | Vertex array containing X coordinates of the points of the polygon. |
Definition at line 2671 of file SDL3_gfxPrimitives.c.
bool _HLineTextured | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | x2, | ||
Sint16 | y, | ||
SDL_Texture * | texture, | ||
int | texture_w, | ||
int | texture_h, | ||
int | texture_dx, | ||
int | texture_dy ) |
Internal function to draw a textured horizontal line.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point (i.e. left) of the line. |
x2 | X coordinate of the second point (i.e. right) of the line. |
y | Y coordinate of the points of the line. |
texture | The texture to retrieve color information from. |
texture_w | The width of the texture. |
texture_h | The height of the texture. |
texture_dx | The X offset for the texture lookup. |
texture_dy | The Y offset for the textured lookup. |
Definition at line 2917 of file SDL3_gfxPrimitives.c.
bool _pieRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | rad, | ||
Sint16 | start, | ||
Sint16 | end, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a, | ||
Uint8 | filled ) |
Internal float (low-speed) pie-calc implementation by drawing polygons.
Note: Determines vertex array and uses polygon or filledPolygon drawing routines to render.
renderer | The renderer to draw on. |
x | X coordinate of the center of the pie. |
y | Y coordinate of the center of the pie. |
rad | Radius in pixels of the pie. |
start | Starting radius in degrees of the pie. |
end | Ending radius in degrees of the pie. |
r | The red value of the pie to draw. |
g | The green value of the pie to draw. |
b | The blue value of the pie to draw. |
a | The alpha value of the pie to draw. |
filled | Flag indicating if the pie should be filled (=1) or not (=0). |
Definition at line 2052 of file SDL3_gfxPrimitives.c.
bool aacircleColor | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | rad, | ||
Uint32 | color ) |
Draw anti-aliased circle with blending.
renderer | The renderer to draw on. |
x | X coordinate of the center of the aa-circle. |
y | Y coordinate of the center of the aa-circle. |
rad | Radius in pixels of the aa-circle. |
color | The color value of the aa-circle to draw (0xRRGGBBAA). |
Definition at line 1410 of file SDL3_gfxPrimitives.c.
bool aacircleRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | rad, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw anti-aliased circle with blending.
renderer | The renderer to draw on. |
x | X coordinate of the center of the aa-circle. |
y | Y coordinate of the center of the aa-circle. |
rad | Radius in pixels of the aa-circle. |
r | The red value of the aa-circle to draw. |
g | The green value of the aa-circle to draw. |
b | The blue value of the aa-circle to draw. |
a | The alpha value of the aa-circle to draw. |
Definition at line 1430 of file SDL3_gfxPrimitives.c.
bool aaellipseColor | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | rx, | ||
Sint16 | ry, | ||
Uint32 | color ) |
Draw anti-aliased ellipse with blending.
renderer | The renderer to draw on. |
x | X coordinate of the center of the aa-ellipse. |
y | Y coordinate of the center of the aa-ellipse. |
rx | Horizontal radius in pixels of the aa-ellipse. |
ry | Vertical radius in pixels of the aa-ellipse. |
color | The color value of the aa-ellipse to draw (0xRRGGBBAA). |
Definition at line 1788 of file SDL3_gfxPrimitives.c.
bool aaellipseRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | rx, | ||
Sint16 | ry, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw anti-aliased ellipse with blending.
renderer | The renderer to draw on. |
x | X coordinate of the center of the aa-ellipse. |
y | Y coordinate of the center of the aa-ellipse. |
rx | Horizontal radius in pixels of the aa-ellipse. |
ry | Vertical radius in pixels of the aa-ellipse. |
r | The red value of the aa-ellipse to draw. |
g | The green value of the aa-ellipse to draw. |
b | The blue value of the aa-ellipse to draw. |
a | The alpha value of the aa-ellipse to draw. |
Definition at line 1809 of file SDL3_gfxPrimitives.c.
bool aalineColor | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Uint32 | color ) |
Draw anti-aliased line with alpha blending.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point of the aa-line. |
y1 | Y coordinate of the first point of the aa-line. |
x2 | X coordinate of the second point of the aa-line. |
y2 | Y coordinate of the second point of the aa-line. |
color | The color value of the aa-line to draw (0xRRGGBBAA). |
Definition at line 1073 of file SDL3_gfxPrimitives.c.
bool aalineRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw anti-aliased line with alpha blending.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point of the aa-line. |
y1 | Y coordinate of the first point of the aa-line. |
x2 | X coordinate of the second point of the aa-line. |
y2 | Y coordinate of the second point of the aa-line. |
r | The red value of the aa-line to draw. |
g | The green value of the aa-line to draw. |
b | The blue value of the aa-line to draw. |
a | The alpha value of the aa-line to draw. |
Definition at line 1094 of file SDL3_gfxPrimitives.c.
bool aapolygonColor | ( | SDL_Renderer * | renderer, |
const Sint16 * | vx, | ||
const Sint16 * | vy, | ||
int | n, | ||
Uint32 | color ) |
Draw anti-aliased polygon with alpha blending.
renderer | The renderer to draw on. |
vx | Vertex array containing X coordinates of the points of the aa-polygon. |
vy | Vertex array containing Y coordinates of the points of the aa-polygon. |
n | Number of points in the vertex array. Minimum number is 3. |
color | The color value of the aa-polygon to draw (0xRRGGBBAA). |
Definition at line 2593 of file SDL3_gfxPrimitives.c.
bool aapolygonRGBA | ( | SDL_Renderer * | renderer, |
const Sint16 * | vx, | ||
const Sint16 * | vy, | ||
int | n, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw anti-aliased polygon with alpha blending.
renderer | The renderer to draw on. |
vx | Vertex array containing X coordinates of the points of the aa-polygon. |
vy | Vertex array containing Y coordinates of the points of the aa-polygon. |
n | Number of points in the vertex array. Minimum number is 3. |
r | The red value of the aa-polygon to draw. |
g | The green value of the aa-polygon to draw. |
b | The blue value of the aa-polygon to draw. |
a | The alpha value of the aa-polygon to draw. |
Definition at line 2613 of file SDL3_gfxPrimitives.c.
bool aatrigonColor | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Sint16 | x3, | ||
Sint16 | y3, | ||
Uint32 | color ) |
Draw anti-aliased trigon (triangle outline) with alpha blending.
Note: Creates vertex array and uses aapolygon routine to render.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point of the aa-trigon. |
y1 | Y coordinate of the first point of the aa-trigon. |
x2 | X coordinate of the second point of the aa-trigon. |
y2 | Y coordinate of the second point of the aa-trigon. |
x3 | X coordinate of the third point of the aa-trigon. |
y3 | Y coordinate of the third point of the aa-trigon. |
color | The color value of the aa-trigon to draw (0xRRGGBBAA). |
Definition at line 2321 of file SDL3_gfxPrimitives.c.
bool aatrigonRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Sint16 | x3, | ||
Sint16 | y3, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw anti-aliased trigon (triangle outline) with alpha blending.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point of the aa-trigon. |
y1 | Y coordinate of the first point of the aa-trigon. |
x2 | X coordinate of the second point of the aa-trigon. |
y2 | Y coordinate of the second point of the aa-trigon. |
x3 | X coordinate of the third point of the aa-trigon. |
y3 | Y coordinate of the third point of the aa-trigon. |
r | The red value of the aa-trigon to draw. |
g | The green value of the aa-trigon to draw. |
b | The blue value of the aa-trigon to draw. |
a | The alpha value of the aa-trigon to draw. |
Definition at line 2353 of file SDL3_gfxPrimitives.c.
bool arcColor | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | rad, | ||
Sint16 | start, | ||
Sint16 | end, | ||
Uint32 | color ) |
Arc with blending.
renderer | The renderer to draw on. |
x | X coordinate of the center of the arc. |
y | Y coordinate of the center of the arc. |
rad | Radius in pixels of the arc. |
start | Starting radius in degrees of the arc. 0 degrees is down, increasing counterclockwise. |
end | Ending radius in degrees of the arc. 0 degrees is down, increasing counterclockwise. |
color | The color value of the arc to draw (0xRRGGBBAA). |
Definition at line 1152 of file SDL3_gfxPrimitives.c.
bool arcRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | rad, | ||
Sint16 | start, | ||
Sint16 | end, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Arc with blending.
renderer | The renderer to draw on. |
x | X coordinate of the center of the arc. |
y | Y coordinate of the center of the arc. |
rad | Radius in pixels of the arc. |
start | Starting radius in degrees of the arc. 0 degrees is down, increasing counterclockwise. |
end | Ending radius in degrees of the arc. 0 degrees is down, increasing counterclockwise. |
r | The red value of the arc to draw. |
g | The green value of the arc to draw. |
b | The blue value of the arc to draw. |
a | The alpha value of the arc to draw. |
Definition at line 1175 of file SDL3_gfxPrimitives.c.
bool bezierColor | ( | SDL_Renderer * | renderer, |
const Sint16 * | vx, | ||
const Sint16 * | vy, | ||
int | n, | ||
int | s, | ||
Uint32 | color ) |
Draw a bezier curve with alpha blending.
renderer | The renderer to draw on. |
vx | Vertex array containing X coordinates of the points of the bezier curve. |
vy | Vertex array containing Y coordinates of the points of the bezier curve. |
n | Number of points in the vertex array. Minimum number is 3. |
s | Number of steps for the interpolation. Minimum number is 2. |
color | The color value of the bezier curve to draw (0xRRGGBBAA). |
Definition at line 3609 of file SDL3_gfxPrimitives.c.
bool bezierRGBA | ( | SDL_Renderer * | renderer, |
const Sint16 * | vx, | ||
const Sint16 * | vy, | ||
int | n, | ||
int | s, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw a bezier curve with alpha blending.
renderer | The renderer to draw on. |
vx | Vertex array containing X coordinates of the points of the bezier curve. |
vy | Vertex array containing Y coordinates of the points of the bezier curve. |
n | Number of points in the vertex array. Minimum number is 3. |
s | Number of steps for the interpolation. Minimum number is 2. |
r | The red value of the bezier curve to draw. |
g | The green value of the bezier curve to draw. |
b | The blue value of the bezier curve to draw. |
a | The alpha value of the bezier curve to draw. |
Definition at line 3630 of file SDL3_gfxPrimitives.c.
bool boxColor | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Uint32 | color ) |
Draw box (filled rectangle) with blending.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point (i.e. top right) of the box. |
y1 | Y coordinate of the first point (i.e. top right) of the box. |
x2 | X coordinate of the second point (i.e. bottom left) of the box. |
y2 | Y coordinate of the second point (i.e. bottom left) of the box. |
color | The color value of the box to draw (0xRRGGBBAA). |
Definition at line 687 of file SDL3_gfxPrimitives.c.
bool boxRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw box (filled rectangle) with blending.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point (i.e. top right) of the box. |
y1 | Y coordinate of the first point (i.e. top right) of the box. |
x2 | X coordinate of the second point (i.e. bottom left) of the box. |
y2 | Y coordinate of the second point (i.e. bottom left) of the box. |
r | The red value of the box to draw. |
g | The green value of the box to draw. |
b | The blue value of the box to draw. |
a | The alpha value of the box to draw. |
Definition at line 708 of file SDL3_gfxPrimitives.c.
bool characterColor | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
char | c, | ||
Uint32 | color ) |
Draw a character of the currently set font.
renderer | The renderer to draw on. |
x | X (horizontal) coordinate of the upper left corner of the character. |
y | Y (vertical) coordinate of the upper left corner of the character. |
c | The character to draw. |
color | The color value of the character to draw (0xRRGGBBAA). |
Definition at line 3468 of file SDL3_gfxPrimitives.c.
bool characterRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
char | c, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw a character of the currently set font.
renderer | The Renderer to draw on. |
x | X (horizontal) coordinate of the upper left corner of the character. |
y | Y (vertical) coordinate of the upper left corner of the character. |
c | The character to draw. |
r | The red value of the character to draw. |
g | The green value of the character to draw. |
b | The blue value of the character to draw. |
a | The alpha value of the character to draw. |
Definition at line 3347 of file SDL3_gfxPrimitives.c.
bool circleColor | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | rad, | ||
Uint32 | color ) |
Draw circle with blending.
renderer | The renderer to draw on. |
x | X coordinate of the center of the circle. |
y | Y coordinate of the center of the circle. |
rad | Radius in pixels of the circle. |
color | The color value of the circle to draw (0xRRGGBBAA). |
Definition at line 1112 of file SDL3_gfxPrimitives.c.
bool circleRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | rad, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw circle with blending.
renderer | The renderer to draw on. |
x | X coordinate of the center of the circle. |
y | Y coordinate of the center of the circle. |
rad | Radius in pixels of the circle. |
r | The red value of the circle to draw. |
g | The green value of the circle to draw. |
b | The blue value of the circle to draw. |
a | The alpha value of the circle to draw. |
Definition at line 1132 of file SDL3_gfxPrimitives.c.
bool ellipseColor | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | rx, | ||
Sint16 | ry, | ||
Uint32 | color ) |
Draw ellipse with blending.
renderer | The renderer to draw on. |
x | X coordinate of the center of the ellipse. |
y | Y coordinate of the center of the ellipse. |
rx | Horizontal radius in pixels of the ellipse. |
ry | Vertical radius in pixels of the ellipse. |
color | The color value of the ellipse to draw (0xRRGGBBAA). |
Definition at line 1669 of file SDL3_gfxPrimitives.c.
bool ellipseRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | rx, | ||
Sint16 | ry, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw ellipse with blending.
renderer | The renderer to draw on. |
x | X coordinate of the center of the ellipse. |
y | Y coordinate of the center of the ellipse. |
rx | Horizontal radius in pixels of the ellipse. |
ry | Vertical radius in pixels of the ellipse. |
r | The red value of the ellipse to draw. |
g | The green value of the ellipse to draw. |
b | The blue value of the ellipse to draw. |
a | The alpha value of the ellipse to draw. |
Definition at line 1690 of file SDL3_gfxPrimitives.c.
bool filledCircleColor | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | rad, | ||
Uint32 | color ) |
Draw filled circle with blending.
renderer | The renderer to draw on. |
x | X coordinate of the center of the filled circle. |
y | Y coordinate of the center of the filled circle. |
rad | Radius in pixels of the filled circle. |
color | The color value of the filled circle to draw (0xRRGGBBAA). |
Definition at line 1708 of file SDL3_gfxPrimitives.c.
bool filledCircleRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | rad, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw filled circle with blending.
renderer | The renderer to draw on. |
x | X coordinate of the center of the filled circle. |
y | Y coordinate of the center of the filled circle. |
rad | Radius in pixels of the filled circle. |
r | The red value of the filled circle to draw. |
g | The green value of the filled circle to draw. |
b | The blue value of the filled circle to draw. |
a | The alpha value of the filled circle to draw. |
Definition at line 1728 of file SDL3_gfxPrimitives.c.
bool filledEllipseColor | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | rx, | ||
Sint16 | ry, | ||
Uint32 | color ) |
Draw filled ellipse with blending.
renderer | The renderer to draw on. |
x | X coordinate of the center of the filled ellipse. |
y | Y coordinate of the center of the filled ellipse. |
rx | Horizontal radius in pixels of the filled ellipse. |
ry | Vertical radius in pixels of the filled ellipse. |
color | The color value of the filled ellipse to draw (0xRRGGBBAA). |
Definition at line 2004 of file SDL3_gfxPrimitives.c.
bool filledEllipseRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | rx, | ||
Sint16 | ry, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw filled ellipse with blending.
renderer | The renderer to draw on. |
x | X coordinate of the center of the filled ellipse. |
y | Y coordinate of the center of the filled ellipse. |
rx | Horizontal radius in pixels of the filled ellipse. |
ry | Vertical radius in pixels of the filled ellipse. |
r | The red value of the filled ellipse to draw. |
g | The green value of the filled ellipse to draw. |
b | The blue value of the filled ellipse to draw. |
a | The alpha value of the filled ellipse to draw. |
Definition at line 2025 of file SDL3_gfxPrimitives.c.
bool filledPieColor | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | rad, | ||
Sint16 | start, | ||
Sint16 | end, | ||
Uint32 | color ) |
Draw filled pie with alpha blending.
renderer | The renderer to draw on. |
x | X coordinate of the center of the filled pie. |
y | Y coordinate of the center of the filled pie. |
rad | Radius in pixels of the filled pie. |
start | Starting radius in degrees of the filled pie. |
end | Ending radius in degrees of the filled pie. |
color | The color value of the filled pie to draw (0xRRGGBBAA). |
Definition at line 2209 of file SDL3_gfxPrimitives.c.
bool filledPieRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | rad, | ||
Sint16 | start, | ||
Sint16 | end, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw filled pie with alpha blending.
renderer | The renderer to draw on. |
x | X coordinate of the center of the filled pie. |
y | Y coordinate of the center of the filled pie. |
rad | Radius in pixels of the filled pie. |
start | Starting radius in degrees of the filled pie. |
end | Ending radius in degrees of the filled pie. |
r | The red value of the filled pie to draw. |
g | The green value of the filled pie to draw. |
b | The blue value of the filled pie to draw. |
a | The alpha value of the filled pie to draw. |
Definition at line 2231 of file SDL3_gfxPrimitives.c.
bool filledPolygonColor | ( | SDL_Renderer * | renderer, |
const Sint16 * | vx, | ||
const Sint16 * | vy, | ||
int | n, | ||
Uint32 | color ) |
Draw filled polygon with alpha blending.
renderer | The renderer to draw on. |
vx | Vertex array containing X coordinates of the points of the filled polygon. |
vy | Vertex array containing Y coordinates of the points of the filled polygon. |
n | Number of points in the vertex array. Minimum number is 3. |
color | The color value of the filled polygon to draw (0xRRGGBBAA). |
Definition at line 2875 of file SDL3_gfxPrimitives.c.
bool filledPolygonRGBA | ( | SDL_Renderer * | renderer, |
const Sint16 * | vx, | ||
const Sint16 * | vy, | ||
int | n, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw filled polygon with alpha blending.
renderer | The renderer to draw on. |
vx | Vertex array containing X coordinates of the points of the filled polygon. |
vy | Vertex array containing Y coordinates of the points of the filled polygon. |
n | Number of points in the vertex array. Minimum number is 3. |
r | The red value of the filled polygon to draw. |
g | The green value of the filled polygon to draw. |
b | The blue value of the filed polygon to draw. |
a | The alpha value of the filled polygon to draw. |
Definition at line 2895 of file SDL3_gfxPrimitives.c.
int filledPolygonRGBAMT | ( | SDL_Renderer * | renderer, |
const Sint16 * | vx, | ||
const Sint16 * | vy, | ||
int | n, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a, | ||
int ** | polyInts, | ||
int * | polyAllocated ) |
Draw filled polygon with alpha blending (multi-threaded capable).
Note: The last two parameters are optional; but are required for multithreaded operation.
renderer | The renderer to draw on. |
vx | Vertex array containing X coordinates of the points of the filled polygon. |
vy | Vertex array containing Y coordinates of the points of the filled polygon. |
n | Number of points in the vertex array. Minimum number is 3. |
r | The red value of the filled polygon to draw. |
g | The green value of the filled polygon to draw. |
b | The blue value of the filled polygon to draw. |
a | The alpha value of the filled polygon to draw. |
polyInts | Preallocated, temporary vertex array used for sorting vertices. Required for multithreaded operation; set to NULL otherwise. |
polyAllocated | Flag indicating if temporary vertex array was allocated. Required for multithreaded operation; set to NULL otherwise. |
Definition at line 2708 of file SDL3_gfxPrimitives.c.
bool filledTrigonColor | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Sint16 | x3, | ||
Sint16 | y3, | ||
Uint32 | color ) |
Draw filled trigon (triangle) with alpha blending.
Note: Creates vertex array and uses aapolygon routine to render.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point of the filled trigon. |
y1 | Y coordinate of the first point of the filled trigon. |
x2 | X coordinate of the second point of the filled trigon. |
y2 | Y coordinate of the second point of the filled trigon. |
x3 | X coordinate of the third point of the filled trigon. |
y3 | Y coordinate of the third point of the filled trigon. |
color | The color value of the filled trigon to draw (0xRRGGBBAA). |
Definition at line 2387 of file SDL3_gfxPrimitives.c.
bool filledTrigonRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Sint16 | x3, | ||
Sint16 | y3, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw filled trigon (triangle) with alpha blending.
Note: Creates vertex array and uses aapolygon routine to render.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point of the filled trigon. |
y1 | Y coordinate of the first point of the filled trigon. |
x2 | X coordinate of the second point of the filled trigon. |
y2 | Y coordinate of the second point of the filled trigon. |
x3 | X coordinate of the third point of the filled trigon. |
y3 | Y coordinate of the third point of the filled trigon. |
r | The red value of the filled trigon to draw. |
g | The green value of the filled trigon to draw. |
b | The blue value of the filled trigon to draw. |
a | The alpha value of the filled trigon to draw. |
Definition at line 2421 of file SDL3_gfxPrimitives.c.
void gfxPrimitivesSetFont | ( | const void * | fontdata, |
Uint32 | cw, | ||
Uint32 | ch ) |
Sets or resets the current global font data.
The font data array is organized in follows: [fontdata] = [character 0][character 1]...[character 255] where [character n] = [byte 1 row 1][byte 2 row 1]...[byte {pitch} row 1][byte 1 row 2] ...[byte {pitch} row height] where [byte n] = [bit 0]...[bit 7] where [bit n] = [0 for transparent pixel|1 for colored pixel]
fontdata | Pointer to array of font data. Set to NULL, to reset global font to the default 8x8 font. |
cw | Width of character in bytes. Ignored if fontdata==NULL. |
ch | Height of character in bytes. Ignored if fontdata==NULL. |
Definition at line 3255 of file SDL3_gfxPrimitives.c.
void gfxPrimitivesSetFontRotation | ( | Uint32 | rotation | ) |
Sets current global font character rotation steps.
Default is 0 (no rotation). 1 = 90deg clockwise. 2 = 180deg clockwise. 3 = 270deg clockwise. Changing the rotation, will reset the character cache.
rotation | Number of 90deg clockwise steps to rotate |
Definition at line 3301 of file SDL3_gfxPrimitives.c.
bool hline | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | x2, | ||
Sint16 | y ) |
Draw horizontal line in currently set color.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point (i.e. left) of the line. |
x2 | X coordinate of the second point (i.e. right) of the line. |
y | Y coordinate of the points of the line. |
Definition at line 135 of file SDL3_gfxPrimitives.c.
bool hlineColor | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | x2, | ||
Sint16 | y, | ||
Uint32 | color ) |
Draw horizontal line with blending.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point (i.e. left) of the line. |
x2 | X coordinate of the second point (i.e. right) of the line. |
y | Y coordinate of the points of the line. |
color | The color value of the line to draw (0xRRGGBBAA). |
Definition at line 152 of file SDL3_gfxPrimitives.c.
bool hlineRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | x2, | ||
Sint16 | y, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw horizontal line with blending.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point (i.e. left) of the line. |
x2 | X coordinate of the second point (i.e. right) of the line. |
y | Y coordinate of the points of the line. |
r | The red value of the line to draw. |
g | The green value of the line to draw. |
b | The blue value of the line to draw. |
a | The alpha value of the line to draw. |
Definition at line 172 of file SDL3_gfxPrimitives.c.
bool line | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2 ) |
Draw line with alpha blending using the currently set color.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point of the line. |
y1 | Y coordinate of the first point of the line. |
x2 | X coordinate of the second point of the line. |
y2 | Y coordinate of the second point of the line. |
Definition at line 778 of file SDL3_gfxPrimitives.c.
bool lineColor | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Uint32 | color ) |
Draw line with alpha blending.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point of the line. |
y1 | Y coordinate of the first point of the line. |
x2 | X coordinate of the second point of the line. |
y2 | Y coordinate of the seond point of the line. |
color | The color value of the line to draw (0xRRGGBBAA). |
Definition at line 798 of file SDL3_gfxPrimitives.c.
bool lineRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw line with alpha blending.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point of the line. |
y1 | Y coordinate of the first point of the line. |
x2 | X coordinate of the second point of the line. |
y2 | Y coordinate of the second point of the line. |
r | The red value of the line to draw. |
g | The green value of the line to draw. |
b | The blue value of the line to draw. |
a | The alpha value of the line to draw. |
Definition at line 819 of file SDL3_gfxPrimitives.c.
bool pieColor | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | rad, | ||
Sint16 | start, | ||
Sint16 | end, | ||
Uint32 | color ) |
Draw pie (outline) with alpha blending.
renderer | The renderer to draw on. |
x | X coordinate of the center of the pie. |
y | Y coordinate of the center of the pie. |
rad | Radius in pixels of the pie. |
start | Starting radius in degrees of the pie. |
end | Ending radius in degrees of the pie. |
color | The color value of the pie to draw (0xRRGGBBAA). |
Definition at line 2167 of file SDL3_gfxPrimitives.c.
bool pieRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Sint16 | rad, | ||
Sint16 | start, | ||
Sint16 | end, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw pie (outline) with alpha blending.
renderer | The renderer to draw on. |
x | X coordinate of the center of the pie. |
y | Y coordinate of the center of the pie. |
rad | Radius in pixels of the pie. |
start | Starting radius in degrees of the pie. |
end | Ending radius in degrees of the pie. |
r | The red value of the pie to draw. |
g | The green value of the pie to draw. |
b | The blue value of the pie to draw. |
a | The alpha value of the pie to draw. |
Definition at line 2190 of file SDL3_gfxPrimitives.c.
bool pixel | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y ) |
Draw pixel in currently set color.
renderer | The renderer to draw on. |
x | X (horizontal) coordinate of the pixel. |
y | Y (vertical) coordinate of the pixel. |
Definition at line 50 of file SDL3_gfxPrimitives.c.
bool pixelColor | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Uint32 | color ) |
Draw pixel with blending enabled if a<255.
renderer | The renderer to draw on. |
x | X (horizontal) coordinate of the pixel. |
y | Y (vertical) coordinate of the pixel. |
color | The color value of the pixel to draw (0xRRGGBBAA). |
Definition at line 65 of file SDL3_gfxPrimitives.c.
bool pixelRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw pixel with blending enabled if a<255.
renderer | The renderer to draw on. |
x | X (horizontal) coordinate of the pixel. |
y | Y (vertical) coordinate of the pixel. |
r | The red color value of the pixel to draw. |
g | The green color value of the pixel to draw. |
b | The blue color value of the pixel to draw. |
a | The alpha value of the pixel to draw. |
Definition at line 84 of file SDL3_gfxPrimitives.c.
bool pixelRGBAWeight | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a, | ||
Uint32 | weight ) |
Draw pixel with blending enabled and using alpha weight on color.
renderer | The renderer to draw on. |
x | The horizontal coordinate of the pixel. |
y | The vertical position of the pixel. |
r | The red color value of the pixel to draw. |
g | The green color value of the pixel to draw. |
b | The blue color value of the pixel to draw. |
a | The alpha value of the pixel to draw. |
weight | The weight multiplied into the alpha value of the pixel. |
Definition at line 107 of file SDL3_gfxPrimitives.c.
bool polygon | ( | SDL_Renderer * | renderer, |
const Sint16 * | vx, | ||
const Sint16 * | vy, | ||
int | n ) |
Draw polygon with the currently set color and blend mode.
renderer | The renderer to draw on. |
vx | Vertex array containing X coordinates of the points of the polygon. |
vy | Vertex array containing Y coordinates of the points of the polygon. |
n | Number of points in the vertex array. Minimum number is 3. |
Definition at line 2466 of file SDL3_gfxPrimitives.c.
bool polygonColor | ( | SDL_Renderer * | renderer, |
const Sint16 * | vx, | ||
const Sint16 * | vy, | ||
int | n, | ||
Uint32 | color ) |
Draw polygon with alpha blending.
renderer | The renderer to draw on. |
vx | Vertex array containing X coordinates of the points of the polygon. |
vy | Vertex array containing Y coordinates of the points of the polygon. |
n | Number of points in the vertex array. Minimum number is 3. |
color | The color value of the polygon to draw (0xRRGGBBAA). |
Definition at line 2450 of file SDL3_gfxPrimitives.c.
bool polygonRGBA | ( | SDL_Renderer * | renderer, |
const Sint16 * | vx, | ||
const Sint16 * | vy, | ||
int | n, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw polygon with alpha blending.
renderer | The renderer to draw on. |
vx | Vertex array containing X coordinates of the points of the polygon. |
vy | Vertex array containing Y coordinates of the points of the polygon. |
n | Number of points in the vertex array. Minimum number is 3. |
r | The red value of the polygon to draw. |
g | The green value of the polygon to draw. |
b | The blue value of the polygon to draw. |
a | The alpha value of the polygon to draw. |
Definition at line 2532 of file SDL3_gfxPrimitives.c.
bool rectangleColor | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Uint32 | color ) |
Draw rectangle with blending.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point (i.e. top right) of the rectangle. |
y1 | Y coordinate of the first point (i.e. top right) of the rectangle. |
x2 | X coordinate of the second point (i.e. bottom left) of the rectangle. |
y2 | Y coordinate of the second point (i.e. bottom left) of the rectangle. |
color | The color value of the rectangle to draw (0xRRGGBBAA). |
Definition at line 252 of file SDL3_gfxPrimitives.c.
bool rectangleRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw rectangle with blending.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point (i.e. top right) of the rectangle. |
y1 | Y coordinate of the first point (i.e. top right) of the rectangle. |
x2 | X coordinate of the second point (i.e. bottom left) of the rectangle. |
y2 | Y coordinate of the second point (i.e. bottom left) of the rectangle. |
r | The red value of the rectangle to draw. |
g | The green value of the rectangle to draw. |
b | The blue value of the rectangle to draw. |
a | The alpha value of the rectangle to draw. |
Definition at line 273 of file SDL3_gfxPrimitives.c.
bool roundedBoxColor | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Sint16 | rad, | ||
Uint32 | color ) |
Draw rounded-corner box (filled rectangle) with blending.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point (i.e. top right) of the box. |
y1 | Y coordinate of the first point (i.e. top right) of the box. |
x2 | X coordinate of the second point (i.e. bottom left) of the box. |
y2 | Y coordinate of the second point (i.e. bottom left) of the box. |
rad | The radius of the corner arcs of the box. |
color | The color value of the box to draw (0xRRGGBBAA). |
Definition at line 490 of file SDL3_gfxPrimitives.c.
bool roundedBoxRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Sint16 | rad, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw rounded-corner box (filled rectangle) with blending.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point (i.e. top right) of the box. |
y1 | Y coordinate of the first point (i.e. top right) of the box. |
x2 | X coordinate of the second point (i.e. bottom left) of the box. |
y2 | Y coordinate of the second point (i.e. bottom left) of the box. |
rad | The radius of the corner arcs of the box. |
r | The red value of the box to draw. |
g | The green value of the box to draw. |
b | The blue value of the box to draw. |
a | The alpha value of the box to draw. |
Definition at line 512 of file SDL3_gfxPrimitives.c.
bool roundedRectangleColor | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Sint16 | rad, | ||
Uint32 | color ) |
Draw rounded-corner rectangle with blending.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point (i.e. top right) of the rectangle. |
y1 | Y coordinate of the first point (i.e. top right) of the rectangle. |
x2 | X coordinate of the second point (i.e. bottom left) of the rectangle. |
y2 | Y coordinate of the second point (i.e. bottom left) of the rectangle. |
rad | The radius of the corner arc. |
color | The color value of the rectangle to draw (0xRRGGBBAA). |
Definition at line 345 of file SDL3_gfxPrimitives.c.
bool roundedRectangleRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Sint16 | rad, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw rounded-corner rectangle with blending.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point (i.e. top right) of the rectangle. |
y1 | Y coordinate of the first point (i.e. top right) of the rectangle. |
x2 | X coordinate of the second point (i.e. bottom left) of the rectangle. |
y2 | Y coordinate of the second point (i.e. bottom left) of the rectangle. |
rad | The radius of the corner arc. |
r | The red value of the rectangle to draw. |
g | The green value of the rectangle to draw. |
b | The blue value of the rectangle to draw. |
a | The alpha value of the rectangle to draw. |
Definition at line 367 of file SDL3_gfxPrimitives.c.
bool stringColor | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
const char * | s, | ||
Uint32 | color ) |
Draw a string in the currently set font.
The spacing between consequtive characters in the string is the fixed number of pixels of the character width of the current global font.
renderer | The renderer to draw on. |
x | X (horizontal) coordinate of the upper left corner of the string. |
y | Y (vertical) coordinate of the upper left corner of the string. |
s | The string to draw. |
color | The color value of the string to draw (0xRRGGBBAA). |
Definition at line 3489 of file SDL3_gfxPrimitives.c.
bool stringRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y, | ||
const char * | s, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw a string in the currently set font.
renderer | The renderer to draw on. |
x | X (horizontal) coordinate of the upper left corner of the string. |
y | Y (vertical) coordinate of the upper left corner of the string. |
s | The string to draw. |
r | The red value of the string to draw. |
g | The green value of the string to draw. |
b | The blue value of the string to draw. |
a | The alpha value of the string to draw. |
Definition at line 3509 of file SDL3_gfxPrimitives.c.
bool texturedPolygon | ( | SDL_Renderer * | renderer, |
const Sint16 * | vx, | ||
const Sint16 * | vy, | ||
int | n, | ||
SDL_Surface * | texture, | ||
int | texture_dx, | ||
int | texture_dy ) |
Draws a polygon filled with the given texture.
This standard version is calling multithreaded versions with NULL cache parameters.
renderer | The renderer to draw on. |
vx | array of x vector components |
vy | array of x vector components |
n | the amount of vectors in the vx and vy array |
texture | the sdl surface to use to fill the polygon |
texture_dx | the offset of the texture relative to the screeen. if you move the polygon 10 pixels to the left and want the texture to apear the same you need to increase the texture_dx value |
texture_dy | see texture_dx |
Definition at line 3187 of file SDL3_gfxPrimitives.c.
bool texturedPolygonMT | ( | SDL_Renderer * | renderer, |
const Sint16 * | vx, | ||
const Sint16 * | vy, | ||
int | n, | ||
SDL_Surface * | texture, | ||
int | texture_dx, | ||
int | texture_dy, | ||
int ** | polyInts, | ||
int * | polyAllocated ) |
Draws a polygon filled with the given texture (Multi-Threading Capable).
renderer | The renderer to draw on. |
vx | array of x vector components |
vy | array of x vector components |
n | the amount of vectors in the vx and vy array |
texture | the sdl surface to use to fill the polygon |
texture_dx | the offset of the texture relative to the screeen. If you move the polygon 10 pixels to the left and want the texture to apear the same you need to increase the texture_dx value |
texture_dy | see texture_dx |
polyInts | Preallocated temp array storage for vertex sorting (used for multi-threaded operation) |
polyAllocated | Flag indicating oif the temp array was allocated (used for multi-threaded operation) |
Definition at line 3016 of file SDL3_gfxPrimitives.c.
bool thickLineColor | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Uint8 | width, | ||
Uint32 | color ) |
Draw a thick line with alpha blending.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point of the line. |
y1 | Y coordinate of the first point of the line. |
x2 | X coordinate of the second point of the line. |
y2 | Y coordinate of the second point of the line. |
width | Width of the line in pixels. Must be >0. |
color | The color value of the line to draw (0xRRGGBBAA). |
Definition at line 3710 of file SDL3_gfxPrimitives.c.
bool thickLineRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Uint8 | width, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw a thick line with alpha blending.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point of the line. |
y1 | Y coordinate of the first point of the line. |
x2 | X coordinate of the second point of the line. |
y2 | Y coordinate of the second point of the line. |
width | Width of the line in pixels. Must be >0. |
r | The red value of the character to draw. |
g | The green value of the character to draw. |
b | The blue value of the character to draw. |
a | The alpha value of the character to draw. |
Definition at line 3732 of file SDL3_gfxPrimitives.c.
bool trigonColor | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Sint16 | x3, | ||
Sint16 | y3, | ||
Uint32 | color ) |
Draw trigon (triangle outline) with alpha blending.
Note: Creates vertex array and uses polygon routine to render.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point of the trigon. |
y1 | Y coordinate of the first point of the trigon. |
x2 | X coordinate of the second point of the trigon. |
y2 | Y coordinate of the second point of the trigon. |
x3 | X coordinate of the third point of the trigon. |
y3 | Y coordinate of the third point of the trigon. |
color | The color value of the trigon to draw (0xRRGGBBAA). |
Definition at line 2255 of file SDL3_gfxPrimitives.c.
bool trigonRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x1, | ||
Sint16 | y1, | ||
Sint16 | x2, | ||
Sint16 | y2, | ||
Sint16 | x3, | ||
Sint16 | y3, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw trigon (triangle outline) with alpha blending.
renderer | The renderer to draw on. |
x1 | X coordinate of the first point of the trigon. |
y1 | Y coordinate of the first point of the trigon. |
x2 | X coordinate of the second point of the trigon. |
y2 | Y coordinate of the second point of the trigon. |
x3 | X coordinate of the third point of the trigon. |
y3 | Y coordinate of the third point of the trigon. |
r | The red value of the trigon to draw. |
g | The green value of the trigon to draw. |
b | The blue value of the trigon to draw. |
a | The alpha value of the trigon to draw. |
Definition at line 2287 of file SDL3_gfxPrimitives.c.
bool vline | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y1, | ||
Sint16 | y2 ) |
Draw vertical line in currently set color.
renderer | The renderer to draw on. |
x | X coordinate of points of the line. |
y1 | Y coordinate of the first point (i.e. top) of the line. |
y2 | Y coordinate of the second point (i.e. bottom) of the line. |
Definition at line 193 of file SDL3_gfxPrimitives.c.
bool vlineColor | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y1, | ||
Sint16 | y2, | ||
Uint32 | color ) |
Draw vertical line with blending.
renderer | The renderer to draw on. |
x | X coordinate of the points of the line. |
y1 | Y coordinate of the first point (i.e. top) of the line. |
y2 | Y coordinate of the second point (i.e. bottom) of the line. |
color | The color value of the line to draw (0xRRGGBBAA). |
Definition at line 209 of file SDL3_gfxPrimitives.c.
bool vlineRGBA | ( | SDL_Renderer * | renderer, |
Sint16 | x, | ||
Sint16 | y1, | ||
Sint16 | y2, | ||
Uint8 | r, | ||
Uint8 | g, | ||
Uint8 | b, | ||
Uint8 | a ) |
Draw vertical line with blending.
renderer | The renderer to draw on. |
x | X coordinate of the points of the line. |
y1 | Y coordinate of the first point (i.e. top) of the line. |
y2 | Y coordinate of the second point (i.e. bottom) of the line. |
r | The red value of the line to draw. |
g | The green value of the line to draw. |
b | The blue value of the line to draw. |
a | The alpha value of the line to draw. |
Definition at line 229 of file SDL3_gfxPrimitives.c.