Modularized Samsung TV port.
svn-id: r50258
This commit is contained in:
parent
96b9c3aa08
commit
d04a2a266d
8 changed files with 71 additions and 33 deletions
|
@ -23,13 +23,17 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "backends/platform/samsungtv/samsungtv.h"
|
|
||||||
#include "common/util.h"
|
|
||||||
#include "common/events.h"
|
|
||||||
|
|
||||||
#if defined(SAMSUNGTV)
|
#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) {
|
switch (ev.type) {
|
||||||
case SDL_KEYDOWN:{
|
case SDL_KEYDOWN:{
|
||||||
if (ev.key.keysym.sym == SDLK_POWER) {
|
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
|
#endif
|
40
backends/events/samsungtv/samsungtv-events.h
Normal file
40
backends/events/samsungtv/samsungtv-events.h
Normal 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
|
|
@ -37,11 +37,11 @@
|
||||||
class SdlEventManager : public DefaultEventManager {
|
class SdlEventManager : public DefaultEventManager {
|
||||||
public:
|
public:
|
||||||
SdlEventManager(Common::EventSource *boss);
|
SdlEventManager(Common::EventSource *boss);
|
||||||
~SdlEventManager();
|
virtual ~SdlEventManager();
|
||||||
|
|
||||||
virtual bool pollSdlEvent(Common::Event &event);
|
virtual bool pollSdlEvent(Common::Event &event);
|
||||||
|
|
||||||
void resetKeyboadEmulation(int16 x_max, int16 y_max);
|
virtual void resetKeyboadEmulation(int16 x_max, int16 y_max);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual void preprocessEvents(SDL_Event *event) {}
|
virtual void preprocessEvents(SDL_Event *event) {}
|
||||||
|
@ -78,9 +78,9 @@ protected:
|
||||||
virtual bool handleJoyAxisMotion(SDL_Event &ev, Common::Event &event);
|
virtual bool handleJoyAxisMotion(SDL_Event &ev, Common::Event &event);
|
||||||
|
|
||||||
virtual void fillMouseEvent(Common::Event &event, int x, int y); // overloaded by CE backend
|
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);
|
virtual bool remapKey(SDL_Event &ev, Common::Event &event);
|
||||||
|
|
||||||
int _lastScreenID;
|
int _lastScreenID;
|
||||||
|
|
|
@ -34,16 +34,23 @@
|
||||||
extern "C" int Game_Main(char *path, char *) {
|
extern "C" int Game_Main(char *path, char *) {
|
||||||
chdir(path);
|
chdir(path);
|
||||||
|
|
||||||
|
// Create OSystem instance
|
||||||
g_system = new OSystem_SDL_SamsungTV();
|
g_system = new OSystem_SDL_SamsungTV();
|
||||||
assert(g_system);
|
assert(g_system);
|
||||||
|
|
||||||
|
// Pre initialize the backend
|
||||||
|
((OSystem_SDL_SamsungTV *)g_system)->init();
|
||||||
|
|
||||||
#ifdef DYNAMIC_MODULES
|
#ifdef DYNAMIC_MODULES
|
||||||
PluginManager::instance().addPluginProvider(new SDLPluginProvider());
|
PluginManager::instance().addPluginProvider(new SDLPluginProvider());
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Invoke the actual ScummVM main entry point:
|
// Invoke the actual ScummVM main entry point:
|
||||||
int res = scummvm_main(0, 0);
|
int res = scummvm_main(0, 0);
|
||||||
((OSystem_SDL *)g_system)->deinit();
|
|
||||||
|
// Free OSystem
|
||||||
|
delete (OSystem_SDL_SamsungTV *)g_system;
|
||||||
|
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
MODULE := backends/platform/samsungtv
|
MODULE := backends/platform/samsungtv
|
||||||
|
|
||||||
MODULE_OBJS := \
|
MODULE_OBJS := \
|
||||||
events.o \
|
|
||||||
main.o \
|
main.o \
|
||||||
samsungtv.o
|
samsungtv.o
|
||||||
|
|
||||||
|
|
|
@ -29,14 +29,14 @@
|
||||||
|
|
||||||
bool OSystem_SDL_SamsungTV::hasFeature(Feature f) {
|
bool OSystem_SDL_SamsungTV::hasFeature(Feature f) {
|
||||||
return
|
return
|
||||||
(f == kFeatureAspectRatioCorrection) ||
|
(f == OSystem::kFeatureAspectRatioCorrection) ||
|
||||||
(f == kFeatureCursorHasPalette);
|
(f == OSystem::kFeatureCursorHasPalette);
|
||||||
}
|
}
|
||||||
|
|
||||||
void OSystem_SDL_SamsungTV::setFeatureState(Feature f, bool enable) {
|
void OSystem_SDL_SamsungTV::setFeatureState(Feature f, bool enable) {
|
||||||
switch (f) {
|
switch (f) {
|
||||||
case kFeatureAspectRatioCorrection:
|
case OSystem::kFeatureAspectRatioCorrection:
|
||||||
setAspectRatioCorrection(enable);
|
_graphicsManager->setFeatureState(f, enable);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
@ -44,11 +44,9 @@ void OSystem_SDL_SamsungTV::setFeatureState(Feature f, bool enable) {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool OSystem_SDL_SamsungTV::getFeatureState(Feature f) {
|
bool OSystem_SDL_SamsungTV::getFeatureState(Feature f) {
|
||||||
assert (_transactionMode == kTransactionNone);
|
|
||||||
|
|
||||||
switch (f) {
|
switch (f) {
|
||||||
case kFeatureAspectRatioCorrection:
|
case OSystem::kFeatureAspectRatioCorrection:
|
||||||
return _videoMode.aspectRatioCorrection;
|
return _graphicsManager->getFeatureState(f);
|
||||||
default:
|
default:
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,26 +26,15 @@
|
||||||
#ifndef SDL_SAMSUNGTV_COMMON_H
|
#ifndef SDL_SAMSUNGTV_COMMON_H
|
||||||
#define 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)
|
#if defined(SAMSUNGTV)
|
||||||
|
|
||||||
namespace Audio {
|
#include "backends/platform/sdl/posix/posix.h"
|
||||||
class MixerImpl;
|
|
||||||
}
|
|
||||||
|
|
||||||
class OSystem_SDL_SamsungTV : public OSystem_SDL {
|
class OSystem_SDL_SamsungTV : public OSystem_SDL {
|
||||||
public:
|
public:
|
||||||
virtual bool hasFeature(Feature f);
|
virtual bool hasFeature(Feature f);
|
||||||
virtual void setFeatureState(Feature f, bool enable);
|
virtual void setFeatureState(Feature f, bool enable);
|
||||||
virtual bool getFeatureState(Feature f);
|
virtual bool getFeatureState(Feature f);
|
||||||
|
|
||||||
protected:
|
|
||||||
|
|
||||||
virtual bool remapKey(SDL_Event &ev, Common::Event &event);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if defined(UNIX) && !defined(MACOSX)
|
#if defined(UNIX) && !defined(MACOSX) && !defined(SAMSUNGTV)
|
||||||
|
|
||||||
#include "common/scummsys.h"
|
#include "common/scummsys.h"
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue