0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

自己生成MJPG格式AVI文件

聚丰开发 2018-11-02 14:37 次阅读


注:本文是作者以前发表在其个人博客,现在发布到“聚丰开发”专栏




现在电子产品经常需要使用到视频,于是对视频技术的需求也日益高涨,通常做法是采用现成的硬件或软件方案来实现对视频数据的处理,要说掌握这部分算法的人并不多,大多数工程师没有时间和精力去消化吸收这些算法。


MJPG是最简单的视频文件格式,存储时是将图像用JPG格式一帧一帧的保存起来,回放的时候按照规定的时间间隔一帧一帧的回放。用这种处理方法算法相对比较简单,如果对图像要求不高可以达到20~30倍的压缩率,对于单片机来说不失为一种可行性较高的备选方案。


以前有个项目需要支持MJPG文件,为此我写了一段PC程序进行代码验证,同时生成测试用MJPG文件。具体做法是预先做好10张JPG图片,每张图片都有VGA和QVGA两种尺寸,然后按输入参数生成相应的MJPG文件。比如输入选择VGA/10帧,生成的MJPG文件第一秒为第一张VGA图片重复10次,依此类推。


程序生成的MJPG用电脑播放,如果能正常播放,就说明代码对文件格式的处理基本正确。这里程序每一帧都对应有自己的JPG数据,实际上可以不这么做,MJPG文件有音频和视频流的播放序号,如果相邻的视频帧内容相同,是可以将播放序号指向同一张JPG图像数据的。




每一帧自己有独立的JPG图像数据
播放序号: JPG01 JPG02 JPG03 ... JPG09 JPG10 JPG11
JPG01_Data:
...(第一张图片内容)...
JPG02_Data:
...(第一张图片内容)...
...
JPG09_Data:
...(第一张图片内容)...
JPG10_Data:
...(第一张图片内容)...
JPG11_Data:
...(第二张图片内容)...

相邻帧相同利用同一张JPG数据
播放序号: JPG01 JPG01 JPG01 ... JPG01 JPG01 JPG02
JPG01_Data:
...(第一张图片内容)...
JPG02_Data:
...(第二张图片内容)...
...
JPG10_Data:
...(第十张图片内容)...

注意代码只是用于临时工具,没有详细注释进行说明,代码书写也存在许多不规范的地方。



-------------------------参考代码---------------------------

#include "string.h"
#include "stdio.h"

