]> Chaos Git - corbenik/ctrulib.git/commitdiff
Added ColoredText example
authorAurelio Mannara <aurelio.mannara@gmail.com>
Sun, 14 Dec 2014 17:00:45 +0000 (18:00 +0100)
committerAurelio Mannara <aurelio.mannara@gmail.com>
Sun, 14 Dec 2014 17:00:45 +0000 (18:00 +0100)
This example shows how to print colored text using ansi escape sequences

examples/Graphics/Printing/ColoredText/Makefile [new file with mode: 0755]
examples/Graphics/Printing/ColoredText/source/main.cpp [new file with mode: 0644]

diff --git a/examples/Graphics/Printing/ColoredText/Makefile b/examples/Graphics/Printing/ColoredText/Makefile
new file mode 100755 (executable)
index 0000000..c4c758e
--- /dev/null
@@ -0,0 +1,170 @@
+#---------------------------------------------------------------------------------
+.SUFFIXES:
+#---------------------------------------------------------------------------------
+
+ifeq ($(strip $(DEVKITARM)),)
+$(error "Please set DEVKITARM in your environment. export DEVKITARM=<path to>devkitARM")
+endif
+
+TOPDIR ?= $(CURDIR)
+include $(DEVKITARM)/3ds_rules
+
+#---------------------------------------------------------------------------------
+# TARGET is the name of the output
+# BUILD is the directory where object files & intermediate files will be placed
+# SOURCES is a list of directories containing source code
+# DATA is a list of directories containing data files
+# INCLUDES is a list of directories containing header files
+#
+# NO_SMDH: if set to anything, no SMDH file is generated.
+# APP_TITLE is the name of the app stored in the SMDH file (Optional)
+# APP_DESCRIPTION is the description of the app stored in the SMDH file (Optional)
+# APP_AUTHOR is the author of the app stored in the SMDH file (Optional)
+# ICON is the filename of the icon (.png), relative to the project folder.
+#   If not set, it attempts to use one of the following (in this order):
+#     - <Project name>.png
+#     - icon.png
+#     - <libctru folder>/default_icon.png
+#---------------------------------------------------------------------------------
+TARGET         :=      $(notdir $(CURDIR))
+BUILD          :=      build
+SOURCES                :=      source
+DATA           :=      data
+INCLUDES       :=      include
+
+#---------------------------------------------------------------------------------
+# options for code generation
+#---------------------------------------------------------------------------------
+ARCH   :=      -march=armv6k -mtune=mpcore -mfloat-abi=softfp
+
+CFLAGS :=      -g -Wall -O2 -mword-relocations \
+                       -fomit-frame-pointer -ffast-math \
+                       $(ARCH)
+
+CFLAGS +=      $(INCLUDE) -DARM11 -D_3DS
+
+CXXFLAGS       := $(CFLAGS) -fno-rtti -fno-exceptions -std=gnu++11
+
+ASFLAGS        :=      -g $(ARCH)
+LDFLAGS        =       -specs=3dsx.specs -g $(ARCH) -Wl,-Map,$(notdir $*.map)
+
+LIBS   := -lctru -lm
+
+#---------------------------------------------------------------------------------
+# list of directories containing libraries, this must be the top level containing
+# include and lib
+#---------------------------------------------------------------------------------
+LIBDIRS        := $(CTRULIB)
+
+
+#---------------------------------------------------------------------------------
+# no real need to edit anything past this point unless you need to add additional
+# rules for different file extensions
+#---------------------------------------------------------------------------------
+ifneq ($(BUILD),$(notdir $(CURDIR)))
+#---------------------------------------------------------------------------------
+
+export OUTPUT  :=      $(CURDIR)/$(TARGET)
+export TOPDIR  :=      $(CURDIR)
+
+export VPATH   :=      $(foreach dir,$(SOURCES),$(CURDIR)/$(dir)) \
+                       $(foreach dir,$(DATA),$(CURDIR)/$(dir))
+
+export DEPSDIR :=      $(CURDIR)/$(BUILD)
+
+CFILES         :=      $(foreach dir,$(SOURCES),$(notdir $(wildcard $(dir)/*.c)))
+CPPFILES       :=      $(foreach dir,$(SOURCES),$(notdir $(wildcard $(dir)/*.cpp)))
+SFILES         :=      $(foreach dir,$(SOURCES),$(notdir $(wildcard $(dir)/*.s)))
+BINFILES       :=      $(foreach dir,$(DATA),$(notdir $(wildcard $(dir)/*.*)))
+
+#---------------------------------------------------------------------------------
+# use CXX for linking C++ projects, CC for standard C
+#---------------------------------------------------------------------------------
+ifeq ($(strip $(CPPFILES)),)
+#---------------------------------------------------------------------------------
+       export LD       :=      $(CC)
+#---------------------------------------------------------------------------------
+else
+#---------------------------------------------------------------------------------
+       export LD       :=      $(CXX)
+#---------------------------------------------------------------------------------
+endif
+#---------------------------------------------------------------------------------
+
+export OFILES  :=      $(addsuffix .o,$(BINFILES)) \
+                       $(CPPFILES:.cpp=.o) $(CFILES:.c=.o) $(SFILES:.s=.o)
+
+export INCLUDE :=      $(foreach dir,$(INCLUDES),-I$(CURDIR)/$(dir)) \
+                       $(foreach dir,$(LIBDIRS),-I$(dir)/include) \
+                       -I$(CURDIR)/$(BUILD)
+
+export LIBPATHS        :=      $(foreach dir,$(LIBDIRS),-L$(dir)/lib)
+
+ifeq ($(strip $(ICON)),)
+       icons := $(wildcard *.png)
+       ifneq (,$(findstring $(TARGET).png,$(icons)))
+               export APP_ICON := $(TOPDIR)/$(TARGET).png
+       else
+               ifneq (,$(findstring icon.png,$(icons)))
+                       export APP_ICON := $(TOPDIR)/icon.png
+               endif
+       endif
+else
+       export APP_ICON := $(TOPDIR)/$(ICON)
+endif
+
+.PHONY: $(BUILD) clean all
+
+#---------------------------------------------------------------------------------
+all: $(BUILD)
+
+$(BUILD):
+       @[ -d $@ ] || mkdir -p $@
+       @make --no-print-directory -C $(BUILD) -f $(CURDIR)/Makefile
+
+#---------------------------------------------------------------------------------
+clean:
+       @echo clean ...
+       @rm -fr $(BUILD) $(TARGET).3dsx $(OUTPUT).smdh $(TARGET).elf
+
+
+#---------------------------------------------------------------------------------
+else
+
+DEPENDS        :=      $(OFILES:.o=.d)
+
+#---------------------------------------------------------------------------------
+# main targets
+#---------------------------------------------------------------------------------
+ifeq ($(strip $(NO_SMDH)),)
+.PHONY: all
+all    :       $(OUTPUT).3dsx $(OUTPUT).smdh
+endif
+$(OUTPUT).3dsx :       $(OUTPUT).elf
+$(OUTPUT).elf  :       $(OFILES)
+
+#---------------------------------------------------------------------------------
+# you need a rule like this for each extension you use as binary data
+#---------------------------------------------------------------------------------
+%.bin.o        :       %.bin
+#---------------------------------------------------------------------------------
+       @echo $(notdir $<)
+       @$(bin2o)
+
+# WARNING: This is not the right way to do this! TODO: Do it right!
+#---------------------------------------------------------------------------------
+%.vsh.o        :       %.vsh
+#---------------------------------------------------------------------------------
+       @echo $(notdir $<)
+       @python $(AEMSTRO)/aemstro_as.py $< ../$(notdir $<).shbin
+       @bin2s ../$(notdir $<).shbin | $(PREFIX)as -o $@
+       @echo "extern const u8" `(echo $(notdir $<).shbin | sed -e 's/^\([0-9]\)/_\1/' | tr . _)`"_end[];" > `(echo $(notdir $<).shbin | tr . _)`.h
+       @echo "extern const u8" `(echo $(notdir $<).shbin | sed -e 's/^\([0-9]\)/_\1/' | tr . _)`"[];" >> `(echo $(notdir $<).shbin | tr . _)`.h
+       @echo "extern const u32" `(echo $(notdir $<).shbin | sed -e 's/^\([0-9]\)/_\1/' | tr . _)`_size";" >> `(echo $(notdir $<).shbin | tr . _)`.h
+       @rm ../$(notdir $<).shbin
+
+-include $(DEPENDS)
+
+#---------------------------------------------------------------------------------------
+endif
+#---------------------------------------------------------------------------------------
diff --git a/examples/Graphics/Printing/ColoredText/source/main.cpp b/examples/Graphics/Printing/ColoredText/source/main.cpp
new file mode 100644 (file)
index 0000000..f0326e1
--- /dev/null
@@ -0,0 +1,82 @@
+/*
+       Colored Text example made by Aurelio Mannara for ctrulib
+       This code was modified for the last time on: 12/12/2014 23:00 UTC+1
+
+       This wouldn't be possible without the amazing work done by:
+       -Smealum
+       -fincs
+       -WinterMute
+       -yellows8
+       -plutoo
+       -mtheall
+       -Many others who worked on 3DS and I'm surely forgetting about
+*/
+
+#include <3ds.h>
+#include <stdio.h>
+
+int main(int argc, char **argv)
+{
+       // Initialize services
+       srvInit();
+       aptInit();
+       gfxInit();
+       hidInit(NULL);
+
+       //Initialize console on top screen. Using NULL as the second argument tells the console library to use the internal console structure as current one
+       consoleInit(GFX_TOP, NULL);
+
+       //Move the cursor to row 15 and column 19 and then prints "Hello World!" 
+       //To move the cursor you have tu print "\x1b[r;cH", where r and c are respectively
+       //the row and column where you want your cursor to move
+       //The top screen has 30 rows and 50 columns
+       //The bottom screen has 30 rows and 40 columns
+       printf("\x1b[15;19HHello World!");
+
+       //Move the cursor to the top left corner of the screen
+       printf("\x1b[0;0H");
+
+       //Print a REALLY crappy poeam with colored text
+       //\x1b[cm set a SGR (Select Graphic Rendition) parameter, where c is the parameter that you want to set
+       //Please refer to http://en.wikipedia.org/wiki/ANSI_escape_code#CSI_codes to see all the possible SGR parameters
+       //As of now ctrulib support only these parameters:
+       //Reset (0), Half bright colors (2), Reverse (7), Text color (30-37) and Background color (40-47)
+       printf("Roses are \x1b[31mred\x1b[0m\n");
+       printf("Violets are \x1b[34mblue\x1b[0m\n");
+       printf("Piracy is bad\n");
+       printf("While homebrews are good\n\n");
+
+       //Black text on white background
+       //In this example we set two parameter in a single escape sequence by separating them by a semicolon
+       //\x1b[47;30m means that it will set a white background (47) and it will print white characters (30)
+       //In this we also could have used the 
+       printf("\x1b[47;30mBlack text on white background\x1b[0m");
+
+
+       printf("\x1b[29;15HPress Start to exit.");
+       // Main loop
+       while (aptMainLoop())
+       {
+               //Scan all the inputs. This should be done once for each frame
+               hidScanInput();
+
+               //hidKeysDown returns information about which buttons have been just pressed (and they weren't in the previous frame)
+               u32 kDown = hidKeysDown();
+
+               if (kDown & KEY_START) break; // break in order to return to hbmenu
+
+               // Flush and swap framebuffers
+               gfxFlushBuffers();
+               gfxSwapBuffers();
+
+               //Wait for VBlank
+               gspWaitForVBlank();
+       }
+
+       // Exit services
+       gfxExit();
+       hidExit();
+       aptExit();
+       srvExit();
+       return 0;
+}