CHDK_DE Vorschauversion  Trunk Rev. 5279
 Alle Datenstrukturen Dateien Funktionen Variablen Typdefinitionen Aufzählungen Aufzählungswerte Makrodefinitionen
lib.c-Dateireferenz
#include "platform.h"
#include "platform_palette.h"
#include "lolevel.h"
+ Include-Abhängigkeitsdiagramm für lib.c:

gehe zum Quellcode dieser Datei

Funktionen

char * camera_jpeg_count_str ()
 
int get_flash_params_count (void)
 
char * hook_raw_image_addr ()
 
char * hook_alt_raw_image_addr ()
 
void vid_bitmap_refresh ()
 
void shutdown ()
 
void debug_led (int state)
 
void camera_set_led (int led, int state, int bright)
 
void * vid_get_bitmap_fb ()
 
void * vid_get_viewport_fb ()
 
void * vid_get_viewport_fb_d ()
 
void * vid_get_viewport_live_fb ()
 
int vid_get_viewport_yscale ()
 
int vid_get_viewport_width ()
 
long vid_get_viewport_height ()
 
int vid_get_viewport_display_xoffset_proper ()
 
int vid_get_palette_type ()
 
int vid_get_palette_size ()
 
int vid_get_aspect_ratio ()
 
void * vid_get_bitmap_active_palette ()
 
void * vid_get_bitmap_active_buffer ()
 

Variablen

int active_raw_buffer
 
char * raw_buffers []
 
int active_palette_buffer
 
int ** palette_buffer_ptr
 
char palette_control
 

Dokumentation der Funktionen

char* camera_jpeg_count_str ( )

Definiert in Zeile 10 der Datei lib.c.

10 { return (char*)0x00220c20; } // Found @0xff2c1778
void camera_set_led ( int  led,
int  state,
int  bright 
)

Definiert in Zeile 49 der Datei lib.c.

50 {
51  static char led_table[3]={0,6,11}; // 0=green power button LED, 6=focus assist lamp (dim), 11=flash LED (bright)
52  _LEDDrive(led_table[led%sizeof(led_table)], state<=1 ? !state : state);
53 }
void debug_led ( int  state)

Definiert in Zeile 42 der Datei lib.c.

43 {
44  if ( state == 1 ) *(int*)0xc022c30c = ( (*(int*)0xc022c30c) & 0xffffffcf ) | 0x20 ;
45  else *(int*)0xc022c30c = ( (*(int*)0xc022c30c) & 0xffffffcf ) ;
46 }
int get_flash_params_count ( void  )

Definiert in Zeile 11 der Datei lib.c.

11 { return 0x91; } // Found @0xff25006c
char* hook_alt_raw_image_addr ( )

Definiert in Zeile 18 der Datei lib.c.

19 {
20  return raw_buffers[(active_raw_buffer^1)];
21 }
char* hook_raw_image_addr ( void  )

Definiert in Zeile 13 der Datei lib.c.

14 {
16 }
void shutdown ( )

Definiert in Zeile 34 der Datei lib.c.

35 {
36  extern void _TurnOffE1(void);
37  _TurnOffE1();
38  while(1);
39 }
void vid_bitmap_refresh ( )

Definiert in Zeile 23 der Datei lib.c.

24 {
25  extern int full_screen_refresh;
26  extern void _ScreenUnlock();
27  extern void _ScreenLock();
28 
29  full_screen_refresh |= 3;
30  _ScreenLock();
31  _ScreenUnlock();
32 }
int vid_get_aspect_ratio ( )

Definiert in Zeile 115 der Datei lib.c.

115 { return 1; }
void* vid_get_bitmap_active_buffer ( )

Definiert in Zeile 123 der Datei lib.c.

124 {
125  return (void*)(*(int*)(0x7510+0x18)); //found Powershot N @ loc_FF1BDFEC (from A1400 example)
126 }
void* vid_get_bitmap_active_palette ( )

Definiert in Zeile 117 der Datei lib.c.

117  {
118  unsigned char theme;
119  get_parameter_data(20, &theme, 1);
120  return palette_buffer_ptr[active_palette_buffer+theme] + 1;
121 }
void* vid_get_bitmap_fb ( )

OSD screen

Definiert in Zeile 56 der Datei lib.c.

56 { return (void*)0x406c5000; } // Found @0xff08d5d8
int vid_get_palette_size ( )

Definiert in Zeile 114 der Datei lib.c.

114 { return 256 * 4; }
int vid_get_palette_type ( )

Definiert in Zeile 113 der Datei lib.c.

113 { return 3; }
int vid_get_viewport_display_xoffset_proper ( )

Definiert in Zeile 112 der Datei lib.c.

112 { return vid_get_viewport_display_xoffset() * 2; }
void* vid_get_viewport_fb ( )

IMG viewport in 'rec' mode

Definiert in Zeile 57 der Datei lib.c.

57 { return (void*)0x4081ab80; } // Found @0xff4b7ba4
void* vid_get_viewport_fb_d ( )

IMG viewport in 'play' mode

Definiert in Zeile 59 der Datei lib.c.

60 {
61  extern char *viewport_fb_d;
62  return viewport_fb_d;
63 }
long vid_get_viewport_height ( )

Definiert in Zeile 95 der Datei lib.c.

96 {
97  if ((mode_get() & MODE_MASK) == MODE_PLAY)
98  {
99  return 240;
100  }
101  extern int _GetVRAMVPixelsSize();
102  return _GetVRAMVPixelsSize() >> 1;
103 
104 }
void* vid_get_viewport_live_fb ( )

Definiert in Zeile 65 der Datei lib.c.

66 {
67  extern char active_viewport_buffer;
68  extern void* viewport_buffers[];
69 
71  return viewport_buffers[0]; // Video only seems to use the first viewport buffer.
72 
73  // Hopefully return the most recently used viewport buffer so that motion detect, histogram, zebra and edge overly are using current image data
74  // -1 used for best MD response - TODO verify this
75  return viewport_buffers[(active_viewport_buffer-7)&7]; // -7 tested best with fudgey's HTML motion detector
76 }
int vid_get_viewport_width ( )

Definiert in Zeile 85 der Datei lib.c.

86 {
87  if ((mode_get() & MODE_MASK) == MODE_PLAY)
88  {
89  return 360;
90  }
91  extern int _GetVRAMHPixelsSize();
92  return _GetVRAMHPixelsSize() >> 1;
93 }
int vid_get_viewport_yscale ( )

Definiert in Zeile 81 der Datei lib.c.

81  {
82  return 2;
83 }

Variablen-Dokumentation

int active_palette_buffer
int active_raw_buffer
int** palette_buffer_ptr
char palette_control
char* raw_buffers[]