Accel
Dependencies: mbed PowerControl SDFileSystem
Fork of HeptaAccel by
hepta_sat/HeptaCamera.cpp@0:d721efd58e4e, 2016-12-09 (annotated)
- Committer:
- tomoya123
- Date:
- Fri Dec 09 03:40:15 2016 +0000
- Revision:
- 0:d721efd58e4e
test
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
tomoya123 | 0:d721efd58e4e | 1 | #include "HeptaCamera.h" |
tomoya123 | 0:d721efd58e4e | 2 | #include "mbed.h" |
tomoya123 | 0:d721efd58e4e | 3 | |
tomoya123 | 0:d721efd58e4e | 4 | int sizex = 0; |
tomoya123 | 0:d721efd58e4e | 5 | int sizey = 0; |
tomoya123 | 0:d721efd58e4e | 6 | |
tomoya123 | 0:d721efd58e4e | 7 | #if defined(BITMAPFILE) || defined(BAYERBITMAPFILE) |
tomoya123 | 0:d721efd58e4e | 8 | |
tomoya123 | 0:d721efd58e4e | 9 | #define FILEHEADERSIZE 14 //ファイルヘッダのサイズ |
tomoya123 | 0:d721efd58e4e | 10 | #define INFOHEADERSIZE 40 //情報ヘッダのサイズ |
tomoya123 | 0:d721efd58e4e | 11 | #define HEADERSIZE (FILEHEADERSIZE+INFOHEADERSIZE) |
tomoya123 | 0:d721efd58e4e | 12 | |
tomoya123 | 0:d721efd58e4e | 13 | int create_header(FILE *fp, int width, int height) { |
tomoya123 | 0:d721efd58e4e | 14 | int real_width; |
tomoya123 | 0:d721efd58e4e | 15 | unsigned char header_buf[HEADERSIZE]; //ヘッダを格納する |
tomoya123 | 0:d721efd58e4e | 16 | unsigned int file_size; |
tomoya123 | 0:d721efd58e4e | 17 | unsigned int offset_to_data; |
tomoya123 | 0:d721efd58e4e | 18 | unsigned long info_header_size; |
tomoya123 | 0:d721efd58e4e | 19 | unsigned int planes; |
tomoya123 | 0:d721efd58e4e | 20 | unsigned int color; |
tomoya123 | 0:d721efd58e4e | 21 | unsigned long compress; |
tomoya123 | 0:d721efd58e4e | 22 | unsigned long data_size; |
tomoya123 | 0:d721efd58e4e | 23 | long xppm; |
tomoya123 | 0:d721efd58e4e | 24 | long yppm; |
tomoya123 | 0:d721efd58e4e | 25 | |
tomoya123 | 0:d721efd58e4e | 26 | real_width = width*3 + width%4; |
tomoya123 | 0:d721efd58e4e | 27 | |
tomoya123 | 0:d721efd58e4e | 28 | //ここからヘッダ作成 |
tomoya123 | 0:d721efd58e4e | 29 | file_size = height * real_width + HEADERSIZE; |
tomoya123 | 0:d721efd58e4e | 30 | offset_to_data = HEADERSIZE; |
tomoya123 | 0:d721efd58e4e | 31 | info_header_size = INFOHEADERSIZE; |
tomoya123 | 0:d721efd58e4e | 32 | planes = 1; |
tomoya123 | 0:d721efd58e4e | 33 | color = 24; |
tomoya123 | 0:d721efd58e4e | 34 | compress = 0; |
tomoya123 | 0:d721efd58e4e | 35 | data_size = height * real_width; |
tomoya123 | 0:d721efd58e4e | 36 | xppm = 1; |
tomoya123 | 0:d721efd58e4e | 37 | yppm = 1; |
tomoya123 | 0:d721efd58e4e | 38 | |
tomoya123 | 0:d721efd58e4e | 39 | header_buf[0] = 'B'; |
tomoya123 | 0:d721efd58e4e | 40 | header_buf[1] = 'M'; |
tomoya123 | 0:d721efd58e4e | 41 | memcpy(header_buf + 2, &file_size, sizeof(file_size)); |
tomoya123 | 0:d721efd58e4e | 42 | header_buf[6] = 0; |
tomoya123 | 0:d721efd58e4e | 43 | header_buf[7] = 0; |
tomoya123 | 0:d721efd58e4e | 44 | header_buf[8] = 0; |
tomoya123 | 0:d721efd58e4e | 45 | header_buf[9] = 0; |
tomoya123 | 0:d721efd58e4e | 46 | memcpy(header_buf + 10, &offset_to_data, sizeof(offset_to_data)); |
tomoya123 | 0:d721efd58e4e | 47 | memcpy(header_buf + 14, &info_header_size, sizeof(info_header_size)); |
tomoya123 | 0:d721efd58e4e | 48 | memcpy(header_buf + 18, &width, sizeof(width)); |
tomoya123 | 0:d721efd58e4e | 49 | height = height * -1; // データ格納順が逆なので、高さをマイナスとしている |
tomoya123 | 0:d721efd58e4e | 50 | memcpy(header_buf + 22, &height, sizeof(height)); |
tomoya123 | 0:d721efd58e4e | 51 | memcpy(header_buf + 26, &planes, sizeof(planes)); |
tomoya123 | 0:d721efd58e4e | 52 | memcpy(header_buf + 28, &color, sizeof(color)); |
tomoya123 | 0:d721efd58e4e | 53 | memcpy(header_buf + 30, &compress, sizeof(compress)); |
tomoya123 | 0:d721efd58e4e | 54 | memcpy(header_buf + 34, &data_size, sizeof(data_size)); |
tomoya123 | 0:d721efd58e4e | 55 | memcpy(header_buf + 38, &xppm, sizeof(xppm)); |
tomoya123 | 0:d721efd58e4e | 56 | memcpy(header_buf + 42, &yppm, sizeof(yppm)); |
tomoya123 | 0:d721efd58e4e | 57 | header_buf[46] = 0; |
tomoya123 | 0:d721efd58e4e | 58 | header_buf[47] = 0; |
tomoya123 | 0:d721efd58e4e | 59 | header_buf[48] = 0; |
tomoya123 | 0:d721efd58e4e | 60 | header_buf[49] = 0; |
tomoya123 | 0:d721efd58e4e | 61 | header_buf[50] = 0; |
tomoya123 | 0:d721efd58e4e | 62 | header_buf[51] = 0; |
tomoya123 | 0:d721efd58e4e | 63 | header_buf[52] = 0; |
tomoya123 | 0:d721efd58e4e | 64 | header_buf[53] = 0; |
tomoya123 | 0:d721efd58e4e | 65 | |
tomoya123 | 0:d721efd58e4e | 66 | //ヘッダの書き込み |
tomoya123 | 0:d721efd58e4e | 67 | fwrite(header_buf, sizeof(unsigned char), HEADERSIZE, fp); |
tomoya123 | 0:d721efd58e4e | 68 | |
tomoya123 | 0:d721efd58e4e | 69 | return 0; |
tomoya123 | 0:d721efd58e4e | 70 | } |
tomoya123 | 0:d721efd58e4e | 71 | #endif |
tomoya123 | 0:d721efd58e4e | 72 | |
tomoya123 | 0:d721efd58e4e | 73 | HeptaCamera::HeptaCamera(PinName sda, PinName scl, PinName vs, PinName hr,PinName we, PinName d7, PinName d6, PinName d5, PinName d4, |
tomoya123 | 0:d721efd58e4e | 74 | PinName d3, PinName d2, PinName d1, PinName d0, PinName rt, PinName o, PinName rc ) : camera(sda,scl),vsync(vs),href(hr),wen(we),data(d0,d1,d2,d3,d4,d5,d6,d7),rrst(rt),oe(o),rclk(rc) |
tomoya123 | 0:d721efd58e4e | 75 | { |
tomoya123 | 0:d721efd58e4e | 76 | camera.stop(); |
tomoya123 | 0:d721efd58e4e | 77 | camera.frequency(OV7670_I2CFREQ); |
tomoya123 | 0:d721efd58e4e | 78 | vsync.fall(this,&HeptaCamera::VsyncHandler); |
tomoya123 | 0:d721efd58e4e | 79 | href.rise(this,&HeptaCamera::HrefHandler); |
tomoya123 | 0:d721efd58e4e | 80 | CaptureReq = false; |
tomoya123 | 0:d721efd58e4e | 81 | Busy = false; |
tomoya123 | 0:d721efd58e4e | 82 | Done = false; |
tomoya123 | 0:d721efd58e4e | 83 | LineCounter = 0; |
tomoya123 | 0:d721efd58e4e | 84 | rrst = 1; |
tomoya123 | 0:d721efd58e4e | 85 | oe = 1; |
tomoya123 | 0:d721efd58e4e | 86 | rclk = 1; |
tomoya123 | 0:d721efd58e4e | 87 | wen = 0; |
tomoya123 | 0:d721efd58e4e | 88 | } |
tomoya123 | 0:d721efd58e4e | 89 | // capture request |
tomoya123 | 0:d721efd58e4e | 90 | void HeptaCamera::CaptureNext(void) |
tomoya123 | 0:d721efd58e4e | 91 | { |
tomoya123 | 0:d721efd58e4e | 92 | CaptureReq = true; |
tomoya123 | 0:d721efd58e4e | 93 | Busy = true; |
tomoya123 | 0:d721efd58e4e | 94 | } |
tomoya123 | 0:d721efd58e4e | 95 | |
tomoya123 | 0:d721efd58e4e | 96 | // capture done? (with clear) |
tomoya123 | 0:d721efd58e4e | 97 | bool HeptaCamera::CaptureDone(void) |
tomoya123 | 0:d721efd58e4e | 98 | { |
tomoya123 | 0:d721efd58e4e | 99 | bool result; |
tomoya123 | 0:d721efd58e4e | 100 | if (Busy) { |
tomoya123 | 0:d721efd58e4e | 101 | result = false; |
tomoya123 | 0:d721efd58e4e | 102 | } else { |
tomoya123 | 0:d721efd58e4e | 103 | result = Done; |
tomoya123 | 0:d721efd58e4e | 104 | Done = false; |
tomoya123 | 0:d721efd58e4e | 105 | } |
tomoya123 | 0:d721efd58e4e | 106 | return result; |
tomoya123 | 0:d721efd58e4e | 107 | } |
tomoya123 | 0:d721efd58e4e | 108 | |
tomoya123 | 0:d721efd58e4e | 109 | // write to camera |
tomoya123 | 0:d721efd58e4e | 110 | void HeptaCamera::WriteReg(int addr,int data) |
tomoya123 | 0:d721efd58e4e | 111 | { |
tomoya123 | 0:d721efd58e4e | 112 | // WRITE 0x42,ADDR,DATA |
tomoya123 | 0:d721efd58e4e | 113 | camera.start(); |
tomoya123 | 0:d721efd58e4e | 114 | camera.write(OV7670_WRITE); |
tomoya123 | 0:d721efd58e4e | 115 | wait_us(OV7670_WRITEWAIT); |
tomoya123 | 0:d721efd58e4e | 116 | camera.write(addr); |
tomoya123 | 0:d721efd58e4e | 117 | wait_us(OV7670_WRITEWAIT); |
tomoya123 | 0:d721efd58e4e | 118 | camera.write(data); |
tomoya123 | 0:d721efd58e4e | 119 | camera.stop(); |
tomoya123 | 0:d721efd58e4e | 120 | } |
tomoya123 | 0:d721efd58e4e | 121 | |
tomoya123 | 0:d721efd58e4e | 122 | // read from camera |
tomoya123 | 0:d721efd58e4e | 123 | int HeptaCamera::ReadReg(int addr) |
tomoya123 | 0:d721efd58e4e | 124 | { |
tomoya123 | 0:d721efd58e4e | 125 | int data; |
tomoya123 | 0:d721efd58e4e | 126 | |
tomoya123 | 0:d721efd58e4e | 127 | // WRITE 0x42,ADDR |
tomoya123 | 0:d721efd58e4e | 128 | camera.start(); |
tomoya123 | 0:d721efd58e4e | 129 | camera.write(OV7670_WRITE); |
tomoya123 | 0:d721efd58e4e | 130 | wait_us(OV7670_WRITEWAIT); |
tomoya123 | 0:d721efd58e4e | 131 | camera.write(addr); |
tomoya123 | 0:d721efd58e4e | 132 | camera.stop(); |
tomoya123 | 0:d721efd58e4e | 133 | wait_us(OV7670_WRITEWAIT); |
tomoya123 | 0:d721efd58e4e | 134 | |
tomoya123 | 0:d721efd58e4e | 135 | // WRITE 0x43,READ |
tomoya123 | 0:d721efd58e4e | 136 | camera.start(); |
tomoya123 | 0:d721efd58e4e | 137 | camera.write(OV7670_READ); |
tomoya123 | 0:d721efd58e4e | 138 | wait_us(OV7670_WRITEWAIT); |
tomoya123 | 0:d721efd58e4e | 139 | data = camera.read(OV7670_NOACK); |
tomoya123 | 0:d721efd58e4e | 140 | camera.stop(); |
tomoya123 | 0:d721efd58e4e | 141 | |
tomoya123 | 0:d721efd58e4e | 142 | return data; |
tomoya123 | 0:d721efd58e4e | 143 | } |
tomoya123 | 0:d721efd58e4e | 144 | |
tomoya123 | 0:d721efd58e4e | 145 | // print register |
tomoya123 | 0:d721efd58e4e | 146 | void HeptaCamera::PrintRegister(void) { |
tomoya123 | 0:d721efd58e4e | 147 | printf("AD : +0 +1 +2 +3 +4 +5 +6 +7 +8 +9 +A +B +C +D +E +F"); |
tomoya123 | 0:d721efd58e4e | 148 | for (int i=0;i<OV7670_REGMAX;i++) { |
tomoya123 | 0:d721efd58e4e | 149 | int data; |
tomoya123 | 0:d721efd58e4e | 150 | data = ReadReg(i); // READ REG |
tomoya123 | 0:d721efd58e4e | 151 | if ((i & 0x0F) == 0) { |
tomoya123 | 0:d721efd58e4e | 152 | printf("\r\n%02X : ",i); |
tomoya123 | 0:d721efd58e4e | 153 | } |
tomoya123 | 0:d721efd58e4e | 154 | printf("%02X ",data); |
tomoya123 | 0:d721efd58e4e | 155 | } |
tomoya123 | 0:d721efd58e4e | 156 | printf("\r\n"); |
tomoya123 | 0:d721efd58e4e | 157 | } |
tomoya123 | 0:d721efd58e4e | 158 | |
tomoya123 | 0:d721efd58e4e | 159 | void HeptaCamera::Reset(void) { |
tomoya123 | 0:d721efd58e4e | 160 | WriteReg(REG_COM7,COM7_RESET); // RESET CAMERA |
tomoya123 | 0:d721efd58e4e | 161 | wait_ms(200); |
tomoya123 | 0:d721efd58e4e | 162 | } |
tomoya123 | 0:d721efd58e4e | 163 | |
tomoya123 | 0:d721efd58e4e | 164 | void HeptaCamera::InitForFIFOWriteReset(void) { |
tomoya123 | 0:d721efd58e4e | 165 | WriteReg(REG_COM10, COM10_VS_NEG); |
tomoya123 | 0:d721efd58e4e | 166 | } |
tomoya123 | 0:d721efd58e4e | 167 | |
tomoya123 | 0:d721efd58e4e | 168 | void HeptaCamera::InitSetColorbar(void) { |
tomoya123 | 0:d721efd58e4e | 169 | int reg_com7 = ReadReg(REG_COM7); |
tomoya123 | 0:d721efd58e4e | 170 | // color bar |
tomoya123 | 0:d721efd58e4e | 171 | WriteReg(REG_COM17, reg_com7|COM17_CBAR); |
tomoya123 | 0:d721efd58e4e | 172 | } |
tomoya123 | 0:d721efd58e4e | 173 | |
tomoya123 | 0:d721efd58e4e | 174 | void HeptaCamera::InitDefaultReg(void) { |
tomoya123 | 0:d721efd58e4e | 175 | // Gamma curve values |
tomoya123 | 0:d721efd58e4e | 176 | WriteReg(0x7a, 0x20); |
tomoya123 | 0:d721efd58e4e | 177 | WriteReg(0x7b, 0x10); |
tomoya123 | 0:d721efd58e4e | 178 | WriteReg(0x7c, 0x1e); |
tomoya123 | 0:d721efd58e4e | 179 | WriteReg(0x7d, 0x35); |
tomoya123 | 0:d721efd58e4e | 180 | WriteReg(0x7e, 0x5a); |
tomoya123 | 0:d721efd58e4e | 181 | WriteReg(0x7f, 0x69); |
tomoya123 | 0:d721efd58e4e | 182 | WriteReg(0x80, 0x76); |
tomoya123 | 0:d721efd58e4e | 183 | WriteReg(0x81, 0x80); |
tomoya123 | 0:d721efd58e4e | 184 | WriteReg(0x82, 0x88); |
tomoya123 | 0:d721efd58e4e | 185 | WriteReg(0x83, 0x8f); |
tomoya123 | 0:d721efd58e4e | 186 | WriteReg(0x84, 0x96); |
tomoya123 | 0:d721efd58e4e | 187 | WriteReg(0x85, 0xa3); |
tomoya123 | 0:d721efd58e4e | 188 | WriteReg(0x86, 0xaf); |
tomoya123 | 0:d721efd58e4e | 189 | WriteReg(0x87, 0xc4); |
tomoya123 | 0:d721efd58e4e | 190 | WriteReg(0x88, 0xd7); |
tomoya123 | 0:d721efd58e4e | 191 | WriteReg(0x89, 0xe8); |
tomoya123 | 0:d721efd58e4e | 192 | |
tomoya123 | 0:d721efd58e4e | 193 | // AGC and AEC parameters. Note we start by disabling those features, |
tomoya123 | 0:d721efd58e4e | 194 | //then turn them only after tweaking the values. |
tomoya123 | 0:d721efd58e4e | 195 | WriteReg(REG_COM8, COM8_FASTAEC | COM8_AECSTEP | COM8_BFILT); |
tomoya123 | 0:d721efd58e4e | 196 | WriteReg(REG_GAIN, 0); |
tomoya123 | 0:d721efd58e4e | 197 | WriteReg(REG_AECH, 0); |
tomoya123 | 0:d721efd58e4e | 198 | WriteReg(REG_COM4, 0x40); |
tomoya123 | 0:d721efd58e4e | 199 | // magic reserved bit |
tomoya123 | 0:d721efd58e4e | 200 | WriteReg(REG_COM9, 0x18); |
tomoya123 | 0:d721efd58e4e | 201 | // 4x gain + magic rsvd bit |
tomoya123 | 0:d721efd58e4e | 202 | WriteReg(REG_BD50MAX, 0x05); |
tomoya123 | 0:d721efd58e4e | 203 | WriteReg(REG_BD60MAX, 0x07); |
tomoya123 | 0:d721efd58e4e | 204 | WriteReg(REG_AEW, 0x95); |
tomoya123 | 0:d721efd58e4e | 205 | WriteReg(REG_AEB, 0x33); |
tomoya123 | 0:d721efd58e4e | 206 | WriteReg(REG_VPT, 0xe3); |
tomoya123 | 0:d721efd58e4e | 207 | WriteReg(REG_HAECC1, 0x78); |
tomoya123 | 0:d721efd58e4e | 208 | WriteReg(REG_HAECC2, 0x68); |
tomoya123 | 0:d721efd58e4e | 209 | WriteReg(0xa1, 0x03); |
tomoya123 | 0:d721efd58e4e | 210 | // magic |
tomoya123 | 0:d721efd58e4e | 211 | WriteReg(REG_HAECC3, 0xd8); |
tomoya123 | 0:d721efd58e4e | 212 | WriteReg(REG_HAECC4, 0xd8); |
tomoya123 | 0:d721efd58e4e | 213 | WriteReg(REG_HAECC5, 0xf0); |
tomoya123 | 0:d721efd58e4e | 214 | WriteReg(REG_HAECC6, 0x90); |
tomoya123 | 0:d721efd58e4e | 215 | WriteReg(REG_HAECC7, 0x94); |
tomoya123 | 0:d721efd58e4e | 216 | WriteReg(REG_COM8, COM8_FASTAEC|COM8_AECSTEP|COM8_BFILT|COM8_AGC|COM8_AEC); |
tomoya123 | 0:d721efd58e4e | 217 | |
tomoya123 | 0:d721efd58e4e | 218 | // Almost all of these are magic "reserved" values. |
tomoya123 | 0:d721efd58e4e | 219 | WriteReg(REG_COM5, 0x61); |
tomoya123 | 0:d721efd58e4e | 220 | WriteReg(REG_COM6, 0x4b); |
tomoya123 | 0:d721efd58e4e | 221 | WriteReg(0x16, 0x02); |
tomoya123 | 0:d721efd58e4e | 222 | WriteReg(REG_MVFP, 0x07); |
tomoya123 | 0:d721efd58e4e | 223 | WriteReg(0x21, 0x02); |
tomoya123 | 0:d721efd58e4e | 224 | WriteReg(0x22, 0x91); |
tomoya123 | 0:d721efd58e4e | 225 | WriteReg(0x29, 0x07); |
tomoya123 | 0:d721efd58e4e | 226 | WriteReg(0x33, 0x0b); |
tomoya123 | 0:d721efd58e4e | 227 | WriteReg(0x35, 0x0b); |
tomoya123 | 0:d721efd58e4e | 228 | WriteReg(0x37, 0x1d); |
tomoya123 | 0:d721efd58e4e | 229 | WriteReg(0x38, 0x71); |
tomoya123 | 0:d721efd58e4e | 230 | WriteReg(0x39, 0x2a); |
tomoya123 | 0:d721efd58e4e | 231 | WriteReg(REG_COM12, 0x78); |
tomoya123 | 0:d721efd58e4e | 232 | WriteReg(0x4d, 0x40); |
tomoya123 | 0:d721efd58e4e | 233 | WriteReg(0x4e, 0x20); |
tomoya123 | 0:d721efd58e4e | 234 | WriteReg(REG_GFIX, 0); |
tomoya123 | 0:d721efd58e4e | 235 | WriteReg(0x6b, 0x0a); |
tomoya123 | 0:d721efd58e4e | 236 | WriteReg(0x74, 0x10); |
tomoya123 | 0:d721efd58e4e | 237 | WriteReg(0x8d, 0x4f); |
tomoya123 | 0:d721efd58e4e | 238 | WriteReg(0x8e, 0); |
tomoya123 | 0:d721efd58e4e | 239 | WriteReg(0x8f, 0); |
tomoya123 | 0:d721efd58e4e | 240 | WriteReg(0x90, 0); |
tomoya123 | 0:d721efd58e4e | 241 | WriteReg(0x91, 0); |
tomoya123 | 0:d721efd58e4e | 242 | WriteReg(0x96, 0); |
tomoya123 | 0:d721efd58e4e | 243 | WriteReg(0x9a, 0); |
tomoya123 | 0:d721efd58e4e | 244 | WriteReg(0xb0, 0x84); |
tomoya123 | 0:d721efd58e4e | 245 | WriteReg(0xb1, 0x0c); |
tomoya123 | 0:d721efd58e4e | 246 | WriteReg(0xb2, 0x0e); |
tomoya123 | 0:d721efd58e4e | 247 | WriteReg(0xb3, 0x82); |
tomoya123 | 0:d721efd58e4e | 248 | WriteReg(0xb8, 0x0a); |
tomoya123 | 0:d721efd58e4e | 249 | |
tomoya123 | 0:d721efd58e4e | 250 | // More reserved magic, some of which tweaks white balance |
tomoya123 | 0:d721efd58e4e | 251 | WriteReg(0x43, 0x0a); |
tomoya123 | 0:d721efd58e4e | 252 | WriteReg(0x44, 0xf0); |
tomoya123 | 0:d721efd58e4e | 253 | WriteReg(0x45, 0x34); |
tomoya123 | 0:d721efd58e4e | 254 | WriteReg(0x46, 0x58); |
tomoya123 | 0:d721efd58e4e | 255 | WriteReg(0x47, 0x28); |
tomoya123 | 0:d721efd58e4e | 256 | WriteReg(0x48, 0x3a); |
tomoya123 | 0:d721efd58e4e | 257 | WriteReg(0x59, 0x88); |
tomoya123 | 0:d721efd58e4e | 258 | WriteReg(0x5a, 0x88); |
tomoya123 | 0:d721efd58e4e | 259 | WriteReg(0x5b, 0x44); |
tomoya123 | 0:d721efd58e4e | 260 | WriteReg(0x5c, 0x67); |
tomoya123 | 0:d721efd58e4e | 261 | WriteReg(0x5d, 0x49); |
tomoya123 | 0:d721efd58e4e | 262 | WriteReg(0x5e, 0x0e); |
tomoya123 | 0:d721efd58e4e | 263 | WriteReg(0x6c, 0x0a); |
tomoya123 | 0:d721efd58e4e | 264 | WriteReg(0x6d, 0x55); |
tomoya123 | 0:d721efd58e4e | 265 | WriteReg(0x6e, 0x11); |
tomoya123 | 0:d721efd58e4e | 266 | WriteReg(0x6f, 0x9f); |
tomoya123 | 0:d721efd58e4e | 267 | // "9e for advance AWB" |
tomoya123 | 0:d721efd58e4e | 268 | WriteReg(0x6a, 0x40); |
tomoya123 | 0:d721efd58e4e | 269 | WriteReg(REG_BLUE, 0x40); |
tomoya123 | 0:d721efd58e4e | 270 | WriteReg(REG_RED, 0x60); |
tomoya123 | 0:d721efd58e4e | 271 | WriteReg(REG_COM8, COM8_FASTAEC|COM8_AECSTEP|COM8_BFILT|COM8_AGC|COM8_AEC|COM8_AWB); |
tomoya123 | 0:d721efd58e4e | 272 | |
tomoya123 | 0:d721efd58e4e | 273 | // Matrix coefficients |
tomoya123 | 0:d721efd58e4e | 274 | WriteReg(0x4f, 0x80); |
tomoya123 | 0:d721efd58e4e | 275 | WriteReg(0x50, 0x80); |
tomoya123 | 0:d721efd58e4e | 276 | WriteReg(0x51, 0); |
tomoya123 | 0:d721efd58e4e | 277 | WriteReg(0x52, 0x22); |
tomoya123 | 0:d721efd58e4e | 278 | WriteReg(0x53, 0x5e); |
tomoya123 | 0:d721efd58e4e | 279 | WriteReg(0x54, 0x80); |
tomoya123 | 0:d721efd58e4e | 280 | WriteReg(0x58, 0x9e); |
tomoya123 | 0:d721efd58e4e | 281 | |
tomoya123 | 0:d721efd58e4e | 282 | WriteReg(REG_COM16, COM16_AWBGAIN); |
tomoya123 | 0:d721efd58e4e | 283 | WriteReg(REG_EDGE, 0); |
tomoya123 | 0:d721efd58e4e | 284 | WriteReg(0x75, 0x05); |
tomoya123 | 0:d721efd58e4e | 285 | WriteReg(0x76, 0xe1); |
tomoya123 | 0:d721efd58e4e | 286 | WriteReg(0x4c, 0); |
tomoya123 | 0:d721efd58e4e | 287 | WriteReg(0x77, 0x01); |
tomoya123 | 0:d721efd58e4e | 288 | WriteReg(0x4b, 0x09); |
tomoya123 | 0:d721efd58e4e | 289 | WriteReg(0xc9, 0x60); |
tomoya123 | 0:d721efd58e4e | 290 | WriteReg(REG_COM16, 0x38); |
tomoya123 | 0:d721efd58e4e | 291 | WriteReg(0x56, 0x40); |
tomoya123 | 0:d721efd58e4e | 292 | |
tomoya123 | 0:d721efd58e4e | 293 | WriteReg(0x34, 0x11); |
tomoya123 | 0:d721efd58e4e | 294 | WriteReg(REG_COM11, COM11_EXP|COM11_HZAUTO_ON); |
tomoya123 | 0:d721efd58e4e | 295 | WriteReg(0xa4, 0x88); |
tomoya123 | 0:d721efd58e4e | 296 | WriteReg(0x96, 0); |
tomoya123 | 0:d721efd58e4e | 297 | WriteReg(0x97, 0x30); |
tomoya123 | 0:d721efd58e4e | 298 | WriteReg(0x98, 0x20); |
tomoya123 | 0:d721efd58e4e | 299 | WriteReg(0x99, 0x30); |
tomoya123 | 0:d721efd58e4e | 300 | WriteReg(0x9a, 0x84); |
tomoya123 | 0:d721efd58e4e | 301 | WriteReg(0x9b, 0x29); |
tomoya123 | 0:d721efd58e4e | 302 | WriteReg(0x9c, 0x03); |
tomoya123 | 0:d721efd58e4e | 303 | WriteReg(0x9d, 0x4c); |
tomoya123 | 0:d721efd58e4e | 304 | WriteReg(0x9e, 0x3f); |
tomoya123 | 0:d721efd58e4e | 305 | WriteReg(0x78, 0x04); |
tomoya123 | 0:d721efd58e4e | 306 | |
tomoya123 | 0:d721efd58e4e | 307 | // Extra-weird stuff. Some sort of multiplexor register |
tomoya123 | 0:d721efd58e4e | 308 | WriteReg(0x79, 0x01); |
tomoya123 | 0:d721efd58e4e | 309 | WriteReg(0xc8, 0xf0); |
tomoya123 | 0:d721efd58e4e | 310 | WriteReg(0x79, 0x0f); |
tomoya123 | 0:d721efd58e4e | 311 | WriteReg(0xc8, 0x00); |
tomoya123 | 0:d721efd58e4e | 312 | WriteReg(0x79, 0x10); |
tomoya123 | 0:d721efd58e4e | 313 | WriteReg(0xc8, 0x7e); |
tomoya123 | 0:d721efd58e4e | 314 | WriteReg(0x79, 0x0a); |
tomoya123 | 0:d721efd58e4e | 315 | WriteReg(0xc8, 0x80); |
tomoya123 | 0:d721efd58e4e | 316 | WriteReg(0x79, 0x0b); |
tomoya123 | 0:d721efd58e4e | 317 | WriteReg(0xc8, 0x01); |
tomoya123 | 0:d721efd58e4e | 318 | WriteReg(0x79, 0x0c); |
tomoya123 | 0:d721efd58e4e | 319 | WriteReg(0xc8, 0x0f); |
tomoya123 | 0:d721efd58e4e | 320 | WriteReg(0x79, 0x0d); |
tomoya123 | 0:d721efd58e4e | 321 | WriteReg(0xc8, 0x20); |
tomoya123 | 0:d721efd58e4e | 322 | WriteReg(0x79, 0x09); |
tomoya123 | 0:d721efd58e4e | 323 | WriteReg(0xc8, 0x80); |
tomoya123 | 0:d721efd58e4e | 324 | WriteReg(0x79, 0x02); |
tomoya123 | 0:d721efd58e4e | 325 | WriteReg(0xc8, 0xc0); |
tomoya123 | 0:d721efd58e4e | 326 | WriteReg(0x79, 0x03); |
tomoya123 | 0:d721efd58e4e | 327 | WriteReg(0xc8, 0x40); |
tomoya123 | 0:d721efd58e4e | 328 | WriteReg(0x79, 0x05); |
tomoya123 | 0:d721efd58e4e | 329 | WriteReg(0xc8, 0x30); |
tomoya123 | 0:d721efd58e4e | 330 | WriteReg(0x79, 0x26); |
tomoya123 | 0:d721efd58e4e | 331 | } |
tomoya123 | 0:d721efd58e4e | 332 | |
tomoya123 | 0:d721efd58e4e | 333 | void HeptaCamera::InitRGB444(void){ |
tomoya123 | 0:d721efd58e4e | 334 | int reg_com7 = ReadReg(REG_COM7); |
tomoya123 | 0:d721efd58e4e | 335 | |
tomoya123 | 0:d721efd58e4e | 336 | WriteReg(REG_COM7, reg_com7|COM7_RGB); |
tomoya123 | 0:d721efd58e4e | 337 | WriteReg(REG_RGB444, RGB444_ENABLE|RGB444_XBGR); |
tomoya123 | 0:d721efd58e4e | 338 | WriteReg(REG_COM15, COM15_R01FE|COM15_RGB444); |
tomoya123 | 0:d721efd58e4e | 339 | |
tomoya123 | 0:d721efd58e4e | 340 | WriteReg(REG_COM1, 0x40); // Magic reserved bit |
tomoya123 | 0:d721efd58e4e | 341 | WriteReg(REG_COM9, 0x38); // 16x gain ceiling; 0x8 is reserved bit |
tomoya123 | 0:d721efd58e4e | 342 | WriteReg(0x4f, 0xb3); // "matrix coefficient 1" |
tomoya123 | 0:d721efd58e4e | 343 | WriteReg(0x50, 0xb3); // "matrix coefficient 2" |
tomoya123 | 0:d721efd58e4e | 344 | WriteReg(0x51, 0x00); // vb |
tomoya123 | 0:d721efd58e4e | 345 | WriteReg(0x52, 0x3d); // "matrix coefficient 4" |
tomoya123 | 0:d721efd58e4e | 346 | WriteReg(0x53, 0xa7); // "matrix coefficient 5" |
tomoya123 | 0:d721efd58e4e | 347 | WriteReg(0x54, 0xe4); // "matrix coefficient 6" |
tomoya123 | 0:d721efd58e4e | 348 | WriteReg(REG_COM13, COM13_GAMMA|COM13_UVSAT|0x2); // Magic rsvd bit |
tomoya123 | 0:d721efd58e4e | 349 | |
tomoya123 | 0:d721efd58e4e | 350 | WriteReg(REG_TSLB, 0x04); |
tomoya123 | 0:d721efd58e4e | 351 | } |
tomoya123 | 0:d721efd58e4e | 352 | |
tomoya123 | 0:d721efd58e4e | 353 | void HeptaCamera::InitRGB555(void){ |
tomoya123 | 0:d721efd58e4e | 354 | int reg_com7 = ReadReg(REG_COM7); |
tomoya123 | 0:d721efd58e4e | 355 | |
tomoya123 | 0:d721efd58e4e | 356 | WriteReg(REG_COM7, reg_com7|COM7_RGB); |
tomoya123 | 0:d721efd58e4e | 357 | WriteReg(REG_RGB444, RGB444_DISABLE); |
tomoya123 | 0:d721efd58e4e | 358 | WriteReg(REG_COM15, COM15_RGB555|COM15_R00FF); |
tomoya123 | 0:d721efd58e4e | 359 | |
tomoya123 | 0:d721efd58e4e | 360 | WriteReg(REG_TSLB, 0x04); |
tomoya123 | 0:d721efd58e4e | 361 | |
tomoya123 | 0:d721efd58e4e | 362 | WriteReg(REG_COM1, 0x00); |
tomoya123 | 0:d721efd58e4e | 363 | WriteReg(REG_COM9, 0x38); // 16x gain ceiling; 0x8 is reserved bit |
tomoya123 | 0:d721efd58e4e | 364 | WriteReg(0x4f, 0xb3); // "matrix coefficient 1" |
tomoya123 | 0:d721efd58e4e | 365 | WriteReg(0x50, 0xb3); // "matrix coefficient 2" |
tomoya123 | 0:d721efd58e4e | 366 | WriteReg(0x51, 0x00); // vb |
tomoya123 | 0:d721efd58e4e | 367 | WriteReg(0x52, 0x3d); // "matrix coefficient 4" |
tomoya123 | 0:d721efd58e4e | 368 | WriteReg(0x53, 0xa7); // "matrix coefficient 5" |
tomoya123 | 0:d721efd58e4e | 369 | WriteReg(0x54, 0xe4); // "matrix coefficient 6" |
tomoya123 | 0:d721efd58e4e | 370 | WriteReg(REG_COM13, COM13_GAMMA|COM13_UVSAT); |
tomoya123 | 0:d721efd58e4e | 371 | } |
tomoya123 | 0:d721efd58e4e | 372 | |
tomoya123 | 0:d721efd58e4e | 373 | void HeptaCamera::InitRGB565(void){ |
tomoya123 | 0:d721efd58e4e | 374 | int reg_com7 = ReadReg(REG_COM7); |
tomoya123 | 0:d721efd58e4e | 375 | |
tomoya123 | 0:d721efd58e4e | 376 | WriteReg(REG_COM7, reg_com7|COM7_RGB); |
tomoya123 | 0:d721efd58e4e | 377 | WriteReg(REG_RGB444, RGB444_DISABLE); |
tomoya123 | 0:d721efd58e4e | 378 | WriteReg(REG_COM15, COM15_R00FF|COM15_RGB565); |
tomoya123 | 0:d721efd58e4e | 379 | |
tomoya123 | 0:d721efd58e4e | 380 | WriteReg(REG_TSLB, 0x04); |
tomoya123 | 0:d721efd58e4e | 381 | |
tomoya123 | 0:d721efd58e4e | 382 | WriteReg(REG_COM1, 0x00); |
tomoya123 | 0:d721efd58e4e | 383 | WriteReg(REG_COM9, 0x38); // 16x gain ceiling; 0x8 is reserved bit |
tomoya123 | 0:d721efd58e4e | 384 | WriteReg(0x4f, 0xb3); // "matrix coefficient 1" |
tomoya123 | 0:d721efd58e4e | 385 | WriteReg(0x50, 0xb3); // "matrix coefficient 2" |
tomoya123 | 0:d721efd58e4e | 386 | WriteReg(0x51, 0x00); // vb |
tomoya123 | 0:d721efd58e4e | 387 | WriteReg(0x52, 0x3d); // "matrix coefficient 4" |
tomoya123 | 0:d721efd58e4e | 388 | WriteReg(0x53, 0xa7); // "matrix coefficient 5" |
tomoya123 | 0:d721efd58e4e | 389 | WriteReg(0x54, 0xe4); // "matrix coefficient 6" |
tomoya123 | 0:d721efd58e4e | 390 | WriteReg(REG_COM13, COM13_GAMMA|COM13_UVSAT); |
tomoya123 | 0:d721efd58e4e | 391 | } |
tomoya123 | 0:d721efd58e4e | 392 | |
tomoya123 | 0:d721efd58e4e | 393 | void HeptaCamera::InitYUV(void){ |
tomoya123 | 0:d721efd58e4e | 394 | int reg_com7 = ReadReg(REG_COM7); |
tomoya123 | 0:d721efd58e4e | 395 | |
tomoya123 | 0:d721efd58e4e | 396 | WriteReg(REG_COM7, reg_com7|COM7_YUV); |
tomoya123 | 0:d721efd58e4e | 397 | WriteReg(REG_RGB444, RGB444_DISABLE); |
tomoya123 | 0:d721efd58e4e | 398 | WriteReg(REG_COM15, COM15_R00FF); |
tomoya123 | 0:d721efd58e4e | 399 | |
tomoya123 | 0:d721efd58e4e | 400 | WriteReg(REG_TSLB, 0x04); |
tomoya123 | 0:d721efd58e4e | 401 | // WriteReg(REG_TSLB, 0x14); |
tomoya123 | 0:d721efd58e4e | 402 | // WriteReg(REG_MANU, 0x00); |
tomoya123 | 0:d721efd58e4e | 403 | // WriteReg(REG_MANV, 0x00); |
tomoya123 | 0:d721efd58e4e | 404 | |
tomoya123 | 0:d721efd58e4e | 405 | WriteReg(REG_COM1, 0x00); |
tomoya123 | 0:d721efd58e4e | 406 | WriteReg(REG_COM9, 0x18); // 4x gain ceiling; 0x8 is reserved bit |
tomoya123 | 0:d721efd58e4e | 407 | WriteReg(0x4f, 0x80); // "matrix coefficient 1" |
tomoya123 | 0:d721efd58e4e | 408 | WriteReg(0x50, 0x80); // "matrix coefficient 2" |
tomoya123 | 0:d721efd58e4e | 409 | WriteReg(0x51, 0x00); // vb |
tomoya123 | 0:d721efd58e4e | 410 | WriteReg(0x52, 0x22); // "matrix coefficient 4" |
tomoya123 | 0:d721efd58e4e | 411 | WriteReg(0x53, 0x5e); // "matrix coefficient 5" |
tomoya123 | 0:d721efd58e4e | 412 | WriteReg(0x54, 0x80); // "matrix coefficient 6" |
tomoya123 | 0:d721efd58e4e | 413 | WriteReg(REG_COM13, COM13_GAMMA|COM13_UVSAT|COM13_UVSWAP); |
tomoya123 | 0:d721efd58e4e | 414 | } |
tomoya123 | 0:d721efd58e4e | 415 | |
tomoya123 | 0:d721efd58e4e | 416 | void HeptaCamera::InitBayerRGB(void){ |
tomoya123 | 0:d721efd58e4e | 417 | int reg_com7 = ReadReg(REG_COM7); |
tomoya123 | 0:d721efd58e4e | 418 | |
tomoya123 | 0:d721efd58e4e | 419 | // odd line BGBG... even line GRGR... |
tomoya123 | 0:d721efd58e4e | 420 | WriteReg(REG_COM7, reg_com7|COM7_BAYER); |
tomoya123 | 0:d721efd58e4e | 421 | // odd line GBGB... even line RGRG... |
tomoya123 | 0:d721efd58e4e | 422 | //WriteReg(REG_COM7, reg_com7|COM7_PBAYER); |
tomoya123 | 0:d721efd58e4e | 423 | |
tomoya123 | 0:d721efd58e4e | 424 | WriteReg(REG_RGB444, RGB444_DISABLE); |
tomoya123 | 0:d721efd58e4e | 425 | WriteReg(REG_COM15, COM15_R00FF); |
tomoya123 | 0:d721efd58e4e | 426 | |
tomoya123 | 0:d721efd58e4e | 427 | WriteReg(REG_COM13, 0x08); /* No gamma, magic rsvd bit */ |
tomoya123 | 0:d721efd58e4e | 428 | WriteReg(REG_COM16, 0x3d); /* Edge enhancement, denoise */ |
tomoya123 | 0:d721efd58e4e | 429 | WriteReg(REG_REG76, 0xe1); /* Pix correction, magic rsvd */ |
tomoya123 | 0:d721efd58e4e | 430 | |
tomoya123 | 0:d721efd58e4e | 431 | WriteReg(REG_TSLB, 0x04); |
tomoya123 | 0:d721efd58e4e | 432 | } |
tomoya123 | 0:d721efd58e4e | 433 | |
tomoya123 | 0:d721efd58e4e | 434 | void HeptaCamera::InitVGA(void) { |
tomoya123 | 0:d721efd58e4e | 435 | // VGA |
tomoya123 | 0:d721efd58e4e | 436 | int reg_com7 = ReadReg(REG_COM7); |
tomoya123 | 0:d721efd58e4e | 437 | |
tomoya123 | 0:d721efd58e4e | 438 | WriteReg(REG_COM7,reg_com7|COM7_VGA); |
tomoya123 | 0:d721efd58e4e | 439 | |
tomoya123 | 0:d721efd58e4e | 440 | WriteReg(REG_HSTART,HSTART_VGA); |
tomoya123 | 0:d721efd58e4e | 441 | WriteReg(REG_HSTOP,HSTOP_VGA); |
tomoya123 | 0:d721efd58e4e | 442 | WriteReg(REG_HREF,HREF_VGA); |
tomoya123 | 0:d721efd58e4e | 443 | WriteReg(REG_VSTART,VSTART_VGA); |
tomoya123 | 0:d721efd58e4e | 444 | WriteReg(REG_VSTOP,VSTOP_VGA); |
tomoya123 | 0:d721efd58e4e | 445 | WriteReg(REG_VREF,VREF_VGA); |
tomoya123 | 0:d721efd58e4e | 446 | WriteReg(REG_COM3, COM3_VGA); |
tomoya123 | 0:d721efd58e4e | 447 | WriteReg(REG_COM14, COM14_VGA); |
tomoya123 | 0:d721efd58e4e | 448 | WriteReg(REG_SCALING_XSC, SCALING_XSC_VGA); |
tomoya123 | 0:d721efd58e4e | 449 | WriteReg(REG_SCALING_YSC, SCALING_YSC_VGA); |
tomoya123 | 0:d721efd58e4e | 450 | WriteReg(REG_SCALING_DCWCTR, SCALING_DCWCTR_VGA); |
tomoya123 | 0:d721efd58e4e | 451 | WriteReg(REG_SCALING_PCLK_DIV, SCALING_PCLK_DIV_VGA); |
tomoya123 | 0:d721efd58e4e | 452 | WriteReg(REG_SCALING_PCLK_DELAY, SCALING_PCLK_DELAY_VGA); |
tomoya123 | 0:d721efd58e4e | 453 | } |
tomoya123 | 0:d721efd58e4e | 454 | |
tomoya123 | 0:d721efd58e4e | 455 | void HeptaCamera::InitFIFO_2bytes_color_nealy_limit_size(void) { |
tomoya123 | 0:d721efd58e4e | 456 | // nealy FIFO limit 544x360 |
tomoya123 | 0:d721efd58e4e | 457 | int reg_com7 = ReadReg(REG_COM7); |
tomoya123 | 0:d721efd58e4e | 458 | |
tomoya123 | 0:d721efd58e4e | 459 | WriteReg(REG_COM7,reg_com7|COM7_VGA); |
tomoya123 | 0:d721efd58e4e | 460 | |
tomoya123 | 0:d721efd58e4e | 461 | WriteReg(REG_HSTART,HSTART_VGA); |
tomoya123 | 0:d721efd58e4e | 462 | WriteReg(REG_HSTOP,HSTOP_VGA); |
tomoya123 | 0:d721efd58e4e | 463 | WriteReg(REG_HREF,HREF_VGA); |
tomoya123 | 0:d721efd58e4e | 464 | WriteReg(REG_VSTART,VSTART_VGA); |
tomoya123 | 0:d721efd58e4e | 465 | WriteReg(REG_VSTOP,VSTOP_VGA); |
tomoya123 | 0:d721efd58e4e | 466 | WriteReg(REG_VREF,VREF_VGA); |
tomoya123 | 0:d721efd58e4e | 467 | WriteReg(REG_COM3, COM3_VGA); |
tomoya123 | 0:d721efd58e4e | 468 | WriteReg(REG_COM14, COM14_VGA); |
tomoya123 | 0:d721efd58e4e | 469 | WriteReg(REG_SCALING_XSC, SCALING_XSC_VGA); |
tomoya123 | 0:d721efd58e4e | 470 | WriteReg(REG_SCALING_YSC, SCALING_YSC_VGA); |
tomoya123 | 0:d721efd58e4e | 471 | WriteReg(REG_SCALING_DCWCTR, SCALING_DCWCTR_VGA); |
tomoya123 | 0:d721efd58e4e | 472 | WriteReg(REG_SCALING_PCLK_DIV, SCALING_PCLK_DIV_VGA); |
tomoya123 | 0:d721efd58e4e | 473 | WriteReg(REG_SCALING_PCLK_DELAY, SCALING_PCLK_DELAY_VGA); |
tomoya123 | 0:d721efd58e4e | 474 | |
tomoya123 | 0:d721efd58e4e | 475 | WriteReg(REG_HSTART, 0x17); |
tomoya123 | 0:d721efd58e4e | 476 | WriteReg(REG_HSTOP, 0x5b); |
tomoya123 | 0:d721efd58e4e | 477 | WriteReg(REG_VSTART, 0x12); |
tomoya123 | 0:d721efd58e4e | 478 | WriteReg(REG_VSTOP, 0x6c); |
tomoya123 | 0:d721efd58e4e | 479 | } |
tomoya123 | 0:d721efd58e4e | 480 | |
tomoya123 | 0:d721efd58e4e | 481 | void HeptaCamera::InitVGA_3_4(void) { |
tomoya123 | 0:d721efd58e4e | 482 | // VGA 3/4 -> 480x360 |
tomoya123 | 0:d721efd58e4e | 483 | int reg_com7 = ReadReg(REG_COM7); |
tomoya123 | 0:d721efd58e4e | 484 | |
tomoya123 | 0:d721efd58e4e | 485 | WriteReg(REG_COM7,reg_com7|COM7_VGA); |
tomoya123 | 0:d721efd58e4e | 486 | |
tomoya123 | 0:d721efd58e4e | 487 | WriteReg(REG_HSTART,HSTART_VGA); |
tomoya123 | 0:d721efd58e4e | 488 | WriteReg(REG_HSTOP,HSTOP_VGA); |
tomoya123 | 0:d721efd58e4e | 489 | WriteReg(REG_HREF,HREF_VGA); |
tomoya123 | 0:d721efd58e4e | 490 | WriteReg(REG_VSTART,VSTART_VGA); |
tomoya123 | 0:d721efd58e4e | 491 | WriteReg(REG_VSTOP,VSTOP_VGA); |
tomoya123 | 0:d721efd58e4e | 492 | WriteReg(REG_VREF,VREF_VGA); |
tomoya123 | 0:d721efd58e4e | 493 | WriteReg(REG_COM3, COM3_VGA); |
tomoya123 | 0:d721efd58e4e | 494 | WriteReg(REG_COM14, COM14_VGA); |
tomoya123 | 0:d721efd58e4e | 495 | WriteReg(REG_SCALING_XSC, SCALING_XSC_VGA); |
tomoya123 | 0:d721efd58e4e | 496 | WriteReg(REG_SCALING_YSC, SCALING_YSC_VGA); |
tomoya123 | 0:d721efd58e4e | 497 | WriteReg(REG_SCALING_DCWCTR, SCALING_DCWCTR_VGA); |
tomoya123 | 0:d721efd58e4e | 498 | WriteReg(REG_SCALING_PCLK_DIV, SCALING_PCLK_DIV_VGA); |
tomoya123 | 0:d721efd58e4e | 499 | WriteReg(REG_SCALING_PCLK_DELAY, SCALING_PCLK_DELAY_VGA); |
tomoya123 | 0:d721efd58e4e | 500 | |
tomoya123 | 0:d721efd58e4e | 501 | WriteReg(REG_HSTART, 0x1b); |
tomoya123 | 0:d721efd58e4e | 502 | WriteReg(REG_HSTOP, 0x57); |
tomoya123 | 0:d721efd58e4e | 503 | WriteReg(REG_VSTART, 0x12); |
tomoya123 | 0:d721efd58e4e | 504 | WriteReg(REG_VSTOP, 0x6c); |
tomoya123 | 0:d721efd58e4e | 505 | } |
tomoya123 | 0:d721efd58e4e | 506 | |
tomoya123 | 0:d721efd58e4e | 507 | void HeptaCamera::InitQVGA(void) { |
tomoya123 | 0:d721efd58e4e | 508 | // QQVGA |
tomoya123 | 0:d721efd58e4e | 509 | int reg_com7 = ReadReg(REG_COM7); |
tomoya123 | 0:d721efd58e4e | 510 | |
tomoya123 | 0:d721efd58e4e | 511 | WriteReg(REG_COM7,reg_com7|COM7_QVGA); |
tomoya123 | 0:d721efd58e4e | 512 | |
tomoya123 | 0:d721efd58e4e | 513 | WriteReg(REG_HSTART,HSTART_QVGA); |
tomoya123 | 0:d721efd58e4e | 514 | WriteReg(REG_HSTOP,HSTOP_QVGA); |
tomoya123 | 0:d721efd58e4e | 515 | WriteReg(REG_HREF,HREF_QVGA); |
tomoya123 | 0:d721efd58e4e | 516 | WriteReg(REG_VSTART,VSTART_QVGA); |
tomoya123 | 0:d721efd58e4e | 517 | WriteReg(REG_VSTOP,VSTOP_QVGA); |
tomoya123 | 0:d721efd58e4e | 518 | WriteReg(REG_VREF,VREF_QVGA); |
tomoya123 | 0:d721efd58e4e | 519 | WriteReg(REG_COM3, COM3_QVGA); |
tomoya123 | 0:d721efd58e4e | 520 | WriteReg(REG_COM14, COM14_QVGA); |
tomoya123 | 0:d721efd58e4e | 521 | WriteReg(REG_SCALING_XSC, SCALING_XSC_QVGA); |
tomoya123 | 0:d721efd58e4e | 522 | WriteReg(REG_SCALING_YSC, SCALING_YSC_QVGA); |
tomoya123 | 0:d721efd58e4e | 523 | WriteReg(REG_SCALING_DCWCTR, SCALING_DCWCTR_QVGA); |
tomoya123 | 0:d721efd58e4e | 524 | WriteReg(REG_SCALING_PCLK_DIV, SCALING_PCLK_DIV_QVGA); |
tomoya123 | 0:d721efd58e4e | 525 | WriteReg(REG_SCALING_PCLK_DELAY, SCALING_PCLK_DELAY_QVGA); |
tomoya123 | 0:d721efd58e4e | 526 | } |
tomoya123 | 0:d721efd58e4e | 527 | |
tomoya123 | 0:d721efd58e4e | 528 | void HeptaCamera::InitQQVGA(void) { |
tomoya123 | 0:d721efd58e4e | 529 | // QQVGA |
tomoya123 | 0:d721efd58e4e | 530 | int reg_com7 = ReadReg(REG_COM7); |
tomoya123 | 0:d721efd58e4e | 531 | |
tomoya123 | 0:d721efd58e4e | 532 | WriteReg(REG_COM7,reg_com7|COM7_QQVGA); |
tomoya123 | 0:d721efd58e4e | 533 | |
tomoya123 | 0:d721efd58e4e | 534 | WriteReg(REG_HSTART,HSTART_QQVGA); |
tomoya123 | 0:d721efd58e4e | 535 | WriteReg(REG_HSTOP,HSTOP_QQVGA); |
tomoya123 | 0:d721efd58e4e | 536 | WriteReg(REG_HREF,HREF_QQVGA); |
tomoya123 | 0:d721efd58e4e | 537 | WriteReg(REG_VSTART,VSTART_QQVGA); |
tomoya123 | 0:d721efd58e4e | 538 | WriteReg(REG_VSTOP,VSTOP_QQVGA); |
tomoya123 | 0:d721efd58e4e | 539 | WriteReg(REG_VREF,VREF_QQVGA); |
tomoya123 | 0:d721efd58e4e | 540 | WriteReg(REG_COM3, COM3_QQVGA); |
tomoya123 | 0:d721efd58e4e | 541 | WriteReg(REG_COM14, COM14_QQVGA); |
tomoya123 | 0:d721efd58e4e | 542 | WriteReg(REG_SCALING_XSC, SCALING_XSC_QQVGA); |
tomoya123 | 0:d721efd58e4e | 543 | WriteReg(REG_SCALING_YSC, SCALING_YSC_QQVGA); |
tomoya123 | 0:d721efd58e4e | 544 | WriteReg(REG_SCALING_DCWCTR, SCALING_DCWCTR_QQVGA); |
tomoya123 | 0:d721efd58e4e | 545 | WriteReg(REG_SCALING_PCLK_DIV, SCALING_PCLK_DIV_QQVGA); |
tomoya123 | 0:d721efd58e4e | 546 | WriteReg(REG_SCALING_PCLK_DELAY, SCALING_PCLK_DELAY_QQVGA); |
tomoya123 | 0:d721efd58e4e | 547 | } |
tomoya123 | 0:d721efd58e4e | 548 | |
tomoya123 | 0:d721efd58e4e | 549 | // vsync handler |
tomoya123 | 0:d721efd58e4e | 550 | void HeptaCamera::VsyncHandler(void) |
tomoya123 | 0:d721efd58e4e | 551 | { |
tomoya123 | 0:d721efd58e4e | 552 | // Capture Enable |
tomoya123 | 0:d721efd58e4e | 553 | if (CaptureReq) { |
tomoya123 | 0:d721efd58e4e | 554 | wen = 1; |
tomoya123 | 0:d721efd58e4e | 555 | Done = false; |
tomoya123 | 0:d721efd58e4e | 556 | CaptureReq = false; |
tomoya123 | 0:d721efd58e4e | 557 | } else { |
tomoya123 | 0:d721efd58e4e | 558 | wen = 0; |
tomoya123 | 0:d721efd58e4e | 559 | if (Busy) { |
tomoya123 | 0:d721efd58e4e | 560 | Busy = false; |
tomoya123 | 0:d721efd58e4e | 561 | Done = true; |
tomoya123 | 0:d721efd58e4e | 562 | } |
tomoya123 | 0:d721efd58e4e | 563 | } |
tomoya123 | 0:d721efd58e4e | 564 | |
tomoya123 | 0:d721efd58e4e | 565 | // Hline Counter |
tomoya123 | 0:d721efd58e4e | 566 | LastLines = LineCounter; |
tomoya123 | 0:d721efd58e4e | 567 | LineCounter = 0; |
tomoya123 | 0:d721efd58e4e | 568 | } |
tomoya123 | 0:d721efd58e4e | 569 | |
tomoya123 | 0:d721efd58e4e | 570 | // href handler |
tomoya123 | 0:d721efd58e4e | 571 | void HeptaCamera::HrefHandler(void) |
tomoya123 | 0:d721efd58e4e | 572 | { |
tomoya123 | 0:d721efd58e4e | 573 | LineCounter++; |
tomoya123 | 0:d721efd58e4e | 574 | } |
tomoya123 | 0:d721efd58e4e | 575 | |
tomoya123 | 0:d721efd58e4e | 576 | // Data Read |
tomoya123 | 0:d721efd58e4e | 577 | int HeptaCamera::ReadOneByte(void) |
tomoya123 | 0:d721efd58e4e | 578 | { |
tomoya123 | 0:d721efd58e4e | 579 | int result; |
tomoya123 | 0:d721efd58e4e | 580 | rclk = 1; |
tomoya123 | 0:d721efd58e4e | 581 | // wait_us(1); |
tomoya123 | 0:d721efd58e4e | 582 | result = data; |
tomoya123 | 0:d721efd58e4e | 583 | rclk = 0; |
tomoya123 | 0:d721efd58e4e | 584 | return result; |
tomoya123 | 0:d721efd58e4e | 585 | } |
tomoya123 | 0:d721efd58e4e | 586 | |
tomoya123 | 0:d721efd58e4e | 587 | // Data Start |
tomoya123 | 0:d721efd58e4e | 588 | void HeptaCamera::ReadStart(void) |
tomoya123 | 0:d721efd58e4e | 589 | { |
tomoya123 | 0:d721efd58e4e | 590 | rrst = 0; |
tomoya123 | 0:d721efd58e4e | 591 | oe = 0; |
tomoya123 | 0:d721efd58e4e | 592 | wait_us(1); |
tomoya123 | 0:d721efd58e4e | 593 | rclk = 0; |
tomoya123 | 0:d721efd58e4e | 594 | wait_us(1); |
tomoya123 | 0:d721efd58e4e | 595 | rclk = 1; |
tomoya123 | 0:d721efd58e4e | 596 | wait_us(1); |
tomoya123 | 0:d721efd58e4e | 597 | rrst = 1; |
tomoya123 | 0:d721efd58e4e | 598 | } |
tomoya123 | 0:d721efd58e4e | 599 | |
tomoya123 | 0:d721efd58e4e | 600 | // Data Stop |
tomoya123 | 0:d721efd58e4e | 601 | void HeptaCamera::ReadStop(void) |
tomoya123 | 0:d721efd58e4e | 602 | { |
tomoya123 | 0:d721efd58e4e | 603 | oe = 1; |
tomoya123 | 0:d721efd58e4e | 604 | ReadOneByte(); |
tomoya123 | 0:d721efd58e4e | 605 | rclk = 1; |
tomoya123 | 0:d721efd58e4e | 606 | } |
tomoya123 | 0:d721efd58e4e | 607 | |
tomoya123 | 0:d721efd58e4e | 608 | void HeptaCamera::shoot() |
tomoya123 | 0:d721efd58e4e | 609 | { |
tomoya123 | 0:d721efd58e4e | 610 | //pc.baud(115200); |
tomoya123 | 0:d721efd58e4e | 611 | |
tomoya123 | 0:d721efd58e4e | 612 | //pc.printf("Camera resetting..\r\n"); |
tomoya123 | 0:d721efd58e4e | 613 | HeptaCamera::Reset(); |
tomoya123 | 0:d721efd58e4e | 614 | |
tomoya123 | 0:d721efd58e4e | 615 | //pc.printf("Before Init...\r\n"); |
tomoya123 | 0:d721efd58e4e | 616 | HeptaCamera::PrintRegister(); |
tomoya123 | 0:d721efd58e4e | 617 | char color_format = '1'; |
tomoya123 | 0:d721efd58e4e | 618 | /*pc.printf("Select color format.\r\n") ; |
tomoya123 | 0:d721efd58e4e | 619 | pc.printf("1: RGB444.\r\n"); |
tomoya123 | 0:d721efd58e4e | 620 | pc.printf("2: RGB555.\r\n"); |
tomoya123 | 0:d721efd58e4e | 621 | pc.printf("3: RGB565.\r\n"); |
tomoya123 | 0:d721efd58e4e | 622 | pc.printf("4: YUV(UYVY).\r\n"); |
tomoya123 | 0:d721efd58e4e | 623 | pc.printf("5: Bayer RGB(BGBG... GRGR...).\r\n");*/ |
tomoya123 | 0:d721efd58e4e | 624 | |
tomoya123 | 0:d721efd58e4e | 625 | /*while(!pc.readable()); |
tomoya123 | 0:d721efd58e4e | 626 | char color_format = pc.getc(); |
tomoya123 | 0:d721efd58e4e | 627 | switch (color_format) { |
tomoya123 | 0:d721efd58e4e | 628 | case '1': |
tomoya123 | 0:d721efd58e4e | 629 | camera.InitRGB444(); |
tomoya123 | 0:d721efd58e4e | 630 | break; |
tomoya123 | 0:d721efd58e4e | 631 | case '2': |
tomoya123 | 0:d721efd58e4e | 632 | camera.InitRGB555(); |
tomoya123 | 0:d721efd58e4e | 633 | break; |
tomoya123 | 0:d721efd58e4e | 634 | case '3': |
tomoya123 | 0:d721efd58e4e | 635 | camera.InitRGB565(); |
tomoya123 | 0:d721efd58e4e | 636 | break; |
tomoya123 | 0:d721efd58e4e | 637 | case '4': |
tomoya123 | 0:d721efd58e4e | 638 | camera.InitYUV(); |
tomoya123 | 0:d721efd58e4e | 639 | break; |
tomoya123 | 0:d721efd58e4e | 640 | case '5': |
tomoya123 | 0:d721efd58e4e | 641 | camera.InitBayerRGB(); |
tomoya123 | 0:d721efd58e4e | 642 | break; |
tomoya123 | 0:d721efd58e4e | 643 | } |
tomoya123 | 0:d721efd58e4e | 644 | pc.printf("select %c\r\n", color_format); |
tomoya123 | 0:d721efd58e4e | 645 | |
tomoya123 | 0:d721efd58e4e | 646 | pc.printf("Select screen size.\r\n") ; |
tomoya123 | 0:d721efd58e4e | 647 | switch (color_format) { |
tomoya123 | 0:d721efd58e4e | 648 | case '5': |
tomoya123 | 0:d721efd58e4e | 649 | pc.printf("1: VGA(640x480).\r\n"); |
tomoya123 | 0:d721efd58e4e | 650 | case '1': |
tomoya123 | 0:d721efd58e4e | 651 | case '2': |
tomoya123 | 0:d721efd58e4e | 652 | case '3': |
tomoya123 | 0:d721efd58e4e | 653 | case '4': |
tomoya123 | 0:d721efd58e4e | 654 | pc.printf("2: FIFO nealy limit(544x360).\r\n"); |
tomoya123 | 0:d721efd58e4e | 655 | pc.printf("3: VGA*3/4(480x360).\r\n"); |
tomoya123 | 0:d721efd58e4e | 656 | pc.printf("4: QVGA(320x240).\r\n"); |
tomoya123 | 0:d721efd58e4e | 657 | pc.printf("5: QQVGA(160x120).\r\n"); |
tomoya123 | 0:d721efd58e4e | 658 | break; |
tomoya123 | 0:d721efd58e4e | 659 | } |
tomoya123 | 0:d721efd58e4e | 660 | char screen_size = 4; |
tomoya123 | 0:d721efd58e4e | 661 | while(!pc.readable()); |
tomoya123 | 0:d721efd58e4e | 662 | char screen_size = pc.getc() ; |
tomoya123 | 0:d721efd58e4e | 663 | switch (screen_size) { |
tomoya123 | 0:d721efd58e4e | 664 | case '1': |
tomoya123 | 0:d721efd58e4e | 665 | sizex = 640; |
tomoya123 | 0:d721efd58e4e | 666 | sizey = 480; |
tomoya123 | 0:d721efd58e4e | 667 | camera.InitVGA(); |
tomoya123 | 0:d721efd58e4e | 668 | break; |
tomoya123 | 0:d721efd58e4e | 669 | case '2': |
tomoya123 | 0:d721efd58e4e | 670 | sizex = 544; |
tomoya123 | 0:d721efd58e4e | 671 | sizey = 360; |
tomoya123 | 0:d721efd58e4e | 672 | camera.InitFIFO_2bytes_color_nealy_limit_size(); |
tomoya123 | 0:d721efd58e4e | 673 | break; |
tomoya123 | 0:d721efd58e4e | 674 | case '3': |
tomoya123 | 0:d721efd58e4e | 675 | sizex = 480; |
tomoya123 | 0:d721efd58e4e | 676 | sizey = 360; |
tomoya123 | 0:d721efd58e4e | 677 | camera.InitVGA_3_4(); |
tomoya123 | 0:d721efd58e4e | 678 | break; |
tomoya123 | 0:d721efd58e4e | 679 | case '4': |
tomoya123 | 0:d721efd58e4e | 680 | sizex = 320; |
tomoya123 | 0:d721efd58e4e | 681 | sizey = 240; |
tomoya123 | 0:d721efd58e4e | 682 | camera.InitQVGA(); |
tomoya123 | 0:d721efd58e4e | 683 | break; |
tomoya123 | 0:d721efd58e4e | 684 | case '5': |
tomoya123 | 0:d721efd58e4e | 685 | sizex = 160; |
tomoya123 | 0:d721efd58e4e | 686 | sizey = 120; |
tomoya123 | 0:d721efd58e4e | 687 | camera.InitQQVGA(); |
tomoya123 | 0:d721efd58e4e | 688 | break; |
tomoya123 | 0:d721efd58e4e | 689 | } |
tomoya123 | 0:d721efd58e4e | 690 | pc.printf("select %c\r\n", screen_size);*/ |
tomoya123 | 0:d721efd58e4e | 691 | char screen_size = '4'; |
tomoya123 | 0:d721efd58e4e | 692 | HeptaCamera::InitRGB444(); |
tomoya123 | 0:d721efd58e4e | 693 | sizex = 320; |
tomoya123 | 0:d721efd58e4e | 694 | sizey = 240; |
tomoya123 | 0:d721efd58e4e | 695 | HeptaCamera::InitQVGA(); |
tomoya123 | 0:d721efd58e4e | 696 | HeptaCamera::InitForFIFOWriteReset(); |
tomoya123 | 0:d721efd58e4e | 697 | HeptaCamera::InitDefaultReg(); |
tomoya123 | 0:d721efd58e4e | 698 | |
tomoya123 | 0:d721efd58e4e | 699 | #ifdef COLORBAR |
tomoya123 | 0:d721efd58e4e | 700 | HeptaCamera::InitSetColorbar(); |
tomoya123 | 0:d721efd58e4e | 701 | #endif |
tomoya123 | 0:d721efd58e4e | 702 | |
tomoya123 | 0:d721efd58e4e | 703 | //pc.printf("After Init...\r\n"); |
tomoya123 | 0:d721efd58e4e | 704 | HeptaCamera::PrintRegister(); |
tomoya123 | 0:d721efd58e4e | 705 | |
tomoya123 | 0:d721efd58e4e | 706 | // CAPTURE and SEND LOOP |
tomoya123 | 0:d721efd58e4e | 707 | |
tomoya123 | 0:d721efd58e4e | 708 | #if defined(BITMAPFILE) || defined(BAYERBITMAPFILE) || defined(HEXFILE) |
tomoya123 | 0:d721efd58e4e | 709 | //pc.printf("Hit Any Key %dx%d Capture Data.\r\n", sizex, sizey) ; |
tomoya123 | 0:d721efd58e4e | 710 | //while(!pc.readable()); |
tomoya123 | 0:d721efd58e4e | 711 | //pc.printf("*\r\n"); |
tomoya123 | 0:d721efd58e4e | 712 | //pc.getc(); |
tomoya123 | 0:d721efd58e4e | 713 | |
tomoya123 | 0:d721efd58e4e | 714 | int real_width = sizex*3 + sizey%4; |
tomoya123 | 0:d721efd58e4e | 715 | |
tomoya123 | 0:d721efd58e4e | 716 | unsigned char *bmp_line_data; //画像1行分のRGB情報を格納する |
tomoya123 | 0:d721efd58e4e | 717 | if((bmp_line_data = (unsigned char *)malloc(sizeof(unsigned char)*real_width)) == NULL){ |
tomoya123 | 0:d721efd58e4e | 718 | fprintf(stderr, "Error: Allocation error.\n"); |
tomoya123 | 0:d721efd58e4e | 719 | //return 1; |
tomoya123 | 0:d721efd58e4e | 720 | } |
tomoya123 | 0:d721efd58e4e | 721 | |
tomoya123 | 0:d721efd58e4e | 722 | //RGB情報を4バイトの倍数に合わせている |
tomoya123 | 0:d721efd58e4e | 723 | for(int i=sizex*3; i<real_width; i++){ |
tomoya123 | 0:d721efd58e4e | 724 | bmp_line_data[i] = 0; |
tomoya123 | 0:d721efd58e4e | 725 | } |
tomoya123 | 0:d721efd58e4e | 726 | #endif |
tomoya123 | 0:d721efd58e4e | 727 | #if defined(BITMAPFILE) || defined(BAYERBITMAPFILE) |
tomoya123 | 0:d721efd58e4e | 728 | FILE *fp; |
tomoya123 | 0:d721efd58e4e | 729 | char *filename = "/local/test.bmp"; |
tomoya123 | 0:d721efd58e4e | 730 | if((fp = fopen(filename, "wb")) == NULL){ |
tomoya123 | 0:d721efd58e4e | 731 | //pc.printf("Error: %s could not open.", filename); |
tomoya123 | 0:d721efd58e4e | 732 | //return 1; |
tomoya123 | 0:d721efd58e4e | 733 | } |
tomoya123 | 0:d721efd58e4e | 734 | |
tomoya123 | 0:d721efd58e4e | 735 | create_header(fp, sizex, sizey); |
tomoya123 | 0:d721efd58e4e | 736 | #endif |
tomoya123 | 0:d721efd58e4e | 737 | #ifdef HEXFILE |
tomoya123 | 0:d721efd58e4e | 738 | FILE *fp2; |
tomoya123 | 0:d721efd58e4e | 739 | char *filename2 = "/local/test.txt"; |
tomoya123 | 0:d721efd58e4e | 740 | if((fp2 = fopen(filename2, "w")) == NULL){ |
tomoya123 | 0:d721efd58e4e | 741 | pc.printf("Error: %s could not open.", filename2); |
tomoya123 | 0:d721efd58e4e | 742 | return 1; |
tomoya123 | 0:d721efd58e4e | 743 | } |
tomoya123 | 0:d721efd58e4e | 744 | #endif |
tomoya123 | 0:d721efd58e4e | 745 | |
tomoya123 | 0:d721efd58e4e | 746 | HeptaCamera::CaptureNext(); |
tomoya123 | 0:d721efd58e4e | 747 | while(HeptaCamera::CaptureDone() == false); |
tomoya123 | 0:d721efd58e4e | 748 | HeptaCamera::ReadStart(); |
tomoya123 | 0:d721efd58e4e | 749 | |
tomoya123 | 0:d721efd58e4e | 750 | int r=0, g=0, b=0, d1, d2; |
tomoya123 | 0:d721efd58e4e | 751 | |
tomoya123 | 0:d721efd58e4e | 752 | switch (color_format) { |
tomoya123 | 0:d721efd58e4e | 753 | case '1': |
tomoya123 | 0:d721efd58e4e | 754 | case '2': |
tomoya123 | 0:d721efd58e4e | 755 | case '3': |
tomoya123 | 0:d721efd58e4e | 756 | |
tomoya123 | 0:d721efd58e4e | 757 | for (int y=0; y<sizey; y++) { |
tomoya123 | 0:d721efd58e4e | 758 | for (int x=0; x<sizex; x++) { |
tomoya123 | 0:d721efd58e4e | 759 | d1 = HeptaCamera::ReadOneByte(); |
tomoya123 | 0:d721efd58e4e | 760 | d2 = HeptaCamera::ReadOneByte(); |
tomoya123 | 0:d721efd58e4e | 761 | |
tomoya123 | 0:d721efd58e4e | 762 | switch (color_format) { |
tomoya123 | 0:d721efd58e4e | 763 | case '1': |
tomoya123 | 0:d721efd58e4e | 764 | // RGB444 to RGB888 |
tomoya123 | 0:d721efd58e4e | 765 | b = (d1 & 0x0F) << 4; |
tomoya123 | 0:d721efd58e4e | 766 | g = (d2 & 0xF0); |
tomoya123 | 0:d721efd58e4e | 767 | r = (d2 & 0x0F) << 4; |
tomoya123 | 0:d721efd58e4e | 768 | break; |
tomoya123 | 0:d721efd58e4e | 769 | case '2': |
tomoya123 | 0:d721efd58e4e | 770 | // RGB555 to RGB888 |
tomoya123 | 0:d721efd58e4e | 771 | b = (d1 & 0x1F) << 3; |
tomoya123 | 0:d721efd58e4e | 772 | g = (((d1 & 0xE0) >> 2) | ((d2 & 0x03) << 6)); |
tomoya123 | 0:d721efd58e4e | 773 | r = (d2 & 0x7c) << 1; |
tomoya123 | 0:d721efd58e4e | 774 | break; |
tomoya123 | 0:d721efd58e4e | 775 | case '3': |
tomoya123 | 0:d721efd58e4e | 776 | // RGB565 to RGB888 |
tomoya123 | 0:d721efd58e4e | 777 | b = (d1 & 0x1F) << 3; |
tomoya123 | 0:d721efd58e4e | 778 | g = (((d1 & 0xE0) >> 3) | ((d2 & 0x07) << 5)); |
tomoya123 | 0:d721efd58e4e | 779 | r = (d2 & 0xF8); |
tomoya123 | 0:d721efd58e4e | 780 | break; |
tomoya123 | 0:d721efd58e4e | 781 | } |
tomoya123 | 0:d721efd58e4e | 782 | #if defined(BITMAPFILE) || defined(HEXFILE) |
tomoya123 | 0:d721efd58e4e | 783 | bmp_line_data[x*3] = (unsigned char)b; |
tomoya123 | 0:d721efd58e4e | 784 | bmp_line_data[x*3 + 1] = (unsigned char)g; |
tomoya123 | 0:d721efd58e4e | 785 | bmp_line_data[x*3 + 2] = (unsigned char)r; |
tomoya123 | 0:d721efd58e4e | 786 | #endif |
tomoya123 | 0:d721efd58e4e | 787 | /* |
tomoya123 | 0:d721efd58e4e | 788 | // RGB |
tomoya123 | 0:d721efd58e4e | 789 | pc.printf ("%2X%2X%2X", r, g, b) ; |
tomoya123 | 0:d721efd58e4e | 790 | */ |
tomoya123 | 0:d721efd58e4e | 791 | } |
tomoya123 | 0:d721efd58e4e | 792 | #ifdef BITMAPFILE |
tomoya123 | 0:d721efd58e4e | 793 | fwrite(bmp_line_data, sizeof(unsigned char), real_width, fp); |
tomoya123 | 0:d721efd58e4e | 794 | #endif |
tomoya123 | 0:d721efd58e4e | 795 | #ifdef HEXFILE |
tomoya123 | 0:d721efd58e4e | 796 | for(int i=0; i<sizex*3; i++){ |
tomoya123 | 0:d721efd58e4e | 797 | fprintf(fp2, "%02X", bmp_line_data[i]); |
tomoya123 | 0:d721efd58e4e | 798 | } |
tomoya123 | 0:d721efd58e4e | 799 | #endif |
tomoya123 | 0:d721efd58e4e | 800 | // pc.printf("\r\n") ; |
tomoya123 | 0:d721efd58e4e | 801 | } |
tomoya123 | 0:d721efd58e4e | 802 | break; |
tomoya123 | 0:d721efd58e4e | 803 | |
tomoya123 | 0:d721efd58e4e | 804 | case '4': |
tomoya123 | 0:d721efd58e4e | 805 | int index = 0; |
tomoya123 | 0:d721efd58e4e | 806 | for (int y=0; y<sizey; y++) { |
tomoya123 | 0:d721efd58e4e | 807 | int U0=0, Y0=0, V0=0, Y1=0; |
tomoya123 | 0:d721efd58e4e | 808 | for (int x=0; x<sizex; x++) { |
tomoya123 | 0:d721efd58e4e | 809 | if(index%2 == 0) { |
tomoya123 | 0:d721efd58e4e | 810 | U0 = HeptaCamera::ReadOneByte(); |
tomoya123 | 0:d721efd58e4e | 811 | Y0 = HeptaCamera::ReadOneByte(); |
tomoya123 | 0:d721efd58e4e | 812 | V0 = HeptaCamera::ReadOneByte(); |
tomoya123 | 0:d721efd58e4e | 813 | Y1 = HeptaCamera::ReadOneByte(); |
tomoya123 | 0:d721efd58e4e | 814 | |
tomoya123 | 0:d721efd58e4e | 815 | b = Y0 + 1.77200 * (U0 - 128); |
tomoya123 | 0:d721efd58e4e | 816 | g = Y0 - 0.34414 * (U0 - 128) - 0.71414 * (V0 - 128); |
tomoya123 | 0:d721efd58e4e | 817 | r = Y0 + 1.40200 * (V0 - 128); |
tomoya123 | 0:d721efd58e4e | 818 | } else { |
tomoya123 | 0:d721efd58e4e | 819 | b = Y1 + 1.77200 * (U0 - 128); |
tomoya123 | 0:d721efd58e4e | 820 | g = Y1 - 0.34414 * (U0 - 128) - 0.71414 * (V0 - 128); |
tomoya123 | 0:d721efd58e4e | 821 | r = Y1 + 1.40200 * (V0 - 128); |
tomoya123 | 0:d721efd58e4e | 822 | } |
tomoya123 | 0:d721efd58e4e | 823 | |
tomoya123 | 0:d721efd58e4e | 824 | b = min(max(b, 0), 255); |
tomoya123 | 0:d721efd58e4e | 825 | g = min(max(g, 0), 255); |
tomoya123 | 0:d721efd58e4e | 826 | r = min(max(r, 0), 255); |
tomoya123 | 0:d721efd58e4e | 827 | |
tomoya123 | 0:d721efd58e4e | 828 | #if defined(BITMAPFILE) || defined(HEXFILE) |
tomoya123 | 0:d721efd58e4e | 829 | bmp_line_data[x*3] = (unsigned char)b; |
tomoya123 | 0:d721efd58e4e | 830 | bmp_line_data[x*3 + 1] = (unsigned char)g; |
tomoya123 | 0:d721efd58e4e | 831 | bmp_line_data[x*3 + 2] = (unsigned char)r; |
tomoya123 | 0:d721efd58e4e | 832 | #endif |
tomoya123 | 0:d721efd58e4e | 833 | /* |
tomoya123 | 0:d721efd58e4e | 834 | // RGB |
tomoya123 | 0:d721efd58e4e | 835 | pc.printf ("%2X%2X%2X", r, g, b) ; |
tomoya123 | 0:d721efd58e4e | 836 | */ |
tomoya123 | 0:d721efd58e4e | 837 | index++; |
tomoya123 | 0:d721efd58e4e | 838 | } |
tomoya123 | 0:d721efd58e4e | 839 | #ifdef BITMAPFILE |
tomoya123 | 0:d721efd58e4e | 840 | fwrite(bmp_line_data, sizeof(unsigned char), real_width, fp); |
tomoya123 | 0:d721efd58e4e | 841 | #endif |
tomoya123 | 0:d721efd58e4e | 842 | #ifdef HEXFILE |
tomoya123 | 0:d721efd58e4e | 843 | for(int i=0; i<sizex*3; i++){ |
tomoya123 | 0:d721efd58e4e | 844 | fprintf(fp2, "%02X", bmp_line_data[i]); |
tomoya123 | 0:d721efd58e4e | 845 | } |
tomoya123 | 0:d721efd58e4e | 846 | #endif |
tomoya123 | 0:d721efd58e4e | 847 | // pc.printf("\r\n") ; |
tomoya123 | 0:d721efd58e4e | 848 | } |
tomoya123 | 0:d721efd58e4e | 849 | break; |
tomoya123 | 0:d721efd58e4e | 850 | |
tomoya123 | 0:d721efd58e4e | 851 | case '5': |
tomoya123 | 0:d721efd58e4e | 852 | unsigned char *bayer_line[2]; |
tomoya123 | 0:d721efd58e4e | 853 | unsigned char *bayer_line_data[2]; //画像1行分のRGB情報を格納する2行分 |
tomoya123 | 0:d721efd58e4e | 854 | for(int i=0; i<2; i++) { |
tomoya123 | 0:d721efd58e4e | 855 | if((bayer_line_data[i] = (unsigned char *)malloc(sizeof(unsigned char)*sizex)) == NULL){ |
tomoya123 | 0:d721efd58e4e | 856 | fprintf(stderr, "Error: Allocation error.\n"); |
tomoya123 | 0:d721efd58e4e | 857 | //return 1; |
tomoya123 | 0:d721efd58e4e | 858 | } |
tomoya123 | 0:d721efd58e4e | 859 | } |
tomoya123 | 0:d721efd58e4e | 860 | |
tomoya123 | 0:d721efd58e4e | 861 | for (int x=0; x<sizex; x++) { |
tomoya123 | 0:d721efd58e4e | 862 | // odd line BGBG... even line GRGR... |
tomoya123 | 0:d721efd58e4e | 863 | bayer_line_data[0][x] = (unsigned char)HeptaCamera::ReadOneByte(); |
tomoya123 | 0:d721efd58e4e | 864 | #ifdef BAYERBITMAPFILE |
tomoya123 | 0:d721efd58e4e | 865 | bmp_line_data[x*3] = (unsigned char)bayer_line_data[0][x]; |
tomoya123 | 0:d721efd58e4e | 866 | bmp_line_data[x*3 + 1] = (unsigned char)bayer_line_data[0][x]; |
tomoya123 | 0:d721efd58e4e | 867 | bmp_line_data[x*3 + 2] = (unsigned char)bayer_line_data[0][x]; |
tomoya123 | 0:d721efd58e4e | 868 | #endif |
tomoya123 | 0:d721efd58e4e | 869 | } |
tomoya123 | 0:d721efd58e4e | 870 | #ifdef BAYERBITMAPFILE |
tomoya123 | 0:d721efd58e4e | 871 | fwrite(bmp_line_data, sizeof(unsigned char), real_width, fp); |
tomoya123 | 0:d721efd58e4e | 872 | #endif |
tomoya123 | 0:d721efd58e4e | 873 | bayer_line[1] = bayer_line_data[0]; |
tomoya123 | 0:d721efd58e4e | 874 | |
tomoya123 | 0:d721efd58e4e | 875 | for (int y=1; y<sizey; y++) { |
tomoya123 | 0:d721efd58e4e | 876 | int line = y%2; |
tomoya123 | 0:d721efd58e4e | 877 | |
tomoya123 | 0:d721efd58e4e | 878 | for (int x=0; x<sizex; x++) { |
tomoya123 | 0:d721efd58e4e | 879 | // odd line BGBG... even line GRGR... |
tomoya123 | 0:d721efd58e4e | 880 | bayer_line_data[line][x] = (unsigned char)HeptaCamera::ReadOneByte(); |
tomoya123 | 0:d721efd58e4e | 881 | #ifdef BAYERBITMAPFILE |
tomoya123 | 0:d721efd58e4e | 882 | bmp_line_data[x*3] = (unsigned char)bayer_line_data[line][x]; |
tomoya123 | 0:d721efd58e4e | 883 | bmp_line_data[x*3 + 1] = (unsigned char)bayer_line_data[line][x]; |
tomoya123 | 0:d721efd58e4e | 884 | bmp_line_data[x*3 + 2] = (unsigned char)bayer_line_data[line][x]; |
tomoya123 | 0:d721efd58e4e | 885 | #endif |
tomoya123 | 0:d721efd58e4e | 886 | } |
tomoya123 | 0:d721efd58e4e | 887 | #ifdef BAYERBITMAPFILE |
tomoya123 | 0:d721efd58e4e | 888 | fwrite(bmp_line_data, sizeof(unsigned char), real_width, fp); |
tomoya123 | 0:d721efd58e4e | 889 | #endif |
tomoya123 | 0:d721efd58e4e | 890 | bayer_line[0] = bayer_line[1]; |
tomoya123 | 0:d721efd58e4e | 891 | bayer_line[1] = bayer_line_data[line]; |
tomoya123 | 0:d721efd58e4e | 892 | |
tomoya123 | 0:d721efd58e4e | 893 | for (int x=0; x<sizex - 1; x++) { |
tomoya123 | 0:d721efd58e4e | 894 | if(y%2==1) { |
tomoya123 | 0:d721efd58e4e | 895 | if(x%2==0) { |
tomoya123 | 0:d721efd58e4e | 896 | // BG |
tomoya123 | 0:d721efd58e4e | 897 | // GR |
tomoya123 | 0:d721efd58e4e | 898 | b = bayer_line[0][x]; |
tomoya123 | 0:d721efd58e4e | 899 | g = ((int)bayer_line[0][x+1] + bayer_line[1][x])>>1; |
tomoya123 | 0:d721efd58e4e | 900 | r = bayer_line[1][x+1]; |
tomoya123 | 0:d721efd58e4e | 901 | } else { |
tomoya123 | 0:d721efd58e4e | 902 | // GB |
tomoya123 | 0:d721efd58e4e | 903 | // RG |
tomoya123 | 0:d721efd58e4e | 904 | b = bayer_line[0][x+1]; |
tomoya123 | 0:d721efd58e4e | 905 | g = ((int)bayer_line[0][x] + bayer_line[1][x+1])>>1; |
tomoya123 | 0:d721efd58e4e | 906 | r = bayer_line[1][x]; |
tomoya123 | 0:d721efd58e4e | 907 | } |
tomoya123 | 0:d721efd58e4e | 908 | } else { |
tomoya123 | 0:d721efd58e4e | 909 | if(x%2==0) { |
tomoya123 | 0:d721efd58e4e | 910 | // GR |
tomoya123 | 0:d721efd58e4e | 911 | // BG |
tomoya123 | 0:d721efd58e4e | 912 | b = bayer_line[1][x]; |
tomoya123 | 0:d721efd58e4e | 913 | g = ((int)bayer_line[0][x] + bayer_line[1][x+1])>>1; |
tomoya123 | 0:d721efd58e4e | 914 | r = bayer_line[0][x+1]; |
tomoya123 | 0:d721efd58e4e | 915 | } else { |
tomoya123 | 0:d721efd58e4e | 916 | // RG |
tomoya123 | 0:d721efd58e4e | 917 | // GB |
tomoya123 | 0:d721efd58e4e | 918 | b = bayer_line[1][x+1]; |
tomoya123 | 0:d721efd58e4e | 919 | g = ((int)bayer_line[0][x+1] + bayer_line[1][x])>>1; |
tomoya123 | 0:d721efd58e4e | 920 | r = bayer_line[0][x]; |
tomoya123 | 0:d721efd58e4e | 921 | } |
tomoya123 | 0:d721efd58e4e | 922 | } |
tomoya123 | 0:d721efd58e4e | 923 | #if defined(BITMAPFILE) || defined(HEXFILE) |
tomoya123 | 0:d721efd58e4e | 924 | bmp_line_data[x*3] = (unsigned char)b; |
tomoya123 | 0:d721efd58e4e | 925 | bmp_line_data[x*3 + 1] = (unsigned char)g; |
tomoya123 | 0:d721efd58e4e | 926 | bmp_line_data[x*3 + 2] = (unsigned char)r; |
tomoya123 | 0:d721efd58e4e | 927 | #endif |
tomoya123 | 0:d721efd58e4e | 928 | } |
tomoya123 | 0:d721efd58e4e | 929 | |
tomoya123 | 0:d721efd58e4e | 930 | #ifdef BITMAPFILE |
tomoya123 | 0:d721efd58e4e | 931 | fwrite(bmp_line_data, sizeof(unsigned char), real_width, fp); |
tomoya123 | 0:d721efd58e4e | 932 | #endif |
tomoya123 | 0:d721efd58e4e | 933 | |
tomoya123 | 0:d721efd58e4e | 934 | #ifdef HEXFILE |
tomoya123 | 0:d721efd58e4e | 935 | for(int i=0; i<sizex*3; i++){ |
tomoya123 | 0:d721efd58e4e | 936 | fprintf(fp2, "%02X", bmp_line_data[i]); |
tomoya123 | 0:d721efd58e4e | 937 | } |
tomoya123 | 0:d721efd58e4e | 938 | #endif |
tomoya123 | 0:d721efd58e4e | 939 | } |
tomoya123 | 0:d721efd58e4e | 940 | |
tomoya123 | 0:d721efd58e4e | 941 | for(int i=0; i<2; i++) { |
tomoya123 | 0:d721efd58e4e | 942 | free(bayer_line_data[i]); |
tomoya123 | 0:d721efd58e4e | 943 | } |
tomoya123 | 0:d721efd58e4e | 944 | #ifdef BITMAPFILE |
tomoya123 | 0:d721efd58e4e | 945 | fwrite(bmp_line_data, sizeof(unsigned char), real_width, fp); |
tomoya123 | 0:d721efd58e4e | 946 | #endif |
tomoya123 | 0:d721efd58e4e | 947 | break; |
tomoya123 | 0:d721efd58e4e | 948 | } |
tomoya123 | 0:d721efd58e4e | 949 | HeptaCamera::ReadStop(); |
tomoya123 | 0:d721efd58e4e | 950 | |
tomoya123 | 0:d721efd58e4e | 951 | #if defined(BITMAPFILE) || defined(BAYERBITMAPFILE) |
tomoya123 | 0:d721efd58e4e | 952 | free(bmp_line_data); |
tomoya123 | 0:d721efd58e4e | 953 | fclose(fp); |
tomoya123 | 0:d721efd58e4e | 954 | #endif |
tomoya123 | 0:d721efd58e4e | 955 | #ifdef HEXFILE |
tomoya123 | 0:d721efd58e4e | 956 | fclose(fp2); |
tomoya123 | 0:d721efd58e4e | 957 | #endif |
tomoya123 | 0:d721efd58e4e | 958 | |
tomoya123 | 0:d721efd58e4e | 959 | } |
tomoya123 | 0:d721efd58e4e | 960 | |
tomoya123 | 0:d721efd58e4e | 961 | void HeptaCamera::shoot2() |
tomoya123 | 0:d721efd58e4e | 962 | { |
tomoya123 | 0:d721efd58e4e | 963 | //pc.baud(115200); |
tomoya123 | 0:d721efd58e4e | 964 | |
tomoya123 | 0:d721efd58e4e | 965 | //pc.printf("Camera resetting..\r\n"); |
tomoya123 | 0:d721efd58e4e | 966 | HeptaCamera::Reset(); |
tomoya123 | 0:d721efd58e4e | 967 | |
tomoya123 | 0:d721efd58e4e | 968 | //pc.printf("Before Init...\r\n"); |
tomoya123 | 0:d721efd58e4e | 969 | HeptaCamera::PrintRegister(); |
tomoya123 | 0:d721efd58e4e | 970 | char color_format = '1'; |
tomoya123 | 0:d721efd58e4e | 971 | /*pc.printf("Select color format.\r\n") ; |
tomoya123 | 0:d721efd58e4e | 972 | pc.printf("1: RGB444.\r\n"); |
tomoya123 | 0:d721efd58e4e | 973 | pc.printf("2: RGB555.\r\n"); |
tomoya123 | 0:d721efd58e4e | 974 | pc.printf("3: RGB565.\r\n"); |
tomoya123 | 0:d721efd58e4e | 975 | pc.printf("4: YUV(UYVY).\r\n"); |
tomoya123 | 0:d721efd58e4e | 976 | pc.printf("5: Bayer RGB(BGBG... GRGR...).\r\n");*/ |
tomoya123 | 0:d721efd58e4e | 977 | |
tomoya123 | 0:d721efd58e4e | 978 | /*while(!pc.readable()); |
tomoya123 | 0:d721efd58e4e | 979 | char color_format = pc.getc(); |
tomoya123 | 0:d721efd58e4e | 980 | switch (color_format) { |
tomoya123 | 0:d721efd58e4e | 981 | case '1': |
tomoya123 | 0:d721efd58e4e | 982 | camera.InitRGB444(); |
tomoya123 | 0:d721efd58e4e | 983 | break; |
tomoya123 | 0:d721efd58e4e | 984 | case '2': |
tomoya123 | 0:d721efd58e4e | 985 | camera.InitRGB555(); |
tomoya123 | 0:d721efd58e4e | 986 | break; |
tomoya123 | 0:d721efd58e4e | 987 | case '3': |
tomoya123 | 0:d721efd58e4e | 988 | camera.InitRGB565(); |
tomoya123 | 0:d721efd58e4e | 989 | break; |
tomoya123 | 0:d721efd58e4e | 990 | case '4': |
tomoya123 | 0:d721efd58e4e | 991 | camera.InitYUV(); |
tomoya123 | 0:d721efd58e4e | 992 | break; |
tomoya123 | 0:d721efd58e4e | 993 | case '5': |
tomoya123 | 0:d721efd58e4e | 994 | camera.InitBayerRGB(); |
tomoya123 | 0:d721efd58e4e | 995 | break; |
tomoya123 | 0:d721efd58e4e | 996 | } |
tomoya123 | 0:d721efd58e4e | 997 | pc.printf("select %c\r\n", color_format); |
tomoya123 | 0:d721efd58e4e | 998 | |
tomoya123 | 0:d721efd58e4e | 999 | pc.printf("Select screen size.\r\n") ; |
tomoya123 | 0:d721efd58e4e | 1000 | switch (color_format) { |
tomoya123 | 0:d721efd58e4e | 1001 | case '5': |
tomoya123 | 0:d721efd58e4e | 1002 | pc.printf("1: VGA(640x480).\r\n"); |
tomoya123 | 0:d721efd58e4e | 1003 | case '1': |
tomoya123 | 0:d721efd58e4e | 1004 | case '2': |
tomoya123 | 0:d721efd58e4e | 1005 | case '3': |
tomoya123 | 0:d721efd58e4e | 1006 | case '4': |
tomoya123 | 0:d721efd58e4e | 1007 | pc.printf("2: FIFO nealy limit(544x360).\r\n"); |
tomoya123 | 0:d721efd58e4e | 1008 | pc.printf("3: VGA*3/4(480x360).\r\n"); |
tomoya123 | 0:d721efd58e4e | 1009 | pc.printf("4: QVGA(320x240).\r\n"); |
tomoya123 | 0:d721efd58e4e | 1010 | pc.printf("5: QQVGA(160x120).\r\n"); |
tomoya123 | 0:d721efd58e4e | 1011 | break; |
tomoya123 | 0:d721efd58e4e | 1012 | } |
tomoya123 | 0:d721efd58e4e | 1013 | char screen_size = 4; |
tomoya123 | 0:d721efd58e4e | 1014 | while(!pc.readable()); |
tomoya123 | 0:d721efd58e4e | 1015 | char screen_size = pc.getc() ; |
tomoya123 | 0:d721efd58e4e | 1016 | switch (screen_size) { |
tomoya123 | 0:d721efd58e4e | 1017 | case '1': |
tomoya123 | 0:d721efd58e4e | 1018 | sizex = 640; |
tomoya123 | 0:d721efd58e4e | 1019 | sizey = 480; |
tomoya123 | 0:d721efd58e4e | 1020 | camera.InitVGA(); |
tomoya123 | 0:d721efd58e4e | 1021 | break; |
tomoya123 | 0:d721efd58e4e | 1022 | case '2': |
tomoya123 | 0:d721efd58e4e | 1023 | sizex = 544; |
tomoya123 | 0:d721efd58e4e | 1024 | sizey = 360; |
tomoya123 | 0:d721efd58e4e | 1025 | camera.InitFIFO_2bytes_color_nealy_limit_size(); |
tomoya123 | 0:d721efd58e4e | 1026 | break; |
tomoya123 | 0:d721efd58e4e | 1027 | case '3': |
tomoya123 | 0:d721efd58e4e | 1028 | sizex = 480; |
tomoya123 | 0:d721efd58e4e | 1029 | sizey = 360; |
tomoya123 | 0:d721efd58e4e | 1030 | camera.InitVGA_3_4(); |
tomoya123 | 0:d721efd58e4e | 1031 | break; |
tomoya123 | 0:d721efd58e4e | 1032 | case '4': |
tomoya123 | 0:d721efd58e4e | 1033 | sizex = 320; |
tomoya123 | 0:d721efd58e4e | 1034 | sizey = 240; |
tomoya123 | 0:d721efd58e4e | 1035 | camera.InitQVGA(); |
tomoya123 | 0:d721efd58e4e | 1036 | break; |
tomoya123 | 0:d721efd58e4e | 1037 | case '5': |
tomoya123 | 0:d721efd58e4e | 1038 | sizex = 160; |
tomoya123 | 0:d721efd58e4e | 1039 | sizey = 120; |
tomoya123 | 0:d721efd58e4e | 1040 | camera.InitQQVGA(); |
tomoya123 | 0:d721efd58e4e | 1041 | break; |
tomoya123 | 0:d721efd58e4e | 1042 | } |
tomoya123 | 0:d721efd58e4e | 1043 | pc.printf("select %c\r\n", screen_size);*/ |
tomoya123 | 0:d721efd58e4e | 1044 | char screen_size = '4'; |
tomoya123 | 0:d721efd58e4e | 1045 | HeptaCamera::InitRGB444(); |
tomoya123 | 0:d721efd58e4e | 1046 | sizex = 320; |
tomoya123 | 0:d721efd58e4e | 1047 | sizey = 240; |
tomoya123 | 0:d721efd58e4e | 1048 | HeptaCamera::InitQVGA(); |
tomoya123 | 0:d721efd58e4e | 1049 | HeptaCamera::InitForFIFOWriteReset(); |
tomoya123 | 0:d721efd58e4e | 1050 | HeptaCamera::InitDefaultReg(); |
tomoya123 | 0:d721efd58e4e | 1051 | |
tomoya123 | 0:d721efd58e4e | 1052 | #ifdef COLORBAR |
tomoya123 | 0:d721efd58e4e | 1053 | HeptaCamera::InitSetColorbar(); |
tomoya123 | 0:d721efd58e4e | 1054 | #endif |
tomoya123 | 0:d721efd58e4e | 1055 | |
tomoya123 | 0:d721efd58e4e | 1056 | //pc.printf("After Init...\r\n"); |
tomoya123 | 0:d721efd58e4e | 1057 | HeptaCamera::PrintRegister(); |
tomoya123 | 0:d721efd58e4e | 1058 | |
tomoya123 | 0:d721efd58e4e | 1059 | // CAPTURE and SEND LOOP |
tomoya123 | 0:d721efd58e4e | 1060 | |
tomoya123 | 0:d721efd58e4e | 1061 | #if defined(BITMAPFILE) || defined(BAYERBITMAPFILE) || defined(HEXFILE) |
tomoya123 | 0:d721efd58e4e | 1062 | //pc.printf("Hit Any Key %dx%d Capture Data.\r\n", sizex, sizey) ; |
tomoya123 | 0:d721efd58e4e | 1063 | //while(!pc.readable()); |
tomoya123 | 0:d721efd58e4e | 1064 | //pc.printf("*\r\n"); |
tomoya123 | 0:d721efd58e4e | 1065 | //pc.getc(); |
tomoya123 | 0:d721efd58e4e | 1066 | |
tomoya123 | 0:d721efd58e4e | 1067 | int real_width = sizex*3 + sizey%4; |
tomoya123 | 0:d721efd58e4e | 1068 | |
tomoya123 | 0:d721efd58e4e | 1069 | unsigned char *bmp_line_data; //画像1行分のRGB情報を格納する |
tomoya123 | 0:d721efd58e4e | 1070 | if((bmp_line_data = (unsigned char *)malloc(sizeof(unsigned char)*real_width)) == NULL){ |
tomoya123 | 0:d721efd58e4e | 1071 | fprintf(stderr, "Error: Allocation error.\n"); |
tomoya123 | 0:d721efd58e4e | 1072 | //return 1; |
tomoya123 | 0:d721efd58e4e | 1073 | } |
tomoya123 | 0:d721efd58e4e | 1074 | |
tomoya123 | 0:d721efd58e4e | 1075 | //RGB情報を4バイトの倍数に合わせている |
tomoya123 | 0:d721efd58e4e | 1076 | for(int i=sizex*3; i<real_width; i++){ |
tomoya123 | 0:d721efd58e4e | 1077 | bmp_line_data[i] = 0; |
tomoya123 | 0:d721efd58e4e | 1078 | } |
tomoya123 | 0:d721efd58e4e | 1079 | #endif |
tomoya123 | 0:d721efd58e4e | 1080 | #if defined(BITMAPFILE) || defined(BAYERBITMAPFILE) |
tomoya123 | 0:d721efd58e4e | 1081 | mkdir("/sd/mydir", 0777); |
tomoya123 | 0:d721efd58e4e | 1082 | FILE *fp = fopen("/sd/mydir/picture.bmp","w"); |
tomoya123 | 0:d721efd58e4e | 1083 | if(fp == NULL) { |
tomoya123 | 0:d721efd58e4e | 1084 | error("Could not open file for write\r\n"); |
tomoya123 | 0:d721efd58e4e | 1085 | } |
tomoya123 | 0:d721efd58e4e | 1086 | |
tomoya123 | 0:d721efd58e4e | 1087 | create_header(fp, sizex, sizey); |
tomoya123 | 0:d721efd58e4e | 1088 | #endif |
tomoya123 | 0:d721efd58e4e | 1089 | #ifdef HEXFILE |
tomoya123 | 0:d721efd58e4e | 1090 | FILE *fp2; |
tomoya123 | 0:d721efd58e4e | 1091 | char *filename2 = "/local/test.txt"; |
tomoya123 | 0:d721efd58e4e | 1092 | if((fp2 = fopen(filename2, "w")) == NULL){ |
tomoya123 | 0:d721efd58e4e | 1093 | pc.printf("Error: %s could not open.", filename2); |
tomoya123 | 0:d721efd58e4e | 1094 | return 1; |
tomoya123 | 0:d721efd58e4e | 1095 | } |
tomoya123 | 0:d721efd58e4e | 1096 | #endif |
tomoya123 | 0:d721efd58e4e | 1097 | |
tomoya123 | 0:d721efd58e4e | 1098 | HeptaCamera::CaptureNext(); |
tomoya123 | 0:d721efd58e4e | 1099 | while(HeptaCamera::CaptureDone() == false); |
tomoya123 | 0:d721efd58e4e | 1100 | HeptaCamera::ReadStart(); |
tomoya123 | 0:d721efd58e4e | 1101 | |
tomoya123 | 0:d721efd58e4e | 1102 | int r=0, g=0, b=0, d1, d2; |
tomoya123 | 0:d721efd58e4e | 1103 | |
tomoya123 | 0:d721efd58e4e | 1104 | switch (color_format) { |
tomoya123 | 0:d721efd58e4e | 1105 | case '1': |
tomoya123 | 0:d721efd58e4e | 1106 | case '2': |
tomoya123 | 0:d721efd58e4e | 1107 | case '3': |
tomoya123 | 0:d721efd58e4e | 1108 | |
tomoya123 | 0:d721efd58e4e | 1109 | for (int y=0; y<sizey; y++) { |
tomoya123 | 0:d721efd58e4e | 1110 | for (int x=0; x<sizex; x++) { |
tomoya123 | 0:d721efd58e4e | 1111 | d1 = HeptaCamera::ReadOneByte(); |
tomoya123 | 0:d721efd58e4e | 1112 | d2 = HeptaCamera::ReadOneByte(); |
tomoya123 | 0:d721efd58e4e | 1113 | |
tomoya123 | 0:d721efd58e4e | 1114 | switch (color_format) { |
tomoya123 | 0:d721efd58e4e | 1115 | case '1': |
tomoya123 | 0:d721efd58e4e | 1116 | // RGB444 to RGB888 |
tomoya123 | 0:d721efd58e4e | 1117 | b = (d1 & 0x0F) << 4; |
tomoya123 | 0:d721efd58e4e | 1118 | g = (d2 & 0xF0); |
tomoya123 | 0:d721efd58e4e | 1119 | r = (d2 & 0x0F) << 4; |
tomoya123 | 0:d721efd58e4e | 1120 | break; |
tomoya123 | 0:d721efd58e4e | 1121 | case '2': |
tomoya123 | 0:d721efd58e4e | 1122 | // RGB555 to RGB888 |
tomoya123 | 0:d721efd58e4e | 1123 | b = (d1 & 0x1F) << 3; |
tomoya123 | 0:d721efd58e4e | 1124 | g = (((d1 & 0xE0) >> 2) | ((d2 & 0x03) << 6)); |
tomoya123 | 0:d721efd58e4e | 1125 | r = (d2 & 0x7c) << 1; |
tomoya123 | 0:d721efd58e4e | 1126 | break; |
tomoya123 | 0:d721efd58e4e | 1127 | case '3': |
tomoya123 | 0:d721efd58e4e | 1128 | // RGB565 to RGB888 |
tomoya123 | 0:d721efd58e4e | 1129 | b = (d1 & 0x1F) << 3; |
tomoya123 | 0:d721efd58e4e | 1130 | g = (((d1 & 0xE0) >> 3) | ((d2 & 0x07) << 5)); |
tomoya123 | 0:d721efd58e4e | 1131 | r = (d2 & 0xF8); |
tomoya123 | 0:d721efd58e4e | 1132 | break; |
tomoya123 | 0:d721efd58e4e | 1133 | } |
tomoya123 | 0:d721efd58e4e | 1134 | #if defined(BITMAPFILE) || defined(HEXFILE) |
tomoya123 | 0:d721efd58e4e | 1135 | bmp_line_data[x*3] = (unsigned char)b; |
tomoya123 | 0:d721efd58e4e | 1136 | bmp_line_data[x*3 + 1] = (unsigned char)g; |
tomoya123 | 0:d721efd58e4e | 1137 | bmp_line_data[x*3 + 2] = (unsigned char)r; |
tomoya123 | 0:d721efd58e4e | 1138 | #endif |
tomoya123 | 0:d721efd58e4e | 1139 | /* |
tomoya123 | 0:d721efd58e4e | 1140 | // RGB |
tomoya123 | 0:d721efd58e4e | 1141 | pc.printf ("%2X%2X%2X", r, g, b) ; |
tomoya123 | 0:d721efd58e4e | 1142 | */ |
tomoya123 | 0:d721efd58e4e | 1143 | } |
tomoya123 | 0:d721efd58e4e | 1144 | #ifdef BITMAPFILE |
tomoya123 | 0:d721efd58e4e | 1145 | fwrite(bmp_line_data, sizeof(unsigned char), real_width, fp); |
tomoya123 | 0:d721efd58e4e | 1146 | #endif |
tomoya123 | 0:d721efd58e4e | 1147 | #ifdef HEXFILE |
tomoya123 | 0:d721efd58e4e | 1148 | for(int i=0; i<sizex*3; i++){ |
tomoya123 | 0:d721efd58e4e | 1149 | fprintf(fp2, "%02X", bmp_line_data[i]); |
tomoya123 | 0:d721efd58e4e | 1150 | } |
tomoya123 | 0:d721efd58e4e | 1151 | #endif |
tomoya123 | 0:d721efd58e4e | 1152 | // pc.printf("\r\n") ; |
tomoya123 | 0:d721efd58e4e | 1153 | } |
tomoya123 | 0:d721efd58e4e | 1154 | break; |
tomoya123 | 0:d721efd58e4e | 1155 | |
tomoya123 | 0:d721efd58e4e | 1156 | case '4': |
tomoya123 | 0:d721efd58e4e | 1157 | int index = 0; |
tomoya123 | 0:d721efd58e4e | 1158 | for (int y=0; y<sizey; y++) { |
tomoya123 | 0:d721efd58e4e | 1159 | int U0=0, Y0=0, V0=0, Y1=0; |
tomoya123 | 0:d721efd58e4e | 1160 | for (int x=0; x<sizex; x++) { |
tomoya123 | 0:d721efd58e4e | 1161 | if(index%2 == 0) { |
tomoya123 | 0:d721efd58e4e | 1162 | U0 = HeptaCamera::ReadOneByte(); |
tomoya123 | 0:d721efd58e4e | 1163 | Y0 = HeptaCamera::ReadOneByte(); |
tomoya123 | 0:d721efd58e4e | 1164 | V0 = HeptaCamera::ReadOneByte(); |
tomoya123 | 0:d721efd58e4e | 1165 | Y1 = HeptaCamera::ReadOneByte(); |
tomoya123 | 0:d721efd58e4e | 1166 | |
tomoya123 | 0:d721efd58e4e | 1167 | b = Y0 + 1.77200 * (U0 - 128); |
tomoya123 | 0:d721efd58e4e | 1168 | g = Y0 - 0.34414 * (U0 - 128) - 0.71414 * (V0 - 128); |
tomoya123 | 0:d721efd58e4e | 1169 | r = Y0 + 1.40200 * (V0 - 128); |
tomoya123 | 0:d721efd58e4e | 1170 | } else { |
tomoya123 | 0:d721efd58e4e | 1171 | b = Y1 + 1.77200 * (U0 - 128); |
tomoya123 | 0:d721efd58e4e | 1172 | g = Y1 - 0.34414 * (U0 - 128) - 0.71414 * (V0 - 128); |
tomoya123 | 0:d721efd58e4e | 1173 | r = Y1 + 1.40200 * (V0 - 128); |
tomoya123 | 0:d721efd58e4e | 1174 | } |
tomoya123 | 0:d721efd58e4e | 1175 | |
tomoya123 | 0:d721efd58e4e | 1176 | b = min(max(b, 0), 255); |
tomoya123 | 0:d721efd58e4e | 1177 | g = min(max(g, 0), 255); |
tomoya123 | 0:d721efd58e4e | 1178 | r = min(max(r, 0), 255); |
tomoya123 | 0:d721efd58e4e | 1179 | |
tomoya123 | 0:d721efd58e4e | 1180 | #if defined(BITMAPFILE) || defined(HEXFILE) |
tomoya123 | 0:d721efd58e4e | 1181 | bmp_line_data[x*3] = (unsigned char)b; |
tomoya123 | 0:d721efd58e4e | 1182 | bmp_line_data[x*3 + 1] = (unsigned char)g; |
tomoya123 | 0:d721efd58e4e | 1183 | bmp_line_data[x*3 + 2] = (unsigned char)r; |
tomoya123 | 0:d721efd58e4e | 1184 | #endif |
tomoya123 | 0:d721efd58e4e | 1185 | /* |
tomoya123 | 0:d721efd58e4e | 1186 | // RGB |
tomoya123 | 0:d721efd58e4e | 1187 | pc.printf ("%2X%2X%2X", r, g, b) ; |
tomoya123 | 0:d721efd58e4e | 1188 | */ |
tomoya123 | 0:d721efd58e4e | 1189 | index++; |
tomoya123 | 0:d721efd58e4e | 1190 | } |
tomoya123 | 0:d721efd58e4e | 1191 | #ifdef BITMAPFILE |
tomoya123 | 0:d721efd58e4e | 1192 | fwrite(bmp_line_data, sizeof(unsigned char), real_width, fp); |
tomoya123 | 0:d721efd58e4e | 1193 | #endif |
tomoya123 | 0:d721efd58e4e | 1194 | #ifdef HEXFILE |
tomoya123 | 0:d721efd58e4e | 1195 | for(int i=0; i<sizex*3; i++){ |
tomoya123 | 0:d721efd58e4e | 1196 | fprintf(fp2, "%02X", bmp_line_data[i]); |
tomoya123 | 0:d721efd58e4e | 1197 | } |
tomoya123 | 0:d721efd58e4e | 1198 | #endif |
tomoya123 | 0:d721efd58e4e | 1199 | // pc.printf("\r\n") ; |
tomoya123 | 0:d721efd58e4e | 1200 | } |
tomoya123 | 0:d721efd58e4e | 1201 | break; |
tomoya123 | 0:d721efd58e4e | 1202 | |
tomoya123 | 0:d721efd58e4e | 1203 | case '5': |
tomoya123 | 0:d721efd58e4e | 1204 | unsigned char *bayer_line[2]; |
tomoya123 | 0:d721efd58e4e | 1205 | unsigned char *bayer_line_data[2]; //画像1行分のRGB情報を格納する2行分 |
tomoya123 | 0:d721efd58e4e | 1206 | for(int i=0; i<2; i++) { |
tomoya123 | 0:d721efd58e4e | 1207 | if((bayer_line_data[i] = (unsigned char *)malloc(sizeof(unsigned char)*sizex)) == NULL){ |
tomoya123 | 0:d721efd58e4e | 1208 | fprintf(stderr, "Error: Allocation error.\n"); |
tomoya123 | 0:d721efd58e4e | 1209 | //return 1; |
tomoya123 | 0:d721efd58e4e | 1210 | } |
tomoya123 | 0:d721efd58e4e | 1211 | } |
tomoya123 | 0:d721efd58e4e | 1212 | |
tomoya123 | 0:d721efd58e4e | 1213 | for (int x=0; x<sizex; x++) { |
tomoya123 | 0:d721efd58e4e | 1214 | // odd line BGBG... even line GRGR... |
tomoya123 | 0:d721efd58e4e | 1215 | bayer_line_data[0][x] = (unsigned char)HeptaCamera::ReadOneByte(); |
tomoya123 | 0:d721efd58e4e | 1216 | #ifdef BAYERBITMAPFILE |
tomoya123 | 0:d721efd58e4e | 1217 | bmp_line_data[x*3] = (unsigned char)bayer_line_data[0][x]; |
tomoya123 | 0:d721efd58e4e | 1218 | bmp_line_data[x*3 + 1] = (unsigned char)bayer_line_data[0][x]; |
tomoya123 | 0:d721efd58e4e | 1219 | bmp_line_data[x*3 + 2] = (unsigned char)bayer_line_data[0][x]; |
tomoya123 | 0:d721efd58e4e | 1220 | #endif |
tomoya123 | 0:d721efd58e4e | 1221 | } |
tomoya123 | 0:d721efd58e4e | 1222 | #ifdef BAYERBITMAPFILE |
tomoya123 | 0:d721efd58e4e | 1223 | fwrite(bmp_line_data, sizeof(unsigned char), real_width, fp); |
tomoya123 | 0:d721efd58e4e | 1224 | #endif |
tomoya123 | 0:d721efd58e4e | 1225 | bayer_line[1] = bayer_line_data[0]; |
tomoya123 | 0:d721efd58e4e | 1226 | |
tomoya123 | 0:d721efd58e4e | 1227 | for (int y=1; y<sizey; y++) { |
tomoya123 | 0:d721efd58e4e | 1228 | int line = y%2; |
tomoya123 | 0:d721efd58e4e | 1229 | |
tomoya123 | 0:d721efd58e4e | 1230 | for (int x=0; x<sizex; x++) { |
tomoya123 | 0:d721efd58e4e | 1231 | // odd line BGBG... even line GRGR... |
tomoya123 | 0:d721efd58e4e | 1232 | bayer_line_data[line][x] = (unsigned char)HeptaCamera::ReadOneByte(); |
tomoya123 | 0:d721efd58e4e | 1233 | #ifdef BAYERBITMAPFILE |
tomoya123 | 0:d721efd58e4e | 1234 | bmp_line_data[x*3] = (unsigned char)bayer_line_data[line][x]; |
tomoya123 | 0:d721efd58e4e | 1235 | bmp_line_data[x*3 + 1] = (unsigned char)bayer_line_data[line][x]; |
tomoya123 | 0:d721efd58e4e | 1236 | bmp_line_data[x*3 + 2] = (unsigned char)bayer_line_data[line][x]; |
tomoya123 | 0:d721efd58e4e | 1237 | #endif |
tomoya123 | 0:d721efd58e4e | 1238 | } |
tomoya123 | 0:d721efd58e4e | 1239 | #ifdef BAYERBITMAPFILE |
tomoya123 | 0:d721efd58e4e | 1240 | fwrite(bmp_line_data, sizeof(unsigned char), real_width, fp); |
tomoya123 | 0:d721efd58e4e | 1241 | #endif |
tomoya123 | 0:d721efd58e4e | 1242 | bayer_line[0] = bayer_line[1]; |
tomoya123 | 0:d721efd58e4e | 1243 | bayer_line[1] = bayer_line_data[line]; |
tomoya123 | 0:d721efd58e4e | 1244 | |
tomoya123 | 0:d721efd58e4e | 1245 | for (int x=0; x<sizex - 1; x++) { |
tomoya123 | 0:d721efd58e4e | 1246 | if(y%2==1) { |
tomoya123 | 0:d721efd58e4e | 1247 | if(x%2==0) { |
tomoya123 | 0:d721efd58e4e | 1248 | // BG |
tomoya123 | 0:d721efd58e4e | 1249 | // GR |
tomoya123 | 0:d721efd58e4e | 1250 | b = bayer_line[0][x]; |
tomoya123 | 0:d721efd58e4e | 1251 | g = ((int)bayer_line[0][x+1] + bayer_line[1][x])>>1; |
tomoya123 | 0:d721efd58e4e | 1252 | r = bayer_line[1][x+1]; |
tomoya123 | 0:d721efd58e4e | 1253 | } else { |
tomoya123 | 0:d721efd58e4e | 1254 | // GB |
tomoya123 | 0:d721efd58e4e | 1255 | // RG |
tomoya123 | 0:d721efd58e4e | 1256 | b = bayer_line[0][x+1]; |
tomoya123 | 0:d721efd58e4e | 1257 | g = ((int)bayer_line[0][x] + bayer_line[1][x+1])>>1; |
tomoya123 | 0:d721efd58e4e | 1258 | r = bayer_line[1][x]; |
tomoya123 | 0:d721efd58e4e | 1259 | } |
tomoya123 | 0:d721efd58e4e | 1260 | } else { |
tomoya123 | 0:d721efd58e4e | 1261 | if(x%2==0) { |
tomoya123 | 0:d721efd58e4e | 1262 | // GR |
tomoya123 | 0:d721efd58e4e | 1263 | // BG |
tomoya123 | 0:d721efd58e4e | 1264 | b = bayer_line[1][x]; |
tomoya123 | 0:d721efd58e4e | 1265 | g = ((int)bayer_line[0][x] + bayer_line[1][x+1])>>1; |
tomoya123 | 0:d721efd58e4e | 1266 | r = bayer_line[0][x+1]; |
tomoya123 | 0:d721efd58e4e | 1267 | } else { |
tomoya123 | 0:d721efd58e4e | 1268 | // RG |
tomoya123 | 0:d721efd58e4e | 1269 | // GB |
tomoya123 | 0:d721efd58e4e | 1270 | b = bayer_line[1][x+1]; |
tomoya123 | 0:d721efd58e4e | 1271 | g = ((int)bayer_line[0][x+1] + bayer_line[1][x])>>1; |
tomoya123 | 0:d721efd58e4e | 1272 | r = bayer_line[0][x]; |
tomoya123 | 0:d721efd58e4e | 1273 | } |
tomoya123 | 0:d721efd58e4e | 1274 | } |
tomoya123 | 0:d721efd58e4e | 1275 | #if defined(BITMAPFILE) || defined(HEXFILE) |
tomoya123 | 0:d721efd58e4e | 1276 | bmp_line_data[x*3] = (unsigned char)b; |
tomoya123 | 0:d721efd58e4e | 1277 | bmp_line_data[x*3 + 1] = (unsigned char)g; |
tomoya123 | 0:d721efd58e4e | 1278 | bmp_line_data[x*3 + 2] = (unsigned char)r; |
tomoya123 | 0:d721efd58e4e | 1279 | #endif |
tomoya123 | 0:d721efd58e4e | 1280 | } |
tomoya123 | 0:d721efd58e4e | 1281 | |
tomoya123 | 0:d721efd58e4e | 1282 | #ifdef BITMAPFILE |
tomoya123 | 0:d721efd58e4e | 1283 | fwrite(bmp_line_data, sizeof(unsigned char), real_width, fp); |
tomoya123 | 0:d721efd58e4e | 1284 | #endif |
tomoya123 | 0:d721efd58e4e | 1285 | |
tomoya123 | 0:d721efd58e4e | 1286 | #ifdef HEXFILE |
tomoya123 | 0:d721efd58e4e | 1287 | for(int i=0; i<sizex*3; i++){ |
tomoya123 | 0:d721efd58e4e | 1288 | fprintf(fp2, "%02X", bmp_line_data[i]); |
tomoya123 | 0:d721efd58e4e | 1289 | } |
tomoya123 | 0:d721efd58e4e | 1290 | #endif |
tomoya123 | 0:d721efd58e4e | 1291 | } |
tomoya123 | 0:d721efd58e4e | 1292 | |
tomoya123 | 0:d721efd58e4e | 1293 | for(int i=0; i<2; i++) { |
tomoya123 | 0:d721efd58e4e | 1294 | free(bayer_line_data[i]); |
tomoya123 | 0:d721efd58e4e | 1295 | } |
tomoya123 | 0:d721efd58e4e | 1296 | #ifdef BITMAPFILE |
tomoya123 | 0:d721efd58e4e | 1297 | fwrite(bmp_line_data, sizeof(unsigned char), real_width, fp); |
tomoya123 | 0:d721efd58e4e | 1298 | #endif |
tomoya123 | 0:d721efd58e4e | 1299 | break; |
tomoya123 | 0:d721efd58e4e | 1300 | } |
tomoya123 | 0:d721efd58e4e | 1301 | HeptaCamera::ReadStop(); |
tomoya123 | 0:d721efd58e4e | 1302 | |
tomoya123 | 0:d721efd58e4e | 1303 | #if defined(BITMAPFILE) || defined(BAYERBITMAPFILE) |
tomoya123 | 0:d721efd58e4e | 1304 | free(bmp_line_data); |
tomoya123 | 0:d721efd58e4e | 1305 | fclose(fp); |
tomoya123 | 0:d721efd58e4e | 1306 | #endif |
tomoya123 | 0:d721efd58e4e | 1307 | #ifdef HEXFILE |
tomoya123 | 0:d721efd58e4e | 1308 | fclose(fp2); |
tomoya123 | 0:d721efd58e4e | 1309 | #endif |
tomoya123 | 0:d721efd58e4e | 1310 | |
tomoya123 | 0:d721efd58e4e | 1311 | } |