CHDK_DE Vorschauversion  Trunk Rev. 5728
 Alle Datenstrukturen Dateien Funktionen Variablen Typdefinitionen Aufzählungen Aufzählungswerte Makrodefinitionen
gui.h-Dateireferenz
+ Dieser Graph zeigt, welche Datei direkt oder indirekt diese Datei enthält:

gehe zum Quellcode dieser Datei

Datenstrukturen

struct  gui_handler
 

Makrodefinitionen

#define GUI_MODE_MAGICNUM   0xd36c1559
 
#define GUI_MODE_FLAG_NODRAWRESTORE   1
 
#define GUI_MODE_FLAG_NORESTORE_ON_SWITCH   2
 

Typdefinitionen

typedef unsigned int gui_mode_t
 

Aufzählungen

enum  Gui_Mode_ {
  GUI_MODE_STARTUP = -1, GUI_MODE_NONE = 0, GUI_MODE_ALT, GUI_MODE_MENU,
  GUI_MODE_SCRIPT, GUI_MODE_MBOX, GUI_MODE_OSD, GUI_MODE_PALETTE,
  GUI_MODE_FSELECT, GUI_MODE_MPOPUP, GUI_MODE_MODULE
}
 
enum  ALT_Mode_State { ALT_MODE_NORMAL = 0, ALT_MODE_ENTER, ALT_MODE_ENTER_SCRIPT, ALT_MODE_LEAVE }
 

Funktionen

void gui_set_alt_mode_state (int)
 
void gui_activate_alt_mode ()
 
int gui_kbd_process ()
 
void gui_default_kbd_process_menu_btn ()
 
int gui_touch_process (int x, int y)
 
void gui_redraw (int flag_gui_enforce_redraw)
 
void gui_set_need_restore ()
 
void gui_cancel_need_restore ()
 
gui_handlergui_set_mode (gui_handler *mode)
 
void gui_reset_alt_helper ()
 
void gui_enum_value_change (int *value, int change, unsigned num_items)
 
const char * gui_subj_dist_override_value_enum (int change, int arg)
 
const char * gui_subj_dist_override_koef_enum (int change, int arg)
 
const char * gui_tv_override_value_enum (int change, int arg)
 
const char * gui_hhmss_enum (int change, int arg)
 
const char * gui_flash_power_modes_enum (int change, int arg)
 
const char * gui_flash_exp_comp_modes_enum (int change, int arg)
 

Variablen

int script_run_on_alt_flag
 
gui_handler altGuiHandler
 

Makro-Dokumentation

#define GUI_MODE_FLAG_NODRAWRESTORE   1

Definiert in Zeile 44 der Datei gui.h.

#define GUI_MODE_FLAG_NORESTORE_ON_SWITCH   2

Definiert in Zeile 45 der Datei gui.h.

#define GUI_MODE_MAGICNUM   0xd36c1559

Definiert in Zeile 41 der Datei gui.h.

Dokumentation der benutzerdefinierten Typen

typedef unsigned int gui_mode_t

Definiert in Zeile 25 der Datei gui.h.

Dokumentation der Aufzählungstypen

Aufzählungswerte
ALT_MODE_NORMAL 
ALT_MODE_ENTER 
ALT_MODE_ENTER_SCRIPT 
ALT_MODE_LEAVE 

Definiert in Zeile 31 der Datei gui.h.

31  {
32  ALT_MODE_NORMAL = 0, // don't change ALT mode
33  ALT_MODE_ENTER, // enter ALT mode
34  ALT_MODE_ENTER_SCRIPT, // enter SCRIPT mode
35  ALT_MODE_LEAVE, // leave ALT mode
36 };
enum Gui_Mode_
Aufzählungswerte
GUI_MODE_STARTUP 
GUI_MODE_NONE 
GUI_MODE_ALT 
GUI_MODE_MENU 
GUI_MODE_SCRIPT 
GUI_MODE_MBOX 
GUI_MODE_OSD 
GUI_MODE_PALETTE 
GUI_MODE_FSELECT 
GUI_MODE_MPOPUP 
GUI_MODE_MODULE 

Definiert in Zeile 11 der Datei gui.h.

11  {
12  GUI_MODE_STARTUP = -1,
13  GUI_MODE_NONE = 0,
18  GUI_MODE_OSD, // OSD editor
22  GUI_MODE_MODULE, // generic module
23 };

Dokumentation der Funktionen

void gui_activate_alt_mode ( )

Definiert in Zeile 3062 der Datei gui.c.

3063 {
3065 
3066  switch (gui_current_alt_state)
3067  {
3068  case ALT_MODE_ENTER:
3069  case ALT_MODE_ENTER_SCRIPT:
3070 
3072 
3074 
3076 
3077  // If user menu set to start automatically when <ALT> mode entered
3078  // then enter user menu mode, unless a script was paused by exiting
3079  // <ALT> mode when the script was running.
3080  gui_user_menu_flag = 0;
3084  gui_user_menu_flag = 1;
3085  }
3086  break;
3087 
3088  case ALT_MODE_LEAVE:
3089  conf_save();
3090 
3091  // Unload all modules which are marked as safe to unload, or loaded for menus
3092  module_exit_alt();
3093 
3097 
3099  break;
3100  }
3101 
3102  // Reset to stable state
3104 }
void gui_cancel_need_restore ( )

Definiert in Zeile 2431 der Datei gui.c.

2432 {
2435 }
void gui_default_kbd_process_menu_btn ( )

Definiert in Zeile 2732 der Datei gui.c.

2733 {
2735 }
void gui_enum_value_change ( int *  value,
int  change,
unsigned  num_items 
)

Definiert in Zeile 72 der Datei gui.c.