/*unsigned char mMJPEG_Header[] =
{
0x52,0x49,0x46,0x46,//0x0000 "RIFF"
0x00,0x00,0x00,0x00,//0x0004 length of data, need update
it
0x41,0x56,0x49,0x20,//0x0008 RIFF form identifier "AVI "

0x4C,0x49,0x53,0x54,//0x000C List identifier "LIST"
0x46,0x01,0x00,0x00,//0x0010 Length of list(326 bytes)
0x68,0x64,0x72,0x6C,//0x0014 List type identifier "hdrl"

0x61,0x76,0x69,0x68,//0x0018 Chunk identifier "avih"
0x38,0x00,0x00,0x00,//0x001C Length of chunk(56 bytes)
0x00,0x00,0x00,0x00,//0x0020 Number of us per fer fram
e(=1000000/FrameRate), need update it
0x00,0x00,0x00,0x00,//0x0024 Max bytes per second(ignored)
0x00,0x00,0x00,0x00,//0x0028 Padding granularity(ignored)
0x10,0x00,0x01,0x00,//0x00,0x00,0x00,0x00,//0x002C Flags
0x00,0x00,0x00,0x00,//0x0030 Total number of frame, need update it
0x00,0x00,0x00,0x00,//0x0034 Intial frame number for frames
0x02,0x00,0x00,0x00,//0x0038 Number of streams(2)
0x00,0x00,0x10,0x00,//0x00,0x00,0x00,0x00,//0x003C Suggested buffer size(ignored)
0x00,0x00,0x00,0x00,//0x0040 Width of video, need update it
0x00,0x00,0x00,0x00,//0x0044 Height of video, need update it
0x00,0x00,0x00,0x00,//0x0048 Reserved
0x00,0x00,0x00,0x00,//0x004C Reserved
0x00,0x00,0x00,0x00,//0x0050 Reserved
0x00,0x00,0x00,0x00,//0x0054 Reserved

0x4C,0x49,0x53,0x54,//0x0058 List identifier "LIST"
0x94,0x00,0x00,0x00,//0x005C Length of list(148 bytes)
0x73,0x74,0x72,0x6C,//0x0060 List type identifier"strl"

0x73,0x74,0x72,0x68,//0x0064 Chunk identifier "strh"
0x38,0x00,0x00,0x00,//0x0068 Length of chunk(56 bytes)
0x76,0x69,0x64,0x73,//0x006C Stream type identifier "vids"
0x4D,0x4A,0x50,0x47,//0x0070 Stream handler identifier "MJPG"
0x00,0x00,0x00,0x00,//0x0074 Flags
0x00,0x00,//0x0078 Priority(ignored)
0x00,0x00,//0x007A Language(ignored)
0x00,0x00,0x00,0x00,//0x007C Initial frame number(usually is 0)
0x01,0x00,0x00,0x00,//0x0080 Scale(usually is 1)
0x40,0x42,0x0f,0x00,//0x00,0x00,0x00,0x00,//0x0084 Frame rate, need update it
0x00,0x00,0x00,0x00,//0x0088 Star(usually is 0)
0x00,0x00,0x00,0x00,//0x008C Length(usually is total numbers
of frames), need update it
0x00,0x00,0x10,0x00,//0x00,0x00,0x00,0x00,//0x0090 Suggested buffer size(ignored)
0x10,0x27,0x00,0x00,//0x00,0x00,0x00,0x00,//0x0094 Quality(ignored)
0x00,0x00,0x00,0x00,//0x0098 Sample size(ignored)
0x00,0x00,//0x009C Frame upper left X coordinate
0x00,0x00,//0x009E Frame upper left Y coordinate
0x00,0x00,//0x00A0 Frame lower right X coordinate, need update it
0x00,0x00,//0x00A2 Frame lower right Y coordinate, need update it

0x73,0x74,0x72,0x66,//0x00A4 Chunk identifier "strf"
0x48,0x00,0x00,0x00,//0x00A8 Length of chunk(72 bytes)
0x28,0x00,0x00,0x00,//0x48,0x00,0x00,0x00,//0x00AC Length of this chunk(72 bytes)
0x00,0x00,0x00,0x00,//0x00B0 Width of video, need update it
0x00,0x00,0x00,0x00,//0x00B4 Height of video, need update it
0x01,0x00,//0x00B8 Number of planes(1)
0x18,0x00,//0x10,0x00,//0x00BA Bits per pi
xel(16)
0x4D,0x4A,0x50,0x47,//0x00BC Stream handler identifier "MJPG"
0x00,0x00,0x00,0x00,//0x00C0 Raw image size, need update it
0x00,0x00,0x00,0x00,//0x00C4 X pixels per meter(ignored)
0x00,0x00,0x00,0x00,//0x00C8 Y pixels pre meter(ignored)
0x00,0x00,0x00,0x00,//0x00CC Number of colors used(ignored)
0x00,0x00,0x00,0x00,//0x00D0 Number of colors important(ignored)
0x00,0x00,0x00,0x00,//0x00D4 DV audio channel 0 auxillary source(ignored)
0x00,0x00,0x00,0x00,//0x00D8 DV audio channel 0 auxillary control(ignored)
0x00,0x00,0x00,0x00,//0x00DC DV audio channel 1 auxillary source(ignored)
0x00,0x00,0x00,0x00,//0x00E0 DV audio channel 1 auxillary control(ignored)
0x00,0x00,0x00,0x00,//0x00E4 DV video auxillary source(ignored)
0x00,0x00,0x00,0x00,//0x00E8 DV video auxillary control(ignored)
0x00,0x00,0x00,0x00,//0x00EC Reserved
0x00,0x00,0x00,0x00,//0x00F0 Reserved

0x4C,0x49,0x53,0x54,//0x00F4 List identifier "LIST"
0x62,0x00,0x00,0x00,//0x00F8 Length of list(98 bytes)
0x73,0x74,0x72,0x6C,//0x00FC List type identifier "strl"

0x73,0x74,0x72,0x68,//0x0100 Chunk indentifier "strh"
0x38,0x00,0x00,0x00,//0x0104 Length of chunk(56 bytes)
0x61,0x75,0x64,0x73,//0x0108 Stream type identifier "auds"
0x00,0x00,0x00,0x00,//0x20,0x20,0x20,0x20,//0x010C Stream handler identifier
0x00,0x00,0x00,0x00,//0x0110 Flags
0x00,0x00,//0x0114 Priority(ignored)
0x00,0x00,//0x0116 Language(ignored)
0x00,0x00,0x00,0x00,//0x0118 Initial frame number(usually is 0)
0x01,0x00,0x00,0x00,//0x011C Scale(usually is 1)
0x40,0x1F,0x00,0x00,//0x0120 Sampling rate(8k)
0x00,0x00,0x00,0x00,//0x0124 Start(usually is 0)
0x00,0x00,0x00,0x00,//0x0128 Length(number of audio data segments), need update it
0x00,0x00,0x10,0x00,//0x00,0x00,0x00,0x00,//0x012C Suggested buffer size(ignored)
0x10,0x27,0x00,0x00,//0x00,0x00,0x00,0x00,//0x0130 Quality(ignored)
0x01,0x00,0x00,0x00,//0x00,0x00,0x00,0x00,//0x0134 Sample size(ignored)
0x00,0x00,//0x0138 Frame upper left X coordinate(ignored)
0x00,0x00,//0x013A Frame upper left Y coordinate(ignored)
0x00,0x00,//0x013C Frame lower right X coordinate(ignored)
0x00,0x00,//0x013E Frame lower right Y coordinate(ignored)

0x73,0x74,0x72,0x66,//0x0140 Chunk identifier "strf"
0x12,0x00,0x00,0x00,//0x0144 Length of chunk(18 bytes)
0x01,0x00,//0x0148 Format tag(PCM is 1)
0x01,0x00,//0x014A Number of audio channels(1)
0x40,0x1F,0x00,0x00,//0x014C Sampling rate(8k)
0x40,0x1F,0x00,0x00,//0x0150 Sampling rate x Number of audio channels
0x01,0x00,//0x00,0x00,//0x0154 Block alignment(ignored)
0x08,0x00,//0x0156 Bits per sample(8)
0x00,0x00,//0x0158 Size of extra information(0)

//0x4C,0x49,0x53,0x54,//0x015A List identifier "LIST"
//0x00,0x00,0x00,0x00,//0x015E Length of list, need update it
//0x6D,0x6F,0x76,0x69//0x0162 List type identifier "movi"
};*/


