0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

自己生成MJPG格式AVI文件

聚豐開發(fā) ? 2018-11-02 14:37 ? 次閱讀


注:本文是作者以前發(fā)表在其個人博客,現(xiàn)在發(fā)布到“聚豐開發(fā)”專欄




現(xiàn)在電子產(chǎn)品經(jīng)常需要使用到視頻,于是對視頻技術(shù)的需求也日益高漲,通常做法是采用現(xiàn)成的硬件或軟件方案來實現(xiàn)對視頻數(shù)據(jù)的處理,要說掌握這部分算法的人并不多,大多數(shù)工程師沒有時間和精力去消化吸收這些算法。


MJPG是最簡單的視頻文件格式,存儲時是將圖像用JPG格式一幀一幀的保存起來,回放的時候按照規(guī)定的時間間隔一幀一幀的回放。用這種處理方法算法相對比較簡單,如果對圖像要求不高可以達(dá)到20~30倍的壓縮率,對于單片機(jī)來說不失為一種可行性較高的備選方案。


以前有個項目需要支持MJPG文件,為此我寫了一段PC程序進(jìn)行代碼驗證,同時生成測試用MJPG文件。具體做法是預(yù)先做好10張JPG圖片,每張圖片都有VGA和QVGA兩種尺寸,然后按輸入參數(shù)生成相應(yīng)的MJPG文件。比如輸入選擇VGA/10幀,生成的MJPG文件第一秒為第一張VGA圖片重復(fù)10次,依此類推。


程序生成的MJPG用電腦播放,如果能正常播放,就說明代碼對文件格式的處理基本正確。這里程序每一幀都對應(yīng)有自己的JPG數(shù)據(jù),實際上可以不這么做,MJPG文件有音頻和視頻流的播放序號,如果相鄰的視頻幀內(nèi)容相同,是可以將播放序號指向同一張JPG圖像數(shù)據(jù)的。




每一幀自己有獨(dú)立的JPG圖像數(shù)據(jù)
播放序號: JPG01 JPG02 JPG03 ... JPG09 JPG10 JPG11
JPG01_Data:
...(第一張圖片內(nèi)容)...
JPG02_Data:
...(第一張圖片內(nèi)容)...
...
JPG09_Data:
...(第一張圖片內(nèi)容)...
JPG10_Data:
...(第一張圖片內(nèi)容)...
JPG11_Data:
...(第二張圖片內(nèi)容)...

相鄰幀相同利用同一張JPG數(shù)據(jù)
播放序號: JPG01 JPG01 JPG01 ... JPG01 JPG01 JPG02
JPG01_Data:
...(第一張圖片內(nèi)容)...
JPG02_Data:
...(第二張圖片內(nèi)容)...
...
JPG10_Data:
...(第十張圖片內(nèi)容)...

注意代碼只是用于臨時工具,沒有詳細(xì)注釋進(jìn)行說明,代碼書寫也存在許多不規(guī)范的地方。



-------------------------參考代碼---------------------------

#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();

}

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • AVI文件
    +關(guān)注

    關(guān)注

    0

    文章

    2

    瀏覽量

    6505
  • MJPG
    +關(guān)注

    關(guān)注

    0

    文章

    3

    瀏覽量

    7192
收藏 人收藏

    評論

    相關(guān)推薦

    EE-110:ELF和DWARF文件格式快速入門

    電子發(fā)燒友網(wǎng)站提供《EE-110:ELF和DWARF文件格式快速入門.pdf》資料免費(fèi)下載
    發(fā)表于 01-05 09:41 ?0次下載
    EE-110:ELF和DWARF<b class='flag-5'>文件格式</b>快速入門

    MOV視頻轉(zhuǎn)換成AVI的方法

    (Audio Video Interleave)格式則因其廣泛的兼容性和較低的壓縮率而被廣泛使用。 為什么需要轉(zhuǎn)換視頻格式 兼容性 :不同的播放器和設(shè)備可能不支持MOV格式,而AVI
    的頭像 發(fā)表于 12-06 14:37 ?401次閱讀

    MOV文件與其他視頻格式的兼容性

    MOV文件作為一種由蘋果公司開發(fā)的視頻文件格式(全稱為QuickTime Movie Format),在兼容性方面表現(xiàn)出色。以下是對MOV文件與其他視頻格式兼容性的分析: 一、MOV
    的頭像 發(fā)表于 12-06 14:36 ?560次閱讀

    EPS文件格式如何轉(zhuǎn)換 EPS和SVG文件的區(qū)別

    EPS文件格式轉(zhuǎn)換 EPS(Encapsulated PostScript)是一種用于存儲矢量圖形的文件格式,最初由Adobe公司開發(fā)。由于EPS文件在打印時能夠保持極高的質(zhì)量,并且廣泛被各種
    的頭像 發(fā)表于 11-19 10:31 ?759次閱讀

    常用對象文件格式

    電子發(fā)燒友網(wǎng)站提供《常用對象文件格式.pdf》資料免費(fèi)下載
    發(fā)表于 10-15 09:25 ?0次下載
    常用對象<b class='flag-5'>文件格式</b>

    labview程序生成exe文件怎么還原

    在LabVIEW中,程序生成exe文件后,通常這個過程是不可逆的,即exe文件無法直接“還原”回原始的LabVIEW項目文件(.vi或.lvproj)。exe
    的頭像 發(fā)表于 09-04 17:12 ?1641次閱讀

    labview工程文件如何生成exe

    生成可執(zhí)行文件(EXE)是LabVIEW程序開發(fā)過程中的一個重要步驟,它允許用戶在沒有安裝LabVIEW的計算機(jī)上運(yùn)行程序。以下是步驟和注意事項: 1. 準(zhǔn)備工作 在開始生成EXE文件
    的頭像 發(fā)表于 09-04 17:09 ?1882次閱讀

    Dave編譯后的bin格式文件大于hex格式文件,可能是什么原因呢?

    如題,今天使用Dave4.5編譯時,生成的.bin文件大于.hex文件,請問可能是什么原因呢?哪里沒設(shè)置嗎? .bin格式編譯的信息,使用release模式編譯的 .hex
    發(fā)表于 05-24 07:40

    Allegro生成光繪文件

    Allegro生成光繪文件
    發(fā)表于 05-06 10:37 ?1次下載

    如何在STM32CUBEMX生成的代碼中添加自己的模塊文件

    如果我想在STM32CUBEMX生成的代碼中添加自己的模塊文件,且在更新引腳配置時不會丟失,要如何實現(xiàn)。
    發(fā)表于 04-26 06:15

    播放avi如何實現(xiàn)快進(jìn)退啊 ?

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

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

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

    谷歌模型怎么用手機(jī)打開文件格式

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

    PackagingTool_x64_v2.0.1.0圖片轉(zhuǎn)檔打包二進(jìn)制文件合并字庫生成圖片軟件介紹

    全系列完美搭配; (2) 新增支持選擇FLASH類型:可將bin檔打包為NOR或者NAND的數(shù)據(jù)格式; (3) 新增顯示縮略圖窗口,便于即時查看添加進(jìn)來的圖片文件; (4) 新增工具:【 視頻轉(zhuǎn)成AVI
    發(fā)表于 02-29 09:30

    ov5640給到cx3的數(shù)據(jù)是yuv格式的,請問cx3可以轉(zhuǎn)換成mjpg視頻流輸出嗎?

    你好,目前ov5640給到cx3的數(shù)據(jù)是yuv格式的,請問cx3可以轉(zhuǎn)換成mjpg視頻流輸出嗎?
    發(fā)表于 02-28 08:17