2014-02-18 23:43:06 -05:00
|
|
|
/* 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.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef MADS_USER_INTERFACE_H
|
|
|
|
#define MADS_USER_INTERFACE_H
|
|
|
|
|
|
|
|
#include "common/scummsys.h"
|
2014-03-15 18:43:39 -04:00
|
|
|
#include "common/rect.h"
|
|
|
|
#include "common/str.h"
|
|
|
|
#include "mads/msurface.h"
|
2014-03-18 22:37:33 -04:00
|
|
|
#include "mads/screen.h"
|
2014-02-18 23:43:06 -05:00
|
|
|
|
|
|
|
namespace MADS {
|
|
|
|
|
2014-04-02 21:24:22 -04:00
|
|
|
enum { IMG_SPINNING_OBJECT = 200, IMG_TEXT_UPDATE = 201 };
|
|
|
|
|
2014-03-17 21:53:22 -04:00
|
|
|
class UISlot {
|
|
|
|
public:
|
2014-04-02 21:24:22 -04:00
|
|
|
int _flags;
|
|
|
|
int _segmentId;
|
2014-03-17 23:14:54 -04:00
|
|
|
int _spritesIndex;
|
|
|
|
int _frameNumber;
|
2014-03-18 19:56:29 -04:00
|
|
|
Common::Point _position;
|
2014-03-17 21:53:22 -04:00
|
|
|
|
|
|
|
UISlot();
|
|
|
|
};
|
|
|
|
|
2014-03-18 22:37:33 -04:00
|
|
|
/**
|
|
|
|
* Sprite list for the user interface
|
|
|
|
*/
|
2014-03-17 21:53:22 -04:00
|
|
|
class UISlots : public Common::Array<UISlot> {
|
2014-03-18 22:37:33 -04:00
|
|
|
private:
|
|
|
|
MADSEngine *_vm;
|
2014-03-17 21:53:22 -04:00
|
|
|
public:
|
2014-03-18 22:37:33 -04:00
|
|
|
/**
|
|
|
|
* Constructor
|
|
|
|
*/
|
|
|
|
UISlots(MADSEngine *vm) : _vm(vm) {}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a sprite to the list
|
|
|
|
*/
|
2014-03-18 19:56:29 -04:00
|
|
|
void add(const Common::Point &pt, int frameNumber, int spritesIndex);
|
2014-03-18 22:37:33 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Adds a special entry for full refresh of the user interface
|
|
|
|
*/
|
2014-03-17 21:53:22 -04:00
|
|
|
void fullRefresh();
|
|
|
|
|
2014-03-18 22:37:33 -04:00
|
|
|
/**
|
|
|
|
* Draw all the sprites in the list on the user interface.
|
|
|
|
* @param updateFlag Flag drawn areas to be updated on physical screen
|
|
|
|
* @param delFlag Controls how used slots are deleted after drawing
|
|
|
|
*/
|
|
|
|
void draw(bool updateFlag, bool delFlag);
|
2014-03-17 21:53:22 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2014-03-15 18:43:39 -04:00
|
|
|
class UserInterface : public MSurface {
|
2014-03-18 22:37:33 -04:00
|
|
|
friend class UISlots;
|
2014-02-18 23:43:06 -05:00
|
|
|
private:
|
|
|
|
MADSEngine *_vm;
|
2014-03-17 21:53:22 -04:00
|
|
|
int _invSpritesIndex;
|
2014-03-17 23:14:54 -04:00
|
|
|
int _invFrameNumber;
|
2014-03-22 18:26:41 -04:00
|
|
|
uint32 _scrollMilli;
|
|
|
|
bool _scrollFlag;
|
2014-02-18 23:43:06 -05:00
|
|
|
|
2014-03-15 20:19:01 -04:00
|
|
|
/**
|
|
|
|
* Loads the elements of the user interface
|
|
|
|
*/
|
2014-03-15 18:43:39 -04:00
|
|
|
void loadElements();
|
2014-03-15 20:19:01 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the area within the user interface a given element falls
|
|
|
|
*/
|
|
|
|
bool getBounds(ScrCategory category, int invIndex, Common::Rect &bounds);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reposition a bounding rectangle to physical co-ordinates
|
|
|
|
*/
|
2014-03-15 21:33:15 -04:00
|
|
|
void moveRect(Common::Rect &bounds);
|
2014-03-16 17:50:47 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Draw options during a conversation.
|
|
|
|
*/
|
|
|
|
void drawTalkList();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Draw the action list
|
|
|
|
*/
|
|
|
|
void drawActions();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Draw the inventory list
|
|
|
|
*/
|
|
|
|
void drawInventoryList();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Draw the inventory item vocab list
|
|
|
|
*/
|
|
|
|
void drawItemVocabList();
|
|
|
|
|
|
|
|
/**
|
2014-03-16 23:40:21 -04:00
|
|
|
* Draw the inventory scroller
|
2014-03-16 17:50:47 -04:00
|
|
|
*/
|
2014-03-16 23:40:21 -04:00
|
|
|
void drawScrolller();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Draw a UI textual element
|
|
|
|
*/
|
|
|
|
void writeVocab(ScrCategory category, int id);
|
2014-03-17 21:53:22 -04:00
|
|
|
|
|
|
|
void refresh();
|
2014-03-24 22:34:09 -04:00
|
|
|
|
|
|
|
void updateRect(const Common::Rect &bounds);
|
2014-02-18 23:43:06 -05:00
|
|
|
public:
|
2014-03-18 23:13:13 -04:00
|
|
|
MSurface _surface;
|
2014-03-18 22:37:33 -04:00
|
|
|
UISlots _uiSlots;
|
|
|
|
DirtyAreas _dirtyAreas;
|
2014-03-15 18:43:39 -04:00
|
|
|
ScrCategory _category;
|
2014-03-18 22:37:33 -04:00
|
|
|
Common::Rect _drawBounds;
|
2014-03-15 18:43:39 -04:00
|
|
|
Common::Rect *_rectP;
|
2014-03-15 20:19:01 -04:00
|
|
|
int _inventoryTopIndex;
|
|
|
|
int _objectY;
|
2014-03-16 23:40:21 -04:00
|
|
|
int _selectedInvIndex;
|
|
|
|
int _selectedActionIndex;
|
|
|
|
int _selectedItemVocabIdx;
|
|
|
|
int _scrollerY;
|
2014-03-27 22:38:28 -04:00
|
|
|
int _highlightedCommandIndex;
|
|
|
|
int _highlightedItemIndex;
|
2014-03-24 22:34:09 -04:00
|
|
|
int _highlightedActionIndex;
|
2014-03-19 00:15:25 -04:00
|
|
|
bool _inventoryChanged;
|
2014-03-22 18:26:41 -04:00
|
|
|
int _categoryIndexes[8];
|
2014-03-20 08:34:56 -04:00
|
|
|
Common::StringArray _talkStrings;
|
|
|
|
Common::Array<int> _talkIds;
|
2014-02-18 23:43:06 -05:00
|
|
|
public:
|
2014-03-15 18:43:39 -04:00
|
|
|
/**
|
|
|
|
* Constructor
|
|
|
|
*/
|
|
|
|
UserInterface(MADSEngine *vm);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Loads an interface from a specified resource
|
|
|
|
*/
|
|
|
|
void load(const Common::String &resName);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set up the interface
|
|
|
|
*/
|
2014-04-03 22:02:12 -04:00
|
|
|
void setup(InputMode inputMode);
|
2014-03-15 18:43:39 -04:00
|
|
|
|
2014-03-16 17:50:47 -04:00
|
|
|
void drawTextElements();
|
2014-03-15 18:43:39 -04:00
|
|
|
|
|
|
|
void setBounds(const Common::Rect &r);
|
2014-03-17 21:53:22 -04:00
|
|
|
|
2014-03-19 23:33:18 -04:00
|
|
|
/**
|
|
|
|
* Loads the animation sprite data for a given inventory object
|
|
|
|
*/
|
2014-03-17 21:53:22 -04:00
|
|
|
void loadInventoryAnim(int objectId);
|
|
|
|
|
2014-03-19 23:33:18 -04:00
|
|
|
/**
|
|
|
|
* Resets the inventory animation when no inventory item is selected
|
|
|
|
*/
|
2014-03-17 21:53:22 -04:00
|
|
|
void noInventoryAnim();
|
2014-03-19 00:15:25 -04:00
|
|
|
|
2014-03-19 23:33:18 -04:00
|
|
|
/**
|
|
|
|
* Handles queuing a new frame of an inventory animation for drawing
|
|
|
|
*/
|
|
|
|
void inventoryAnim();
|
|
|
|
|
2014-03-19 00:15:25 -04:00
|
|
|
void categoryChanged();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Select an item from the inventory list
|
|
|
|
* @param invIndex Index in the inventory list of the item to select
|
|
|
|
*/
|
|
|
|
void selectObject(int invIndex);
|
2014-03-22 12:02:17 -04:00
|
|
|
|
2014-03-24 22:34:09 -04:00
|
|
|
void updateSelection(ScrCategory category, int newIndex, int *idx);
|
2014-03-22 12:02:17 -04:00
|
|
|
|
|
|
|
void scrollerChanged();
|
2014-03-22 18:26:41 -04:00
|
|
|
|
|
|
|
void scrollInventory();
|
2014-02-18 23:43:06 -05:00
|
|
|
};
|
|
|
|
|
|
|
|
} // End of namespace MADS
|
|
|
|
|
|
|
|
#endif /* MADS_USER_INTERFACE_H */
|