unsigned char mMJPEG_Header[]={
0x52, 0x49, 0x46, 0x46, 0x34, 0x06, 0x1c, 0x00, 0x41, 0x56, 0x49, 0x20, 0x4c, 0x49, 0x53, 0x54,
0x46, 0x01, 0x00, 0x00, 0x68, 0x64, 0x72, 0x6c, 0x61, 0x76, 0x69, 0x68, 0x38, 0x00, 0x00, 0x00,
0x6a, 0x04, 0x01, 0x00, 0x4a, 0x65, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x00, 0x01, 0x00,
0x68, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x26, 0x48, 0x00, 0x00,
0x40, 0x01, 0x00, 0x00, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x4c, 0x49, 0x53, 0x54, 0x74, 0x00, 0x00, 0x00,
0x73, 0x74, 0x72, 0x6c, 0x73, 0x74, 0x72, 0x68, 0x38, 0x00, 0x00, 0x00, 0x76, 0x69, 0x64, 0x73,
0x6d, 0x6a, 0x70, 0x67, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x6a, 0x04, 0x01, 0x00, 0x40, 0x42, 0x0f, 0x00, 0x00, 0x00, 0x00, 0x00, 0x68, 0x00, 0x00, 0x00,
0x26, 0x48, 0x00, 0x00, 0x10, 0x27, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x40, 0x01, 0xf0, 0x00, 0x73, 0x74, 0x72, 0x66, 0x28, 0x00, 0x00, 0x00, 0x28, 0x00, 0x00, 0x00,
0x40, 0x01, 0x00, 0x00, 0xf0, 0x00, 0x00, 0x00, 0x01, 0x00, 0x18, 0x00, 0x4d, 0x4a, 0x50, 0x47,
0x00, 0x84, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x4c, 0x49, 0x53, 0x54, 0x5c, 0x00, 0x00, 0x00, 0x73, 0x74, 0x72, 0x6c,
0x73, 0x74, 0x72, 0x68, 0x38, 0x00, 0x00, 0x00, 0x61, 0x75, 0x64, 0x73, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00,
0x10, 0x2b, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x92, 0x2a, 0x01, 0x00, 0x10, 0x2b, 0x00, 0x00,
0x10, 0x27, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x73, 0x74, 0x72, 0x66, 0x10, 0x00, 0x00, 0x00, 0x01, 0x00, 0x01, 0x00, 0x10, 0x2b, 0x00, 0x00,
0x10, 0x2b, 0x00, 0x00, 0x01, 0x00, 0x08, 0x00, 0x49, 0x44, 0x49, 0x54, 0x1a, 0x00, 0x00, 0x00,
0x54, 0x48, 0x55, 0x20, 0x4e, 0x4f, 0x56, 0x20, 0x30, 0x36, 0x20, 0x31, 0x36, 0x3a, 0x34, 0x32,
0x3a, 0x32, 0x36, 0x20, 0x32, 0x30, 0x30, 0x38, 0x0a, 0x00, 0x4c, 0x49, 0x53, 0x54, 0x18, 0x00,
0x00, 0x00, 0x49, 0x4e, 0x46, 0x4f, 0x49, 0x53, 0x46, 0x54, 0x0c, 0x00, 0x00, 0x00, 0x43, 0x61,
0x6e, 0x6f, 0x6e, 0x4d, 0x56, 0x49, 0x30, 0x32, 0x00, 0x00, 0x4a, 0x55, 0x4e, 0x4b, 0x7e, 0x06,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x4c, 0x49, 0x53, 0x54, 0x3c, 0xf7, 0x1b, 0x00, 0x6d, 0x6f, 0x76, 0x69};

