Contiki 2.6
|
00001 /* 00002 * Copyright (c) 2008 Swedish Institute of Computer Science 00003 * All rights reserved. 00004 * 00005 * Redistribution and use in source and binary forms, with or without 00006 * modification, are permitted provided that the following conditions are met: 00007 * 00008 * * Redistributions of source code must retain the above copyright 00009 * notice, this list of conditions and the following disclaimer. 00010 * * Redistributions in binary form must reproduce the above copyright 00011 * notice, this list of conditions and the following disclaimer in 00012 * the documentation and/or other materials provided with the 00013 * distribution. 00014 * * Neither the name of the copyright holders nor the names of 00015 * contributors may be used to endorse or promote products derived 00016 * from this software without specific prior written permission. 00017 * 00018 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 00019 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00020 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00021 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 00022 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 00023 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 00024 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00025 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 00026 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 00027 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00028 * POSSIBILITY OF SUCH DAMAGE. 00029 */ 00030 /** 00031 * \file 00032 * 00033 * \brief 00034 * This file operates the menu flow chart described in the readme 00035 * notes. This will create the proper commands needed to control the 1284p. 00036 * 00037 * \author 00038 * Mike Vidales mavida404@gmail.com 00039 * 00040 */ 00041 00042 #ifndef MENU_H 00043 #define MENU_H 00044 00045 #include <avr/pgmspace.h> 00046 #include <stdbool.h> 00047 00048 /** \brief Pointer to function, used to dispatch a menu-driven function. See tmenu_item */ 00049 typedef void (*tmenufunc)(uint8_t *); 00050 00051 /** \brief This structure defines the joystick operation within the menu_items[]. */ 00052 typedef struct { 00053 const char * PROGMEM text; /**< Menu text to display. */ 00054 uint8_t left; /**< Contains next menu position for left. */ 00055 uint8_t right; /**< Contains next menu position for right. */ 00056 uint8_t up; /**< Contains next menu position for up. */ 00057 uint8_t down; /**< Contains next menu position for down. */ 00058 uint8_t *state; /**< State variable used as argument for menu enter function. */ 00059 tmenufunc enter_func; /**< Pointer to function to call when enter button is pressed. */ 00060 } tmenu_item; 00061 00062 extern uint8_t ping_response; 00063 extern bool ping_mode; 00064 extern bool timeout_flag; 00065 extern bool temp_flag; 00066 extern bool auto_temp; 00067 extern const PROGMEM tmenu_item menu_items[]; 00068 char top_menu_text[20]; 00069 00070 #define EEPROM_DEBUG_ADDR 0 00071 00072 void menu_run_sleep(uint8_t *val); 00073 void menu_run_doze(uint8_t *val); 00074 void dectoascii(uint8_t val, char *str); 00075 uint8_t *signed_dectoascii(int16_t n, uint8_t *str); 00076 void eeprom_init(void); 00077 void menu_ping_request(uint8_t * val); 00078 uint8_t menu_send_ping(void); 00079 void menu_stop_ping(void); 00080 void menu_debug_mode(uint8_t *val); 00081 void menu_read_temp(uint8_t *val); 00082 void menu_display_temp(void); 00083 void menu_clear_temp(void); 00084 void menu_prepare_temp(uint8_t *val); 00085 void menu_stop_temp(void); 00086 void menu_send_temp(void); 00087 00088 #endif /* MENU_H */