X-Git-Url: https://git.ucc.asn.au/?p=ipdf%2Fcode.git;a=blobdiff_plain;f=src%2Fmain.h;h=7cfa22c739ef14edac3f0e85fd0ac4d4e9b9ecea;hp=ee8076aee26d7fb4d98f0b3f4c7083bfc948046e;hb=4f0feb025e48aaaa0ffe0226c5135e116d1cb986;hpb=0d33eac5144178de754ad9f53e39463f79a31398 diff --git a/src/main.h b/src/main.h index ee8076a..7cfa22c 100644 --- a/src/main.h +++ b/src/main.h @@ -3,15 +3,59 @@ #include "document.h" #include "view.h" #include "screen.h" +#include using namespace std; using namespace IPDF; -inline void MainLoop(Document & doc) +inline void OverlayBMP(Document & doc, const char * input, const char * output, const Rect & bounds = Rect(0,0,1,1), const Colour & c = Colour(0.f,0.f,0.f,1.f)) { - View view(doc); + View view(doc, bounds, c); Screen scr; + //view.Render(); + scr.RenderBMP(input); + scr.Present(); + sleep(1); + scr.ScreenShot(output); + sleep(1); +} + +inline void MainLoop(Document & doc, const Rect & bounds = Rect(0,0,1,1), const Colour & c = Colour(0.f,0.f,0.f,1.f)) +{ + View view(doc,bounds, c); + Screen scr; + scr.SetMouseHandler([&](int x, int y, int buttons, int wheel) // [?] wtf + { + static bool oldButtonDown = false; + static int oldx, oldy; + if (buttons && !oldButtonDown) + { + // We're beginning a drag. + oldButtonDown = true; + oldx = x; + oldy = y; + scr.SetMouseCursor(Screen::CursorMove); + } + if (buttons) + { + view.Translate(Real(oldx-x)/Real(scr.ViewportWidth()), Real(oldy-y)/Real(scr.ViewportHeight())); + } + else + { + oldButtonDown = false; + scr.SetMouseCursor(Screen::CursorArrow); + } + oldx = x; + oldy = y; + + if (wheel) + { + view.ScaleAroundPoint(Real(x)/Real(scr.ViewportWidth()),Real(y)/Real(scr.ViewportHeight()), expf(-wheel/20.f)); + } + } + ); + while (scr.PumpEvents()) { view.Render();