void make_qvga_mjpeg()
{
unsigned long mFrameRate,mFrameTime,i,j,k,mTemp;
unsigned long mTargetFileLength,mSourceFileLength;
unsigned long mOffset,mSize;
unsigned char sFileName[256],ch;
FILE *fp1,*fp2,*fp3,*fp4;

mFrameRate=0;
printf("\r\nBegin make QVGA MJPG file\r\n");
while((mFrameRate<5)||(mframerate>30))
{
printf("Please input frame rate(5~30):");
scan
f("%d",&mFrameRate);
}
printf("Please input target filename:");
scanf("%s",sFileName);

mFrameTime=1000000/mFrameRate;

mMJPEG_Header[0x20]=(unsigned char)mFrameTime&0xFF;
mMJPEG_Header[0x21]=(unsigned char)(mFrameTime>>8)&0xFF;
mMJPEG_Header[0x22]=(unsigned char)(mFrameTime>>16)&0xFF;
mMJPEG_Header[0x23]=(unsigned char)(mFrameTime>>24)&0xFF;

mMJPEG_Header[0x30]=(unsigned char)(mFrameRate*10)&0xFF;
mMJPEG_Header[0x31]=(unsigned char)((mFrameRate*10)>>8)&0xFF;
mMJPEG_Header[0x32]=(unsigned char)((mFrameRate*10)>>16)&0xFF;
mMJPEG_Header[0x33]=(unsigned char)((mFrameRate*10)>>24)&0xFF;

mMJPEG_Header[0x40]=0x40;
mMJPEG_Header[0x41]=0x01;
mMJPEG_Header[0x42]=0x00;
mMJPEG_Header[0x43]=0x00;

mMJPEG_Header[0x44]=0xF0;
mMJPEG_Header[0x45]=0x00;
mMJPEG_Header[0x46]=0x00;
mMJPEG_Header[0x47]=0x00;

mMJPEG_Header[0x80]=(unsigned char)mFrameTime&0xFF;
mMJPEG_Header[0x81]=(unsigned char)(mFrameTime>>8)&0xFF;
mMJPEG_Header[0x82]=(unsigned char)(mFrameTime>>16)&0xFF;
mMJPEG_Header[0x83]=(unsigned char)(mFrameTime>>24)&0xFF;

//mMJPEG_Header[0x84]=(unsigned char)mFrameRate&0xFF;
//mMJPEG_Header[0x85]=(unsigned char)(mFrameRate>>8)&0xFF;
//mMJPEG_Header[0x86]=(unsigned char)(mFrameRate>>16)&0xFF;
//mMJPEG_Header[0x87]=(unsigned char)(mFrameRate>>24)&0xFF;

mMJPEG_Header[0x8C]=(unsigned char)(mFrameRate*10)&0xFF;
mMJPEG_Header[0x8D]=(unsigned char)((mFrameRate*10)>>8)&0xFF;
mMJPEG_Header[0x8E]=(unsigned char)((mFrameRate*10)>>16)&0xFF;
mMJPEG_Header[0x8F]=(unsigned char)((mFrameRate*10)>>24)&0xFF;

mMJPEG_Header[0xA0]=0x40;
mMJPEG_Header[0xA1]=0x01;
mMJPEG_Header[0xA2]=0xF0;
mMJPEG_Header[0xA3]=0x00;

mMJPEG_Header[0xB0]=0x40;
mMJPEG_Header[0xB1]=0x01;
mMJPEG_Header[0xB2]=0x00;
mMJPEG_Header[0xB3]=0x00;

mMJPEG_Header[0xB4]=0xF0;
mMJPEG_Header[0xB5]=0x00;
mMJPEG_Header[0xB6]=0x00;
mMJPEG_Header[0xB7]=0x00;

//mMJPEG_Header[0xBA]=0x18;//must set as 24
//mMJPEG_Header[0xBB]=0x00;

mMJPEG_Header[0xC0]=0x00;
mMJPEG_Header[0xC1]=0x58;
mMJPEG_Header[0xC2]=0x02;
mMJPEG_Header[0xC3]=0x00;

mMJPEG_Header[0x120-0x20]=0x40;
mMJPEG_Header[0x121-0x20]=0x1F;
mMJPEG_Header[0x122-0x20]=0x00;
mMJPEG_Header[0x123-0x20]=0x00;

mMJPEG_Header[0x128-0x20]=(unsigned char)(8000*10)&0xFF;
mMJPEG_Header[0x129-0x20]=(unsigned char)((8000*10)>>8)&0xFF;
mMJPEG_Header[0x12A-0x20]=(unsigned char)((8000*10)>>16)&0xFF;
mMJPEG_Header[0x12B-0x20]=(unsigned char)((8000*10)>>24)&0xFF;

mMJPEG_Header[0x12C-0x20]=0x40;
mMJPEG_Header[0x12D-0x20]=0x1F;
mMJPEG_Header[0x12E-0x20]=0x00;
mMJPEG_Header[0x12F-0x20]=0x00;

mMJPEG_Header[0x14C-0x20]=0x40;
mMJPEG_Header[0x14D-0x20]=0x1F;
mMJPEG_Header[0x14E-0x20]=0x00;
mMJPEG_Header[0x14F-0x20]=0x00;

mMJPEG_Header[0x150-0x20]=0x40;
mMJPEG_Header[0x151-0x20]=0x1f;
mMJPEG_Header[0x152-0x20]=0x00;
mMJPEG_Header[0x153-0x20]=0x00;

/*mMJPEG_Header[0x120]=0x10;
mMJPEG_Header[0x121]=0x2B;
mMJPEG_Header[0x122]=0x00;
mMJPEG_Header[0x123]=0x00;

mMJPEG_Header[0x128]=(unsigned char)(8000*10)&0xFF;
mMJPEG_Header[0x129]=(unsigned char)((8000*10)>>8)&0xFF;
mMJPEG_Header[0x12A]=(unsigned char)((8000*10)>>16)&0xFF;
mMJPEG_Header[0x12B]=(unsigned char)((8000*10)>>24)&0xFF;

mMJPEG_Header[0x12C]=0x10;
mMJPEG_Header[0x12D]=0x2B;
mMJPEG_Header[0x12E]=0x00;
mMJPEG_Header[0x12F]=0x00;

mMJPEG_Header[0x14C]=0x10;
mMJPEG_Header[0x14D]=0x2B;
mMJPEG_Header[0x14E]=0x00;
mMJPEG_Header[0x14F]=0x00;

mMJPEG_Header[0x150]=0x10;
mMJPEG_Header[0x151]=0x2B;
mMJPEG_Header[0x152]=0x00;
mMJPEG_Header[0x153]=0x00;*/

mMJPEG_Header[0x3C]=0x00;
mMJPEG_Header[0x3D]=0x00;
mMJPEG_Header[0x3E]=0x10;
mMJPEG_Header[0x3F]=0x00;

mMJPEG_Header[0x90]=0x00;
mMJPEG_Header[0x91]=0x00;
mMJPEG_Header[0x92]=0x10;
mMJPEG_Header[0x93]=0x00;


fp1=fopen(sFileName,"wb+");
if(fp1==NULL)
{
printf("Target file open error!\r\n");
fcloseall();
return;
}
fp3=fopen("idx_tmp.bin","wb+");
if(fp3==NULL)
{
printf("Target file open error!\r\n");
fcloseall();
return;
}
fp4=fopen("10.pcm","rb+");
if(fp4==NULL)
{
printf("Source file open error!\r\n");
fcloseall();
return;
}

fwrite(mMJPEG_Header,1,sizeof(mMJPEG_Header),fp1);

//----------------
/*ch='L';
fwrite(&ch,1,1,fp3);
ch='I';
fwrite(&ch,1,1,fp3);
ch='S';
fwrite(&ch,1,1,fp3);
ch='T';
fwrite(&ch,1,1,fp3);
ch=0;
fwrite(&ch,1,1,fp3);
ch=0;
fwrite(&ch,1,1,fp3);
ch=0;
fwrite(&ch,1,1,fp3);
ch=0;
fwrite(&ch,1,1,fp3);
ch='m';
fwrite(&ch,1,1,fp3);
ch='o';
fwrite(&ch,1,1,fp3);
ch='v';
fwrite(&ch,1,1,fp3);
ch='i';
fwrite(&ch,1,1,fp3);*/
//-------------

ch='i';
fwrite(&ch,1,1,fp3);
ch='d';
fwrite(&ch,1,1,fp3);
ch='x';
fwrite(&ch,1,1,fp3);
ch='1';
fwrite(&ch,1,1,fp3);
mTemp=0;
fwrite(&mTemp,1,4,fp3);
mOffset=4;

for(i=0;i<10;i++)
{
switch(i)
{
case 0:
printf("0b.jpg ");
fp2=fopen("0b.jpg","rb+");
break;
case 1:
printf("1b.jpg ");
fclose(fp2);
fp2=fopen("1b.jpg","rb+");
break;
case 2:
printf("2b.jpg ");
fclose(fp2);
fp2=fopen("2b.jpg","rb+");
break;
case 3:
printf("3b.jpg ");
fclose(fp2);
fp2=fopen("3b.jpg","rb+");
break;
case 4:
printf("4b.jpg ");
fclose(fp2);
fp2=fopen("4b.jpg","rb");
break;
case 5:
printf("5b.jpg ");
fclose(fp2);
fp2=fopen("5b.jpg","rb+");
break;
case 6:
printf("6b.jpg ");
fclose(fp2);
fp2=fopen("6b.jpg","rb+");
break;
case 7:
printf("7b.jpg ");
fclose(fp2);
fp2=fopen("7b.jpg","rb+");
break;
case 8:
printf("8b.jpg ");
fclose(fp2);
fp2=fopen("8b.jpg","rb+");
break;
default:
printf("9b.jpg ");
fclose(fp2);
fp2=fopen("9b.jpg","rb+");
break;
}
if(fp2==NULL)
{
printf("Source file open error!\r\n");
fcloseall();
return;
}
//mSourceFileLength=(unsigned long)filelength(fp2);
fseek(fp2,0,SEEK_END);
mSourceFileLength=(unsigned long)ftell(fp2);


for(j=0;j{
//video
ch='0';
fwrite(&ch,1,1,fp3);
ch='0';
fwrite(&ch,1,1,fp3);
ch='d';
fwrite(&ch,1,1,fp3);
ch='c';
fwrite(&ch,1,1,fp3);
mTemp=0x00000010;
fwrite(&mTemp,1,4,fp3);
fwrite(&mOffset,1,4,fp3);
mSize=mSourceFileLength;
if(mSize&1)
{
//mSize++;
}
fwrite(&mSize,1,4,fp3);
mOffset+=(mSize+8);


ch='0';
fwrite(&ch,1,1,fp1);
ch='0';
fwrite(&ch,1,1,fp1);
ch='d';
fwrite(&ch,1,1,fp1);
ch='c';
fwrite(&ch,1,1,fp1);
mSize=mSourceFileLength;
if(mSize&1)
{
//mSize++;
}
fwrite(&mSize,1,4,fp1);
fseek(fp2,0,SEEK_SET);
for(k=0;k{
if((k&0xFF)==0)
{
printf(".");
}
fread(&ch,1,1,fp2);
fwrite(&ch,1,1,fp1);
}
if(mSourceFileLength&1)
{
ch=0;//double bytes align
//fwrite(&ch,1,1,fp1);
}

//audio
ch='0';
fwrite(&ch,1,1,fp3);
ch='1';
fwrite(&ch,1,1,fp3);
ch='w';
fwrite(&ch,1,1,fp3);
ch='b';
fwrite(&ch,1,1,fp3);
mTemp=0x00000010;
fwrite(&mTemp,1,4,fp3);
fwrite(&mOffset,1,4,fp3);
mSize=8000/mFrameRate;
if(mSize&1)
{
//mSize++;//double bytes align
}
fwrite(&mSize,1,4,fp3);
mOffset+=(mSize+8);

k=ftell(fp1);
ch='0';
fwrite(&ch,1,1,fp1);
ch='1';
fwrite(&ch,1,1,fp1);
ch='w';
fwrite(&ch,1,1,fp1);
ch='b';
fwrite(&ch,1,1,fp1);
mSize=8000/mFrameRate;
if(mSize&1)
{
//mSize++;//double bytes align
}
fwrite(&mSize,1,4,fp1);
ch=0;
for(k=0;k{
if((k&0xFF)==0)
{
printf(".");
}
//ch++;
fread(&ch,1,1,fp4);
fwrite(&ch,1,1,fp1);
}
}
}
mTargetFileLength=ftell(fp1);
if(mTargetFileLength&1)
{
ch=0;
fwrite(&ch,1,1,fp1);
}
mSize=ftell(fp3);
mSize-=8;
fseek(fp3,4,SEEK_SET);
fwrite(&mSize,1,4,fp3);

mTargetFileLength=ftell(fp1);
mTargetFileLength-=0x808;
fseek(fp1,0x0804,SEEK_SET);
fwrite(&mTargetFileLength,1,4,fp1);
//mTargetFileLength=ftell(fp1);
//mTargetFileLength-=(sizeof(mMJPEG_Header)+8);
//fseek(fp1,sizeof(mMJPEG_Header)+4,SEEK_SET);
//fwrite(&mTargetFileLength,1,4,fp1);

fseek(fp1,0,SEEK_END);
mSize+=8;
fseek(fp3,0,SEEK_SET);
for(i=0;i{
fread(&ch,1,1,fp3);
fwrite(&ch,1,1,fp1);
}

mTargetFileLength=ftell(fp1);
fseek(fp1,0x0004,SEEK_SET);
mTargetFileLength-=8;
fwrite(&mTargetFileLength,1,4,fp1);

printf("\r\n");
fcloseall();
}

void make_vga_mjpeg()
{
unsigned long mFrameRate,mFrameTime,i,j,k,mTemp;
unsigned long mTargetFileLength,mSourceFileLength;
unsigned long mOffset,mSize;
unsigned char sFileName[256],ch;
FILE *fp1,*fp2,*fp3,*fp4;

mFrameRate=0;
printf("\r\nBegin make VGA MJPG file\r\n");
while((mFrameRate<5)||(mframerate>30))
{
printf("Please input frame rate(5~30):");
scanf("%d",&mFrameRate);
}
printf("Please input target filename:");
scanf("%s",sFileName);

mFrameTime=1000000/mFrameRate;

mMJPEG_Header[0x20]=(unsigned char)mFrameTime&0xFF;
mMJPEG_Header[0x21]=(unsigned char)(mFrameTime>>8)&0xFF;
mMJPEG_Header[0x22]=(unsigned char)(mFrameTime>>16)&0xFF;
mMJPEG_Header[0x23]=(unsigned char)(mFrameTime>>24)&0xFF;

mMJPEG_Header[0x30]=(unsigned char)(mFrameRate*10)&0xFF;
mMJPEG_Header[0x31]=(unsigned char)((mFrameRate*10)>>8)&0xFF;
mMJPEG_Header[0x32]=(unsigned char)((mFrameRate*10)>>16)&0xFF;
mMJPEG_Header[0x33]=(unsigned char)((mFrameRate*10)>>24)&0xFF;

mMJPEG_Header[0x40]=0x80;
mMJPEG_Header[0x41]=0x02;
mMJPEG_Header[0x42]=0x00;
mMJPEG_Header[0x43]=0x00;

mMJPEG_Header[0x44]=0xE0;
mMJPEG_Header[0x45]=0x01;
mMJPEG_Header[0x46]=0x00;
mMJPEG_Header[0x47]=0x00;

mMJPEG_Header[0x80]=(unsigned char)mFrameTime&0xFF;
mMJPEG_Header[0x81]=(unsigned char)(mFrameTime>>8)&0xFF;
mMJPEG_Header[0x82]=(unsigned char)(mFrameTime>>16)&0xFF;
mMJPEG_Header[0x83]=(unsigned char)(mFrameTime>>24)&0xFF;

//mMJPEG_Header[0x84]=(unsigned char)mFrameRate&0xFF;
//mMJPEG_Header[0x85]=(unsigned char)(mFrameRate>>8)&0xFF;
//mMJPEG_Header[0x86]=(unsigned char)(mFrameRate>>16)&0xFF;
//mMJPEG_Header[0x87]=(unsigned char)(mFrameRate>>24)&0xFF;

mMJPEG_Header[0x8C]=(unsigned char)(mFrameRate*10)&0xFF;
mMJPEG_Header[0x8D]=(unsigned char)((mFrameRate*10)>>8)&0xFF;
mMJPEG_Header[0x8E]=(unsigned char)((mFrameRate*10)>>16)&0xFF;
mMJPEG_Header[0x8F]=(unsigned char)((mFrameRate*10)>>24)&0xFF;

mMJPEG_Header[0xA0]=0x80;
mMJPEG_Header[0xA1]=0x02;
mMJPEG_Header[0xA2]=0xE0;
mMJPEG_Header[0xA3]=0x01;

mMJPEG_Header[0xB0]=0x80;
mMJPEG_Header[0xB1]=0x02;
mMJPEG_Header[0xB2]=0x00;
mMJPEG_Header[0xB3]=0x00;

mMJPEG_Header[0xB4]=0xE0;
mMJPEG_Header[0xB5]=0x01;
mMJPEG_Header[0xB6]=0x00;
mMJPEG_Header[0xB7]=0x00;

//mMJPEG_Header[0xBA]=0x18;//must set as 24
//mMJPEG_Header[0xBB]=0x00;

mMJPEG_Header[0xC0]=0x00;
mMJPEG_Header[0xC1]=0x60;
mMJPEG_Header[0xC2]=0x09;
mMJPEG_Header[0xC3]=0x00;

mMJPEG_Header[0x120-0x20]=0x40;
mMJPEG_Header[0x121-0x20]=0x1F;
mMJPEG_Header[0x122-0x20]=0x00;
mMJPEG_Header[0x123-0x20]=0x00;

mMJPEG_Header[0x128-0x20]=(unsigned char)(8000*10)&0xFF;
mMJPEG_Header[0x129-0x20]=(unsigned char)((8000*10)>>8)&0xFF;
mMJPEG_Header[0x12A-0x20]=(unsigned char)((8000*10)>>16)&0xFF;
mMJPEG_Header[0x12B-0x20]=(unsigned char)((8000*10)>>24)&0xFF;

mMJPEG_Header[0x12C-0x20]=0x40;
mMJPEG_Header[0x12D-0x20]=0x1F;
mMJPEG_Header[0x12E-0x20]=0x00;
mMJPEG_Header[0x12F-0x20]=0x00;

mMJPEG_Header[0x14C-0x20]=0x40;
mMJPEG_Header[0x14D-0x20]=0x1F;
mMJPEG_Header[0x14E-0x20]=0x00;
mMJPEG_Header[0x14F-0x20]=0x00;

mMJPEG_Header[0x150-0x20]=0x40;
mMJPEG_Header[0x151-0x20]=0x1F;
mMJPEG_Header[0x152-0x20]=0x00;
mMJPEG_Header[0x153-0x20]=0x00;

/*mMJPEG_Header[0x120]=0x10;
mMJPEG_Header[0x121]=0x2B;
mMJPEG_Header[0x122]=0x00;
mMJPEG_Header[0x123]=0x00;

mMJPEG_Header[0x128]=(unsigned char)(8000*10)&0xFF;
mMJPEG_Header[0x129]=(unsigned char)((8000*10)>>8)&0xFF;
mMJPEG_Header[0x12A]=(unsigned char)((8000*10)>>16)&0xFF;
mMJPEG_Header[0x12B]=(unsigned char)((8000*10)>>24)&0xFF;

mMJPEG_Header[0x12C]=0x10;
mMJPEG_Header[0x12D]=0x2B;
mMJPEG_Header[0x12E]=0x00;
mMJPEG_Header[0x12F]=0x00;

mMJPEG_Header[0x14C]=0x10;
mMJPEG_Header[0x14D]=0x2B;
mMJPEG_Header[0x14E]=0x00;
mMJPEG_Header[0x14F]=0x00;

mMJPEG_Header[0x150]=0x10;
mMJPEG_Header[0x151]=0x2B;
mMJPEG_Header[0x152]=0x00;
mMJPEG_Header[0x153]=0x00;*/

mMJPEG_Header[0x3C]=0x00;
mMJPEG_Header[0x3D]=0x00;
mMJPEG_Header[0x3E]=0x10;
mMJPEG_Header[0x3F]=0x00;

mMJPEG_Header[0x90]=0x00;
mMJPEG_Header[0x91]=0x00;
mMJPEG_Header[0x92]=0x10;
mMJPEG_Header[0x93]=0x00;

fp1=fopen(sFileName,"wb+");
if(fp1==NULL)
{
printf("Target file open error!\r\n");
fcloseall();
return;
}
fp3=fopen("idx_tmp.bin","wb+");
if(fp3==NULL)
{
printf("Target file open error!\r\n");
fcloseall();
return;
}
fp4=fopen("10.pcm","rb+");
if(fp4==NULL)
{
printf("Source file open error!\r\n");
fcloseall();
return;
}

fwrite(mMJPEG_Header,1,sizeof(mMJPEG_Header),fp1);


//----------------
/*ch='L';
fwrite(&ch,1,1,fp3);
ch='I';
fwrite(&ch,1,1,fp3);
ch='S';
fwrite(&ch,1,1,fp3);
ch='T';
fwrite(&ch,1,1,fp3);
ch=0;
fwrite(&ch,1,1,fp3);
ch=0;
fwrite(&ch,1,1,fp3);
ch=0;
fwrite(&ch,1,1,fp3);
ch=0;
fwrite(&ch,1,1,fp3);
ch='m';
fwrite(&ch,1,1,fp3);
ch='o';
fwrite(&ch,1,1,fp3);
ch='v';
fwrite(&ch,1,1,fp3);
ch='i';
fwrite(&ch,1,1,fp3);*/
//-------------

ch='i';
fwrite(&ch,1,1,fp3);
ch='d';
fwrite(&ch,1,1,fp3);
ch='x';
fwrite(&ch,1,1,fp3);
ch='1';
fwrite(&ch,1,1,fp3);
mTemp=0;
fwrite(&mTemp,1,4,fp3);
mOffset=4;

for(i=0;i<10;i++)
{
switch(i)
{
case 0:
printf("0a.jpg ");
fp2=fopen("0a.jpg","rb+");
break;
case 1:
printf("1a.jpg ");
fclose(fp2);
fp2=fopen("1a.jpg","rb+");
break;
case 2:
printf("2a.jpg ");
fclose(fp2);
fp2=fopen("2a.jpg","rb+");
break;
case 3:
printf("3a.jpg ");
fclose(fp2);
fp2=fopen("3a.jpg","rb+");
break;
case 4:
printf("4a.jpg ");
fclose(fp2);
fp2=fopen("4a.jpg","rb");
break;
case 5:
printf("5a.jpg ");
fclose(fp2);
fp2=fopen("5a.jpg","rb+");
break;
case 6:
printf("6a.jpg ");
fclose(fp2);
fp2=fopen("6a.jpg","rb+");
break;
case 7:
printf("7a.jpg ");
fclose(fp2);
fp2=fopen("7a.jpg","rb+");
break;
case 8:
printf("8a.jpg ");
fclose(fp2);
fp2=fopen("8a.jpg","rb+");
break;
default:
printf("9a.jpg ");
fclose(fp2);
fp2=fopen("9a.jpg","rb+");
break;
}
if(fp2==NULL)
{
printf("Source file open error!\r\n");
fcloseall();
return;
}
//mSourceFileLength=(unsigned long)filelength(fp2);
fseek(fp2,0,SEEK_END);
mSourceFileLength=(unsigned long)ftell(fp2);


for(j=0;j{
//video
ch='0';
fwrite(&ch,1,1,fp3);
ch='0';
fwrite(&ch,1,1,fp3);
ch='d';
fwrite(&ch,1,1,fp3);
ch='c';
fwrite(&ch,1,1,fp3);
mTemp=0x00000010;
fwrite(&mTemp,1,4,fp3);
fwrite(&mOffset,1,4,fp3);
mSize=mSourceFileLength;
if(mSize&1)
{
//mSize++;
}
fwrite(&mSize,1,4,fp3);
mOffset+=(mSize+8);


ch='0';
fwrite(&ch,1,1,fp1);
ch='0';
fwrite(&ch,1,1,fp1);
ch='d';
fwrite(&ch,1,1,fp1);
ch='c';
fwrite(&ch,1,1,fp1);
mSize=mSourceFileLength;
if(mSize&1)
{
//mSize++;
}
fwrite(&mSize,1,4,fp1);
fseek(fp2,0,SEEK_SET);
for(k=0;k{
if((k&0xFF)==0)
{
printf(".");
}
fread(&ch,1,1,fp2);
fwrite(&ch,1,1,fp1);
}
if(mSourceFileLength&1)
{
ch=0;//double bytes align
//fwrite(&ch,1,1,fp1);
}

//audio
ch='0';
fwrite(&ch,1,1,fp3);
ch='1';
fwrite(&ch,1,1,fp3);
ch='w';
fwrite(&ch,1,1,fp3);
ch='b';
fwrite(&ch,1,1,fp3);
mTemp=0x00000010;
fwrite(&mTemp,1,4,fp3);
fwrite(&mOffset,1,4,fp3);
mSize=8000/mFrameRate;
if(mSize&1)
{
//mSize++;//double bytes align
}
fwrite(&mSize,1,4,fp3);
mOffset+=(mSize+8);

k=ftell(fp1);
ch='0';
fwrite(&ch,1,1,fp1);
ch='1';
fwrite(&ch,1,1,fp1);
ch='w';
fwrite(&ch,1,1,fp1);
ch='b';
fwrite(&ch,1,1,fp1);
mSize=8000/mFrameRate;
if(mSize&1)
{
//mSize++;//double bytes align
}
fwrite(&mSize,1,4,fp1);
ch=0;
for(k=0;k{
if((k&0xFF)==0)
{
printf(".");
}
//ch++;
fread(&ch,1,1,fp4);
fwrite(&ch,1,1,fp1);
}
}
}
mTargetFileLength=ftell(fp1);
if(mTargetFileLength&1)
{
ch=0;
fwrite(&ch,1,1,fp1);
}
mSize=ftell(fp3);
mSize-=8;
fseek(fp3,4,SEEK_SET);
fwrite(&mSize,1,4,fp3);


mTargetFileLength=ftell(fp1);
mTargetFileLength-=0x808;
fseek(fp1,0x0804,SEEK_SET);
fwrite(&mTargetFileLength,1,4,fp1);
//mTargetFileLength=ftell(fp1);
//mTargetFileLength-=(sizeof(mMJPEG_Header)+8);
//fseek(fp1,sizeof(mMJPEG_Header)+4,SEEK_SET);
//fwrite(&mTargetFileLength,1,4,fp1);

fseek(fp1,0,SEEK_END);
mSize+=8;
fseek(fp3,0,SEEK_SET);
for(i=0;i{
fread(&ch,1,1,fp3);
fwrite(&ch,1,1,fp1);
}

mTargetFileLength=ftell(fp1);
fseek(fp1,0x0004,SEEK_SET);
mTargetFileLength-=8;
fwrite(&mTargetFileLength,1,4,fp1);

printf("\r\n");
fcloseall();
}

main()
{
char ch;
do
{
printf("\r\nSelect image size(1 QVGA, 2 VGA):");
//scanf("%c",&ch);
ch=getch();
printf("%c",ch);
}while((ch!='1')&&(ch!='2'));

if(ch=='1')
{
make_qvga_mjpeg();
}
else
{
make_vga_mjpeg();
}
printf("\r\nPress any key to Exit");
getch();

}

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • AVI文件
    +关注

    关注

    0

    文章

    2

    浏览量

    6468
  • MJPG
    +关注

    关注

    0

    文章

    3

    浏览量

    7155
收藏 人收藏

    评论

    相关推荐

    播放avi如何实现快进退啊 ?

    请教下,播放avi如何实现快进退啊 ??? 自己捣鼓了了一下,没有成功,代码如下: void AVI_TimeSet(FIL *_pFile, VideoPlayCtrlRTOS
    发表于 04-26 06:09

    谷歌模型怎么PS打开文件格式不变

    要将谷歌模型与Photoshop结合使用,并保持文件格式不变,这通常涉及将谷歌模型生成的图像或图形导入到Photoshop中进行进一步编辑或处理。
    的头像 发表于 02-29 18:09 447次阅读

    PackagingTool_x64_v2.0.1.0图片转档打包二进制文件合并字库生成图片软件介绍

    全系列完美搭配; (2) 新增支持选择FLASH类型:可将bin档打包为NOR或者NAND的数据格式; (3) 新增显示缩略图窗口,便于即时查看添加进来的图片文件; (4) 新增工具:【 视频转成AVI
    发表于 02-29 09:30

    ov5640给到cx3的数据是yuv格式的,请问cx3可以转换成mjpg视频流输出吗?

    你好,目前ov5640给到cx3的数据是yuv格式的,请问cx3可以转换成mjpg视频流输出吗?
    发表于 02-28 08:17

    Android文件格式详解

    dex是android虚拟机的可执行字节码文件,java文件经过javac编译成class文件,class文件又被dx处理后生成dex
    的头像 发表于 01-02 10:21 884次阅读
    Android<b class='flag-5'>文件格式</b>详解

    labview生成exe文件如何配置文件

    LabVIEW是一种用于实时测试、控制和数据采集的编程环境。在开发过程中,您可以使用LabVIEW软件生成可执行文件(.exe),以便在没有LabVIEW开发环境的计算机上运行您的应用程序。生成
    的头像 发表于 12-27 16:28 648次阅读

    keil如何生成bin文件

    Keil是一种集成开发环境(IDE),专为ARM架构的嵌入式系统开发而设计。在Keil中生成bin文件是将代码编译并转换为可执行文件的过程。本文将详细介绍Keil生成bin
    的头像 发表于 12-15 13:43 3331次阅读

    ADgerber文件怎么生成PCB

    。ADGerber 文件是一种图像文件格式,它将电路板设计的不同层次和特性转换为加工厂能够理解和制造的一系列图案。 首先,我们需要了解一些关于ADGerber文件格式的基本知识。ADGerber
    的头像 发表于 12-07 17:19 1430次阅读

    WAV文件格式详解

    WAV是微软公司开发的一种音频格式文件,用于保存Windows平台的音频信息资源,它符合资源互换文件格式(Resource Interchange File Format,RIFF)文件规范。标准
    的头像 发表于 10-21 09:52 2205次阅读
    WAV<b class='flag-5'>文件格式</b>详解

    RIFF文件格式简介

    RIFF(Resources Interchange File Format)中文翻译为资源互换文件格式,是Windows下大部分多媒体文件遵循的一种文件结构。
    的头像 发表于 10-07 16:25 1051次阅读
    RIFF<b class='flag-5'>文件格式</b>简介

    单片机Hex文件格式详解

    玩单片机的朋友都会使用hex文件作为烧录文件。那么当我们写一个在线升级软件要支持hex文件的升级,就需要通过hex文件转成bin文件进行传输
    的头像 发表于 09-24 11:50 2554次阅读
    单片机Hex<b class='flag-5'>文件</b>的<b class='flag-5'>格式</b>详解

    【米尔-STM32MP135开发板-入门级MPU试用】基于mjpg\\-streamer实时监控

    文件。 --enable-static参数是设置生成的lib库为静态库,即生成***.a文件(注意:如果不需要在项目中加入静态库的话,此参数可以不加)。 【注2】这几个参数可以根据
    发表于 09-12 23:02

    将MacOLM文件转换为OutlookPST文件格式的工具

    批量将MacOLM文件导出为MSG、MBOX、PDF和EML文件格式的选项 高效地生成所有电子邮件和附件的即时预览 允许将OLM存档邮件文件夹转换为Outlo
    的头像 发表于 06-16 10:56 1950次阅读
    将MacOLM<b class='flag-5'>文件</b>转换为OutlookPST<b class='flag-5'>文件格式</b>的工具

    将PDF文件转换为其他格式文件使用指南

    万兴PDF支持将PDF导出到MSOffice,Image,HTML,RTF和HWP格式文件(PDF文件6标准版仅支持将PDF转换为MSOffice,Image)。这里有两种方法可以转换单个PDF文件
    的头像 发表于 06-05 16:47 673次阅读
    将PDF<b class='flag-5'>文件</b>转换为其他<b class='flag-5'>格式文件</b>使用指南

    国产IC板载AVI检测

    AVI
    李开鸿
    发布于 :2023年05月15日 13:38:28