QT知识小结(二)

http://oceangy.iteye.com/blog/1772808


1、取消对话框最大,最小按钮

     

      #include <Qt>

 

       QPixmap splImg("images//Splash.png");

       QPalette p;

        p.setBrush(splshDlg.backgroundRole(),QBrush(splImg));

        splshDlg.setPalette(p);

        splshDlg.setWindowFlags(Qt::Dialog|Qt::CustomizeWindowHint);//没有标题栏

        //splshDlg.setAttribute(Qt::WA_TranslucentBackground);

       splshDlg.show();

 

2、设置启动画面

       #include <Qt/qsplashscreen.h>

 

          QSplashScreen *splash=new QSplashScreen;

          splash->setPixmap(QPixmap("images//Splash.png"));

          splash->show();

         //splash->finish(&dlg);

         //delete splash;

 

3、对话框大小固定,不允许用户拉大,拉小

      dlg.setMaximumHeight(350);

      dlg.setMaximumWidth(450);

 

      dlg.setMinimumHeight(350);

      dlg.setMinimumWidth(450);

 

4、设置QT程序字体

    QFont font("Fangsong Ti");

         #ifdef WIN32

font.setFamily("宋体");

font.setPointSize(12);

         #else

font.setFamily("Song");

font.setPointSize(15)

          #endif

//a.setFont(font);

 

 5、汉字为乱码的解决方法

      #include <Qt/qtextcodec.h>

       QTextCodec::setCodecForTr(QTextCodec::codecForName("gb18030"));

 

 6QT连接数据库

  

连接数据库需要的头文件:

#include <QSqlDatabase>

#include <QSqlQuery>

 

1、连接微软的Access-------------------------------------------------------------

 QSqlDatabase ldb = QSqlDatabase::addDatabase("QODBC");

 ldb.setDatabaseName("DRIVER={Microsoft Access Driver (*.mdb)};FIL={MS Access};DBQ=system.mdb;UID=;PWD=xiaozhuset");

bool ok = ldb.open();

//新定义一个查询集合,并指定 链接关键字。 如果有多个连接,可以随意指定一个你需要的。

QSqlQuery mquery=QSqlQuery::QSqlQuery(ldb);

if(ok)

{

  bool isok=mquery.exec("select * from sql_set;");

 if (!isok)

 {

   ldb.close();

   return -1;

  }

 

//这个是必须的,因为查处的结果集当前位置不在第一条记录上。

mquery.next();

 

QString sHostName=mquery.value(1).toString();

QString sDatabaseName=mquery.value(2).toString();

QString sUserName=mquery.value(3).toString();

QString sPassword=mquery.value(4).toString();

 

//清除结果集

mquery.clear();

// 如果该连接不再使用,就可以关闭。

ldb.close();

 

//这里是将从数据库读出的数据写到一个list控件里

ui.list_out->insertItem(ui.list_out->count(),sHostName);

ui.list_out->insertItem(ui.list_out->count(),sDatabaseName);

 

}

else

{

// 打开本地数据库失败,

QMessageBox::critical(0, QObject::tr("读取Access数据库错误!"),db.lastError().text());

return -1;

}

 

 

2、连接mssql2000 数据库--------------------------------------------------------------------------------------------

QString strDatabaseName = QString("DRIVER={SQL Server};Server=(%1);Database=%2").arg("local").arg(sDatabaseName);

 

db=QSqlDatabase::addDatabase("QODBC","db"); // 使用odbc数据库驱动

db.setHostName(sHostName);

db.setPort(1433);

db.setDatabaseName(strDatabaseName); // 我们之前建立的数据库连接关键字

db.setUserName(sUserName);

db.setPassword(sPassword);

bool ok = db.open(); //尝试连接数据库

if(ok)

{

menuset_set->db=db;

// 这里用sa已经成功连上数据库

return 0;

}

else

{

// 打开数据库失败,

QMessageBox::critical(0, QObject::tr("数据库连接错误!"),db.lastError().text());

return -2;

}

mssql2000数据库连接的使用和Access连接使用方法一样。

QSqlQuery mquery=QSqlQuery::QSqlQuery(db);

bool ok1=mquery.exec("select * from CarteMenu;");

if (ok1==false)return -1;

QString menu_mkey=mquery.value(13).toString();

QString strmenu_lang=mquery.value(3).toString();

//清除结果集

mquery.clear();

 

3、连接mysql 数据库

QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL"); // 使用mysql数据库驱动

db.setHostName("localhost");

db.setDatabaseName("exampledb"); // 数据库名称

db.setUserName("sa"); // 用户名

db.setPassword("1"); // 密码

bool ok = db.open(); // 尝试连接数据库

if(ok)

{

QSqlQuery myquery;

if(myquery.exec("select * from employeedb"))

{

int num = 0;

if(db.driver()->hasFeature(QSqlDriver::QuerySize))

{

num = myquery.size(); // 如果支持结果影响的行数,那么直接记录下来

}

else

{

myquery.last(); //否则定位到结果最后

num = myquery.at() + 1;

}

//这里添加数据库的查询结果处理操作

 

}

else // 如果查询失败

{

QSqlError error = myquery.lastError();

}

}

