當前位置:首頁 > 單片機 > 單片機
[導讀]jpeg格式是一種針對相片影像而廣泛使用的一種失真壓縮標準,其壓縮技術十分先進,用有損壓縮方式去除冗余的圖像數(shù)據(jù),在獲得極高壓縮率的同時,能展現(xiàn)十分豐富生動的圖像,能用最少的磁盤空間得到較好的圖像品質。由

jpeg格式是一種針對相片影像而廣泛使用的一種失真壓縮標準,其壓縮技術十分先進,用有損壓縮方式去除冗余的圖像數(shù)據(jù),在獲得極高壓縮率的同時,能展現(xiàn)十分豐富生動的圖像,能用最少的磁盤空間得到較好的圖像品質。由于其尺寸較小,能夠較快地在網(wǎng)絡上傳輸,因此在數(shù)碼相機、網(wǎng)頁等領域均廣泛應用到jpeg圖像格式。筆者此處就移植libjpeg開源庫來應用jpeg作一個簡單的介紹。

1. 代碼準備

libjpeg源碼,libjpeg是一個完全用c語言編寫的庫,包含了被廣泛使用的jpeg編碼、jpeg解碼和其它的jpeg功能的實現(xiàn),這個庫由獨立的jpeg工作組維護。請讀者自行到官網(wǎng)下載最新的源碼。

s3c2416啟動代碼工程,啟動代碼是s3c2416/50/51這系列arm9芯片在運行用戶c代碼main函數(shù)之前必須先運行的代碼,啟動代碼支持sd、Nand啟動,為用戶設置系統(tǒng)時鐘,初始化內(nèi)存,自動識別啟動設備并搬移代碼到RAM,MMU映射,中斷管理等,支持x、ymodem文件傳輸協(xié)議,代碼可直接通過串口下載進RAM執(zhí)行,用戶只需專注于用c開發(fā)其它功能函數(shù)即可。關于啟動代碼以及啟動代碼的實現(xiàn)過程,筆者前面章節(jié)有非常詳細的介紹。此處在MDK下開發(fā),下載”MDK啟動代碼工程應用實例”中的啟動代碼源碼。

用戶代碼,用c開發(fā)的所有功能代碼,其中,用戶代碼入口為main()函數(shù),在這里用libjpeg庫實現(xiàn)在屏上顯示jpeg圖像以及屏幕截圖保存成jpeg圖片。

2. 標準io庫函數(shù)

libjpeg由于其開源免費,對桌面操作系統(tǒng)均有良好的支持,因此在linux、windows操作系統(tǒng)下均常用libjpeg來編解碼jpeg圖片。libjpeg以及例程使用了標準io庫函數(shù),如文件操作fopen、fread、fwrite等;輸入、輸出、錯誤流函數(shù)printf、fprintf等。對于嵌入式開發(fā)來說,所有的io操作均是面對特定設備,編譯器的標準c庫是無法統(tǒng)一實現(xiàn)的,應由用戶去實現(xiàn)。在arm編譯器中,是使用一種半主機的模式,當用戶使用了標準io庫函數(shù)時,默認情況下,編譯器是通過一組定義好的軟中斷來把io應用請求傳送至運行調(diào)試器的主機,如用printf和scanf來使用主機的屏幕以及鍵盤,需要jtag的支持。一旦目標板脫離主機,需單獨運行時,在半主機模式下是無法運行,因為io軟中斷請求無法得到處理。因此對于libjpeg移植,我們必須先對所使用到的io庫函數(shù)進行重定向,如把輸入、輸出、錯誤流重定向到串口,把文件操作重定向到對sd卡的文件操作。此處我們在sd卡中采用的是fatfs文件系統(tǒng),關于fatfs的移植,筆者在前面的章節(jié)有詳細的介紹,此處不再詳述。在MDK中,標準io庫函數(shù)最終是通過系統(tǒng)調(diào)用接口來完成實質的io請求,我們必須在這些系統(tǒng)調(diào)用接口上重定向為目標板上特定設備的請求操作。對于linux操作系統(tǒng),標準io庫函數(shù)最終也是通過系統(tǒng)調(diào)用,從用戶態(tài)轉到內(nèi)核態(tài),通過系統(tǒng)api完成實質的io請求操作。在Retarget.c中我們實現(xiàn)所有的標準io庫函數(shù)的重定向,該部分的代碼如下:

#include

#include

#include

#include

#include

#include "ff.h"

#include "diskio.h"

#include "UART0.h"

#pragma import (__use_no_semihosting_swi)

#defineSTDIO 1

/* Standard IO device handles. */

#define STDIN 0x1

#define STDOUT 0x2

#define STDERR 0x3

/* Standard IO device name defines. */

const char __stdin_name[] = "STDIN";

const char __stdout_name[] = "STDOUT";

const char __stderr_name[] = "STDERR";

struct __FILE {int handle; /* Add whatever you need here */ };

#ifdef STDIO

/*-----------------------------------------------------------------------------

Write character to the Serial Port

*----------------------------------------------------------------------------*/

