Skip to content

Latest commit

 

History

History
193 lines (159 loc) · 4.92 KB

SDL_ph_mouse.c

File metadata and controls

193 lines (159 loc) · 4.92 KB
 
Apr 26, 2001
Apr 26, 2001
1
2
/*
SDL - Simple DirectMedia Layer
Mar 6, 2002
Mar 6, 2002
3
Copyright (C) 1997, 1998, 1999, 2000, 2001, 2002 Sam Lantinga
Apr 26, 2001
Apr 26, 2001
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
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
Library General Public License for more details.
You should have received a copy of the GNU Library General Public
License along with this library; if not, write to the Free
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Sam Lantinga
Dec 14, 2001
Dec 14, 2001
20
slouken@libsdl.org
Apr 26, 2001
Apr 26, 2001
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
*/
#ifdef SAVE_RCSID
static char rcsid =
"@(#) $Id$";
#endif
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include "SDL_error.h"
#include "SDL_mouse.h"
#include "SDL_events_c.h"
#include "SDL_cursor_c.h"
#include "SDL_ph_mouse_c.h"
struct WMcursor {
Mar 23, 2002
Mar 23, 2002
39
PhCursorDef_t *ph_cursor ;
Apr 26, 2001
Apr 26, 2001
40
41
42
43
44
};
void ph_FreeWMCursor(_THIS, WMcursor *cursor)
{
Mar 23, 2002
Mar 23, 2002
45
46
47
if (window != NULL)
{
SDL_Lock_EventThread();
Apr 26, 2001
Apr 26, 2001
48
Mar 23, 2002
Mar 23, 2002
49
50
51
52
53
54
55
56
57
if (PtSetResource( window, Pt_ARG_CURSOR_TYPE, Ph_CURSOR_INHERIT, 0 ) < 0)
{
/* TODO: output error msg */
}
SDL_Unlock_EventThread();
}
/* free(cursor->ph_cursor.images); */
free(cursor);
Apr 26, 2001
Apr 26, 2001
58
59
60
61
62
63
64
}
WMcursor *ph_CreateWMCursor(_THIS,
Uint8 *data, Uint8 *mask, int w, int h, int hot_x, int hot_y)
{
WMcursor* cursor;
int clen, i;
Feb 20, 2002
Feb 20, 2002
65
unsigned char bit, databit, maskbit;
Apr 26, 2001
Apr 26, 2001
66
67
68
69
/* Allocate and initialize the cursor memory */
if ((cursor = (WMcursor*)malloc(sizeof(WMcursor))) == NULL)
{
May 28, 2002
May 28, 2002
70
71
SDL_OutOfMemory();
return(NULL);
Apr 26, 2001
Apr 26, 2001
72
73
}
memset(cursor,0,sizeof(WMcursor));
Feb 20, 2002
Feb 20, 2002
74
Apr 26, 2001
Apr 26, 2001
75
76
77
78
79
cursor->ph_cursor = (PhCursorDef_t *) malloc(sizeof(PhCursorDef_t) + 32*4*2);
if(cursor->ph_cursor == NULL)
printf("cursor malloc failed\n");
memset(cursor->ph_cursor,0,(sizeof(PhCursorDef_t) + 32*4*2));
Feb 20, 2002
Feb 20, 2002
80
Apr 26, 2001
Apr 26, 2001
81
82
83
84
85
86
87
88
cursor->ph_cursor->hdr.type =Ph_RDATA_CURSOR;
cursor->ph_cursor->size1.x = (short)w;
cursor->ph_cursor->size1.y = (short)h;
cursor->ph_cursor->offset1.x = (short)hot_x;
cursor->ph_cursor->offset1.y = (short)hot_y;
cursor->ph_cursor->bytesperline1 = (char)w/8;
cursor->ph_cursor->color1 = Pg_WHITE;
cursor->ph_cursor->size2.x = (short)w;
Jan 18, 2002
Jan 18, 2002
89
90
91
92
93
cursor->ph_cursor->size2.y = (short)h;
cursor->ph_cursor->offset2.x = (short)hot_x;
cursor->ph_cursor->offset2.y = (short)hot_y;
cursor->ph_cursor->bytesperline2 = (char)w/8;
cursor->ph_cursor->color2 = Pg_BLACK;
Feb 20, 2002
Feb 20, 2002
94
Apr 26, 2001
Apr 26, 2001
95
96
97
98
clen = (w/8)*h;
/* Copy the mask and the data to different
bitmap planes */
Jan 18, 2002
Jan 18, 2002
99
for ( i=0; i<clen; ++i )
Feb 20, 2002
Feb 20, 2002
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
{
for ( bit = 0; bit < 8; bit++ )
{
databit = data[i] & (1 << bit);
maskbit = mask[i] & (1 << bit);
cursor->ph_cursor->images[i] |=
(databit == 0) ? maskbit : 0;
/* If the databit != 0, treat it as a black pixel and
* ignore the maskbit (can't do an inverted color) */
cursor->ph_cursor->images[i+clen] |= databit;
}
}
/* #bytes following the hdr struct */
Apr 26, 2001
Apr 26, 2001
115
116
117
118
119
120
121
122
cursor->ph_cursor->hdr.len =sizeof(PhCursorDef_t) + clen*2 - sizeof(PhRegionDataHdr_t);
return (cursor);
}
PhCursorDef_t ph_GetWMPhCursor(WMcursor *cursor)
{
Mar 23, 2002
Mar 23, 2002
123
return(*cursor->ph_cursor);
Apr 26, 2001
Apr 26, 2001
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
}
int ph_ShowWMCursor(_THIS, WMcursor *cursor)
{
PtArg_t args[3];
int nargs = 0;
short cursor_is_defined = 0;
/* Don't do anything if the display is gone */
if ( window == NULL ) {
return(0);
}
/* Set the photon cursor cursor, or blank if cursor is NULL */
if ( window ) {
if ( cursor != NULL ) {
PtSetArg( &args[0], Pt_ARG_CURSOR_TYPE, Ph_CURSOR_BITMAP, 0 );
Feb 20, 2002
Feb 20, 2002
142
/* Could set next to any PgColor_t value */
Apr 26, 2001
Apr 26, 2001
143
144
145
146
147
PtSetArg( &args[1], Pt_ARG_CURSOR_COLOR,Ph_CURSOR_DEFAULT_COLOR , 0 );
PtSetArg( &args[2], Pt_ARG_BITMAP_CURSOR, cursor->ph_cursor, (cursor->ph_cursor->hdr.len + sizeof(PhRegionDataHdr_t)) );
nargs = 3;
cursor_is_defined = 1;
}
Feb 20, 2002
Feb 20, 2002
148
else /* Ph_CURSOR_NONE */
Apr 26, 2001
Apr 26, 2001
149
150
151
152
153
154
{
PtSetArg( &args[0], Pt_ARG_CURSOR_TYPE,Ph_CURSOR_NONE, 0);
nargs = 1;
cursor_is_defined = 1;
}
if (cursor_is_defined)
Jan 18, 2002
Jan 18, 2002
155
156
{
SDL_Lock_EventThread();
Apr 26, 2001
Apr 26, 2001
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
if (PtSetResources( window, nargs, args ) < 0 )
{
return(0);
}
SDL_Unlock_EventThread();
}
else
return(0);
}
return(1);
}
void ph_WarpWMCursor(_THIS, Uint16 x, Uint16 y)
{
Mar 23, 2002
Mar 23, 2002
173
short abs_x, abs_y;
Feb 20, 2002
Feb 20, 2002
174
Mar 23, 2002
Mar 23, 2002
175
176
177
178
SDL_Lock_EventThread();
PtGetAbsPosition( window, &abs_x, &abs_y );
PhMoveCursorAbs( PhInputGroup(NULL), x + abs_x, y + abs_y );
SDL_Unlock_EventThread();
Apr 26, 2001
Apr 26, 2001
179
180
181
182
183
}
void ph_CheckMouseMode(_THIS)
{
Mar 23, 2002
Mar 23, 2002
184
185
186
187
188
189
190
191
192
/* If the mouse is hidden and input is grabbed, we use relative mode */
if ( !(SDL_cursorstate & CURSOR_VISIBLE) && (this->input_grab != SDL_GRAB_OFF))
{
mouse_relative = 1;
}
else
{
mouse_relative = 0;
}
Apr 26, 2001
Apr 26, 2001
193
}