else // 打开数据库失败

{

 

}

 

7、验证当前系统支持哪些数据库

 

#include <QApplication>

#include <QSqlDatabase>

#include <QStringList>

#include <QDebug>

 

int main(int argc, char* argv[]) {

QApplication app(argc, argv);

 

qDebug() << "Available drivers:";

QStringList drivers = QSqlDatabase::drivers();

foreach(QString driver, drivers)

qDebug() << "\t" << driver;

 

QSqlDatabase db = QSqlDatabase::addDatabase("QODBC");

qDebug() << "ODBC driver valid?" << db.isValid();

}

 

8QT连接SQL Server2000报错

     出错信息:[Microsoft][ODBC SQL Server Driver][SQL Server]用户 'sa' 登录失败。原因: 未与信任 SQL Server 连接相关联。 QODBC3: Unable to connect

 

    解决方法

           找到解决这个问题的方法了,这样问题解决了。

             这一问题一般是由于SQL Server未集成Windows身份验证导致的,所以解决方案为:

            1、打开SQL Server企业管理器。

            2、选择服务器名称上右键选择“编辑SQL Server注册属性”,然后在对话框中选择“使用windows身份验证”。

            3、同样右键,选择“属性”,然后打开“安全性”选项卡。

            4、在选项卡中,选择身份验证为“SQL Server Windows ”,其他不变。

 

9QT数据库操作

         

qt-win-commercial-src-4.3.1、qt-x11-commercial-src-4.3.1

Microsoft Visual C++ 6.0、KDevelop 3.5.0

Windows Xp、Solaris 10、Fedora 8

SQL Server、Oracle 10g Client

*********************************************************************************

■、驱动编译

这里要提及两个数据库驱动,分别是ODBCOCI

Windows操作系统中编译ODBC驱动:

执行以下命令,会在%QTDIR%\plugins\sqldrivers目录下面生成qsqlodbc4.dll

cd %QTDIR%\src\plugins\sqldrivers\odbc

qmake -o Makefile odbc.pro

nmake

Unix操作系统下编译unixODBC驱动:

unixODBC可以在http://www.unixodbc.org下载。这里假定unixODBC安装在/usr/local/unixODBC。

执行以下命令,会在$QTDIR/plugins/sqldrivers目录下面生成qsqlodbc4.a

cd $QTDIR/src/plugins/sqldrivers/odbc

qmake "INCLUDEPATH+=/usr/local/unixODBC/include" "LIBS+=-L/usr/local/unixODBC/lib -lodbc"

make

Windows操作系统中编译OCI驱动:

这里假定Oracle Client安装在C:\oracle。添加oci.dll动态连接库的环境变量c:\oracle\bin

set INCLUDE=%INCLUDE%;c:\oracle\oci\include

set LIB=%LIB%;c:\oracle\oci\lib\msvc

cd %QTDIR%\src\plugins\sqldrivers\oci

qmake -o Makefile oci.pro

nmake

Unix操作系统下编译OCI驱动:

当然根据你的oracle修正下相应的版本号。

cd $QTDIR/src/plugins/sqldrivers/oci

qmake -o Makefile "INCLUDEPATH+=/usr/include/oracle/10.1.0.3/client/" "LIBS+=-L/usr/lib/oracle/10.1.0.3/client/lib" oci.pro

make

在程序中包含头文件

#include <QtSql>

在程序的.pro文件中添加

QT += sql

 

■、数据库连接

这里则要提及单一数据库连接和多个数据库连接:

单一数据库连接:

static bool sqlConnection(const QString& HostName,

const QString& DatabaseName,

const QString& UserName,

const QString& Password)

{

QSqlDatabase db = QSqlDatabase::addDatabase("QODBC");

db.setHostName(HostName);

db.setDatabaseName(DatabaseName);

db.setUserName(UserName);

db.setPassword(Password);

if(!db.open())

{

QMessageBox::critical(0, QObject::tr("Error"),

QObject::tr("The database reported an error: %1").arg(db.lastError().text()));

return false;

}

//Qt数据库连接后,运行"SET NAMES 'UTF8'"语句或"SET NAMES 'GBK'"

//db.exec("SET NAMES 'UTF8'");

return true;

}

//多个数据库连接

static bool sqlConnections()

