From 298bfc3d109110b8f4332083b4f9aca850f43eea Mon Sep 17 00:00:00 2001 From: Miroslav Remák Date: Mon, 23 Jul 2018 19:49:08 +0200 Subject: MUTATIONOFJB: Subclass Graphics::Font to reuse existing code. --- engines/mutationofjb/font.h | 20 ++++++++++++-------- 1 file changed, 12 insertions(+), 8 deletions(-) (limited to 'engines/mutationofjb/font.h') diff --git a/engines/mutationofjb/font.h b/engines/mutationofjb/font.h index a27303eb0d..51825dbe13 100644 --- a/engines/mutationofjb/font.h +++ b/engines/mutationofjb/font.h @@ -25,7 +25,9 @@ #include "common/scummsys.h" #include "common/hashmap.h" +#include "graphics/font.h" #include "graphics/managed_surface.h" +#include "graphics/surface.h" namespace Common { class String; @@ -33,24 +35,26 @@ class String; namespace MutationOfJB { -class Font { +class Font : public Graphics::Font { + friend class FontBlitOperation; public: - Font(const Common::String &fileName, int horizSpacing, int vertSpacing); - virtual ~Font() {} - int getLineHeight() const; - int16 getWidth(const Common::String &text) const; - void drawString(const Common::String &str, uint8 baseColor, int16 x, int16 y, Graphics::ManagedSurface &surf) const; - void wordWrap(const Common::String &str, int16 maxLineWidth, Common::Array &lines) const; + Font(const Common::String &fileName, int horizSpacing, int lineHeight); + + virtual int getFontHeight() const override; + virtual int getMaxCharWidth() const override; + virtual int getCharWidth(uint32 chr) const override; + virtual int getKerningOffset(uint32 left, uint32 right) const override; + virtual void drawChar(Graphics::Surface *dst, uint32 chr, int x, int y, uint32 color) const override; protected: virtual uint8 transformColor(uint8 baseColor, uint8 glyphColor) const; private: - void drawGlyph(uint8 glyph, uint8 baseColor, int16 &x, int16 &y, Graphics::ManagedSurface &surf) const; bool load(const Common::String &fileName); int _horizSpacing; int _lineHeight; + int _maxCharWidth; typedef Common::HashMap GlyphMap; GlyphMap _glyphs; }; -- cgit v1.2.3