Modularized Samsung TV port.

svn-id: r50258
This commit is contained in:
Alejandro Marzini 2010-06-25 05:02:40 +00:00
parent 96b9c3aa08
commit d04a2a266d
8 changed files with 71 additions and 33 deletions

View File

@ -23,13 +23,17 @@
*
*/
#include "backends/platform/samsungtv/samsungtv.h"
#include "common/util.h"
#include "common/events.h"
#if defined(SAMSUNGTV)
bool OSystem_SDL_SamsungTV::remapKey(SDL_Event &ev, Common::Event &event) {
#include "backends/events/samsungtv/samsungtv-events.h"
SdlSamsungTVEventManager::SdlSamsungTVEventManager(Common::EventSource *boss)
:
SdlEventManager(boss) {
}
bool SdlSamsungTVEventManager::remapKey(SDL_Event &ev, Common::Event &event) {
switch (ev.type) {
case SDL_KEYDOWN:{
if (ev.key.keysym.sym == SDLK_POWER) {
@ -67,7 +71,8 @@ bool OSystem_SDL_SamsungTV::remapKey(SDL_Event &ev, Common::Event &event) {
}
}
return false;
// Invoke parent implementation of this method
return SdlEventManager::remapKey(ev, event);
}
#endif

View File

@ -0,0 +1,40 @@
/* ScummVM - Graphic Adventure Engine
*
* ScummVM is the legal property of its developers, whose names
* are too numerous to list here. Please refer to the COPYRIGHT
* file distributed with this source distribution.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
* $URL$
* $Id$
*
*/
#if !defined(BACKEND_EVENTS_SDL_SAMSUNGTV_H) && !defined(DISABLE_DEFAULT_EVENTMANAGER)
#define BACKEND_EVENTS_SDL_SAMSUNGTV_H
#include "backends/events/sdl/sdl-events.h"
class SdlSamsungTVEventManager : public SdlEventManager {
public:
SdlSamsungTVEventManager(Common::EventSource *boss);
~SdlSamsungTVEventManager() {}
protected:
bool remapKey(SDL_Event &ev, Common::Event &event);
};
#endif

View File

@ -37,11 +37,11 @@
class SdlEventManager : public DefaultEventManager {
public:
SdlEventManager(Common::EventSource *boss);
~SdlEventManager();
virtual ~SdlEventManager();
virtual bool pollSdlEvent(Common::Event &event);
void resetKeyboadEmulation(int16 x_max, int16 y_max);
virtual void resetKeyboadEmulation(int16 x_max, int16 y_max);
protected:
virtual void preprocessEvents(SDL_Event *event) {}
@ -78,9 +78,9 @@ protected:
virtual bool handleJoyAxisMotion(SDL_Event &ev, Common::Event &event);
virtual void fillMouseEvent(Common::Event &event, int x, int y); // overloaded by CE backend
void toggleMouseGrab();
virtual void toggleMouseGrab();
void handleKbdMouse();
virtual void handleKbdMouse();
virtual bool remapKey(SDL_Event &ev, Common::Event &event);
int _lastScreenID;

View File

@ -34,16 +34,23 @@
extern "C" int Game_Main(char *path, char *) {
chdir(path);
// Create OSystem instance
g_system = new OSystem_SDL_SamsungTV();
assert(g_system);
// Pre initialize the backend
((OSystem_SDL_SamsungTV *)g_system)->init();
#ifdef DYNAMIC_MODULES
PluginManager::instance().addPluginProvider(new SDLPluginProvider());
#endif
// Invoke the actual ScummVM main entry point:
int res = scummvm_main(0, 0);
((OSystem_SDL *)g_system)->deinit();
// Free OSystem
delete (OSystem_SDL_SamsungTV *)g_system;
return res;
}

View File

@ -1,7 +1,6 @@
MODULE := backends/platform/samsungtv
MODULE_OBJS := \
events.o \
main.o \
samsungtv.o

View File

@ -29,14 +29,14 @@
bool OSystem_SDL_SamsungTV::hasFeature(Feature f) {
return
(f == kFeatureAspectRatioCorrection) ||
(f == kFeatureCursorHasPalette);
(f == OSystem::kFeatureAspectRatioCorrection) ||
(f == OSystem::kFeatureCursorHasPalette);
}
void OSystem_SDL_SamsungTV::setFeatureState(Feature f, bool enable) {
switch (f) {
case kFeatureAspectRatioCorrection:
setAspectRatioCorrection(enable);
case OSystem::kFeatureAspectRatioCorrection:
_graphicsManager->setFeatureState(f, enable);
break;
default:
break;
@ -44,11 +44,9 @@ void OSystem_SDL_SamsungTV::setFeatureState(Feature f, bool enable) {
}
bool OSystem_SDL_SamsungTV::getFeatureState(Feature f) {
assert (_transactionMode == kTransactionNone);
switch (f) {
case kFeatureAspectRatioCorrection:
return _videoMode.aspectRatioCorrection;
case OSystem::kFeatureAspectRatioCorrection:
return _graphicsManager->getFeatureState(f);
default:
return false;
}

View File

@ -26,26 +26,15 @@
#ifndef SDL_SAMSUNGTV_COMMON_H
#define SDL_SAMSUNGTV_COMMON_H
#include <SDL.h>
#include "backends/base-backend.h"
#include "backends/platform/sdl/sdl.h"
#if defined(SAMSUNGTV)
namespace Audio {
class MixerImpl;
}
#include "backends/platform/sdl/posix/posix.h"
class OSystem_SDL_SamsungTV : public OSystem_SDL {
public:
virtual bool hasFeature(Feature f);
virtual void setFeatureState(Feature f, bool enable);
virtual bool getFeatureState(Feature f);
protected:
virtual bool remapKey(SDL_Event &ev, Common::Event &event);
};
#endif

View File

@ -23,7 +23,7 @@
*
*/
#if defined(UNIX) && !defined(MACOSX)
#if defined(UNIX) && !defined(MACOSX) && !defined(SAMSUNGTV)
#include "common/scummsys.h"