{

// 创建一个名为odbc的连接

QSqlDatabase *odbc = QSqlDatabase::addDatabase( "QODBC", "ODBC" );

if ( ! defaultDB ) {

qWarning( "Failed to connect to odbc driver" );

return FALSE;

}

odbc->setDatabaseName( DB_ODBC_DBNAME );

odbc->setUserName( DB_ODBC_USER );

odbc->setPassword( DB_ODBC_PASSWD );

odbc->setHostName( DB_ODBC_HOST );

if ( ! odbc->open() ) {

qWarning( "Failed to open sales database: " + odbc->lastError().driverText() );

qWarning( odbc->lastError().databaseText() );

return FALSE;

}

// 创建一个名为oracle的连接

QSqlDatabase *oracle = QSqlDatabase::addDatabase( "QOCI", "ORACLE" );

if ( ! oracle ) {

qWarning( "Failed to connect to oracle driver" );

return FALSE;

}

oracle->setDatabaseName( DB_ORACLE_DBNAME );

oracle->setUserName( DB_ORACLE_USER );

oracle->setPassword( DB_ORACLE_PASSWD );

oracle->setHostName( DB_ORACLE_HOST );

if ( ! oracle->open() ) {

qWarning( "Failed to open orders database: " + oracle->lastError().driverText() );

qWarning( oracle->lastError().databaseText() );

return FALSE;

}

return TRUE;

}

QSqlDatabase维护着通过addDatabase()这个静态函数返回的的连接指针。

如果有移去一个连接,先调用QSqlDatabase::close()来关闭连接,然后通过静态函数QSqlDatabase::removeDatabase()来移除连接。

int main(int argc, char *argv[])

{

QApplication app(argc, argv);

QTextCodec::setCodecForCStrings(QTextCodec::codecForLocale());

QTextCodec::setCodecForTr(QTextCodec::codecForLocale());

QFont font("Times", 9, QFont::Normal, FALSE);

app.setFont(font);

//连接单一数据库

if (!sqlConnection("10.0.0.3", "qjkzdb", "sa", "syth7777"))

return 1;

//连接多个数据库

if (!sqlConnections())

return 1;

// 数据库被成功打开,得到它们的指针:

QSqlDatabase *oracledb = QSqlDatabase::database( "ORACLE" );

// 现在我们可以在oracle连接或默认连接上执行SQL命令

...

return app.exec();

}

 

■、SQL执行操作

QSqlQuery提供了对数据库记录的SelectInsertUpdateDelete操作。

SELECT操作:

QSqlQuery query;

query.exec("SELECT name, salary FROM employee WHERE salary > 50000");

while (query.next()) {

QString name = query.value(0).toString();

int salary = query.value(1).toInt();

qDebug() << name << salary;

}

通过QSqlQuery::next()QSqlQuery::previous()QSqlQuery::first()QSqlQuery::last()QSqlQuery::seek()

可以得到下一条、上一条、第一条、最后一条、任意一条记录的位置。

INSERT操作:

//单一插入数据

QSqlQuery query;

query.prepare("INSERT INTO employee (id, name, salary) "

"VALUES (:id, :name, :salary)");

query.bindValue(":id", 1001);

query.bindValue(":name", "Thad Beaumont");

query.bindValue(":salary", 65000);

query.exec();

//批量插入数据

QSqlQuery query;

query.prepare("insert into myTable values (?, ?)");

QVariantList ints;

ints << 1 << 2 << 3 << 4;

query.addBindValue(ints);

QVariantList names;

names << "Harald" << "Boris" << "Trond" << QVariant(QVariant::String);

query.addBindValue(names);

if (!query.execBatch())

qDebug() << query.lastError();

UPDATE操作:

QSqlQuery query;

query.prepare("UPDATE employee SET salary = ? WHERE id = 1003");

query.bindValue(0, 70000);

query.exe();

DELETE操作:

QSqlQuery query;

query.exec("DELETE FROM employee WHERE id = 1007");

事务处理:

QSqlDatabase::database().transaction();

QSqlQuery query;

query.exec("SELECT id FROM employee WHERE name = 'Torild Halvorsen'");

if (query.next()) {

int employeeId = query.value(0).toInt();

query.exec("INSERT INTO project (id, name, ownerid) "

"VALUES (201, 'Manhattan Project', "

+ QString::number(employeeId) + ")");

}

QSqlDatabase::database().commit();

如果数据库引擎支持事务处理,则函数QSqlDriver::hasFeature(QSqlDriver::Transactions)将返回真。

可以通过调用QSqlDatabase::transaction()来初始化一个事务处理。之后执行你想在该事务处理的工作。

完了再执行QSqlDatabase::commit()来提交事务处理或QSqlDatabase::rollback()取消事务处理。

这里在举个QSqlDriver::hasFeature(QSqlDriver::QuerySize)例子,可以较快的统计查询记录行数。

QSqlQuery query;

int numRows;

query.exec("SELECT name, salary FROM employee WHERE salary > 50000");

QSqlDatabase defaultDB = QSqlDatabase::database();

if (defaultDB.driver()->hasFeature(QSqlDriver::QuerySize)) {

numRows = query.size();

} else {

// this can be very slow

query.last();

numRows = query.at() + 1;

}

存储过程:

AsciiToInt()是数据库中的一个存储过程。

但我在网上以前好像看过说是SQL Server中的存储过程是通过"EXEC"完成的,而不是"CALL",这里我不确定!留下一个疑问吧~

QSqlQuery query;

query.prepare("CALL AsciiToInt(?, ?)");

