先上一下OV7670的框架图
OV7670常用寄存器设置说明
直接看OV7670 Implementation Guide (V1.0)等
资料我已经上传了
https://files.cnblogs.com/files/libra13179/OV7670%E5%AE%98%E6%96%B9%E6%96%87%E6%A1%A3.zip
我的寄存器配置
struct regval_list { unsigned char reg_num; unsigned char value; };
1 static struct regval_list ov7670_default_regs[] = 2 { 3 /** 4 *Frame Rate Adjustment for x Mhz input clock 5 *x fps, PCLK = xMhz 6 */ 7 {0x11, 0x00},// 内部时钟 CLKRC,对于拍照来说,值越大,越清楚,刷屏现像 越不重,摄像时,值过大 会造成跟不上 8 // 00 时,可能是对于 2.8的屏,对于 2.4屏 会出现 7格分屏现象 9 // 值越大时,摄头移动 图像拖尾就会越严重,反之OK 10 // 3值适中,2已有3分屏,0有7分屏,5拖尾重,10已花屏 11 // [7] 保留 12 // [6] 直接使用外部时钟(没有预分频) 13 // [5~0] 内部时钟分频 内部时钟 = 输入时钟/([5~0] + 1) [5~0] = 00000~11111 14 {0x6b, 0x40},//PLL*4 15 {0x2a, 0x00},//虚拟像素高位插入 16 {0x2b, 0x00},//虚拟像素低位插入 17 {0x92, 0x00},// DM_LNL 空行低8位 18 {0x93, 0x00},// DM_LNH 空行高8位 19 {0x3b, 0x02}, 20 21 //Output format 22 {0x12, 0x14},//QVGA(320*240)、RGB输出 23 24 //RGB555/565 option(must set COM7[2] = 1 and COM7[0] = 0) 25 {0x40, 0x10},//RGB565,effective only when RGB444[1] is low 26 {0x8c, 0x00}, 27 28 /** 29 *Special effects - 特效 30 */ 31 //normal 32 {0x3a, 0x04}, 33 {0x67, 0xc0}, 34 {0x68, 0x80}, 35 36 37 /** 38 *Mirror/VFlip Enable - 水平镜像/竖直翻转使能 39 */ 40 {0x1e, 0x37},//修改配置值将产生图像显示上下或左右颠倒 41 42 43 {0x01, 0x80}, //蓝色通道增益 44 {0x02, 0x80}, //红色通道增益 45 46 47 /** 48 * Banding Filter Setting for 24Mhz Input Clock - 条纹滤波器 49 * 30fps for 60Hz light frequency 50 */ 51 {0x13, 0xe0},//banding filer enable 52 {0x9d, 0x4c},//50Hz banding filer 53 {0x9e, 0x3f},//60Hz banding filer 54 {0xa5, 0x05},//3 step for 50Hz 55 {0xab, 0x07},//4 step for 60Hz 56 {0x3b, 0x02},//select 60Hz banding filer 57 58 59 //Simple White Balance - 白平衡 60 {0x13, 0xe0},//AWB、AGC、AGC Enable and ... 61 {0x6f, 0x9f},// AWBCTR0 AWB控制0 62 63 64 //AWBC - 自动白平衡控制(Automatic white balance control) 65 {0x43, 0x14},//用户手册里这些寄存器的值都是保留(Reserved),不用设置的呀? 66 {0x44, 0xf0}, 67 {0x45, 0x34}, 68 {0x46, 0x58}, 69 {0x47, 0x28}, 70 {0x48, 0x3a}, 71 //AWB Control 72 {0x59, 0x88},//用户手册连寄存器都是保留,初始值都没提供 73 {0x5a, 0x88}, 74 {0x5b, 0x44}, 75 {0x5c, 0x67}, 76 {0x5d, 0x49}, 77 {0x5e, 0x0e}, 78 //AWB Control 79 {0x6a, 0x40},// G通道 AWB增益 80 {0x6c, 0x0a},// AWBCTR3 AWB控制3 81 {0x6d, 0x55},// AWBCTR2 AWB控制2 82 {0x6e, 0x11},// AWBCTR1 AWB控制1 83 {0x6f, 0x9f},// AWBCTR0 AWB控制0 84 85 86 //AGC/AEC - Automatic Gain Control自动增益补偿/Automatic exposure Control自动曝光控制 87 {0x00, 0x00},// AGC 自动增益控制 (值越大 能有效控制 黑像时刷花屏现象) 88 {0x14, 0x20},//0x38, limit the max gain 89 {0x24, 0x75},// AEW AGC/AEC稳定运行区域上限 90 {0x25, 0x63},// AEB AGC/AEC稳定运行区域下限 91 {0x26, 0xA5},// VPT AGC/AEC快速运行区域 92 93 94 //AEC algorithm selection - AEC公式选择 95 {0xaa, 0x94},//基于平均值的AEC算法Average-based AEC algorithm/基于直方图的AEC算法Histogram-based AEC algorithm 96 //基于直方图的AGC/AEC的控制 97 {0x9f, 0x78},// HAECC1 基于直方图的AEC/AGC控制1 98 {0xa0, 0x68},// HAECC2 基于直方图的AEC/AGC控制2 99 {0xa6, 0xdf},// HAECC3 基于直方图的AEC/AGC控制3 100 {0xa7, 0xdf},// HAECC4 基于直方图的AEC/AGC控制4 101 {0xa8, 0xf0},// HAECC5 基于直方图的AEC/AGC控制5 102 {0xa9, 0x90},// HAECC6 基于直方图的AEC/AGC控制6 103 104 105 //Fix Gain Control - 固定增益控制 106 {0x69, 0x5d},//Fix gain for Gr channel/for Gb channel/for R channel/for B channel 107 108 109 //Matrix Coefficient - 色彩矩阵系数 110 //Color saturation 颜色饱和度 + 0 111 {0x4f, 0x80},// MTX1 色彩矩阵系数1 112 {0x50, 0x80},// MTX2 色彩矩阵系数2 113 {0x51, 0x00},// MTX3 色彩矩阵系数3 114 {0x52, 0x22},// MTX4 色彩矩阵系数4 115 {0x53, 0x5e},// MTX5 色彩矩阵系数5 116 {0x54, 0x80},// MTX6 色彩矩阵系数6 117 {0x58, 0x9e},// MTXS 色彩矩阵系数5~0的符号 118 119 120 //Brightness - 亮度 + 0 121 {0x55, 0x00}, //亮度控制 122 123 124 //Contrast - 对比度 + 0 125 {0x56, 0x60},//对比度 126 {0x57, 0x80},//对比度中心 127 128 /*Gamma Curve - 伽马曲线*/ 129 {0x7a, 0x20}, 130 {0x7b, 0x1c}, 131 {0x7c, 0x28}, 132 {0x7d, 0x3c}, 133 {0x7e, 0x55}, 134 {0x7f, 0x68}, 135 {0x80, 0x76}, 136 {0x81, 0x80}, 137 {0x82, 0x88}, 138 {0x83, 0x8f}, 139 {0x84, 0x96}, 140 {0x85, 0xa3}, 141 {0x86, 0xaf}, 142 {0x87, 0xc4}, 143 {0x88, 0xd7}, 144 {0x89, 0xe8}, 145 146 147 /** 148 *Lens Correction Option - 镜头补偿选项 149 */ 150 {0x62, 0x00};// LCC1 镜头补偿选项1 151 {0x63, 0x00};// LCC2 镜头补偿选项2 152 {0x64, 0x04},// LCC3 镜头补偿选项3 153 {0x65, 0x20},// LCC4 镜头补偿选项4 154 {0x66, 0x05},// LCC5 镜头补偿选项5 155 {0x94, 0x04},// LCC6 镜头校正选项(在LCC5[2]=1有效) 156 {0x95, 0x08},// LCC7 镜头校正选项(在LCC5[2]=1有效) 157 158 159 //输出窗口设置 160 //注释这些配置的话,就倾斜显示,并显示多块,这到底是控制什么的?跟时序图有关? 161 {0x17, 0x16},// HSTART 行输出格式 行帧(HREF列)起始的高8位(低3位在HREF[2~0]) 162 {0x18, 0x04},// HSTOP 行输出格式 行帧(HREF列)结束的高位(低3位在HREF[5~3]) 163 {0x19, 0x02},// VSTRT 场输出格式 场帧(行)起始的高8位(低2位在VREF[1~0]) 164 {0x1a, 0x7a},// VSTOP 场输出格式 场帧(行)结束的高8位(低2位在VREF[3~2]) 165 166 {0x32, 0x80},// HREF 控制 167 {0x03, 0x0a},// VREF 场帧控制 168 169 170 //注释这个配置的话,就显示花屏了 171 {0x15, 0x00},//配置PCLK、HREF、VSYNC相关 172 173 174 //Automatic black Level Compensation - 自动黑电平校正 175 {0xb0, 0x84},//调试时注释这项配置时,颜色显示不正常了,红色练绿色,绿色变红色,但用户手册对这寄存器是保留RSVD 176 177 {0xb1, 0x0c},// ABLC1 178 {0xb2, 0x0e},//保留 179 180 {0xb3, 0x82},//ABLC target 181 {0xb8, 0x0a},// 保留 182 183 184 //SCALING_xx寄存器 185 {0x70, 0x00},//SCALING_XSC,水平缩放系数 186 {0x71, 0x00},//SCALING_YSC,垂直缩放系数 187 {0x72, 0x11}, //SCALING_DCWCTR,DCW 控制 188 {0x73, 0x00},//SCALING_PC,旁路 DSP 缩放时钟分频控制 189 {0xa2, 0x02},//SCALING_PCLK_DELAY,像素始终延迟 190 {0x3e, 0x00},// COM14 通用控制14 191 // [7~5] 保留 192 // [4] DCW 和 PCLK 控制: 0 正常的 PCLK 1 DCW和PCLK由COM12[2~0]及SCALING_PCLK_DIV[3~0](0X73)控制 193 // [3] 手动缩放控制,应用于预定尺寸(CIF QCIF QVGA)时:0 禁止手动缩放 1 允许手动缩放 194 // [2~0] PCLK分频 (在COM14[4]为1时有效) 195 // 000 /1 196 // 001 /2 197 // 010 /4 198 // 011 /8 199 // 100 /16 200 // 101~111 不允许 201 202 //ADC 203 {0x37, 0x1d},//ADC控制ADC Control 204 {0x38, 0x71},//ADC和模拟共模控制ADC and Analog Common Mode Control 205 {0x39, 0x2a},//ADC偏移控制ADC Offset Control 206 207 208 //零杂的寄存器 209 210 211 212 {0x0c, 0x0c},// COM3 通用控制3 213 // [7] 保留 214 // [6] 输出数据进行 MSB和LSB 交换 215 // [5] 掉电期间输出时钟的状态 0 三态时钟 1 非三态时钟 216 // [4] 掉电期音输出数据的状态 0 三态数据 1 非三态数据 217 // [3] 缩放 0 禁止 1 使能(若设置(COM7[5~3])成预定模式的像时,然后将COM14[3]设成1 即可手动调节) 218 // [2] DCW控制 0 禁止 1 使能(若设置(COM7[5~3])成预定模式的像时,然后将COM14[3]设成1 即可手动调节) 219 // [1~0] 保留 220 221 222 {0x10, 0x00},// AECH 曝光值 223 224 225 {0x0d, 0x00}, 226 227 228 {0x0f, 0x4b}, 229 230 231 {0x3c, 0x78},//COM12 通用控制12 232 // [7] HERF操作 0 在VSYNC为低时没有HREF 1 HREF总是存在 233 // [6~0] 保留 234 235 236 {0x74, 0x19}, 237 238 239 //用户手册里这几个寄存器都是保留RSVD 240 {0x0e, 0x61}, 241 {0x16, 0x02}, 242 {0x21, 0x02},// ADCCTR1 保留 243 {0x22, 0x91},// ADCCTR2 保留 244 {0x29, 0x07},// ADCCTR3 保留 245 {0x33, 0x0b},// CHLF 感光阵列电流控制 保留 246 {0x35, 0x0b}, 247 {0x4d, 0x40}, 248 {0x4e, 0x20}, 249 {0x8d, 0x4f}, 250 {0x8e, 0x00}, 251 {0x8f, 0x00}, 252 {0x90, 0x00}, 253 {0x91, 0x00}, 254 {0x96, 0x00}, 255 {0x9a, 0x80}, 256 {0x97, 0x30}, 257 {0x98, 0x20}, 258 {0x99, 0x30}, 259 {0x9b, 0x29}, 260 {0x9c, 0x03}, 261 };