diff options
| author | Simon Robertshaw <simon@hardwired.org.uk> | 2012-05-31 09:24:44 (GMT) |
|---|---|---|
| committer | Simon Robertshaw <simon@hardwired.org.uk> | 2012-05-31 09:24:44 (GMT) |
| commit | e0c9dab8cb981172c5de81f5963e28db67f1b295 (patch) | |
| tree | dd78e82f54a7ed87915a7d5100437cd42ac0c415 /src/powdertoyjava/PowderToyJava.cpp | |
| parent | 708d52bcc5f0e13fa6540751e2402ccfdf02bec7 (diff) | |
| download | powder-e0c9dab8cb981172c5de81f5963e28db67f1b295.zip powder-e0c9dab8cb981172c5de81f5963e28db67f1b295.tar.gz | |
Move more SDL dependancies out of program, OpenGLCanvas for JNI and JNI methods.
Diffstat (limited to 'src/powdertoyjava/PowderToyJava.cpp')
| -rw-r--r-- | src/powdertoyjava/PowderToyJava.cpp | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/src/powdertoyjava/PowderToyJava.cpp b/src/powdertoyjava/PowderToyJava.cpp new file mode 100644 index 0000000..969d9b2 --- /dev/null +++ b/src/powdertoyjava/PowderToyJava.cpp @@ -0,0 +1,82 @@ +#if defined(USE_JNI) && defined(MACOSX) + +#include <time.h> +#include <iostream> +#include <sstream> +#include <string> + +#include "Config.h" +#include "PowderToyJava.h" +#include "Graphics.h" +#if defined(LIN32) || defined(LIN64) +#include "icon.h" +#endif + +#include "game/GameController.h" + +using namespace std; + +GameController * gameController; +ui::Engine * engine; + +int elapsedTime = 0, currentTime = 0, lastTime = 0, currentFrame = 0; +float fps = 0, delta = 1.0f; + +JNIEXPORT void JNICALL Java_PowderToy_initialise(JNIEnv * env, jobject canvas) +{ + //InitWindowMac(env, canvas); + + ui::Engine::Ref().g = new Graphics(); + + engine = &ui::Engine::Ref(); + engine->Begin(XRES+BARSIZE, YRES+MENUSIZE); + + gameController = new GameController(); + engine->ShowWindow(gameController->GetView()); + engine->SetFps(fps); +} + +JNIEXPORT void JNICALL Java_PowderToy_tick(JNIEnv * env, jobject canvas) +{ + engine->Tick(); +} + +JNIEXPORT void JNICALL Java_PowderToy_draw(JNIEnv * env, jobject canvas) +{ + engine->Draw(); + engine->g->Finalise(); +} + +JNIEXPORT void JNICALL Java_PowderToy_finish(JNIEnv * env, jobject canvas) +{ + ui::Engine::Ref().CloseWindow(); + delete gameController; + delete ui::Engine::Ref().g; +} + +JNIEXPORT jint JNICALL Java_PowderToy_getWidth(JNIEnv * env, jobject canvas) +{ + return XRES+BARSIZE; +} + +JNIEXPORT jint JNICALL Java_PowderToy_getHeight(JNIEnv * env, jobject canvas) +{ + return YRES+MENUSIZE; +} + +JNIEXPORT void JNICALL Java_PowderToy_mousePressed(JNIEnv * env, jobject canvas, jint mouseX, jint mouseY, jint mouseButton) +{ + engine->onMouseClick(mouseX, mouseY, mouseButton); +} + +JNIEXPORT void JNICALL Java_PowderToy_mouseReleased(JNIEnv * env, jobject canvas, jint mouseX, jint mouseY, jint mouseButton) +{ + engine->onMouseUnclick(mouseX, mouseY, mouseButton); +} + +JNIEXPORT void JNICALL Java_PowderToy_mouseMoved(JNIEnv * env, jobject canvas, jint mouseX, jint mouseY) +{ + engine->onMouseMove(mouseX, mouseY); +} + +#endif |