query.bindValue(0, "A");

query.bindValue(1, 0, QSql::Out);

query.exec();

int i = query.boundValue(1).toInt(); // i is 65

 

■、使用SQL Model

QSqlQueryModel:一个只读的读取数据库数据的模型。

QSqlTableModel:一个可读写的单一表格模型,可以不用写SQL语句。

QSqlRelationalTableModelQSqlTableModel的一个子类,可多表关联在一起。

这些类都继承于QAbstractTableModel,而它们又都继承于QAbstractItemModel

QSqlQueryModel 只读模式,基于SQL查询基础。

QSqlQueryModel model;

model.setQuery("SELECT * FROM employee");

for (int i = 0; i < model.rowCount(); ++i) {

int id = model.record(i).value("id").toInt();

QString name = model.record(i).value("name").toString();

qDebug() << id << name;

}

QSqlTableModel 可对单一表操作,进行读写操作。

//读取数据

QSqlTableModel model;

model.setTable("employee");

model.setFilter("salary > 50000");

model.setSort(2, Qt::DescendingOrder);

model.select();

for (int i = 0; i < model.rowCount(); ++i) {

QString name = model.record(i).value("name").toString();

int salary = model.record(i).value("salary").toInt();

qDebug() << name << salary;

}

//通过QSqlTableModel::setRecord()修改数据

for (int i = 0; i < model.rowCount(); ++i) {

QSqlRecord record = model.record(i);

double salary = record.value("salary").toInt();

salary *= 1.1;

record.setValue("salary", salary);

model.setRecord(i, record);

}

model.submitAll();

//通过QSqlTableModel::setData()update一条记录

model.setData(model.index(row, column), 75000);

model.submitAll();

//insert一条记录

model.insertRows(row, 1);

model.setData(model.index(row, 0), 1013);

model.setData(model.index(row, 1), "Peter Gordon");

model.setData(model.index(row, 2), 68500);

model.submitAll();

//delete一条记录

model.removeRows(row, 5);

model.submitAll();

函数QSqlTableModel::submitAll()确保记录写入数据库中。

QSqlRelationalTableModel 通过外键实现了多表关联。

//employee表中关联city表、country表。

model->setTable("employee");

model->setRelation(2, QSqlRelation("city", "id", "name"));

model->setRelation(3, QSqlRelation("country", "id", "name"));

■、数据呈现视图中

QSqlQueryModelQSqlTableModelQSqlRelationalTableModel一般都是借助QListViewQTableViewQTreeView吧数据呈现出来的~

这里我并不想对QTableView详细讲解,这里不做过多的介绍了,也许会在以后单独QTableViewQTableWidget详细介绍。

数据库部分是这次的重点!

继续在对QSqlRelationalTableModel这个作以讲解补充,因为上面提及的实在太少了。

QSqlRelationalTableModel model;

model->setTable("employee");

model->setRelation(2, QSqlRelation("city", "id", "name"));

model->setRelation(3, QSqlRelation("country", "id", "name"));

//设置标题头部标签信息

model->setHeaderData(0, Qt::Horizontal, QObject::tr("ID"));

model->setHeaderData(1, Qt::Horizontal, QObject::tr("Name"));

model->setHeaderData(2, Qt::Horizontal, QObject::tr("City"));

model->setHeaderData(3, Qt::Horizontal, QObject::tr("Country"));

//值得注意的是,在查询时应该明确指明那个表的数据信息,以下两种方式是等价的。

model.setFilter(tr("city.name = '%1'").arg("Mucich"));

//model.setFilter(tr("employee.cityid = %1").arg(312));

model.select();

//借助QTableView,把数据信息显示出来,

QTableView *view = new QTableView;

view->setModel(model);

//将表中的项,设计为不能编辑模式

view->setEditTriggers(QAbstractItemView::NoEditTriggers);

view->show();

在将一种通过QSqlField进行InsertUpdateDelete的操作。上边的例子,继续~

QSqlField idField("id", QVariant::Int);

QSqlField nameField("name", QVariant::String);

QSqlField cityIdField("cityId", QVariant::Int);

QSqlField countryIdField("countryId", QVariant::Int);

//一条记录 Id = 12Name = vic.MINgCity = ShenYangCountry = China(沈阳区号024、中国086)

idField.setValue(12);

nameField.setValue("vic.MINg");

cityIdField.setValue(24);

countryIdField.setValue(86);

//insert一条记录,-1表示在最尾端加入

QSqlRecord record;

record.append(idField);

record.append(nameField);

record.append(cityIdField);

record.append(countryIdField);

model->insertRecord(-1, record);

//update一条记录, row表示要修改的行

QSqlRecord record = model->record(row);

record.replace(1, nameField);

record.replace(2, cityIdField);

record.replace(3, countryIdField);

model->setRecord(row, record);

//delete一条记录, row表示要修改的行

model->removeRow(row);

 

■、数据呈现窗体中

通过QDataWidgetMapper可以在窗体控件与数据库中的记录关联在一起。

