Nut/OS  4.10.3
API Reference
keys.h
Go to the documentation of this file.
00001 #ifndef _KEYS_H_
00002 #define _KEYS_H_
00003 
00004 /*
00005  * Copyright (C) 2001-2009 by egnite Software GmbH. All rights reserved.
00006  * Copyright (C) 2009 by Ulrich Prinz (uprinz2@netscape.net)
00007  *
00008  * Redistribution and use in source and binary forms, with or without
00009  * modification, are permitted provided that the following conditions
00010  * are met:
00011  *
00012  * 1. Redistributions of source code must retain the above copyright
00013  *    notice, this list of conditions and the following disclaimer.
00014  * 2. Redistributions in binary form must reproduce the above copyright
00015  *    notice, this list of conditions and the following disclaimer in the
00016  *    documentation and/or other materials provided with the distribution.
00017  * 3. Neither the name of the copyright holders nor the names of
00018  *    contributors may be used to endorse or promote products derived
00019  *    from this software without specific prior written permission.
00020  *
00021  * THIS SOFTWARE IS PROVIDED BY EGNITE SOFTWARE GMBH AND CONTRIBUTORS
00022  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00023  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
00024  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL EGNITE
00025  * SOFTWARE GMBH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
00026  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
00027  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
00028  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
00029  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
00030  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
00031  * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
00032  * SUCH DAMAGE.
00033  *
00034  * For additional information see http://www.ethernut.de/
00035  *
00036  */
00037 
00038 /*
00039  * $Log$
00040  *
00041  * Revision 0.3  2009/09/12 ulrichprinz
00042  * First checkin, new push button driver example
00043  * (currently SAM7X256 is tested only)
00044  *
00045  */
00046 
00056 
00072 #define KEY_NOT_PRESSED         0x00            /* key is currently not pressed */
00073 
00080 #define KEY_IS_DOWN         0x01        /* key is currently down */
00081 
00090 #define KEY_PENDING         0x02        /* Key action is pending, reset on NutGetKey() */
00091 
00098 #define KEY_IS_LOCKED       0x04        /* for preventing double execution */
00099 
00116 #define KEY_ACTION_DOWN     0x10        /* assign action on key press, no timing possible */
00117 
00124 #define KEY_ACTION_UP       0x20        /* assign action on key release, no timing possible*/
00125 
00133 #define KEY_ACTION_HOLD     0x40        /* assign action on time pressed */
00134 
00142 #define KEY_ACTION_SHORT    0x80        /* assign action on release before given time */
00143 
00146 __BEGIN_DECLS
00147 /* Function prototypes. */
00148 
00149 extern int NutGetKeyState( HANDLE keyh);
00150 extern uint32_t NutGetKeyTime( HANDLE keyh);
00151 
00152 int NutRegisterKey( HANDLE *keyhp, int bank, int pin, int fx, uint32_t fxt);
00153 int NutAssignKeyFkt( HANDLE *keyhp, void (*callback)(void));
00154 int NutAssignKeyEvt( HANDLE *keyhp, HANDLE *event);
00155 
00156 __END_DECLS
00157 /* */
00158 
00159 #endif