1 // Camera - A2300 - platform_camera.h 2 3 // This file contains the various settings values specific to the A2300 camera. 4 // This file is referenced via the 'include/camera.h' file and should not be loaded directly. 5 6 // If adding a new settings value put a suitable default in 'include/camera.h', 7 // along with documentation on what the setting does and how to determine the correct value. 8 // If the setting should not have a default value then add it in 'include/camera.h' 9 // using the '#undef' directive along with appropriate documentation. 10 11 // Override any default values with your camera specific values in this file. Try and avoid 12 // having override values that are the same as the default value. 13 14 // When overriding a setting value there are two cases: 15 // 1. If removing the value, because it does not apply to your camera, use the '#undef' directive. 16 // 2. If changing the value it is best to use an '#undef' directive to remove the default value 17 // followed by a '#define' to set the new value. 18 19 // When porting CHDK to a new camera, check the documentation in 'include/camera.h' 20 // for information on each setting. If the default values are correct for your camera then 21 // don't override them again in here. 22 23 #define CAM_DRYOS 1 24 #define CAM_PROPSET 5 25 26 #define CAM_DRYOS_2_3_R39 1 // Defined for cameras with DryOS version R39 or higher 27 #define CAM_DRYOS_2_3_R47 1 // Defined for cameras with DryOS version R47 or higher 28 29 #define CAM_RAW_ROWPIX 4704 // Found @0xff92e1c4 a2300 30 #define CAM_RAW_ROWS 3504 // Found @0xff92e1d0 a2300 31 32 #undef CAM_UNCACHED_BIT 33 #define CAM_UNCACHED_BIT 0x40000000 // Found @0xff834324 a2300 34 35 #define CAM_JPEG_WIDTH 4608 36 #define CAM_JPEG_HEIGHT 3456 37 #define CAM_ACTIVE_AREA_X1 16 //Not verified 38 #define CAM_ACTIVE_AREA_Y1 26 //Not verified 39 #define CAM_ACTIVE_AREA_X2 4640 //Not verified 40 #define CAM_ACTIVE_AREA_Y2 3486 //Not verified 41 42 #define CAM_DNG_LENS_INFO { 50,10, 250,10, 28,10, 69,10 } // See comments in camera.h a2300is 43 44 #undef CAM_SENSOR_BITS_PER_PIXEL 45 #define CAM_SENSOR_BITS_PER_PIXEL 12 46 47 #define cam_CFAPattern 0x01000201 // [Green Blue Red Green] 48 49 #define CAM_COLORMATRIX1 \ 50 827547, 1000000, -290458, 1000000, -126086, 1000000, \ 51 -12829, 1000000, 530507, 1000000, 50537, 1000000, \ 52 5181, 1000000, 48183, 1000000, 245014, 1000000 53 54 #define cam_CalibrationIlluminant1 1 // Daylight 55 56 #define CAM_ZEBRA_NOBUF 1 57 58 #define PARAM_CAMERA_NAME 4 // parameter number for GetParameterData 59 60 #define CAM_HAS_ND_FILTER 1 61 62 #define CAM_HAS_VIDEO_BUTTON 1 63 #undef CAM_VIDEO_CONTROL 64 #define CAM_VIDEO_QUALITY_ONLY 1 65 66 #define CAM_DATE_FOLDER_NAMING 0x400 67 68 #define CAM_DRIVE_MODE_FROM_TIMER_MODE 1 69 70 #undef CAM_HAS_IRIS_DIAPHRAGM 71 72 #undef CAM_HAS_ERASE_BUTTON 73 74 #undef CAM_HAS_IS // Camera does not have an image stabilizer 75 76 #undef CAM_HAS_MANUAL_FOCUS 77 78 #define CAM_LOAD_CUSTOM_COLORS 1 // Enable loading CHDK colors into the camera palette memory/hardware 79 80 #undef CAM_USES_ASPECT_CORRECTION 81 #define CAM_USES_ASPECT_CORRECTION 1 82 #undef CAM_BITMAP_WIDTH 83 #define CAM_BITMAP_WIDTH 720 // Actual width of bitmap screen in bytes 84 85 #define CAM_ADJUSTABLE_ALT_BUTTON 1 // ALT-button can be set from menu 86 #define CAM_ALT_BUTTON_NAMES { "Playback", "Help" } 87 #define CAM_ALT_BUTTON_OPTIONS { KEY_PRINT, KEY_HELP } 88 #undef CAM_HAS_DISP_BUTTON 89 90 #define CAM_HAS_FILEWRITETASK_HOOK 1 91 #define CAM_FILEWRITETASK_SEEKS 1 92 93 #define CAM_NEED_SET_ZOOM_DELAY 300 // Define to add a delay after setting the zoom position 94 #define CAM_USE_OPTICAL_MAX_ZOOM_STATUS 1 // Use ZOOM_OPTICAL_MAX to reset zoom_status when switching from digital to optical zoom 95 96 #define CAM_QUALITY_OVERRIDE 1 97 98 #undef CAM_USB_EVENTID 99 #define CAM_USB_EVENTID 0x202 // Levent ID for USB control. Changed in DryOS R49, R50 so needs to be overridable. 100 #define CAM_MISSING_RAND 1 // srand()/rand() functions not found in firmware. If defined, CHDK use functions implemented in C 101 #define MKDIR_RETURN_ONE_ON_SUCCESS 1 // mkdir() return 1 on success, 0 on fail. 102 103 // #define REMOTE_SYNC_STATUS_LED 0xC0223030 // TODO specifies an LED that turns on while camera waits for USB remote to sync 104 105 #define CAM_SD_OVER_IN_AF 1 106 #define CAM_SD_OVER_IN_MF 1 107 108 //--------------------------------------------------