Yuv420轉Jpeg(C語言實現)
YUV2Jpg(in_Y,in_U,in_V,0x400,0x1b0,75,0x420,pData,&dwSize);
引數說明:in_Y:輸入的420的Y分量;in_U:輸入的420的U分量,in_V:輸入420的V分量;width:表示影象的寬;height表示影象的高;quality表示量化因子,n_Stride表示Yuv的跨度,即Yuv的寬,因為該函式只能處理16的整數倍,所以width為0x400;pOut表示轉化後的資料;pnOutSize為轉化後的jpeg檔案的大小;
int YUV2Jpg(PBYTE in_Y,PBYTE in_U,PBYTE in_V,int width,int height,int quality,int nStride,PBYTE pOut,DWORD *pnOutSize) //
{
PBYTE pYBuf,pUBuf,pVBuf;
int nYLen = nStride * height;
int nUVLen = nStride * height / 4;
int nDataLen;
JPEGINFO JpgInfo;
ZeroMemory(&JpgInfo,sizeof(JPEGINFO));
JpgInfo.bytenew = 0;
JpgInfo.bytepos = 7;
pYBuf = (PBYTE)malloc(nYLen); //獲取Y的值
memcpy(pYBuf,in_Y,nYLen);
pUBuf = (PBYTE)malloc(nYLen);
pVBuf = (PBYTE)malloc(nYLen);
ProcessUV(pUBuf,in_U,width,height,nStride); //獲取U的值
ProcessUV(pVBuf,in_V,width,height,nStride); //獲取V
// GetDataFromSource(pYBuf,pUBuf,pVBuf,in_Y,in_U,in_V,width);
DivBuff(pYBuf,width,height,nStride,DCTSIZE,DCTSIZE);
DivBuff(pUBuf,width,height,nStride,DCTSIZE,DCTSIZE);
DivBuff(pVBuf,width,height,nStride,DCTSIZE,DCTSIZE);
quality = QualityScaling(quality);
SetQuantTable(std_Y_QT,JpgInfo.YQT, quality); // 設定Y量化表
SetQuantTable(std_UV_QT,JpgInfo.UVQT,quality); // 設定UV量化表
InitQTForAANDCT(&JpgInfo); // 初始化AA&N需要的量化表
JpgInfo.pVLITAB=JpgInfo.VLI_TAB + 2048; // 設定VLI_TAB的別名
BuildVLITable(&JpgInfo); // 計算VLI表
nDataLen = 0;
// 寫入各段
nDataLen = WriteSOI(pOut,nDataLen);
nDataLen = WriteAPP0(pOut,nDataLen);
nDataLen = WriteDQT(&JpgInfo,pOut,nDataLen);
nDataLen = WriteSOF(pOut,nDataLen,width,height);
nDataLen = WriteDHT(pOut,nDataLen);
nDataLen = WriteSOS(pOut,nDataLen);
// 計算Y/UV訊號的交直分量的huffman表,這裡使用標準的huffman表,並不是計算得出,缺點是檔案略長,但是速度快
BuildSTDHuffTab(STD_DC_Y_NRCODES,STD_DC_Y_VALUES,JpgInfo.STD_DC_Y_HT);
BuildSTDHuffTab(STD_AC_Y_NRCODES,STD_AC_Y_VALUES,JpgInfo.STD_AC_Y_HT);
BuildSTDHuffTab(STD_DC_UV_NRCODES,STD_DC_UV_VALUES,JpgInfo.STD_DC_UV_HT);
BuildSTDHuffTab(STD_AC_UV_NRCODES,STD_AC_UV_VALUES,JpgInfo.STD_AC_UV_HT);
// 處理單後設資料
nDataLen = ProcessData(&JpgInfo,pYBuf,pUBuf,pVBuf,width,height,pOut,nDataLen);
nDataLen = WriteEOI(pOut,nDataLen);
free(pYBuf);
free(pUBuf);
free(pVBuf);
*pnOutSize = nDataLen;
return 0;
}
具體程式碼參考YUV2Jpg程式;
相關文章
- 掃雷--C語言實現C語言
- c語言實現階乘C語言
- c語言單向連結串列逆轉實現方法C語言
- C語言__LINE__實現原理C語言
- C語言實現檔案加密C語言加密
- c語言實現this指標效果C語言指標
- 高精度加法(C語言實現)C語言
- C語言實現TCP通訊C語言TCP
- C語言,實現數字譜到簡譜的轉換(二)C語言
- C++圖片格式轉換:BMP轉JPEGC++
- 排序演算法-C語言實現排序演算法C語言
- 高精度減法(C語言實現)C語言
- C語言實現推箱子游戲C語言
- C語言實現繼承多型C語言繼承多型
- C語言實現桌面貪吃蛇C語言
- 作業系統:程式狀態轉換模擬,C語言實現作業系統C語言
- Object-C語言Block的實現方式ObjectC語言BloC
- C 語言實現泛型 swap 函式泛型函式
- PID演算法的C語言實現演算法C語言
- C語言如何實現繼承及容器C語言繼承
- C語言實現矩陣螺旋輸出C語言矩陣
- 【C語言】聊聊輾轉相除法C語言
- c語言實現貓吃老鼠的問題C語言
- C語言回撥日誌庫的實現C語言
- 探秘掃雷遊戲的C語言實現遊戲C語言
- c 語言實現 tcp/udp 伺服器功能TCPUDP伺服器
- 線性表-順序表C語言實現C語言
- C語言實現多級濾波—乾貨C語言
- C語言怎麼實現可變引數C語言
- C語言陣列實現三子棋C語言陣列
- C語言如何實現泛型程式設計?C語言泛型程式設計
- C語言實用之道C語言
- C語言實驗二C語言
- C語言實驗1C語言
- 順序表的基本方法實現C語言版C語言
- 執行緒池的原理與C語言實現執行緒C語言
- 三種語言實現快速排序(C++/Python/Java)排序C++PythonJava
- 三種語言實現差分(C++/Python/Java)C++PythonJava
- C 語言實現物體檢測:使用 YOLO 模型YOLO模型