| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 |
- /*
- * ScreenManager.cpp
- * TAU
- *
- * Created by Ivan Safrin on 3/15/08.
- * Copyright 2008 __MyCompanyName__. All rights reserved.
- *
- */
- #include "PolyScreenManager.h"
- using namespace Polycode;
- ScreenManager::ScreenManager() : EventDispatcher() {
- }
- ScreenManager::~ScreenManager() {
- }
- void ScreenManager::removeScreen(Screen *screen) {
- for(int i=0;i<screens.size();i++) {
- if(screens[i] == screen) {
- screens.erase(screens.begin()+i);
- delete screen;
- }
- }
- }
- void ScreenManager::addScreen(Screen *screen) {
- screen->setRenderer(CoreServices::getInstance()->getRenderer());
- screens.push_back(screen);
- }
- void ScreenManager::handleEvent(Event *event) {
- // if(event->getDispatcher() == CoreServices::getInstance()->getCore()->getInput()) {
- InputEvent *inputEvent = (InputEvent*)event;
- for(int i=0;i<screens.size();i++) {
- screens[i]->handleInputEvent(inputEvent);
- }
- // }
- }
- /*
- Screen *ScreenManager::createScreen(int screenType) {
- Screen *screen;
- switch(screenType) {
- case REGULAR_SCREEN:
- screen = new Screen();
- break;
- case PHYSICS_SCREEN:
- screen = new PhysicsScreen();
- break;
- }
-
- screen->setRenderer(CoreServices::getInstance()->getRenderer());
- screens.push_back(screen);
- return screen;
- }
- */
- void ScreenManager::Update() {
- Renderer *renderer = CoreServices::getInstance()->getRenderer();
- for(int i=0;i<screens.size();i++) {
- if(screens[i]->enabled) {
- if(!screens[i]->usesNormalizedCoordinates()) {
- renderer->setOrthoMode(renderer->getXRes(), renderer->getYRes());
- } else {
- Number yCoordinateSize = screens[i]->getYCoordinateSize();
- Number ratio = ((Number)renderer->getXRes())/((Number)renderer->getYRes());
- renderer->setOrthoMode(ratio*yCoordinateSize, yCoordinateSize);
- }
-
- if(screens[i]->hasFilterShader()) {
- screens[i]->drawFilter();
- } else {
- screens[i]->Render();
- }
- }
- }
- }
|