Orxonox  0.0.5 Codename: Arcturus
Win32InputManager.h
Go to the documentation of this file.
1 /*
2 The zlib/libpng License
3 
4 Copyright (c) 2005-2007 Phillip Castaneda (pjcast -- www.wreckedgames.com)
5 
6 This software is provided 'as-is', without any express or implied warranty. In no event will
7 the authors be held liable for any damages arising from the use of this software.
8 
9 Permission is granted to anyone to use this software for any purpose, including commercial
10 applications, and to alter it and redistribute it freely, subject to the following
11 restrictions:
12 
13  1. The origin of this software must not be misrepresented; you must not claim that
14  you wrote the original software. If you use this software in a product,
15  an acknowledgment in the product documentation would be appreciated but is
16  not required.
17 
18  2. Altered source versions must be plainly marked as such, and must not be
19  misrepresented as being the original software.
20 
21  3. This notice may not be removed or altered from any source distribution.
22 */
23 #ifndef OIS_Win32InputManager_H
24 #define OIS_Win32InputManager_H
25 
26 #include "OISInputManager.h"
27 #include "OISFactoryCreator.h"
28 #include "win32/Win32Prereqs.h"
29 
30 namespace OIS
31 {
34  {
35  public:
37  virtual ~Win32InputManager();
38 
39  //InputManager Overrides
41  void _initialize( ParamList &paramList );
42 
43  //FactoryCreator Overrides
46 
48  int totalDevices(Type iType);
49 
51  int freeDevices(Type iType);
52 
54  bool vendorExist(Type iType, const std::string & vendor);
55 
57  Object* createObject(InputManager* creator, Type iType, bool bufferMode, const std::string & vendor = "");
58 
60  void destroyObject(Object* obj);
61 
62  //Internal Items
64  void _setKeyboardUsed(bool used) {keyboardUsed = used; }
65 
67  void _setMouseUsed(bool used) { mouseUsed = used; }
68 
70  void _returnJoyStick(const JoyStickInfo& joystick);
71 
73  HWND getWindowHandle() { return hWnd; }
74 
75  protected:
77  void _parseConfigSettings( ParamList &paramList );
78 
80  void _enumerateDevices();
81 
83  static BOOL CALLBACK _DIEnumDevCallback(LPCDIDEVICEINSTANCE lpddi, LPVOID pvRef);
84 
87 
89  HWND hWnd;
90 
92  IDirectInput8* mDirectInput;
93 
95  DWORD kbSettings;
96 
99 
101  DWORD joySettings;
102 
104  char joySticks;
105 
108 
110  bool mouseUsed;
111  };
112 }
113 #endif
Object * createObject(InputManager *creator, Type iType, bool bufferMode, const std::string &vendor="")
Definition: Win32InputManager.cpp:228
std::vector< JoyStickInfo > JoyStickInfoList
Definition: LinuxPrereqs.h:79
bool mouseUsed
Used to know if we used up mouse.
Definition: Win32InputManager.h:110
int freeDevices(Type iType)
Definition: Win32InputManager.cpp:199
static BOOL CALLBACK _DIEnumDevCallback(LPCDIDEVICEINSTANCE lpddi, LPVOID pvRef)
Used during device enumeration.
Definition: Win32InputManager.cpp:137
::std::string string
Definition: gtest-port.h:756
void _setKeyboardUsed(bool used)
Internal method, used for flaggin keyboard as available/unavailable for creation. ...
Definition: Win32InputManager.h:64
virtual ~Win32InputManager()
Definition: Win32InputManager.cpp:49
DWORD kbSettings
Used for keyboard device settings.
Definition: Win32InputManager.h:95
void _enumerateDevices()
internal class method for finding attached devices
Definition: Win32InputManager.cpp:117
JoyStickInfoList unusedJoyStickList
Keep a list of all joysticks enumerated, but not in use.
Definition: Win32InputManager.h:86
Interface for creating devices - all devices ultimately get enumerated/created via a factory...
Definition: OISFactoryCreator.h:34
DWORD mouseSettings
Used for mouse device settings.
Definition: Win32InputManager.h:98
void destroyObject(Object *obj)
Definition: Win32InputManager.cpp:270
Win32InputManager()
Definition: Win32InputManager.cpp:32
bool vendorExist(Type iType, const std::string &vendor)
Definition: Win32InputManager.cpp:211
The base class of all input types.
Definition: OISObject.h:32
int totalDevices(Type iType)
Definition: Win32InputManager.cpp:187
DWORD joySettings
Used for joystick device settings.
Definition: Win32InputManager.h:101
void _setMouseUsed(bool used)
Internal method, used for flaggin mouse as available/unavailable for creation.
Definition: Win32InputManager.h:67
Type
Each Input class has a General Type variable, a form of RTTI.
Definition: OISPrereqs.h:138
Definition: LinuxPrereqs.h:53
HWND hWnd
The window handle we are using.
Definition: Win32InputManager.h:89
Base Manager class.
Definition: OISInputManager.h:38
void _parseConfigSettings(ParamList &paramList)
internal class method for dealing with param list
Definition: Win32InputManager.cpp:90
std::multimap< Type, std::string > DeviceList
Map of device objects connected and their respective vendors.
Definition: OISPrereqs.h:149
Definition: EventHelpers.h:31
char joySticks
Number of total joysticks (inuse or not)
Definition: Win32InputManager.h:104
HWND getWindowHandle()
Returns HWND needed by DirectInput Device Object.
Definition: Win32InputManager.h:73
IDirectInput8 * mDirectInput
Direct Input Interface.
Definition: Win32InputManager.h:92
void _initialize(ParamList &paramList)
Definition: Win32InputManager.cpp:59
void _returnJoyStick(const JoyStickInfo &joystick)
Internal method, return unused joystick to queue.
Definition: Win32InputManager.cpp:164
DeviceList freeDeviceList()
Definition: Win32InputManager.cpp:170
bool keyboardUsed
Used to know if we used up keyboard.
Definition: Win32InputManager.h:107
Win32InputManager specialization - Using DirectInput8.
Definition: Win32InputManager.h:33
std::multimap< std::string, std::string > ParamList
Way to send OS nuetral parameters.. ie OS Window handles, modes, flags.
Definition: OISPrereqs.h:126