aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorjohndoe1232012-10-25 12:35:14 +0000
committerWillem Jan Palenstijn2013-05-08 20:47:37 +0200
commit228d9264c8e9f5e1930e8b69ce809783d303bbbc (patch)
treec037dcb509ff1deb984fa99919b6f026a55ca943
parent4df22cf9795eb5612865e4a977f03986c4d4aeb1 (diff)
downloadscummvm-rg350-228d9264c8e9f5e1930e8b69ce809783d303bbbc.tar.gz
scummvm-rg350-228d9264c8e9f5e1930e8b69ce809783d303bbbc.tar.bz2
scummvm-rg350-228d9264c8e9f5e1930e8b69ce809783d303bbbc.zip
NEVERHOOD: Start with menu widget stuff (doesn't do anything yet!)
-rw-r--r--engines/neverhood/menumodule.cpp96
-rw-r--r--engines/neverhood/menumodule.h35
2 files changed, 131 insertions, 0 deletions
diff --git a/engines/neverhood/menumodule.cpp b/engines/neverhood/menumodule.cpp
index fdde1a23e0..bec640e5d4 100644
--- a/engines/neverhood/menumodule.cpp
+++ b/engines/neverhood/menumodule.cpp
@@ -354,4 +354,100 @@ uint32 CreditsScene::handleMessage(int messageNum, const MessageParam &param, En
return 0;
}
+WidgetScene::WidgetScene(NeverhoodEngine *vm, Module *parentModule)
+ : Scene(vm, parentModule, true), _currWidget(NULL) {
+}
+
+void WidgetScene::getMousPos(NPoint &pt) {
+ pt.x = _mouseCursor->getX();
+ pt.y = _mouseCursor->getY();
+}
+
+void WidgetScene::setCurrWidget(Widget *newWidget) {
+ if (newWidget && newWidget != _currWidget) {
+ if (_currWidget)
+ _currWidget->exitWidget();
+ newWidget->enterWidget();
+ _currWidget = newWidget;
+ }
+}
+
+Widget::Widget(NeverhoodEngine *vm, int16 x, int16 y, int16 itemID, WidgetScene *parentScene,
+ int baseObjectPriority, int baseSurfacePriority, bool visible)
+ : StaticSprite(vm, baseObjectPriority), _itemID(itemID), _parentScene(parentScene),
+ _baseObjectPriority(baseObjectPriority), _baseSurfacePriority(baseSurfacePriority), _visible(visible) {
+
+ SetUpdateHandler(&Widget::update);
+ SetMessageHandler(&Widget::handleMessage);
+
+ setPosition(x, y);
+}
+
+void Widget::show() {
+ if (_surface)
+ _surface->setVisible(true);
+ _visible = true;
+}
+
+void Widget::hide() {
+ if (_surface)
+ _surface->setVisible(false);
+ _visible = false;
+}
+
+void Widget::onClick() {
+ _parentScene->setCurrWidget(this);
+ // TODO Somehow _parentScene->onClick(_itemID, 0);
+}
+
+void Widget::setPosition(int16 x, int16 y) {
+ _x = x;
+ _y = y;
+ updateBounds();
+}
+
+void Widget::refresh() {
+ _needRefresh = true;
+ StaticSprite::updatePosition();
+ _collisionBoundsOffset.set(0, 0,
+ _spriteResource.getDimensions().width, _spriteResource.getDimensions().height);
+ updateBounds();
+}
+
+void Widget::addSprite() {
+ // Empty
+}
+
+int16 Widget::getWidth() {
+ return _spriteResource.getDimensions().width;
+}
+
+int16 Widget::getHeight() {
+ return _spriteResource.getDimensions().height;
+}
+
+void Widget::enterWidget() {
+ // Empty
+}
+
+void Widget::exitWidget() {
+ // Empty
+}
+
+void Widget::update() {
+ handleSpriteUpdate();
+ StaticSprite::updatePosition();
+}
+
+uint32 Widget::handleMessage(int messageNum, const MessageParam &param, Entity *sender) {
+ uint32 messageResult = Sprite::handleMessage(messageNum, param, sender);
+ switch (messageNum) {
+ case 0x1011:
+ onClick();
+ messageResult = 1;
+ break;
+ }
+ return messageResult;
+}
+
} // End of namespace Neverhood
diff --git a/engines/neverhood/menumodule.h b/engines/neverhood/menumodule.h
index 77cef449d1..1b6ba8a9f7 100644
--- a/engines/neverhood/menumodule.h
+++ b/engines/neverhood/menumodule.h
@@ -79,6 +79,41 @@ protected:
uint32 handleMessage(int messageNum, const MessageParam &param, Entity *sender);
};
+class Widget;
+
+class WidgetScene : public Scene {
+public:
+ WidgetScene(NeverhoodEngine *vm, Module *parentModule);
+ void getMousPos(NPoint &pt);
+ virtual void setCurrWidget(Widget *newWidget);
+protected:
+ Widget *_currWidget;
+};
+
+class Widget : public StaticSprite {
+public:
+ Widget(NeverhoodEngine *vm, int16 x, int16 y, int16 itemID, WidgetScene *parentScene,
+ int baseObjectPriority, int baseSurfacePriority, bool visible);
+ virtual void show();
+ virtual void hide();
+ virtual void onClick();
+ virtual void setPosition(int16 x, int16 y);
+ virtual void refresh();
+ virtual void addSprite();
+ virtual int16 getWidth();
+ virtual int16 getHeight();
+ virtual void enterWidget();
+ virtual void exitWidget();
+protected:
+ int16 _itemID;
+ WidgetScene *_parentScene;
+ int _baseObjectPriority;
+ int _baseSurfacePriority;
+ bool _visible;
+ void update();
+ uint32 handleMessage(int messageNum, const MessageParam &param, Entity *sender);
+};
+
} // End of namespace Neverhood
#endif /* NEVERHOOD_MENUMODULE_H */