;;; guile-2d ;;; Copyright (C) 2013 David Thompson ;;; ;;; Guile-2d is free software: you can redistribute it and/or modify it ;;; under the terms of the GNU Lesser General Public License as ;;; published by the Free Software Foundation, either version 3 of the ;;; License, or (at your option) any later version. ;;; ;;; Guile-2d is distributed in the hope that it will be useful, but ;;; WITHOUT ANY WARRANTY; without even the implied warranty of ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ;;; Lesser General Public License for more details. ;;; ;;; You should have received a copy of the GNU Lesser General Public ;;; License along with this program. If not, see ;;; . ;;; Commentary: ;; ;; Font rendering. ;; ;;; Code: (define-module (2d font) #:use-module (figl gl) #:use-module (srfi srfi-9) #:use-module (system foreign) #:use-module (2d wrappers ftgl) #:use-module (2d color) #:use-module (2d vector)) ;;; ;;; Font ;;; ;; Font objects represent an FTGL texture font at a given size. (define-record-type (make-font ftgl-font size) font? (ftgl-font font-ftgl-font) (size font-size)) (define (load-font filename size) "Loads a font from a file with a given size in points." (let ((ftgl-font (ftgl-create-texture-font filename))) ;; Hardcoded 72 dpi for now. (ftgl-set-font-face-size ftgl-font size 72) (make-font ftgl-font size))) (define (draw-font font text) "Renders the string text using the given font." (ftgl-render-font (font-ftgl-font font) text (ftgl-render-mode all))) (export make-font font? font-ftgl-font font-size load-font draw-font) ;;; ;;; Textbox ;;; ;; A textbox is a string of word-wrapped text (define-record-type (%make-textbox font text position color alignment line-length layout) textbox? (font textbox-font) (text textbox-text set-textbox-text!) (position textbox-position set-textbox-position!) (color textbox-color set-textbox-color!) (alignment textbox-alignment) (line-length textbox-line-length) (layout textbox-layout)) (define (make-textbox font text position color alignment line-length) (let ((layout (ftgl-create-layout))) (ftgl-set-layout-font layout (font-ftgl-font font)) ;; (ftgl-set-layout-alignment layout (ftgl-text-alignment alignment)) (ftgl-set-layout-line-length layout line-length) (%make-textbox font text position color alignment line-length layout))) (define (draw-textbox textbox) (let ((pos (textbox-position textbox))) (with-gl-push-matrix (gl-translate (vx pos) (vy pos) 0) (apply-color (textbox-color textbox)) (ftgl-render-layout (textbox-layout textbox) (textbox-text textbox) (ftgl-render-mode all))))) (export make-textbox textbox? textbox-font textbox-text set-textbox-text! textbox-position set-textbox-position! textbox-color set-textbox-color! textbox-alignment textbox-line-length textbox-layout draw-textbox)