]> git.tdb.fi Git - libs/gl.git/blobdiff - source/font.h
Drop Id tags and copyright notices from files
[libs/gl.git] / source / font.h
index a55933519b6c792a72bf967a7bdce2d7514afdf1..6ae5c6d3862426c9bbb74bfb7198fb3444fe3125 100644 (file)
@@ -1,54 +1,73 @@
-/* $Id$
-
-This file is part of libmspgl
-Copyright © 2007  Mikko Rasa, Mikkosoft Productions
-Distributed under the LGPL
-*/
-
 #ifndef MSP_GL_FONT_H_
 #define MSP_GL_FONT_H_
 
 #include <map>
 #include <string>
-#include <msp/datafile/loader.h>
-#include <msp/strings/codec.h>
+#include <msp/datafile/objectloader.h>
+#include <msp/strings/utf8.h>
 #include "vertexarray.h"
 
 namespace Msp {
 namespace GL {
 
+class PrimitiveBuilder;
 class Texture2D;
 
 class Font
 {
 public:
-       class Loader: public Msp::DataFile::Loader
+       class Loader: public DataFile::CollectionObjectLoader<Font>
        {
        public:
                Loader(Font &);
-               ~Loader();
-               Font &get_object() { return font; }
-       private:
-               Font &font;
+               Loader(Font &, Collection &);
 
-               void texture(const std::string &);
+       private:
+               void init();
                void glyph(unsigned);
+               void texture();
+               void texture_ref(const std::string &);
+       };
+
+private:
+       struct Glyph
+       {
+               class Loader: public Msp::DataFile::ObjectLoader<Glyph>
+               {
+               public:
+                       Loader(Glyph &);
+               private:
+                       void texcoords(float, float, float, float);
+               };
+
+               unsigned code;
+               float x1,y1;
+               float x2,y2;
+               float w,h;
+               float off_x, off_y;
+               float advance;
        };
 
+       typedef std::map<unsigned, Glyph> GlyphMap;
+
+       RefPtr<const Texture2D> texture;
+       float native_size;
+       float ascent;
+       float descent;
+       GlyphMap glyphs;
+
+public:
        Font();
-       ~Font();
 
-       void  set_texture(const Texture2D &);
-       void  add_glyph(unsigned, float, float, float, float, float, float, float, float, float);
-       float get_default_size() const { return default_size; }
+       void set_texture(const Texture2D &);
+       const Texture2D &get_texture() const;
+       void add_glyph(unsigned, float, float, float, float, float, float, float, float, float);
+       float get_native_size() const { return native_size; }
+       float get_default_size() const { return native_size; }  // Deprecated
        float get_ascent() const { return ascent; }
        float get_descent() const { return descent; }
-       float get_string_width(const std::string &) const;
+
        float get_string_width(const std::string &, Codecs::Decoder &) const;
-       void  draw_glyph(unsigned);
-       void  draw_string(const std::string &) const;
-       void  draw_string(const std::string &, Codecs::Decoder &) const;
-       void  draw_multiline(const std::string &) const;
 
        template<class C>
        float get_string_width(const std::string &str) const
@@ -57,48 +76,34 @@ public:
                return get_string_width(str, dec);
        }
 
+       float get_string_width(const std::string &str) const
+       { return get_string_width<Codecs::Utf8>(str); }
+
+       void draw_string(const std::string &, Codecs::Decoder &) const;
+       void draw_string(const std::string &, Codecs::Decoder &, PrimitiveBuilder &) const;
+
        template<class C>
        void draw_string(const std::string &str) const
        {
                typename C::Decoder dec;
                draw_string(str, dec);
        }
-private:
-       struct Glyph
-       {
-               class Loader: public Msp::DataFile::Loader
-               {
-               public:
-                       Loader(Glyph &);
-                       Glyph &get_object() { return glyph; }
-               private:
-                       Glyph &glyph;
 
-                       void texcoords(float, float, float, float);
-               };
+       void draw_string(const std::string &str) const
+       { draw_string<Codecs::Utf8>(str); }
 
-               unsigned code;
-               float x1,y1;
-               float x2,y2;
-               float w,h;
-               float off_x, off_y;
-               float advance;
-               unsigned index;
-       };
-       typedef std::map<unsigned, Glyph> GlyphMap;
+       template<class C>
+       void draw_string(const std::string &str, PrimitiveBuilder &pb) const
+       {
+               typename C::Decoder dec;
+               draw_string(str, dec, pb);
+       }
 
-       const Texture2D *tex;
-       bool     own_tex;
-       float    default_size;
-       float    ascent;
-       float    descent;
-       GlyphMap glyphs;
-       VertexArray varray;
+       void draw_string(const std::string &str, PrimitiveBuilder &pb) const
+       { return draw_string<Codecs::Utf8>(str, pb); }
 
-       void create_glyph_vertices();
-       void create_glyph_vertices(const Glyph &, VertexArrayBuilder &);
-       void prepare_render() const;
-       void draw_glyph(unsigned) const;
+private:
+       void create_glyph_vertices(const Glyph &, VertexBuilder &) const;
        float get_glyph_advance(unsigned) const;
 };