X-Git-Url: https://git.ucc.asn.au/?p=ipdf%2Fcode.git;a=blobdiff_plain;f=src%2Fmain.cpp;h=2612afca1acad968bf0db867a79136e1a428cf85;hp=12d8d561d755059d7981bac5dbc9386f37ee7426;hb=5456793e2aad4235c3db2ca75532c868aaa7c518;hpb=eb7a30473a78452a890bd453f80d4a90aee5d364 diff --git a/src/main.cpp b/src/main.cpp index 12d8d56..2612afc 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -1,17 +1,30 @@ #include "main.h" #include // Because we can. + +#include "controlpanel.h" + + + int main(int argc, char ** argv) { + #ifndef __STDC_IEC_559__ + Warn("__STDC_IEC_559__ not defined. IEEE 754 floating point not fully supported.\n"); + #endif + + + Debug("Compiled with REAL = %d => \"%s\" sizeof(Real) == %d bytes", REAL, g_real_name[REAL], sizeof(Real)); + Document doc; srand(time(NULL)); enum {OUTPUT_TO_BMP, LOOP} mode = LOOP; - Rect bounds(0,0,1,1); + Colour c(0,0,0,1); const char * input_bmp = NULL; const char * output_bmp = NULL; const char * input_filename = NULL; + float b[4] = {0,0,1,1}; int i = 0; while (++i < argc) @@ -49,21 +62,64 @@ int main(int argc, char ** argv) i += 4; break; } + case 'b': + { + Debug("Reading view bounds"); + for (int j = 1; j <= 4; ++j) + { + if (i+j >= argc) + Fatal("No %d bounds component following -b switch", j); + char * e; + b[j-1] = strtof(argv[i+j], &e); + if (*e != '\0') + Fatal("Bounds component %d not a valid float", j); + } + i += 4; + break; + } } } if (input_filename != NULL) { - doc.Load(input_filename); + doc.LoadSVG(input_filename, Rect(0,0,Real(1)/Real(800),Real(1)/Real(600))); } else { - doc.Add(RECT_FILLED, Rect(0.2,0.2,0.6,0.6)); + //doc.AddBezier(Bezier(0,0, 1,0.5, 0.5,1, 1,1)); + doc.AddText("The quick brown\nfox jumps over\nthe lazy dog",0.1,0,0.5); + //doc.AddBezier(Bezier(0,0,0,0.1,0,0.1,0,0.1)); } + Debug("Start!"); + Rect bounds(b[0],b[1],b[2],b[3]); + + Screen scr; + View view(doc,scr, bounds); + + #ifndef CONTROLPANEL_DISABLED + ControlPanel::RunArgs args = {argc, argv, view, doc, scr}; + SDL_Thread * cp_thread = SDL_CreateThread(ControlPanel::Run, "ControlPanel", &args); + if (cp_thread == NULL) + { + Error("Couldn't create ControlPanel thread: %s", SDL_GetError()); + } + #endif //CONTROLPANEL_DISABLED if (mode == LOOP) - MainLoop(doc, bounds, c); - else if (mode == OUTPUT_TO_BMP) + MainLoop(doc, scr, view); + else if (mode == OUTPUT_TO_BMP) //TODO: Remove this shit OverlayBMP(doc, input_bmp, output_bmp, bounds, c); + + #ifndef CONTROLPANEL_DISABLED + + if (cp_thread != NULL) + { + int cp_return; + qApp->quit(); // will close the control panel + // (seems to not explode if the qApp has already been quit) + SDL_WaitThread(cp_thread, &cp_return); + Debug("ControlPanel thread returned %d", cp_return); + } + #endif //CONTROLPANEL_DISABLED return 0; }