72  {
73  *value+=change;
74  if (*value<0)
75  *value = num_items-1;
76  else if (*value>=(int)num_items)
77  *value = 0;
78 }
const char* gui_flash_exp_comp_modes_enum ( int  change,
int  arg 
)
const char* gui_flash_power_modes_enum ( int  change,
int  arg 
)
const char* gui_hhmss_enum ( int  change,
int  arg 
)

Definiert in Zeile 1412 der Datei gui.c.

1413 {
1414  int *v = (int*)arg;
1415 
1416  int h, m, s;
1417  h = *v / 3600;
1418  m = (*v % 3600) / 60;
1419  s = *v % 60;
1420 
1421  switch (change)
1422  {
1423  case 1:
1424  case -1:
1425  s += change;
1426  if (s < 0) s = 59;
1427  if (s > 59) s = 0;
1428  break;
1429  case 10:
1430  case -10:
1431  m += change / 10;
1432  if (m < 0) m = 59;
1433  if (m > 59) m = 0;
1434  break;
1435  default:
1436  h += change /100;
1437  if (h < 0) h = 1;
1438  if (h > 1) h = 0;
1439  break;
1440  }
1441  *v = (h * 3600) + (m * 60) + s;
1442 
1443  sprintf(buf, "%1d:%02d:%02d", h, m, s);
1444 
1445  return buf;
1446 }
int gui_kbd_process ( )

Definiert in Zeile 3024 der Datei gui.c.

3025 {
3026  if (gui_mode)
3027  {
3028  // Call menu button handler if menu button pressed
3030  {
3032  {
3034  return 0;
3035  }
3036  }
3037 
3038  // Call mode handler for other buttons
3039  if (gui_mode->kbd_process) return gui_mode->kbd_process();
3040  }
3041  return 0;
3042 }
void gui_redraw ( int  flag_gui_enforce_redraw)

Definiert in Zeile 2971 der Datei gui.c.

2972 {
2973  if (!draw_test_guard() && (!camera_info.state.gui_mode_none || gui_splash)) // Attempt to detect screen erase in <Alt> mode, redraw if needed
2974  {
2975  draw_set_guard();
2976  flag_gui_enforce_redraw = 1;
2977 #ifdef CAM_TOUCHSCREEN_UI
2978  redraw_buttons = 1;
2979 #endif
2980  }
2981 
2982 #ifdef CAM_TOUCHSCREEN_UI
2983  extern void virtual_buttons();
2984  virtual_buttons();
2985 #endif
2986 
2987  // Erase screen if needed
2989  {
2990  draw_restore();
2992  flag_gui_enforce_redraw = 1;
2993  }
2994 
2995  // Force mode redraw if needed
2997  {
2999  flag_gui_enforce_redraw = 1;
3000  }
3001 
3002 #ifdef OPT_EXPIRE_TEST
3003  do_expire_check();
3004 #endif
3005 
3006  gui_handle_splash(flag_gui_enforce_redraw);
3007 
3008  // visible warning if modules missing
3010 
3011 // DEBUG: uncomment if you want debug values always on top
3012 //gui_draw_debug_vals_osd();
3013 
3014  // Call redraw handler
3015  if (gui_mode->redraw)
3016  gui_mode->redraw(flag_gui_enforce_redraw);
3017 }
void gui_reset_alt_helper ( )
void gui_set_alt_mode_state ( int  )

Definiert in Zeile 3056 der Datei gui.c.

3057 {
3058  gui_current_alt_state = new_state;
3059 }
gui_handler* gui_set_mode ( gui_handler mode)

Definiert in Zeile 2461 der Datei gui.c.

2462 {
2463  // Set up gui mode & state variables
2464  camera_info.state.gui_mode = mode->mode;
2467 
2468  if ( gui_mode == mode )
2469  return gui_mode;
2470 
2471 #ifdef CAM_TOUCHSCREEN_UI
2472  if (((gui_mode->mode == GUI_MODE_NONE) != (mode->mode == GUI_MODE_NONE)) || // Change from GUI_MODE_NONE to any other or vice-versa
2473  ((gui_mode->mode > GUI_MODE_MENU) != (mode->mode > GUI_MODE_MENU))) // Switch in & out of menu mode
2474  redraw_buttons = 1;
2475 #endif
2476 
2478 
2480  gui_mode = mode;
2481 
2483 
2484  // Flag for screen erase/redraw unless mode is marked not to (e.g. menu box popup)
2486  ((old_mode->flags & GUI_MODE_FLAG_NORESTORE_ON_SWITCH) == 0))
2488  // If old mode did not erase screen on exit then force current mode to redraw itself (e.g. exit menu popup back to file select)
2489  if ((old_mode->flags & (GUI_MODE_FLAG_NORESTORE_ON_SWITCH)) != 0)
2491 
2492 #ifdef CAM_DISP_ALT_TEXT
2495 #endif
2496 
2497  return old_mode;
2498 }
void gui_set_need_restore ( )

Definiert in Zeile 2426 der Datei gui.c.

2427 {
2429 }
const char* gui_subj_dist_override_koef_enum ( int  change,
int  arg 
)
const char* gui_subj_dist_override_value_enum ( int  change,
int  arg 
)
int gui_touch_process ( int  x,
int  y 
)

Definiert in Zeile 3045 der Datei gui.c.

3046 {
3048  return gui_mode->touch_handler(x, y);
3049  return 0;
3050 }
const char* gui_tv_override_value_enum ( int  change,
int  arg 
)

Variablen-Dokumentation

gui_handler altGuiHandler

Definiert in Zeile 2967 der Datei gui.c.

int script_run_on_alt_flag

Definiert in Zeile 55 der Datei gui.c.