Skip to content
This repository has been archived by the owner on Feb 11, 2021. It is now read-only.

Latest commit

 

History

History
181 lines (155 loc) · 5.53 KB

SDL_mouse.h

File metadata and controls

181 lines (155 loc) · 5.53 KB
 
Apr 26, 2001
Apr 26, 2001
1
2
/*
SDL - Simple DirectMedia Layer
Feb 1, 2006
Feb 1, 2006
3
Copyright (C) 1997-2006 Sam Lantinga
Apr 26, 2001
Apr 26, 2001
4
5
This library is free software; you can redistribute it and/or
Feb 1, 2006
Feb 1, 2006
6
modify it under the terms of the GNU Lesser General Public
Apr 26, 2001
Apr 26, 2001
7
License as published by the Free Software Foundation; either
Feb 1, 2006
Feb 1, 2006
8
version 2.1 of the License, or (at your option) any later version.
Apr 26, 2001
Apr 26, 2001
9
10
11
12
This library 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
Feb 1, 2006
Feb 1, 2006
13
Lesser General Public License for more details.
Apr 26, 2001
Apr 26, 2001
14
Feb 1, 2006
Feb 1, 2006
15
16
17
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
Apr 26, 2001
Apr 26, 2001
18
19
Sam Lantinga
Dec 14, 2001
Dec 14, 2001
20
slouken@libsdl.org
Apr 26, 2001
Apr 26, 2001
21
22
*/
May 28, 2006
May 28, 2006
23
24
25
26
27
/**
* \file SDL_mouse.h
*
* Include file for SDL mouse event handling
*/
Apr 26, 2001
Apr 26, 2001
28
29
30
31
#ifndef _SDL_mouse_h
#define _SDL_mouse_h
Feb 10, 2006
Feb 10, 2006
32
#include "SDL_stdinc.h"
Feb 10, 2006
Feb 10, 2006
33
#include "SDL_error.h"
Apr 26, 2001
Apr 26, 2001
34
35
36
37
38
#include "SDL_video.h"
#include "begin_code.h"
/* Set up for C function definitions, even when using C++ */
#ifdef __cplusplus
May 28, 2006
May 28, 2006
39
/* *INDENT-OFF* */
Apr 26, 2001
Apr 26, 2001
40
extern "C" {
May 28, 2006
May 28, 2006
41
/* *INDENT-ON* */
Apr 26, 2001
Apr 26, 2001
42
43
#endif
Jun 7, 2006
Jun 7, 2006
44
typedef struct SDL_Cursor SDL_Cursor; /* Implementation dependent */
Apr 26, 2001
Apr 26, 2001
45
46
/* Function prototypes */
Jun 7, 2006
Jun 7, 2006
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/* \fn int SDL_GetNumMice(void)
*
* \brief Get the number of mouse input devices available.
*
* \sa SDL_SelectMouse()
*/
extern DECLSPEC int SDLCALL SDL_GetNumMice(void);
/* \fn int SDL_SelectMouse(int index)
*
* \brief Set the index of the currently selected mouse.
*
* \return The index of the currently selected mouse.
*
* \note You can query the currently selected mouse by passing an index of -1.
*
* \sa SDL_GetNumMice()
*/
extern DECLSPEC int SDLCALL SDL_SelectMouse(int index);
/* \fn SDL_WindowID SDL_GetMouseFocusWindow(void)
*
* \brief Get the window which currently has focus for the currently selected mouse.
*/
extern DECLSPEC SDL_WindowID SDLCALL SDL_GetMouseFocusWindow(void);
Apr 26, 2001
Apr 26, 2001
74
/*
Jun 7, 2006
Jun 7, 2006
75
76
77
78
* \fn Uint8 SDL_GetMouseState(int *x, int *y)
*
* \brief Retrieve the current state of the mouse.
*
Apr 26, 2001
Apr 26, 2001
79
80
* The current button state is returned as a button bitmask, which can
* be tested using the SDL_BUTTON(X) macros, and x and y are set to the
Jun 7, 2006
Jun 7, 2006
81
82
* mouse cursor position relative to the focus window for the currently
* selected mouse. You can pass NULL for either x or y.
Apr 26, 2001
Apr 26, 2001
83
*/
May 29, 2006
May 29, 2006
84
extern DECLSPEC Uint8 SDLCALL SDL_GetMouseState(int *x, int *y);
Apr 26, 2001
Apr 26, 2001
85
86
/*
Jun 7, 2006
Jun 7, 2006
87
88
89
90
* \fn Uint8 SDL_GetRelativeMouseState(int *x, int *y)
*
* \brief Retrieve the current state of the mouse.
*
Apr 26, 2001
Apr 26, 2001
91
92
93
94
* The current button state is returned as a button bitmask, which can
* be tested using the SDL_BUTTON(X) macros, and x and y are set to the
* mouse deltas since the last call to SDL_GetRelativeMouseState().
*/
May 29, 2006
May 29, 2006
95
extern DECLSPEC Uint8 SDLCALL SDL_GetRelativeMouseState(int *x, int *y);
Apr 26, 2001
Apr 26, 2001
96
97
/*
Jun 7, 2006
Jun 7, 2006
98
99
100
101
102
103
104
105
106
* \fn void SDL_WarpMouseInWindow(SDL_WindowID windowID, int x, int y)
*
* \brief Moves the currently selected mouse to the given position within the window.
*
* \param windowID The window to move the mouse into, or 0 for the current mouse focus
* \param x The x coordinate within the window
* \param y The y coordinate within the window
*
* \note This function generates a mouse motion event
Apr 26, 2001
Apr 26, 2001
107
*/
Jun 7, 2006
Jun 7, 2006
108
109
extern DECLSPEC void SDLCALL SDL_WarpMouseInWindow(SDL_WindowID windowID,
int x, int y);
Apr 26, 2001
Apr 26, 2001
110
111
112
113
114
115
116
117
118
119
120
121
122
123
/*
* Create a cursor using the specified data and mask (in MSB format).
* The cursor width must be a multiple of 8 bits.
*
* The cursor is created in black and white according to the following:
* data mask resulting pixel on screen
* 0 1 White
* 1 1 Black
* 0 0 Transparent
* 1 0 Inverted color if possible, black if not.
*
* Cursors created with this function must be freed with SDL_FreeCursor().
*/
May 28, 2006
May 28, 2006
124
125
extern DECLSPEC SDL_Cursor *SDLCALL SDL_CreateCursor
(Uint8 * data, Uint8 * mask, int w, int h, int hot_x, int hot_y);
Apr 26, 2001
Apr 26, 2001
126
127
128
129
130
131
/*
* Set the currently active cursor to the specified one.
* If the cursor is currently visible, the change will be immediately
* represented on the display.
*/
May 29, 2006
May 29, 2006
132
extern DECLSPEC void SDLCALL SDL_SetCursor(SDL_Cursor * cursor);
Apr 26, 2001
Apr 26, 2001
133
134
135
136
/*
* Returns the currently active cursor.
*/
May 29, 2006
May 29, 2006
137
extern DECLSPEC SDL_Cursor *SDLCALL SDL_GetCursor(void);
Apr 26, 2001
Apr 26, 2001
138
139
140
141
/*
* Deallocates a cursor created with SDL_CreateCursor().
*/
May 29, 2006
May 29, 2006
142
extern DECLSPEC void SDLCALL SDL_FreeCursor(SDL_Cursor * cursor);
Apr 26, 2001
Apr 26, 2001
143
144
145
146
147
148
149
150
/*
* Toggle whether or not the cursor is shown on the screen.
* The cursor start off displayed, but can be turned off.
* SDL_ShowCursor() returns 1 if the cursor was being displayed
* before the call, or 0 if it was not. You can query the current
* state by passing a 'toggle' value of -1.
*/
May 29, 2006
May 29, 2006
151
extern DECLSPEC int SDLCALL SDL_ShowCursor(int toggle);
Apr 26, 2001
Apr 26, 2001
152
153
154
155
156
/* Used as a mask when testing buttons in buttonstate
Button 1: Left mouse button
Button 2: Middle mouse button
Button 3: Right mouse button
Aug 19, 2002
Aug 19, 2002
157
158
Button 4: Mouse wheel up (may also be a real button)
Button 5: Mouse wheel down (may also be a real button)
Apr 26, 2001
Apr 26, 2001
159
*/
Feb 6, 2006
Feb 6, 2006
160
#define SDL_BUTTON(X) (1 << ((X)-1))
Apr 26, 2001
Apr 26, 2001
161
162
163
#define SDL_BUTTON_LEFT 1
#define SDL_BUTTON_MIDDLE 2
#define SDL_BUTTON_RIGHT 3
Aug 19, 2002
Aug 19, 2002
164
165
#define SDL_BUTTON_WHEELUP 4
#define SDL_BUTTON_WHEELDOWN 5
Apr 26, 2001
Apr 26, 2001
166
167
168
169
170
171
172
#define SDL_BUTTON_LMASK SDL_BUTTON(SDL_BUTTON_LEFT)
#define SDL_BUTTON_MMASK SDL_BUTTON(SDL_BUTTON_MIDDLE)
#define SDL_BUTTON_RMASK SDL_BUTTON(SDL_BUTTON_RIGHT)
/* Ends C function definitions when using C++ */
#ifdef __cplusplus
May 28, 2006
May 28, 2006
173
/* *INDENT-OFF* */
Apr 26, 2001
Apr 26, 2001
174
}
May 28, 2006
May 28, 2006
175
/* *INDENT-ON* */
Apr 26, 2001
Apr 26, 2001
176
177
178
179
#endif
#include "close_code.h"
#endif /* _SDL_mouse_h */
May 28, 2006
May 28, 2006
180
181
/* vi: set ts=4 sw=4 expandtab: */