資料介紹
分享到:標(biāo)簽:Qt圖形編程 Linux 操作系統(tǒng)
12.3 實(shí)驗(yàn)內(nèi)容——使用Qt編寫“Hello,World”程序
1.實(shí)驗(yàn)?zāi)康?br /> 通過編寫一個(gè)跳動(dòng)的“Hello,World”字符串,進(jìn)一步熟悉嵌入式Qt的開發(fā)過程。
2.實(shí)驗(yàn)步驟
(1)生成一個(gè)工程文件(.pro文件)。
使用命令progen產(chǎn)生一個(gè)工程文件(progen程序可在tmake的安裝路徑下找到)。
如下所示:
progen –t app.t –o hello.pro
那樣產(chǎn)生的hello.pro工程文件并不完整,開發(fā)者還需添加工程所包含的頭文件,源文件等信息。
?。?)新建一個(gè)窗體。
啟動(dòng)Qt圖形編輯器,使用如下命令:
。/designer(該程序在qt-2.3.x for x11的安裝路徑的bin目錄下)
接著單擊編輯器的“new”菜單,彈出了一個(gè)“new Form”對(duì)話框,在這個(gè)對(duì)話框里選擇“Widget”,然后單擊“OK”按鈕,這樣就新建了一個(gè)窗體。
接下來再對(duì)這個(gè)窗體的屬性進(jìn)行設(shè)置,注意把窗體的“name”屬性設(shè)為“Hello”;窗體的各種尺寸設(shè)為寬“240”、高“320”,目的是使窗體大小和FS2410帶的顯示屏的大小一致;窗體背景顏色設(shè)置為白色。具體設(shè)置如圖12.18所示。
圖12.18 Hello窗體的屬性設(shè)置
設(shè)置完成后,將其保存為hello.ui文件,這個(gè)文件就是Hello窗體的界面存儲(chǔ)文件。
?。?)生成Hello窗體類的頭文件和實(shí)現(xiàn)文件。
下面根據(jù)上述的界面文件hello.ui使用uic工具產(chǎn)生Hello窗體類的頭文件和實(shí)現(xiàn)文件,具體方法是:
$ cd qt-2.3.7/bin
$ uic –o hello.h hello.ui
$ uic –o hello.cpp –impl hello.h hello.ui
這樣就得到了Hello窗體類的頭文件hello.h和實(shí)現(xiàn)文件hello.cpp。下面就可以根據(jù)需要實(shí)現(xiàn)的具體功能,在hello.cpp文件里添加相應(yīng)的代碼。
比如要在Hello的窗體上顯示一個(gè)動(dòng)態(tài)的字符串“Hello,World”,那么需要重新實(shí)現(xiàn)paintEvent(QPaintEvent *)方法,同時(shí)還需要添加一個(gè)定時(shí)器QTimer實(shí)例,以周期性刷新屏幕,從而得到動(dòng)畫的效果。下面是修改后的hello.h和hello.cpp文件。
/****************************************************************************
** 以下是 hello.h 的代碼
****************************************************************************/
#ifndef HELLO_H
#define HELLO_H
#include 《qvariant.h》
#include 《qwidget.h》
class QVBoxLayout;
class QHBoxLayout;
class QGridLayout;
class Hello : public QWidget
{
Q_OBJECT
public:
Hello(QWidget* parent = 0, const char* name = 0, WFlags fl = 0);
~Hello();
/* 以下是手動(dòng)添加的代碼 */
signals:
void clicked();
protected:
void mouseReleaseEvent(QMouseEvent *);
void paintEvent(QPaintEvent *);
private slots:
void animate();
private:
QString t;
int b;
};
#endif // HELLO_H
/****************************************************************************
** 以下是 hello.cpp 源代碼
****************************************************************************/
#include “hello.h”
#include 《qlayout.h》
#include 《qvariant.h》
#include 《qtooltip.h》
#include 《qwhatsthis.h》
#include 《qpushbutton.h》
#include 《qtimer.h》
#include 《qpainter.h》
#include 《qpixmap.h》
/*
* Constructs a Hello which is a child of ‘parent’, with the
* name ‘name’ and widget flags set to ‘f’
*/
Hello::Hello(QWidget* parent, const char* name, WFlags fl)
?。?QWidget(parent, name, fl)
{
if (!name)
setName(“Hello”);
resize(240, 320);
setMinimumSize(QSize(240, 320));
setMaximumSize(QSize(240, 320));
setSizeIncrement(QSize(240, 320));
setBaseSize(QSize(240, 320));
QPalette pal;
QColorGroup cg;
cg.setColor(QColorGroup::Foreground, black);
cg.setColor(QColorGroup::Button, QColor(192, 192, 192));
cg.setColor(QColorGroup::Light, white);
cg.setColor(QColorGroup::Midlight, QColor(223, 223, 223));
cg.setColor(QColorGroup::Dark, QColor(96, 96, 96));
cg.setColor(QColorGroup::Mid, QColor(128, 128, 128));
cg.setColor(QColorGroup::Text, black);
cg.setColor(QColorGroup::BrightText, white);
cg.setColor(QColorGroup::ButtonText, black);
cg.setColor(QColorGroup::Base, white);
cg.setColor(QColorGroup::Background, white);
cg.setColor(QColorGroup::Shadow, black);
cg.setColor(QColorGroup::Highlight, black);
cg.setColor(QColorGroup::HighlightedText, white);
pal.setActive(cg);
cg.setColor(QColorGroup::Foreground, black);
cg.setColor(QColorGroup::Button, QColor(192, 192, 192));
cg.setColor(QColorGroup::Light, white);
cg.setColor(QColorGroup::Midlight, QColor(220, 220, 220));
cg.setColor(QColorGroup::Dark, QColor(96, 96, 96));
cg.setColor(QColorGroup::Mid, QColor(128, 128, 128));
cg.setColor(QColorGroup::Text, black);
cg.setColor(QColorGroup::BrightText, white);
cg.setColor(QColorGroup::ButtonText, black);
cg.setColor(QColorGroup::Base, white);
cg.setColor(QColorGroup::Background, white);
cg.setColor(QColorGroup::Shadow, black);
cg.setColor(QColorGroup::Highlight, black);
cg.setColor(QColorGroup::HighlightedText, white);
pal.setInactive(cg);
cg.setColor(QColorGroup::Foreground, QColor(128, 128, 128));
cg.setColor(QColorGroup::Button, QColor(192, 192, 192));
cg.setColor(QColorGroup::Light, white);
cg.setColor(QColorGroup::Midlight, QColor(220, 220, 220));
cg.setColor(QColorGroup::Dark, QColor(96, 96, 96));
cg.setColor(QColorGroup::Mid, QColor(128, 128, 128));
cg.setColor(QColorGroup::Text, black);
cg.setColor(QColorGroup::BrightText, white);
cg.setColor(QColorGroup::ButtonText, QColor(128, 128, 128));
cg.setColor(QColorGroup::Base, white);
cg.setColor(QColorGroup::Background, white);
cg.setColor(QColorGroup::Shadow, black);
cg.setColor(QColorGroup::Highlight, black);
cg.setColor(QColorGroup::HighlightedText, white);
pal.setDisabled(cg);
setPalette(pal);
QFont f(font());
f.setFamily(“adobe-helvetica”);
f.setPointSize(29);
f.setBold(TRUE);
setFont(f);
setCaption(tr(“”));
/* 以下是手動(dòng)添加的代碼 */
t = “Hello,World”;
b = 0;
QTimer *timer = new QTimer(this);
connect(timer, SIGNAL(timeout()), SLOT(animate()));
timer-》start(40);
}
/*
* Destroys the object and frees any allocated resources
*/
Hello::~Hello()
{
}
/* 以下至結(jié)尾是手動(dòng)添加的代碼 */
void Hello::animate()
{
b = (b + 1) & 15;
repaint(FALSE);
}
/*
Handles mouse button release events for the Hello widget.
We emit the clicked() signal when the mouse is released inside
the widget.
*/
void Hello::mouseReleaseEvent(QMouseEvent *e)
{
if (rect().contains(e-》pos()))
emit clicked();
}
/* Handles paint events for the Hello widget.
Flicker-free update. The text is first drawn in the pixmap and the
pixmap is then blt‘ed to the screen.
*/
void Hello::paintEvent(QPaintEvent *)
{
static int sin_tbl[16] = {0, 38, 71, 92, 100, 92,
71, 38, 0, -38, -71, -92, -100, -92, -71, -38};
if (t.isEmpty())
eturn;
/* 1: Compute some sizes, positions etc. */
QFontMetrics fm = fontMetrics();
int w = fm.width(t) + 20;
int h = fm.height() * 2;
int pmx = width()/2 - w/2;
int pmy = height()/2 - h/2;
/* 2: Create the pixmap and fill it with the widget’s background */
QPixmap pm(w, h);
pm.fill(this, pmx, pmy);
/* 3: Paint the pixmap. Cool wave effect */
QPainter p;
int x = 10;
int y = h/2 + fm.descent();
int i = 0;
p.begin(&pm);
p.setFont(font());
while (!t[i].isNull())
{
nt i16 = (b+i) & 15;
.setPen(QColor((15-i16)*16,255,255,QColor::Hsv));
wText(x, y-sin_tbl[i16]*h/800, t.mid(i,1), 1);
+= fm.width(t[i]);
+;
}
p.end();
/* 4: Copy the pixmap to the Hello widget */
bitBlt(this, pmx, pmy, &pm);
}
?。?)編寫主函數(shù)main()。
一個(gè)Qt/Embeded應(yīng)用程序應(yīng)該包含一個(gè)主函數(shù),主函數(shù)所在的文件名是main.cpp。主函數(shù)是應(yīng)用程序執(zhí)行的入口點(diǎn)。以下是“Hello,World”例子的主函數(shù)文件main.cpp的實(shí)現(xiàn)代碼:
/****************************************************************************
** 以下是 main.cpp 源代碼
****************************************************************************/
#include “hello.h”
#include 《qapplication.h》
/*
The program starts here. It parses the command line and builds a message
string to be displayed by the Hello widget.
*/
#define QT_NO_WIZARD
int main(int argc, char **argv)
{
QApplication a(argc,argv);
Hello dlg;
QObject::connect(&dlg, SIGNAL(clicked()), &a, SLOT(quit()));
a.setMainWidget(&dlg);
dlg.show();
return a.exec();
}
(5)編輯工程文件hello.pro文件。
到目前為止,為Hello,World例子編寫了一個(gè)頭文件和兩個(gè)源文件,這3個(gè)文件應(yīng)該被包括在工程文件中,因此還需要編輯hello.pro文件,加入hello.h、hello.cpp、main.cpp這3個(gè)文件名。具體定義如下:
/****************************************************************************
** 以下是 hello.pro 文件的內(nèi)容
****************************************************************************/
TEMPLATE = app
CONFIG = qt warn_on release
HEADERS = hello.h
SOURCES = hello.cpp \
main.cpp
INTERFACES =
?。?)生成Makefile文件。
編譯器是根據(jù)Makefile文件內(nèi)容來進(jìn)行編譯的,所以需要生成Makefile文件。Qt提供的tmake工具可以幫助我們從一個(gè)工程文件(.pro文件)中產(chǎn)生Makefile文件。結(jié)合當(dāng)前例子,要從hello.pro生成一個(gè)Makefile文件的做法是首先查看環(huán)境變量$TMAKEPATH是否指向ARM編譯器的配置目錄,在命令行下輸入以下命令:
ECHO $TMAKEPATH
如果返回的結(jié)果末尾不是…/qws/linux-arm-g++的字符串,那么需要把環(huán)境變量$TMAKEPATH所指的目錄設(shè)置為指向arm編譯器的配置目錄,過程如下:
EXPORT TMAKEPATH = /TMAKE 安裝路徑/QWS/LINUX-ARM-G++
同時(shí),應(yīng)確保當(dāng)前的QTDIR環(huán)境變量指向Qt/Embedded的安裝路徑,如果不是,則需要執(zhí)行以下過程。
EXPORT QTDIR = ……/qt-2.3.7
上述步驟完成后,就可以使用tmake生成Makefile文件,具體做法是在命令行輸入以下命令:
TMAKE –O MAKEFILE HELLO.PRO
這樣就可以看到當(dāng)前目錄下新生成了一個(gè)名為Makefile的文件。下一步,需要打開這個(gè)文件,做一些小的修改。
?、?將LINK = arm-linux-gcc改為:LINK = arm-linux-g++
這樣做是因?yàn)橐胊rm-linux-g++進(jìn)行鏈接。
?、?將LIBS = $(SUBLIBS) -L$(QTDIR)/lib -lm –lqte改為:
LIBS = $(SUBLIBS) -L/usr/local/arm/2.95.3/lib -L$(QTDIR)/lib -lm –lqte
這是因?yàn)殒溄訒r(shí)要用到交叉編譯工具toolchain的庫。
(7)編譯鏈接整個(gè)工程。
最后就可以在命令行下輸入make命令對(duì)整個(gè)工程進(jìn)行編譯鏈接了。
make生成的二進(jìn)制文件hello就是可以在FS2410上運(yùn)行的可執(zhí)行文件。
?
12.3 實(shí)驗(yàn)內(nèi)容——使用Qt編寫“Hello,World”程序
1.實(shí)驗(yàn)?zāi)康?br /> 通過編寫一個(gè)跳動(dòng)的“Hello,World”字符串,進(jìn)一步熟悉嵌入式Qt的開發(fā)過程。
2.實(shí)驗(yàn)步驟
(1)生成一個(gè)工程文件(.pro文件)。
使用命令progen產(chǎn)生一個(gè)工程文件(progen程序可在tmake的安裝路徑下找到)。
如下所示:
progen –t app.t –o hello.pro
那樣產(chǎn)生的hello.pro工程文件并不完整,開發(fā)者還需添加工程所包含的頭文件,源文件等信息。
?。?)新建一個(gè)窗體。
啟動(dòng)Qt圖形編輯器,使用如下命令:
。/designer(該程序在qt-2.3.x for x11的安裝路徑的bin目錄下)
接著單擊編輯器的“new”菜單,彈出了一個(gè)“new Form”對(duì)話框,在這個(gè)對(duì)話框里選擇“Widget”,然后單擊“OK”按鈕,這樣就新建了一個(gè)窗體。
接下來再對(duì)這個(gè)窗體的屬性進(jìn)行設(shè)置,注意把窗體的“name”屬性設(shè)為“Hello”;窗體的各種尺寸設(shè)為寬“240”、高“320”,目的是使窗體大小和FS2410帶的顯示屏的大小一致;窗體背景顏色設(shè)置為白色。具體設(shè)置如圖12.18所示。
圖12.18 Hello窗體的屬性設(shè)置
設(shè)置完成后,將其保存為hello.ui文件,這個(gè)文件就是Hello窗體的界面存儲(chǔ)文件。
?。?)生成Hello窗體類的頭文件和實(shí)現(xiàn)文件。
下面根據(jù)上述的界面文件hello.ui使用uic工具產(chǎn)生Hello窗體類的頭文件和實(shí)現(xiàn)文件,具體方法是:
$ cd qt-2.3.7/bin
$ uic –o hello.h hello.ui
$ uic –o hello.cpp –impl hello.h hello.ui
這樣就得到了Hello窗體類的頭文件hello.h和實(shí)現(xiàn)文件hello.cpp。下面就可以根據(jù)需要實(shí)現(xiàn)的具體功能,在hello.cpp文件里添加相應(yīng)的代碼。
比如要在Hello的窗體上顯示一個(gè)動(dòng)態(tài)的字符串“Hello,World”,那么需要重新實(shí)現(xiàn)paintEvent(QPaintEvent *)方法,同時(shí)還需要添加一個(gè)定時(shí)器QTimer實(shí)例,以周期性刷新屏幕,從而得到動(dòng)畫的效果。下面是修改后的hello.h和hello.cpp文件。
/****************************************************************************
** 以下是 hello.h 的代碼
****************************************************************************/
#ifndef HELLO_H
#define HELLO_H
#include 《qvariant.h》
#include 《qwidget.h》
class QVBoxLayout;
class QHBoxLayout;
class QGridLayout;
class Hello : public QWidget
{
Q_OBJECT
public:
Hello(QWidget* parent = 0, const char* name = 0, WFlags fl = 0);
~Hello();
/* 以下是手動(dòng)添加的代碼 */
signals:
void clicked();
protected:
void mouseReleaseEvent(QMouseEvent *);
void paintEvent(QPaintEvent *);
private slots:
void animate();
private:
QString t;
int b;
};
#endif // HELLO_H
/****************************************************************************
** 以下是 hello.cpp 源代碼
****************************************************************************/
#include “hello.h”
#include 《qlayout.h》
#include 《qvariant.h》
#include 《qtooltip.h》
#include 《qwhatsthis.h》
#include 《qpushbutton.h》
#include 《qtimer.h》
#include 《qpainter.h》
#include 《qpixmap.h》
/*
* Constructs a Hello which is a child of ‘parent’, with the
* name ‘name’ and widget flags set to ‘f’
*/
Hello::Hello(QWidget* parent, const char* name, WFlags fl)
?。?QWidget(parent, name, fl)
{
if (!name)
setName(“Hello”);
resize(240, 320);
setMinimumSize(QSize(240, 320));
setMaximumSize(QSize(240, 320));
setSizeIncrement(QSize(240, 320));
setBaseSize(QSize(240, 320));
QPalette pal;
QColorGroup cg;
cg.setColor(QColorGroup::Foreground, black);
cg.setColor(QColorGroup::Button, QColor(192, 192, 192));
cg.setColor(QColorGroup::Light, white);
cg.setColor(QColorGroup::Midlight, QColor(223, 223, 223));
cg.setColor(QColorGroup::Dark, QColor(96, 96, 96));
cg.setColor(QColorGroup::Mid, QColor(128, 128, 128));
cg.setColor(QColorGroup::Text, black);
cg.setColor(QColorGroup::BrightText, white);
cg.setColor(QColorGroup::ButtonText, black);
cg.setColor(QColorGroup::Base, white);
cg.setColor(QColorGroup::Background, white);
cg.setColor(QColorGroup::Shadow, black);
cg.setColor(QColorGroup::Highlight, black);
cg.setColor(QColorGroup::HighlightedText, white);
pal.setActive(cg);
cg.setColor(QColorGroup::Foreground, black);
cg.setColor(QColorGroup::Button, QColor(192, 192, 192));
cg.setColor(QColorGroup::Light, white);
cg.setColor(QColorGroup::Midlight, QColor(220, 220, 220));
cg.setColor(QColorGroup::Dark, QColor(96, 96, 96));
cg.setColor(QColorGroup::Mid, QColor(128, 128, 128));
cg.setColor(QColorGroup::Text, black);
cg.setColor(QColorGroup::BrightText, white);
cg.setColor(QColorGroup::ButtonText, black);
cg.setColor(QColorGroup::Base, white);
cg.setColor(QColorGroup::Background, white);
cg.setColor(QColorGroup::Shadow, black);
cg.setColor(QColorGroup::Highlight, black);
cg.setColor(QColorGroup::HighlightedText, white);
pal.setInactive(cg);
cg.setColor(QColorGroup::Foreground, QColor(128, 128, 128));
cg.setColor(QColorGroup::Button, QColor(192, 192, 192));
cg.setColor(QColorGroup::Light, white);
cg.setColor(QColorGroup::Midlight, QColor(220, 220, 220));
cg.setColor(QColorGroup::Dark, QColor(96, 96, 96));
cg.setColor(QColorGroup::Mid, QColor(128, 128, 128));
cg.setColor(QColorGroup::Text, black);
cg.setColor(QColorGroup::BrightText, white);
cg.setColor(QColorGroup::ButtonText, QColor(128, 128, 128));
cg.setColor(QColorGroup::Base, white);
cg.setColor(QColorGroup::Background, white);
cg.setColor(QColorGroup::Shadow, black);
cg.setColor(QColorGroup::Highlight, black);
cg.setColor(QColorGroup::HighlightedText, white);
pal.setDisabled(cg);
setPalette(pal);
QFont f(font());
f.setFamily(“adobe-helvetica”);
f.setPointSize(29);
f.setBold(TRUE);
setFont(f);
setCaption(tr(“”));
/* 以下是手動(dòng)添加的代碼 */
t = “Hello,World”;
b = 0;
QTimer *timer = new QTimer(this);
connect(timer, SIGNAL(timeout()), SLOT(animate()));
timer-》start(40);
}
/*
* Destroys the object and frees any allocated resources
*/
Hello::~Hello()
{
}
/* 以下至結(jié)尾是手動(dòng)添加的代碼 */
void Hello::animate()
{
b = (b + 1) & 15;
repaint(FALSE);
}
/*
Handles mouse button release events for the Hello widget.
We emit the clicked() signal when the mouse is released inside
the widget.
*/
void Hello::mouseReleaseEvent(QMouseEvent *e)
{
if (rect().contains(e-》pos()))
emit clicked();
}
/* Handles paint events for the Hello widget.
Flicker-free update. The text is first drawn in the pixmap and the
pixmap is then blt‘ed to the screen.
*/
void Hello::paintEvent(QPaintEvent *)
{
static int sin_tbl[16] = {0, 38, 71, 92, 100, 92,
71, 38, 0, -38, -71, -92, -100, -92, -71, -38};
if (t.isEmpty())
eturn;
/* 1: Compute some sizes, positions etc. */
QFontMetrics fm = fontMetrics();
int w = fm.width(t) + 20;
int h = fm.height() * 2;
int pmx = width()/2 - w/2;
int pmy = height()/2 - h/2;
/* 2: Create the pixmap and fill it with the widget’s background */
QPixmap pm(w, h);
pm.fill(this, pmx, pmy);
/* 3: Paint the pixmap. Cool wave effect */
QPainter p;
int x = 10;
int y = h/2 + fm.descent();
int i = 0;
p.begin(&pm);
p.setFont(font());
while (!t[i].isNull())
{
nt i16 = (b+i) & 15;
.setPen(QColor((15-i16)*16,255,255,QColor::Hsv));
wText(x, y-sin_tbl[i16]*h/800, t.mid(i,1), 1);
+= fm.width(t[i]);
+;
}
p.end();
/* 4: Copy the pixmap to the Hello widget */
bitBlt(this, pmx, pmy, &pm);
}
?。?)編寫主函數(shù)main()。
一個(gè)Qt/Embeded應(yīng)用程序應(yīng)該包含一個(gè)主函數(shù),主函數(shù)所在的文件名是main.cpp。主函數(shù)是應(yīng)用程序執(zhí)行的入口點(diǎn)。以下是“Hello,World”例子的主函數(shù)文件main.cpp的實(shí)現(xiàn)代碼:
/****************************************************************************
** 以下是 main.cpp 源代碼
****************************************************************************/
#include “hello.h”
#include 《qapplication.h》
/*
The program starts here. It parses the command line and builds a message
string to be displayed by the Hello widget.
*/
#define QT_NO_WIZARD
int main(int argc, char **argv)
{
QApplication a(argc,argv);
Hello dlg;
QObject::connect(&dlg, SIGNAL(clicked()), &a, SLOT(quit()));
a.setMainWidget(&dlg);
dlg.show();
return a.exec();
}
(5)編輯工程文件hello.pro文件。
到目前為止,為Hello,World例子編寫了一個(gè)頭文件和兩個(gè)源文件,這3個(gè)文件應(yīng)該被包括在工程文件中,因此還需要編輯hello.pro文件,加入hello.h、hello.cpp、main.cpp這3個(gè)文件名。具體定義如下:
/****************************************************************************
** 以下是 hello.pro 文件的內(nèi)容
****************************************************************************/
TEMPLATE = app
CONFIG = qt warn_on release
HEADERS = hello.h
SOURCES = hello.cpp \
main.cpp
INTERFACES =
?。?)生成Makefile文件。
編譯器是根據(jù)Makefile文件內(nèi)容來進(jìn)行編譯的,所以需要生成Makefile文件。Qt提供的tmake工具可以幫助我們從一個(gè)工程文件(.pro文件)中產(chǎn)生Makefile文件。結(jié)合當(dāng)前例子,要從hello.pro生成一個(gè)Makefile文件的做法是首先查看環(huán)境變量$TMAKEPATH是否指向ARM編譯器的配置目錄,在命令行下輸入以下命令:
ECHO $TMAKEPATH
如果返回的結(jié)果末尾不是…/qws/linux-arm-g++的字符串,那么需要把環(huán)境變量$TMAKEPATH所指的目錄設(shè)置為指向arm編譯器的配置目錄,過程如下:
EXPORT TMAKEPATH = /TMAKE 安裝路徑/QWS/LINUX-ARM-G++
同時(shí),應(yīng)確保當(dāng)前的QTDIR環(huán)境變量指向Qt/Embedded的安裝路徑,如果不是,則需要執(zhí)行以下過程。
EXPORT QTDIR = ……/qt-2.3.7
上述步驟完成后,就可以使用tmake生成Makefile文件,具體做法是在命令行輸入以下命令:
TMAKE –O MAKEFILE HELLO.PRO
這樣就可以看到當(dāng)前目錄下新生成了一個(gè)名為Makefile的文件。下一步,需要打開這個(gè)文件,做一些小的修改。
?、?將LINK = arm-linux-gcc改為:LINK = arm-linux-g++
這樣做是因?yàn)橐胊rm-linux-g++進(jìn)行鏈接。
?、?將LIBS = $(SUBLIBS) -L$(QTDIR)/lib -lm –lqte改為:
LIBS = $(SUBLIBS) -L/usr/local/arm/2.95.3/lib -L$(QTDIR)/lib -lm –lqte
這是因?yàn)殒溄訒r(shí)要用到交叉編譯工具toolchain的庫。
(7)編譯鏈接整個(gè)工程。
最后就可以在命令行下輸入make命令對(duì)整個(gè)工程進(jìn)行編譯鏈接了。
make生成的二進(jìn)制文件hello就是可以在FS2410上運(yùn)行的可執(zhí)行文件。
?
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 基于QT的簡(jiǎn)單的上位機(jī)
- QT篇QT上位機(jī)串口編程
- 基于QT應(yīng)用、TCP應(yīng)用界面程序 4次下載
- Qt 嵌入式圖形開發(fā)大全和QT開發(fā)手冊(cè)
- 讓Qt Creator顯示Hello World字符串的課件免費(fèi)下載 11次下載
- 使用Qt編寫的串口調(diào)試工具的應(yīng)用程序和源代碼資料免費(fèi)下載 75次下載
- 什么是Qt?Qt的入門教程免費(fèi)下載使用 2次下載
- 使用ARM進(jìn)行QT4移植的詳細(xì)資料說明 2次下載
- 嵌入式linux應(yīng)用開發(fā)之QT 4次下載
- Qt與Matlab混合編程 0次下載
- 跨平臺(tái)C++圖形用戶界面應(yīng)用程序QT4中文教程手冊(cè) 0次下載
- qt編寫的觸摸小鍵盤 7次下載
- Qt嵌入式圖形開發(fā)(基礎(chǔ)篇) 51次下載
- 基于Qt4的圖形用戶界面程序設(shè)計(jì) 75次下載
- Linux下Qt編程入門教程下載
- Qt上位機(jī)開發(fā)實(shí)戰(zhàn)案例 1731次閱讀
- 3562-Qt工程編譯說明 317次閱讀
- QT串口通信的簡(jiǎn)單使用 1337次閱讀
- Rust GUI實(shí)踐之Rust-Qt模塊 1356次閱讀
- Qt 5.14.2超詳細(xì)安裝教程 4669次閱讀
- Qt的QApplication不簡(jiǎn)單! 1877次閱讀
- Qt“靈魂”之Meta-Object系統(tǒng) 1449次閱讀
- 用PyQt5做圖形界面(一)Hello world 1490次閱讀
- QT環(huán)境搭建教程 1211次閱讀
- Qt應(yīng)用程序出現(xiàn)卡頓的現(xiàn)象怎么解決呢 7945次閱讀
- Qt Quick開發(fā)工具總結(jié) 1723次閱讀
- 在MPSoC ZCU106單板的HDMI-Tx上基于eglfs_kms的運(yùn)行QT應(yīng)用程序 2773次閱讀
- 如何編寫第一個(gè)hello world程序 8142次閱讀
- 米爾科技Linux簡(jiǎn)單Hello World應(yīng)用程序的教程 1300次閱讀
- ZedBoard學(xué)習(xí)手記(九) 在ZedBoard上運(yùn)行QT圖形軟件 1414次閱讀
下載排行
本周
- 1TC358743XBG評(píng)估板參考手冊(cè)
- 1.36 MB | 330次下載 | 免費(fèi)
- 2開關(guān)電源基礎(chǔ)知識(shí)
- 5.73 MB | 6次下載 | 免費(fèi)
- 3100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 4嵌入式linux-聊天程序設(shè)計(jì)
- 0.60 MB | 3次下載 | 免費(fèi)
- 5基于FPGA的光纖通信系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)
- 0.61 MB | 2次下載 | 免費(fèi)
- 6基于FPGA的C8051F單片機(jī)開發(fā)板設(shè)計(jì)
- 0.70 MB | 2次下載 | 免費(fèi)
- 751單片機(jī)窗簾控制器仿真程序
- 1.93 MB | 2次下載 | 免費(fèi)
- 8基于51單片機(jī)的RGB調(diào)色燈程序仿真
- 0.86 MB | 2次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 2555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33564次下載 | 免費(fèi)
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費(fèi)
- 4開關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21548次下載 | 免費(fèi)
- 5電氣工程師手冊(cè)免費(fèi)下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費(fèi)
- 6數(shù)字電路基礎(chǔ)pdf(下載)
- 未知 | 13750次下載 | 免費(fèi)
- 7電子制作實(shí)例集錦 下載
- 未知 | 8113次下載 | 免費(fèi)
- 8《LED驅(qū)動(dòng)電路設(shè)計(jì)》 溫德爾著
- 0.00 MB | 6653次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537796次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191185次下載 | 免費(fèi)
- 7十天學(xué)會(huì)AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183278次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138040次下載 | 免費(fèi)
評(píng)論
查看更多