src/joystick/SDL_sysjoystick.h
author Sam Lantinga
Thu, 26 Apr 2001 16:45:43 +0000
changeset 0 74212992fb08
child 252 e8157fcb3114
permissions -rw-r--r--
Initial revision
slouken@0
     1
/*
slouken@0
     2
    SDL - Simple DirectMedia Layer
slouken@0
     3
    Copyright (C) 1997, 1998, 1999, 2000, 2001  Sam Lantinga
slouken@0
     4
slouken@0
     5
    This library is free software; you can redistribute it and/or
slouken@0
     6
    modify it under the terms of the GNU Library General Public
slouken@0
     7
    License as published by the Free Software Foundation; either
slouken@0
     8
    version 2 of the License, or (at your option) any later version.
slouken@0
     9
slouken@0
    10
    This library is distributed in the hope that it will be useful,
slouken@0
    11
    but WITHOUT ANY WARRANTY; without even the implied warranty of
slouken@0
    12
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
slouken@0
    13
    Library General Public License for more details.
slouken@0
    14
slouken@0
    15
    You should have received a copy of the GNU Library General Public
slouken@0
    16
    License along with this library; if not, write to the Free
slouken@0
    17
    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
slouken@0
    18
slouken@0
    19
    Sam Lantinga
slouken@0
    20
    slouken@devolution.com
slouken@0
    21
*/
slouken@0
    22
slouken@0
    23
#ifdef SAVE_RCSID
slouken@0
    24
static char rcsid =
slouken@0
    25
 "@(#) $Id$";
slouken@0
    26
#endif
slouken@0
    27
slouken@0
    28
/* This is the system specific header for the SDL joystick API */
slouken@0
    29
slouken@0
    30
#include "SDL_joystick.h"
slouken@0
    31
slouken@0
    32
/* The SDL joystick structure */
slouken@0
    33
struct _SDL_Joystick {
slouken@0
    34
	Uint8 index;		/* Device index */
slouken@0
    35
	const char *name;	/* Joystick name - system dependent */
slouken@0
    36
slouken@0
    37
	int naxes;		/* Number of axis controls on the joystick */
slouken@0
    38
	Sint16 *axes;		/* Current axis states */
slouken@0
    39
slouken@0
    40
	int nhats;		/* Number of hats on the joystick */
slouken@0
    41
	Uint8 *hats;		/* Current hat states */
slouken@0
    42
	
slouken@0
    43
	int nballs;		/* Number of trackballs on the joystick */
slouken@0
    44
	struct balldelta {
slouken@0
    45
		int dx;
slouken@0
    46
		int dy;
slouken@0
    47
	} *balls;		/* Current ball motion deltas */
slouken@0
    48
	
slouken@0
    49
	int nbuttons;		/* Number of buttons on the joystick */
slouken@0
    50
	Uint8 *buttons;		/* Current button states */
slouken@0
    51
	
slouken@0
    52
	struct joystick_hwdata *hwdata;	/* Driver dependent information */
slouken@0
    53
slouken@0
    54
	int ref_count;		/* Reference count for multiple opens */
slouken@0
    55
};
slouken@0
    56
slouken@0
    57
/* Function to scan the system for joysticks.
slouken@0
    58
 * Joystick 0 should be the system default joystick.
slouken@0
    59
 * This function should return the number of available joysticks, or -1
slouken@0
    60
 * on an unrecoverable fatal error.
slouken@0
    61
 */
slouken@0
    62
extern int SDL_SYS_JoystickInit(void);
slouken@0
    63
slouken@0
    64
/* Function to get the device-dependent name of a joystick */
slouken@0
    65
extern const char *SDL_SYS_JoystickName(int index);
slouken@0
    66
slouken@0
    67
/* Function to open a joystick for use.
slouken@0
    68
   The joystick to open is specified by the index field of the joystick.
slouken@0
    69
   This should fill the nbuttons and naxes fields of the joystick structure.
slouken@0
    70
   It returns 0, or -1 if there is an error.
slouken@0
    71
 */
slouken@0
    72
extern int SDL_SYS_JoystickOpen(SDL_Joystick *joystick);
slouken@0
    73
slouken@0
    74
/* Function to update the state of a joystick - called as a device poll.
slouken@0
    75
 * This function shouldn't update the joystick structure directly,
slouken@0
    76
 * but instead should call SDL_PrivateJoystick*() to deliver events
slouken@0
    77
 * and update joystick device state.
slouken@0
    78
 */
slouken@0
    79
extern void SDL_SYS_JoystickUpdate(SDL_Joystick *joystick);
slouken@0
    80
slouken@0
    81
/* Function to close a joystick after use */
slouken@0
    82
extern void SDL_SYS_JoystickClose(SDL_Joystick *joystick);
slouken@0
    83
slouken@0
    84
/* Function to perform any system-specific joystick related cleanup */
slouken@0
    85
extern void SDL_SYS_JoystickQuit(void);
slouken@0
    86