A text and image layout library for LÖVE
Pull request Compare This branch is 25 commits behind gvx:master.
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Failed to load latest commit information.


richtext is a text and image formatting library for the LÖVE framework.


require 'richtext'

rt = rich.new{"Hello {green}world{red}, {smile} {big}Big text.", 200,
              black = {0, 0, 0}, green = {0, 255, 0},
              big = love.graphics.newFont(20), red = {255, 0, 0},
              smile = love.graphics.newImage('smile.png')}

function love.draw()
    rt:draw(10, 10)


  • automatically pads images to PO2, without any alignment problems

  • wraps words and images together

current issues

  • richtext is still not well-tested

  • word wrapping might not be optimally done, because it always splits the first word, which might lead to a lot of splitting (the end result is fine, though)

  • words keep their final space in wrapping, which may cause words to be wrapped just a bit too soon

  • any initial text color (other than white) has to be specified manually by starting text


Copyright (c) 2010 Robin Wellner

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.