QDataWidgetMapper *mapper = new QDataWidgetMapper;

mapper->setModel(model);

mapper->addMapping(idSpinBox, 0);

mapper->addMapping(nameLineEdit, 1);

mapper->addMapping(cityComboBox, 2);

mapper->addMapping(countryComboBox, 3);

//可以通过toFirst()toNext()toPrevious()toLast()setCurrentIndex()来设置当前记录位置,显示相应数据

mapper->toFirst();

//信号、槽的机制modelviewmapper三个联系再一起

connect(view->selectionModel(), SIGNAL(currentRowChanged(QModelIndex,QModelIndex)),

mapper, SLOT(setCurrentModelIndex(QModelIndex)));


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
初 级 篇 \第1章 Qt初步实践 2 \1.1 第一个Qt程序 2 \1.1.1 建立主程序 2 \1.1.2 建立工程 3 \1.1.3 编译/运行第一个Qt应用程序 8 \1.1.4 第一个Qt程序的代码分析 8 \1.2 使用Qt布局管理器 11 \1.3 关联操作 12 \1.4 小结 13 \第2章 对话框——QDialog 14 \2.1 自定义对话框 14 \2.1.1 建立新类 14 \2.1.2 添加子窗口部件 15 \2.2 加入主程序 22 \2.3 Qt内建(built-in)对话框 24 \2.4 小结 34 \第3章 基础窗口部件——QWidget 35 \3.1 Qt设计器绘制窗口部件 35 \3.1.1 Qt设计器基础 35 \3.1.2 绘制窗口部件 40 \3.2 程序中引入自定义窗口部件 47 \3.2.1 直接使用方式 47 \3.2.2 单一继承方式 49 \3.2.3 多继承方式 51 \3.3 Qt的信号和槽机制 53 \3.3.1 基本原理 53 \3.3.2 设计信号和槽 55 \3.3.3 信号和槽的自动关联 62 \3.4 窗口标志及几何布局 63 \3.4.1窗口标志 64 \3.4.2窗口部件的几何布局 66 \ \3.5 Qt样式表 74 \3.5.1 样式表语法 74 \3.5.2 样式表的应用 76 \3.6 Qt对象模型 79 \3.6.1 元对象系统 79 \3.6.2 属性系统 80 \3.6.3 对象树 83 \3.7 小结 86 \第4章 程序主窗口——QMainWindow 87 \4.1 QMainWindow主窗口框架 87 \4.2 Qt设计器绘制主窗口 88 \4.2.1 菜单 90 \4.2.2 工具栏 93 \4.2.3 中心部件 96 \4.3 代码创建主窗口 98 \4.3.1 创建资源文件 98 \4.3.2 定义主窗口类 98 \4.4 锚接部件 102 \4.5 状态栏 105 \4.6 实现文本编辑器功能 107 \4.7 多文档 118 \4.8 打印文档 119 \4.9 小结 120 \第5章 布局管理 121 \5.1 Qt布局管理器——QLayout 121 \5.1.1 Qt布局管理器简介 121 \5.1.2 布局管理器及窗口部件大小策略 \5.1.2 的应用 125 \5.2 分裂器部件QSplitter 132 \5.3 栈部件QStackedWidget 134 \5.4 工作空间部件QWorkspace 135 \5.5 多文档区部件QMdiArea 148 \5.6 小结 150 \ \中 级 篇 \第6章 2D绘图 152 \6.1 Arthur绘图基础 152 \6.1.1 绘图 152 \6.1.2 绘图设备 174 \6.2 坐标系统与坐标变换 175 \6.2.1 坐标系统 175 \6.2.2 坐标变换 175 \6.3 用不同的字体 177 \6.4 绘图路径——QPainterPath 180 \6.5 QImage与QPixmap绘图设备 182 \6.5.1 QImage 182 \6.5.2 Pixmap 183 \6.6 组合模式绘图 192 \6.7 Graphics View框架 200 \6.7.1 Graphics View体系结构 200 \6.7.2 Graphics View坐标系统 201 \6.7.3 深入Graphics View 202 \6.8 图形图像打印 208 \6.8.1 普通打印过程 208 \6.8.2 特殊窗口部件的打印 210 \6.9 小结 211 \第7章 拖放操作和剪贴板 212 \7.1 拖放操作 212 \7.1.1 拖放操作 212 \7.1.2 定义新的拖放操作类型 214 \7.1.3 Graphics View框架下的拖放 \7.1.3 操作 215 \7.2 使用剪贴板 217 \7.3 小结 218 \第8章 文件处理 219 \8.1 读写文本文件 219 \8.2 操作进制文件 220 \8.3 临时文件 222 \8.4 目录操作和文件管理 222 \8.4.1 目录操作 222 \8.4.2 文件管理 224 \8.5 监视文件系统变化 225 \8.6 文件引擎 226 \8.7 小结 226 \第9章 网络 227 \9.1 FTP客户端 227 \9.2 HTTP客户端 235 \9.3 UDP应用 239 \9.4 TCP应用 243 \9.5 高级应用 253 \9.5.1 底层操作 253 \9.5.2 使用代理 256 \9.5.3 扩展Qt网络功能 256 \9.5.4 效率问题 260 \9.6 小结 260 \第10章 多线程 261 \10.1 启动一个线程 261 \10.2 线程互斥与同步 264 \10.2.1 临界区问题 265 \10.2.2 使用QMutex 265 \10.2.3 使用QSemaphore 266 \10.2.4 使用QWaitConditon 269 \10.3 线程的其他问题 271 \10.3.1 优先级问题 271 \10.3.2 死锁及优先级反转问题 274 \10.3.3 本地存储问题 275 \10.4 Qt的线程机制 276 \10.4.1 可重入与线程安全 276 \10.4.2 线程与事件循环 277 \10.4.3 线程与信号/槽机制 278 \10.4.4 多线程网络示例 279 \10.5 小结 282 \第11章 事件处理 283 \11.1 事件机制 283 \11.1.1 事件来源与类型 283 \11.1.2 事件处理方法 284 \11.2 事件处理器 285 \11.3 事件过滤器 290 \11.4 加快用户界面响应 292 \11.4.1 使用processEvents()函数 293 \11.4.2 使用定时器 294 \11.5 小结 296 \第12章 数据库 297 \12.1 连接数据库 297 \12.2 常用数据库操作 301 \12.2.1 使用SQL语句 302 \12.2.2 事务操作 304 \12.2.3 使用SQL模型类 304 \12.2.4 数据表示 308 \12.3 Qt数据库应用 310 \12.3.1 使用嵌入式数据库 310 \12.3.2 使用Oracle数据库 313 \12.4 小结 325 \第13章 Qt的模板库和工具类 326 \13.1 Qt容器类 326 \13.1.1 QList、QLinkedList和QVector 327 \13.1.2 QMap、QHash 332 \13.2 QString 334 \13.2.1 隐式共享 335 \13.2.2 内存分配策略 336 \13.2.3 操作字符串 336 \13.2.4 查询字符串数据 337 \13.2.5 字符串的转换 338 \13.3 QVariant 339 \13.4 Qt的算法 341 \13.5 正则表达式 342 \13.5.1 基本的正则表达式 342 \13.5.2 文字捕获 344 \13.6 小结 345 \高 级 篇 \第14章 XML 348 \14.1 DOM 348 \14.1.1 DOM入门 348 \14.1.2 使用DOM 348 \14.1.3 使用DOM写XML文件 352 \14.2 SAX 354 \14.3 基于流的XML API 359 \14.4 小结 365 \第15章 模型/视图结构 366 \15.1 模型/视图结构与MVC设计 \15.1 模式 366 \15.1.1 模型 366 \15.1.2 视图 367 \15.1.3 代理 368 \15.2 使用已有的模型视图类 368 \15.2.1 使用已有的模型和视图类 368 \15.2.2 QListWidget、QtreeWidget \15.2.2 和QTableWidget 370 \15.3 模型(Models) 381 \15.3.1 模型索引 381 \15.3.2 模型角色 382 \15.3.3 自定义模型 382 \15.3.4 代理模型 385 \15.4 视图(Views) 390 \15.4.1 自定义视图 390 \15.4.2 数据-窗口部件映射 390 \15.5 代理(Delegates) 396 \15.5.1 使用已有的代理 396 \15.5.2 自定义代理 396 \15.6 拖放与选中 401 \15.6.1 拖放操作 401 \15.6.2 选中模式 404 \15.7 小结 405 \第16章 高级绘图 406 \16.1 3D绘图——使用OpenGL 406 \16.1.1 创建OpenGL窗口 406 \16.1.2 着色 410 \16.1.3 3D和旋转 411 \16.1.4 纹理贴图 414 \16.2 SVG 417 \16.2.1 绘制SVG图形 418 \16.2.2 生成SVG文件 419 \16.3 小结 420 \第17章 进程与进程间通信 421 \17.1 使用QProcess 421 \17.2 Linux进程间通信 423 \17.3 新型进程间通信——D-Bus 425 \17.3.1 D-Bus简介 425 \17.3.2 安装QtDBus模块 427 \17.3.3 接口与适配器 429 \17.3.4 QtDBus应用实例 432 \17.4 小结 441 \第18章 Qt插件 442 \18.1 Qt插件开发基础 442 \18.2 Qt设计器插件 443 \18.2.1 使用Scratchpad 443 \18.2.2 提升自定义窗口部件 444 \18.2.3 Qt设计器插件开发 444 \18.3 编写数据库插件 451 \18.4 自定义风格插件 455 \18.5 小结 458 \第19章 脚本——QtScript 459 \19.1 执行ECMAScript脚本 459 \19.2 QtScript中的信号和槽 460 \19.3 使用JavaScript操作Qt对象 463 \19.4 基于Prototype的继承 467 \19.5 小结 467 \第20章 国际化 468 \20.1 Unicode与字符编码 468 \20.1.1 Unicode 468 \20.1.2 汉字编码 469 \20.1.3 编码转换 469 \20.2 Qt Linguist 471 \20.2.1 发布管理器 472 \20.2.2 翻译器 474 \20.2.3 加载翻译文件 476 \20.3 语言切换 477 \20.4 小结 477 \第21章 Qt单元测试框架 478 \21.1 QTestLib框架 478 \21.1.1 QTestLib 478 \21.1.2 第一个Qt单元测试 478 \21.2 数据驱动测试 480 \21.3 GUI测试 481 \21.2.1 仿真GUI事件 481 \21.2.2 重放GUI事件 483 \21.3 小结 484 \附录A Qt安装 485 \附录B Qt集成开发环境 492 \附录C qmake速查 501 \附录D 深入Qt源代码 506 \附录E Qt资源 512 序言/前言    前言 \两年前,当我们准备在Linux系统下开发GUI应用软件时,首先想到的就是选择一个GUI应用框架来简化开发。在三大GUI框架GTK+、Qt和wxWidgets 之间,我们选择了Qt 4工具包。作为重量级桌面系统KDE多年的坚实基础,Qt应该是经受了足够的考验。当我们准备编写自己的应用软件时,却发现图书市场上没有一本关于Qt 4的书籍,仅有的只是一些关于Qt 3的资料。由于Qt 3到Qt 4的变化很大,甚至源代码都不兼容,所以这些资料的参考价值并不是太大。于是,我们通过阅读Qt的assistant和examples来学习并使用Qt 4。在逐渐掌握Qt 4的过程中,我们萌发了编写一本关于Qt 4的书来帮助初学者入门的想法。最终,在电子工业出版社博文视点资讯有限公司的大力支持下,我们的想法终于得以付诸实施。 \关于Qt \Qt是挪威的Trolltech公司的旗舰产品,作为跨平台的应用程序框架,是开源的桌面系统KDE的基石。Google Earth,Skype,Opera,Adobe Photoshop Elements,Peforce Visual Client等软件都是基于Qt写成。自Trolltech公司1996年推出Qt 1.0版以来,Qt已经从2.x,3.x发展到了现在的Qt 4.3,本书就是基于最新的Qt 4.3写成。因为Qt 4框架设计得非常优秀,在2006年的第16届Jolt大奖上,Qt 4获得了类库、框架和组件类别的Jolt生产力奖。 \和Java的“一次编译,到处运行”跨平台不同的是,Qt是源代码级的跨平台,一次编写,随处编译。一次开发的Qt应用程序可以移植到不同的平台上,只需重新编译即可运行。Qt支持的平台有: \? Microsoft Windows,包括Windows 98/NT 4.0/2000/XP/Vista; \? UNIX/X11,包括Linux,Sun Solaris,HP-UX,HP Tru64 UNIX,IBM AIX,SGI IRIX等; \? Mac OS X,支持Mac OS X 10.3以上版本; \? 嵌入式Linux,包括支持framebuffer的所有Linux平台。 \Qt还支持嵌入式系统,Qt的嵌入式版本称为Qtopia Core,可以在多种处理器上运行,目标操作系统通常是嵌入式Linux。Qtopia Core应用程序直接使用framebuffer,而不是笨重的X Window系统。Qt相关的另一个产品——Qt Jambi,则是基于Qt库构建的,面向Java程序员的应用程序框架。另外,还有一些开源的在其他语言上的Qt绑定,如C#/Mono的绑定Qyoto,Python的绑定PyQt,Ruby的绑定QtRuby等。有了这些产品,编写Qt程序不再是C++程序员的专利了。 \Qt的发行版本有商业版和开源版。开源版遵循QPL(Q Public License)和GPL(GNU General Public License)协议,商业版则提供了一些特有的模块,如Windows平台上的ActiveQt框架,Oralce、DB2等商业数据库的驱动。本书主要介绍开源版的Qt 4.3。 \阅读本书的基础 \阅读本书的读者需要具有基本的C++程序设计知识,毕竟Qt是用C++编写的应用程序框架。如果要学习QtScript,还需要了解JavaScript。 \本书的结构 \本书共21章,每章讨论一个专题。章节安排上基本采用循序渐进、由浅到深的原则。但最后的高级篇中的章节没有很强的关联,可以按照随意的顺序阅读。每章内容及作者分述如下: \篇章 章 名 作者 内 容 简 介 页码 \初级篇 第1章 Qt初步实践 卢传富 建立了第一个较简单的Qt应用程序,在GUI用户界面中显示一行中文。 2 \ 第2章 对话框 \——QDialog 卢传富介绍了Qt的对话框类QDialog,实现了一个自定义的登录对话框,举例说明了Qt提供的内建对话框类的应用。 14 \ 第3章 基础窗口部件——QWidget 卢传富 \蔡志明首次引入Qt设计器的使用,绘制并实现了一个查找文件功能的部件,介绍了Qt应用程序中使用ui文件的基本方法以及Qt样式表;较深入地分析了Qt对象模型的一些基本知识,涉及信号和槽机制、Qt元对象系统、属性系统和对象树机制,以及部件类型和部件的几何布局等内容。 35 \ 第4章 程序主窗口—— QMainWindow 卢传富 Qt应用程序的主窗口是由多个部件/组件构成的框架,本章通过一个简单文本编辑器的例子,介绍了主窗口的菜单、工具条、中心部件、锚接部件和状态条,并通过Qt设计器绘制和手写代码两种方法实现了简单文本编辑器主窗口界面的排布和管理。 87 \ 第5章 布局管理 卢传富布局管理是GUI应用程序编程的一个重要方面。Qt提供了多种布局管理部件,包括Qt布局管理器、分裂器、栈部件、工作空间部件和多文档区部件等。本章一一介绍了这些部件,并举例说明了它们在图形用户界面编程中的应用。 121 \中级篇 第6章 2D绘图 蔡志明本章内容较多,包括Qt的绘图要素、图形变换与坐标系统、绘图设备、图像处理、图像打印等。最后讲解了Qt 4图形系统的模型视图框架——Graphics View框架。 152 \ 第7章 拖放操作与剪贴板 蔡志明 本章简要地说明了基于MIME的拖放操作和剪贴板的使用,关于Graphics View框架的拖放操作也在本章。 212 \ 第8章 文件处理 蔡志明介绍了Qt的文件处理,包括基于流的文本文件和进制文件处理,文件信息和目录操作,目录以及文件的变化监控,文件引擎的编写。 219 \ 第9章 网络 李立夏介绍了Qt的网络处理,包括编写常见的FTP、HTTP、UDP和TCP程序,以及访问底层网络接口信息和扩展Qt网络模块功能的方法。 227 \ 第10章 多线程 李立夏介绍了Qt的多线程处理,包括两方面内容:传统的线程操作,以及与Qt事件机制相关的操作。这一章还涉及较多的基本概念,并逐一做了介绍。 261 \ 第11章 事件机制 李立夏介绍了Qt的事件处理模型,详细介绍了在Qt程序设计中处理事件的五种方法,并讨论了如何利用Qt事件机制加快用户界面响应速度。 283 \ 第12章 数据库 李立夏介绍了Qt的数据库处理,重点介绍了如何在Qt中使用SQL语句进行数据库操作和如何利用QSqlTableModel这类高层次类进行常见的数据库编程。 297 \ 第13章 Qt的模板库和工具类 卢传富 \蔡志明 Qt提供了丰富的模板库和工具类,本章只是介绍了部分内容。在这一章,重点介绍了Qt的容器类、QString和QVariant类,简介了Qt的算法和Qt正则表达式的使用。 326 \ \ \续表 \篇章 章 名 作者 内 容 简 介 页码 \高级篇 第14章 XML 蔡志明对Qt中的三种XML解析方式(DOM、SAX和基于流的解析)进行了比较和举例。还讲解了如何使用API写XML文件。 348 \ 第15章 模型/视图结构 蔡志明阐述了Qt的模型/视图结构,分别对模型视图的三个组成部分(模型、视图和代理)进行了介绍,演示了如何自定义这些组成部分,并简要说明了拖放以及选中操作。 366 \ 第16章 高级绘图 蔡志明叙述了在Qt中如何使用OpenGL绘图,对基本的OpenGL绘图进行了讲解,介绍了矢量图型文件SVG的读写操作。 406 \ 第17章 进程间通信 李立夏 介绍进程和进程间通信的知识,重点介绍了Qt中桌面环境下基于D-Bus的多进程应用程序开发。 421 \ 第18章 Qt插件 蔡志明 说明了Qt的插件系统,并对Qt Designer插件、数据库插件、风格插件进行了较详细的介绍。 442 \ 第19章 脚本——QtScript 蔡志明 这是Qt 4.3中引入的最新内容,使得Qt能够支持ECMAScript脚本。本章简要地举例说明了在Qt中如何使用脚本,如何将C++对象暴露给脚本。 459 \ 第20章 国际化 骆艳 本章包括编码的处理,Qt Linguist的使用步骤,动态语言切换的内容。 468 \ 第21章 Qt单元测试框架 蔡志明 本章阐述了如何使用QTestLib框架进行数据测试、GUI测试。 478 \ 附录A~E 蔡志明附录中包括Qt在Linux、Windows、Solaris上的安装,KDevelop、Eclipse集成开发环境的使用,qmake的基本应用,Qt源代码分析举例,Qt资源。 485 \如何获取源代码 \由于Qt是跨平台的,因此书中的内容应用能够在Windows、Linux、UNIX和Mac OS上运行,书中的程序可能是在下列三种平台之一上编写:Windows XP/Vista、Linux(SuSE、Fedora Core或红旗)以及Solaris 10 SPARC/X86。因此书中的屏幕截图可能来源于其中的任何一种操作系统。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值