int sendchar(int c) {

if (c == 'n') {

Uart0_SendByte('r');

}

Uart0_SendByte(c);

return (c);

}

/*-----------------------------------------------------------------------------

Read character from the Serial Port

*----------------------------------------------------------------------------*/

int getkey(void) {

int ch = Uart0_ReceiveByte();

if (ch < 0) {

return 0;

}

return ch;

}

#endif

/*---------------------------_ttywrch ---------------------------------------*/

void _ttywrch(int ch) {

#ifdef STDIO

sendchar (ch);

#endif

}

/*---------------------------_sys_open --------------------------------------*/

FILEHANDLE _sys_open (const char *name, int openmode) {

FRESULT Res;

FILEHANDLE fh;

BYTE Mode = FA_READ;

/* Register standard Input Output devices. */

if (strcmp(name, "STDIN") == 0) {

return (STDIN);

}

if (strcmp(name, "STDOUT") == 0) {

return (STDOUT);

}

if (strcmp(name, "STDERR") == 0) {

return (STDERR);

}

if (openmode& OPEN_W) {

Mode|= FA_WRITE | FA_OPEN_ALWAYS;

Mode&= ~FA_READ;

}

if (openmode& OPEN_PLUS) {

Mode|= FA_WRITE | FA_READ;

}

if (openmode & OPEN_A) {

Mode|= FA_OPEN_ALWAYS;

}

fh = (FILEHANDLE)malloc(sizeof(FIL));

if (fh == NULL) {

return -1;

}

Res =f_open((FIL *)fh, name, Mode);

if (Res == RES_OK) {

return fh;

} else {

free((FIL *)fh);

return -1;

}

}

/*---------------------------_sys_close -------------------------------------*/

int _sys_close(FILEHANDLE fh) {

FRESULT Res;

if (fh > 0 && fh < 4) {

return (0);

}

Res = f_close((FIL *)fh);

free((FIL *)fh);

if (Res == RES_OK) {

return 0;

}

return -1;

}

/*---------------------------_sys_write -------------------------------------*/

int _sys_write(FILEHANDLE fh, const uint8_t *buf, uint32_t len, int32_t mode) {

FRESULT Res;

UINT ByteWrite;

#ifdef STDIO

if (fh > 0 && fh < 4) {

if (fh == STDOUT) {

/* Standard Output device. */

for (; len; len--) {

sendchar (*buf++);

}

return (0);

} else {

return (-1);

}

}

#endif

#if!(_FS_READONLY)

Res = f_write((FIL *)fh, buf, len,&ByteWrite);

if (Res == RES_OK) {

if(ByteWrite < len) {

return (len-ByteWrite);

}

return 0;

}

#endif

return -1;

}

/*---------------------------_sys_read --------------------------------------*/

int _sys_read(FILEHANDLE fh, uint8_t *buf, uint32_t len, int32_t mode) {

FRESULT Res;

UINT ByteRead;

#ifdef STDIO

if (fh > 0 && fh < 4) {

if (fh == STDIN) {

/* Standard Input device. */

for (; len; len--) {

*buf++ = getkey ();

}

return (0);

} else {

return (-1);

}

}

#endif

Res = f_read((FIL *)fh, buf, len,&ByteRead);

if (Res == RES_OK) {

if(ByteRead < len) {

return (len-ByteRead);

}

return 0;

}

return -1;

}

/*---------------------------_sys_istty -------------------------------------*/

int _sys_istty(FILEHANDLE fh) {

if (fh > 0 && fh < 4) {

return (1);

}

return (0);

}

/*---------------------------_sys_seek --------------------------------------*/

int _sys_seek(FILEHANDLE fh, long pos) {

FRESULT Res;

if (fh > 0 && fh < 4) {

return (-1);

}

#if_FS_MINIMIZE < 3

Res = f_lseek((FIL *)fh, pos);

if (Res == RES_OK) {

return 0;

}

#endif

return (-1);

}

/*---------------------------_sys_ensure ------------------------------------*/

int _sys_ensure(FILEHANDLE fh) {

FRESULT Res;

if (fh > 0 && fh < 4) {

return (-1);

}

#if!(_FS_READONLY)

Res = f_sync((FIL *)fh);

if (Res == RES_OK) {

return 0;

}

#endif

return -1;

}

/*---------------------------_sys_flen --------------------------------------*/

long _sys_flen(FILEHANDLE fh) {

if (fh > 0 && fh < 4) {

return (0);

}

return f_tell((FIL *)fh);

}

/*---------------------------_sys_tmpnam ------------------------------------*/

int _sys_tmpnam(char *name, int sig, unsigned maxlen) {

return (1);

}

/*----------------

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或將催生出更大的獨角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關鍵字: 汽車 人工智能 智能驅動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權最終是由生態(tài)的繁榮決定的。

關鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質量發(fā)展策略,塑強核心競爭優(yōu)勢...

關鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術學會聯(lián)合牽頭組建的NVI技術創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術創(chuàng)新聯(lián)...

關鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關鍵字: BSP 信息技術
關閉
關閉