<acronym id="s8ci2"><small id="s8ci2"></small></acronym>
<rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
<acronym id="s8ci2"></acronym>
<acronym id="s8ci2"><center id="s8ci2"></center></acronym>
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

    瀏覽量

    6473
  • MJPG
    +關注

    關注

    0

    文章

    3

    瀏覽量

    7162
收藏 人收藏

    評論

    相關推薦

    Allegro生成光繪文件

    Allegro生成光繪文件
    發表于 05-06 10:37 ?0次下載

    播放avi如何實現快進退啊 ?

    請教下,播放avi如何實現快進退啊 ??? 自己搗鼓了了一下,沒有成功,代碼如下: void AVI_TimeSet(FIL *_pFile, VideoPlayCtrlRTOS
    發表于 04-26 06:09

    谷歌模型怎么PS打開文件格式不變

    要將谷歌模型與Photoshop結合使用,并保持文件格式不變,這通常涉及將谷歌模型生成的圖像或圖形導入到Photoshop中進行進一步編輯或處理。
    的頭像 發表于 02-29 18:09 ?511次閱讀

    谷歌模型怎么用手機打開文件格式

    谷歌在其AI技術中集成了多種工具和功能,用于處理和識別文件格式。具體到手機上打開的文件格式,這主要依賴于谷歌提供的服務和應用。例如,在Gmail中,用戶可以直接查看多種格式文件,包括
    的頭像 發表于 02-29 17:38 ?486次閱讀

    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 ?1128次閱讀
    Android<b class='flag-5'>文件格式</b>詳解

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

    LabVIEW是一種用于實時測試、控制和數據采集的編程環境。在開發過程中,您可以使用LabVIEW軟件生成可執行文件(.exe),以便在沒有LabVIEW開發環境的計算機上運行您的應用程序。生成
    的頭像 發表于 12-27 16:28 ?976次閱讀

    keil如何生成bin文件

    Keil是一種集成開發環境(IDE),專為ARM架構的嵌入式系統開發而設計。在Keil中生成bin文件是將代碼編譯并轉換為可執行文件的過程。本文將詳細介紹Keil生成bin
    的頭像 發表于 12-15 13:43 ?5558次閱讀

    ADgerber文件怎么生成PCB

    。ADGerber 文件是一種圖像文件格式,它將電路板設計的不同層次和特性轉換為加工廠能夠理解和制造的一系列圖案。 首先,我們需要了解一些關于ADGerber文件格式的基本知識。ADGerber
    的頭像 發表于 12-07 17:19 ?1802次閱讀

    WAV文件格式詳解

    WAV是微軟公司開發的一種音頻格式文件,用于保存Windows平臺的音頻信息資源,它符合資源互換文件格式(Resource Interchange File Format,RIFF)文件規范。標準
    的頭像 發表于 10-21 09:52 ?2670次閱讀
    WAV<b class='flag-5'>文件格式</b>詳解

    RIFF文件格式簡介

    RIFF(Resources Interchange File Format)中文翻譯為資源互換文件格式,是Windows下大部分多媒體文件遵循的一種文件結構。
    的頭像 發表于 10-07 16:25 ?1165次閱讀
    RIFF<b class='flag-5'>文件格式</b>簡介

    單片機Hex文件格式詳解

    玩單片機的朋友都會使用hex文件作為燒錄文件。那么當我們寫一個在線升級軟件要支持hex文件的升級,就需要通過hex文件轉成bin文件進行傳輸
    的頭像 發表于 09-24 11:50 ?2961次閱讀
    單片機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 ?2070次閱讀
    將MacOLM<b class='flag-5'>文件</b>轉換為OutlookPST<b class='flag-5'>文件格式</b>的工具
    亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看
    <acronym id="s8ci2"><small id="s8ci2"></small></acronym>
    <rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
    <acronym id="s8ci2"></acronym>
    <acronym id="s8ci2"><center id="s8ci2"></center></acronym>