summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorjussi2024-06-13 14:52:56 +0300
committerjussi2024-06-13 14:52:56 +0300
commite9539e9373947b7424df8bbb34d8ae30e49a591f (patch)
tree0719f3bf5a00c53a43317d34c28d3b3925d4b4cd /src
parentf3dbe7d24bcf01d9a23326880dbb1a28457ff51f (diff)
downloadreilua-enhanced-e9539e9373947b7424df8bbb34d8ae30e49a591f.tar.gz
reilua-enhanced-e9539e9373947b7424df8bbb34d8ae30e49a591f.tar.bz2
reilua-enhanced-e9539e9373947b7424df8bbb34d8ae30e49a591f.zip
DrawTextBoxed uses lineSpacing. GetTextLineSpacing.
Diffstat (limited to 'src')
-rw-r--r--src/lua_core.c1
-rw-r--r--src/state.c1
-rw-r--r--src/text.c29
3 files changed, 24 insertions, 7 deletions
diff --git a/src/lua_core.c b/src/lua_core.c
index 049a310..1dacc86 100644
--- a/src/lua_core.c
+++ b/src/lua_core.c
@@ -1841,6 +1841,7 @@ void luaRegister() {
assingGlobalFunction( "DrawTextBoxedTinted", ltextDrawTextBoxedTinted );
/* Text font info functions. */
assingGlobalFunction( "SetTextLineSpacing", ltextSetTextLineSpacing );
+ assingGlobalFunction( "GetTextLineSpacing", ltextGetTextLineSpacing );
assingGlobalFunction( "MeasureText", ltextMeasureText );
assingGlobalFunction( "MeasureTextEx", ltextMeasureTextEx );
assingGlobalFunction( "GetGlyphIndex", ltextGetGlyphIndex );
diff --git a/src/state.c b/src/state.c
index 52742e5..c17f3f0 100644
--- a/src/state.c
+++ b/src/state.c
@@ -18,6 +18,7 @@ bool stateInit( int argn, const char** argc, const char* basePath ) {
state->luaState = NULL;
state->logLevelInvalid = LOG_ERROR;
state->gcUnload = true;
+ state->lineSpacing = 15;
InitWindow( state->resolution.x, state->resolution.y, "ReiLua" );
diff --git a/src/text.c b/src/text.c
index a9402d4..2a4ec1d 100644
--- a/src/text.c
+++ b/src/text.c
@@ -12,14 +12,14 @@ void unloadGlyphInfo( GlyphInfo* glyph ) {
// Draw text using font inside rectangle limits
static int DrawTextBoxed( Font font, const char* text, Rectangle rec, float fontSize, float spacing,
-bool wordWrap, Color* tints, int tintCount, Color* backTints, int backTintCount )
-{
+bool wordWrap, Color* tints, int tintCount, Color* backTints, int backTintCount ) {
int length = TextLength(text); // Total length in bytes of the text, scanned by codepoints in loop
float textOffsetY = 0; // Offset between lines (on line break '\n')
float textOffsetX = 0.0f; // Offset X to next character to draw
float scaleFactor = fontSize/(float)font.baseSize; // Character rectangle scaling factor
+ int lineSpacing = state->lineSpacing;
// Word/character wrapping mechanism variables
enum { MEASURE_STATE = 0, DRAW_STATE = 1 };
@@ -103,7 +103,8 @@ bool wordWrap, Color* tints, int tintCount, Color* backTints, int backTintCount
{
if (!wordWrap)
{
- textOffsetY += (font.baseSize + font.baseSize/2)*scaleFactor;
+ // textOffsetY += (font.baseSize + font.baseSize/2)*scaleFactor;
+ textOffsetY += lineSpacing;
textOffsetX = 0;
}
}
@@ -111,7 +112,8 @@ bool wordWrap, Color* tints, int tintCount, Color* backTints, int backTintCount
{
if (!wordWrap && ((textOffsetX + glyphWidth) > rec.width))
{
- textOffsetY += (font.baseSize + font.baseSize/2)*scaleFactor;
+ // textOffsetY += (font.baseSize + font.baseSize/2)*scaleFactor;
+ textOffsetY += lineSpacing;
textOffsetX = 0;
}
@@ -144,7 +146,8 @@ bool wordWrap, Color* tints, int tintCount, Color* backTints, int backTintCount
if (wordWrap && (i == endLine))
{
- textOffsetY += (font.baseSize + font.baseSize/2)*scaleFactor;
+ // textOffsetY += (font.baseSize + font.baseSize/2)*scaleFactor;
+ textOffsetY += lineSpacing;
textOffsetX = 0;
startLine = endLine;
endLine = -1;
@@ -606,7 +609,7 @@ int ltextDrawTextBoxed( lua_State* L ) {
}
/*
-> mouseCharId = RL.DrawTextBoxedTinted( Font font, string text, Rectangle rec, float fontSize, float spacing, bool wordWrap, Color tints, Color backTints )
+> mouseCharId = RL.DrawTextBoxedTinted( Font font, string text, Rectangle rec, float fontSize, float spacing, bool wordWrap, Color tints{}, Color backTints{} )
Draw text using font inside rectangle limits with support for tint and background tint for each character. Return character id from mouse position (default -1)
@@ -653,17 +656,29 @@ int ltextDrawTextBoxedTinted( lua_State* L ) {
*/
/*
-> size = RL.SetTextLineSpacing( int spacing )
+> RL.SetTextLineSpacing( int spacing )
Set vertical line spacing when drawing with line-breaks
*/
int ltextSetTextLineSpacing( lua_State* L ) {
int spacing = luaL_checkinteger( L, 1 );
+ state->lineSpacing = spacing;
SetTextLineSpacing( spacing );
}
/*
+> spacing = RL.GetTextLineSpacing()
+
+Get vertical line spacing when drawing with line-breaks
+
+- Success return int
+*/
+int ltextGetTextLineSpacing( lua_State* L ) {
+ lua_pushinteger( L, state->lineSpacing );
+}
+
+/*
> width = RL.MeasureText( string text, int fontSize )
Measure string width for default font