From 890ec11a49fb670b49d70c024318194253b4a908 Mon Sep 17 00:00:00 2001 From: Neeraj Kumar Date: Tue, 27 Jul 2010 12:56:30 +0000 Subject: TESTBED: added finish zone in mouse event tests svn-id: r51365 --- engines/testbed/events.cpp | 40 ++++++++++++++++++++++++++++++---------- engines/testbed/events.h | 1 + 2 files changed, 31 insertions(+), 10 deletions(-) (limited to 'engines') diff --git a/engines/testbed/events.cpp b/engines/testbed/events.cpp index 612e8081d8..a8e2816266 100644 --- a/engines/testbed/events.cpp +++ b/engines/testbed/events.cpp @@ -100,6 +100,22 @@ char EventTests::keystrokeToChar() { return 0; } +Common::Rect EventTests::drawFinishZone() { + Graphics::Surface *screen = g_system->lockScreen(); + const Graphics::Font &font(*FontMan.getFontByUsage(Graphics::FontManager::kBigGUIFont)); + int width = 35; + int height = 20; + int right = g_system->getWidth(); + Common::Rect rect(0, 0, right, height); + Common::Rect rect2(0, 0, right - width, height); + screen->fillRect(rect, kColorSpecial); + screen->fillRect(rect2, kColorBlack); + g_system->unlockScreen(); + font.drawString(screen, "Close", rect.left, rect.top, screen->w, kColorBlack, Graphics::kTextAlignRight); + g_system->updateScreen(); + return Common::Rect(right - width, 0, right, height); +} + bool EventTests::mouseEvents() { Testsuite::clearScreen(); @@ -115,12 +131,13 @@ bool EventTests::mouseEvents() { Common::EventManager *eventMan = g_system->getEventManager(); Common::Point pt(0, 100); - Testsuite::writeOnScreen("Generate mouse events make L/R/M button clicks", pt); + Common::Rect rect = Testsuite::writeOnScreen("Generate mouse events make L/R/M button clicks", pt); pt.y = 120; Testsuite::writeOnScreen("Testbed should be able to detect them, Press X to exit", pt); // Init Mouse Palette GFXtests::initMousePalette(); + Common::Rect finishZone = drawFinishZone(); bool quitLoop = false; bool passed = true; @@ -141,40 +158,43 @@ bool EventTests::mouseEvents() { // Movements havee already been tested in GFX break; case Common::EVENT_LBUTTONDOWN: - Testsuite::clearScreen(); + Testsuite::clearScreen(rect); Testsuite::writeOnScreen("Mouse left-button pressed", pt); break; case Common::EVENT_RBUTTONDOWN: - Testsuite::clearScreen(); + Testsuite::clearScreen(rect); Testsuite::writeOnScreen("Mouse right-button pressed", pt); break; case Common::EVENT_WHEELDOWN: - Testsuite::clearScreen(); + Testsuite::clearScreen(rect); Testsuite::writeOnScreen("Mouse wheel moved down", pt); break; case Common::EVENT_MBUTTONDOWN: - Testsuite::clearScreen(); + Testsuite::clearScreen(rect); Testsuite::writeOnScreen("Mouse middle-button pressed ", pt); break; case Common::EVENT_LBUTTONUP: - Testsuite::clearScreen(); + Testsuite::clearScreen(rect); + if (finishZone.contains(eventMan->getMousePos())) { + quitLoop = true; + } Testsuite::writeOnScreen("Mouse left-button released", pt); break; case Common::EVENT_RBUTTONUP: - Testsuite::clearScreen(); + Testsuite::clearScreen(rect); Testsuite::writeOnScreen("Mouse right-button released", pt); break; case Common::EVENT_WHEELUP: - Testsuite::clearScreen(); + Testsuite::clearScreen(rect); Testsuite::writeOnScreen("Mouse wheel moved up", pt); break; case Common::EVENT_MBUTTONUP: - Testsuite::clearScreen(); + Testsuite::clearScreen(rect); Testsuite::writeOnScreen("Mouse middle-button released ", pt); break; case Common::EVENT_KEYDOWN: if (event.kbd.keycode == Common::KEYCODE_x) { - Testsuite::clearScreen(); + Testsuite::clearScreen(rect); Testsuite::writeOnScreen("Exit requested", pt); quitLoop = true; } diff --git a/engines/testbed/events.h b/engines/testbed/events.h index d6c78ce1cb..e857deec25 100644 --- a/engines/testbed/events.h +++ b/engines/testbed/events.h @@ -33,6 +33,7 @@ namespace EventTests { // Helper functions for Event tests char keystrokeToChar(); +Common::Rect drawFinishZone(); // will contain function declarations for Event tests bool mouseEvents(); bool kbdEvents(); -- cgit v1.2.3