2024-10-07 14:53:09 +00:00
|
|
|
#ifndef TWN_DRAW_H
|
|
|
|
#define TWN_DRAW_H
|
|
|
|
|
2024-10-12 18:16:25 +00:00
|
|
|
#include "twn_types.h"
|
2024-10-07 14:53:09 +00:00
|
|
|
#include "twn_option.h"
|
|
|
|
#include "twn_engine_api.h"
|
|
|
|
|
|
|
|
#include <stdbool.h>
|
|
|
|
|
|
|
|
/* pushes a sprite onto the sprite render queue */
|
2024-10-29 09:25:24 +00:00
|
|
|
TWN_API void draw_sprite(char const *texture,
|
2024-10-07 14:53:09 +00:00
|
|
|
Rect rect,
|
|
|
|
Rect const *texture_region, /* optional, default: NULL */
|
|
|
|
Color color, /* optional, default: all 255 */
|
|
|
|
float rotation, /* optional, default: 0 */
|
|
|
|
bool flip_x, /* optional, default: false */
|
|
|
|
bool flip_y, /* optional, default: false */
|
2024-10-29 09:25:24 +00:00
|
|
|
bool stretch); /* optional, default: true */
|
2024-10-07 14:53:09 +00:00
|
|
|
|
|
|
|
/* pushes a filled rectangle onto the rectangle render queue */
|
|
|
|
TWN_API void draw_rectangle(Rect rect, Color color);
|
|
|
|
|
|
|
|
/* pushes a filled circle onto the circle render queue */
|
2024-10-14 01:32:59 +00:00
|
|
|
/* note that its edges may look jagged with a radius larger than 2048 */
|
2024-10-07 14:53:09 +00:00
|
|
|
TWN_API void draw_circle(Vec2 position, float radius, Color color);
|
|
|
|
|
|
|
|
/* TODO: have font optional, with something minimal coming embedded */
|
|
|
|
TWN_API void draw_text(char const *string,
|
|
|
|
Vec2 position,
|
2024-10-29 09:25:24 +00:00
|
|
|
float height, /* optional, default: 22 */
|
|
|
|
Color color, /* optional, default: all 0 */
|
|
|
|
char const *font); /* optional, default: NULL */
|
2024-10-07 14:53:09 +00:00
|
|
|
|
|
|
|
|
2024-10-29 09:25:24 +00:00
|
|
|
TWN_API float draw_text_width(char const *string,
|
|
|
|
float height, /* optional, default: 22 */
|
|
|
|
char const *font); /* optional, default: NULL */
|
2024-10-07 14:53:09 +00:00
|
|
|
|
2024-10-29 09:25:24 +00:00
|
|
|
TWN_API void draw_nine_slice(char const *texture,
|
|
|
|
Vec2 corners,
|
2024-10-22 10:52:24 +00:00
|
|
|
Rect rect,
|
2024-10-29 09:25:24 +00:00
|
|
|
float border_thickness, /* optional, default: 0 */
|
|
|
|
Color color); /* optional, default: all 255 */
|
2024-10-07 14:53:09 +00:00
|
|
|
|
|
|
|
/* pushes a textured 3d triangle onto the render queue */
|
|
|
|
/* texture coordinates are in pixels */
|
2024-10-29 09:25:24 +00:00
|
|
|
TWN_API void draw_triangle(char const *texture,
|
2024-10-07 14:53:09 +00:00
|
|
|
Vec3 v0,
|
|
|
|
Vec3 v1,
|
|
|
|
Vec3 v2,
|
|
|
|
Vec2 uv0,
|
|
|
|
Vec2 uv1,
|
|
|
|
Vec2 uv2);
|
|
|
|
|
|
|
|
// TODO: decide whether it's needed to begin with?
|
|
|
|
// intended usage for it is baked lighting, i would think.
|
|
|
|
/* pushes a colored textured 3d triangle onto the render queue */
|
|
|
|
// void unfurl_colored_triangle(const char *path,
|
|
|
|
// Vec3 v0,
|
|
|
|
// Vec3 v1,
|
|
|
|
// Vec3 v2,
|
|
|
|
// Vec2sh uv0,
|
|
|
|
// Vec2sh uv1,
|
|
|
|
// Vec2sh uv2,
|
|
|
|
// Color c0,
|
|
|
|
// Color c1,
|
|
|
|
// Color c2);
|
|
|
|
|
2024-10-29 09:25:24 +00:00
|
|
|
TWN_API void draw_billboard(const char *path,
|
|
|
|
Vec3 position,
|
2025-01-03 18:59:00 +00:00
|
|
|
Vec2 size,
|
|
|
|
Color color, /* optional, default: all 255 */
|
|
|
|
bool cylindrical); /* optional, default: false */
|
2024-10-07 14:53:09 +00:00
|
|
|
|
2024-10-28 09:34:48 +00:00
|
|
|
/* sets a perspective 3d camera to be used for all 3d commands */
|
|
|
|
TWN_API void draw_camera(Vec3 position, float fov, Vec3 up, Vec3 direction);
|
|
|
|
|
|
|
|
/* same as draw_camera(), but with specific use case */
|
|
|
|
/* direction and up vectors are inferred from roll, pitch and yaw parameters (in radians) */
|
|
|
|
/* return value is direction and up vectors, so that you can use them in logic (such as controllers) */
|
|
|
|
typedef struct DrawCameraFromPrincipalAxesResult {
|
|
|
|
Vec3 direction;
|
|
|
|
Vec3 up;
|
|
|
|
} DrawCameraFromPrincipalAxesResult;
|
2024-10-28 10:04:07 +00:00
|
|
|
TWN_API DrawCameraFromPrincipalAxesResult draw_camera_from_principal_axes(Vec3 position,
|
2024-10-28 09:34:48 +00:00
|
|
|
float fov,
|
|
|
|
float roll,
|
|
|
|
float pitch,
|
|
|
|
float yaw);
|
2024-10-07 14:53:09 +00:00
|
|
|
|
|
|
|
/* expects '*' masks that will be expanded to 6 names: 'up', 'down', 'east', 'west', 'north' and 'south' */
|
|
|
|
TWN_API void draw_skybox(const char *paths);
|
|
|
|
|
|
|
|
TWN_API void draw_fog(float start, float end, float density, Color color);
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef TWN_NOT_C
|
|
|
|
|
|
|
|
typedef struct DrawSpriteArgs {
|
2024-10-29 09:25:24 +00:00
|
|
|
char const *texture;
|
2024-10-07 14:53:09 +00:00
|
|
|
Rect rect;
|
|
|
|
|
|
|
|
m_option_list(
|
|
|
|
Rect, texture_region,
|
|
|
|
Color, color,
|
|
|
|
float, rotation,
|
|
|
|
bool, flip_x,
|
|
|
|
bool, flip_y,
|
|
|
|
bool, stretch )
|
|
|
|
} DrawSpriteArgs;
|
|
|
|
|
|
|
|
TWN_API void draw_sprite_args(DrawSpriteArgs args);
|
|
|
|
#define m_sprite(...) (draw_sprite_args((DrawSpriteArgs){__VA_ARGS__}))
|
|
|
|
|
|
|
|
/* TODO: define more */
|
|
|
|
|
|
|
|
#endif /* TWN_NOT_C */
|
|
|
|
|
|
|
|
#endif
|