From d4622366d9886fcb62a74507af362dbe73573bcc Mon Sep 17 00:00:00 2001 From: Andreas Regel Date: Sun, 26 Apr 2015 09:27:25 +0200 Subject: Add skintest tool. --- tools/Makefile | 4 + tools/skintest/DejaVuSans.ttf | Bin 0 -> 720012 bytes tools/skintest/Makefile | 42 ++++++++++ tools/skintest/skintest.c | 190 ++++++++++++++++++++++++++++++++++++++++++ tools/skintest/test.skin | 50 +++++++++++ 5 files changed, 286 insertions(+) create mode 100644 tools/skintest/DejaVuSans.ttf create mode 100644 tools/skintest/Makefile create mode 100644 tools/skintest/skintest.c create mode 100644 tools/skintest/test.skin (limited to 'tools') diff --git a/tools/Makefile b/tools/Makefile index 572067b..d923139 100644 --- a/tools/Makefile +++ b/tools/Makefile @@ -16,6 +16,7 @@ endif @$(MAKE) -C showpic all @$(MAKE) -C showtext all @$(MAKE) -C lcdtestpattern all + @$(MAKE) -C skintest all install: @$(MAKE) -C convpic install @@ -26,6 +27,7 @@ endif @$(MAKE) -C showpic install @$(MAKE) -C showtext install @$(MAKE) -C lcdtestpattern install + @$(MAKE) -C skintest install uninstall: @$(MAKE) -C convpic uninstall @@ -36,6 +38,7 @@ endif @$(MAKE) -C showpic uninstall @$(MAKE) -C showtext uninstall @$(MAKE) -C lcdtestpattern uninstall + @$(MAKE) -C skintest uninstall clean: @$(MAKE) -C convpic clean @@ -44,4 +47,5 @@ clean: @$(MAKE) -C showpic clean @$(MAKE) -C showtext clean @$(MAKE) -C lcdtestpattern clean + @$(MAKE) -C skintest clean diff --git a/tools/skintest/DejaVuSans.ttf b/tools/skintest/DejaVuSans.ttf new file mode 100644 index 0000000..2375915 Binary files /dev/null and b/tools/skintest/DejaVuSans.ttf differ diff --git a/tools/skintest/Makefile b/tools/skintest/Makefile new file mode 100644 index 0000000..fe73388 --- /dev/null +++ b/tools/skintest/Makefile @@ -0,0 +1,42 @@ +# +# Makefile for the GraphLCD tool showtext +# + +-include ../../Make.config + +PRGNAME = skintest + +OBJS = skintest.o + +INCLUDES += -I../../ +LIBDIRS += -L../../glcdgraphics/ -L../../glcddrivers/ -L../../glcdskin/ + + +all: $(PRGNAME) +.PHONY: all + +# Implicit rules: + +%.o: %.c + $(CXX) $(CXXEXTRA) $(CXXFLAGS) -c $(DEFINES) $(INCLUDES) $< + +# Dependencies: + +DEPFILE = $(OBJS:%.o=%.d) + +-include $(DEPFILE) + +# The main program: + +$(PRGNAME): $(OBJS) + $(CXX) $(CXXFLAGS) $(LDFLAGS) -rdynamic $(OBJS) $(LIBS) $(LIBDIRS) -lglcdgraphics -lglcddrivers -lglcdskin -lstdc++ -o $(PRGNAME) + +install: $(PRGNAME) + install -d $(BINDIR) + install -m 755 -o root -g root $(HAVE_STRIP) $(PRGNAME) $(BINDIR) + +uninstall: + rm -f $(BINDIR)/$(PRGNAME) + +clean: + @-rm -f $(OBJS) $(DEPFILE) $(PRGNAME) *~ diff --git a/tools/skintest/skintest.c b/tools/skintest/skintest.c new file mode 100644 index 0000000..747dd91 --- /dev/null +++ b/tools/skintest/skintest.c @@ -0,0 +1,190 @@ +#include +#include +#include +#include +#include + +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +class cMySkinConfig : public GLCD::cSkinConfig +{ +private: + GLCD::cDriver * mDriver; +public: + cMySkinConfig(GLCD::cDriver * Driver); + virtual std::string SkinPath(void); + virtual std::string CharSet(void); + virtual std::string Translate(const std::string & Text); + virtual GLCD::cType GetToken(const GLCD::tSkinToken & Token); + virtual GLCD::cDriver * GetDriver(void) const { return mDriver; } +}; + +cMySkinConfig::cMySkinConfig(GLCD::cDriver * Driver) +: mDriver(Driver) +{ +} + +std::string cMySkinConfig::SkinPath(void) +{ + return "."; +} + +std::string cMySkinConfig::CharSet(void) +{ + return "iso8859-15"; +} + +std::string cMySkinConfig::Translate(const std::string & Text) +{ + return Text; +} + +GLCD::cType cMySkinConfig::GetToken(const GLCD::tSkinToken & Token) +{ + return 10; +} + + +static const char * kDefaultConfigFile = "/etc/graphlcd.conf"; + +int main(int argc, char ** argv) +{ + static struct option long_options[] = + { + {"config", required_argument, NULL, 'c'}, + {"display", required_argument, NULL, 'd'}, + {"skin", required_argument, NULL, 's'}, + {"upsidedown", no_argument, NULL, 'u'}, + {"invert", no_argument, NULL, 'i'}, + {"brightness", required_argument, NULL, 'b'}, + {NULL} + }; + + std::string configName = ""; + std::string displayName = ""; + std::string skinFileName = ""; + bool upsideDown = false; + bool invert = false; + int brightness = -1; + unsigned int displayNumber = 0; + + int c, option_index = 0; + while ((c = getopt_long(argc, argv, "c:d:s:uib:", long_options, &option_index)) != -1) + { + switch (c) + { + case 'c': + configName = optarg; + break; + + case 'd': + displayName = optarg; + break; + + case 's': + skinFileName = optarg; + break; + + case 'u': + upsideDown = true; + break; + + case 'i': + invert = true; + break; + + case 'b': + brightness = atoi(optarg); + if (brightness < 0) brightness = 0; + if (brightness > 100) brightness = 100; + break; + + default: + //usage(); + return 1; + } + } + + if (configName.length() == 0) + { + configName = kDefaultConfigFile; + fprintf(stdout, "WARNING: No config file specified, using default (%s).\n", configName.c_str()); + } + + if (GLCD::Config.Load(configName) == false) + { + fprintf(stderr, "Error loading config file!\n"); + return 1; + } + if (GLCD::Config.driverConfigs.size() > 0) + { + if (displayName.length() > 0) + { + for (displayNumber = 0; displayNumber < GLCD::Config.driverConfigs.size(); displayNumber++) + { + if (GLCD::Config.driverConfigs[displayNumber].name == displayName) + break; + } + if (displayNumber == GLCD::Config.driverConfigs.size()) + { + fprintf(stderr, "ERROR: Specified display %s not found in config file!\n", displayName.c_str()); + return 1; + } + } + else + { + fprintf(stdout, "WARNING: No display specified, using first one.\n"); + displayNumber = 0; + } + } + else + { + fprintf(stderr, "ERROR: No displays specified in config file!\n"); + return 1; + } + + GLCD::Config.driverConfigs[displayNumber].upsideDown ^= upsideDown; + GLCD::Config.driverConfigs[displayNumber].invert ^= invert; + if (brightness != -1) + GLCD::Config.driverConfigs[displayNumber].brightness = brightness; + + GLCD::cDriver * lcd = GLCD::CreateDriver(GLCD::Config.driverConfigs[displayNumber].id, &GLCD::Config.driverConfigs[displayNumber]); + if (!lcd) + { + fprintf(stderr, "ERROR: Failed creating display object %s\n", displayName.c_str()); + return 9; + } + if (lcd->Init() != 0) + { + fprintf(stderr, "ERROR: Failed initializing display %s\n", displayName.c_str()); + delete lcd; + return 10; + } + + GLCD::cBitmap * screen = new GLCD::cBitmap(lcd->Width(), lcd->Height()); + screen->Clear(); + + cMySkinConfig skinConfig(lcd); + GLCD::cSkin * skin = GLCD::XmlParse(skinConfig, "test", skinFileName); + skin->SetBaseSize(screen->Width(), screen->Height()); + GLCD::cSkinDisplay * display = skin->GetDisplay("normal"); + + display->Render(screen); + lcd->SetScreen(screen->Data(), screen->Width(), screen->Height()); + lcd->Refresh(true); + + lcd->DeInit(); + delete lcd; + + return 0; +} diff --git a/tools/skintest/test.skin b/tools/skintest/test.skin new file mode 100644 index 0000000..1632b03 --- /dev/null +++ b/tools/skintest/test.skin @@ -0,0 +1,50 @@ + + + + + + + + + + + + This is a left aligned text. + + + This is a right aligned text. + + + This is a centered text. + + + This is a longer text that should be wrapped. It really works! + + + + + + -- cgit v1.2.3