(QMake) 库的操作
2023-12-27 07:25:51
预备
目录结构
采用一个顶级工程qmake,管理两个子工程。
root:.
│ .qmake.conf
│ qtlib.pro
│
├─creator
│ creator.pro
│ mywidget.cpp
│ mywidget.h
│
└─user
main.cpp
user.pro
Code
测试代码非常简单。但关键是需要使用Qt库中的内容。
比如这里用了最具代表的QWidget。
user/main.cpp
#include <QApplication>
#include "mywidget.h"
int main(int argc, char** argv) {
QApplication app(argc, argv);
MyWidget myWidget;
myWidget.show();
return app.exec();
}
creator/mywidget.h
#ifndef MYWIDGET_H
#define MYWIDGET_H
#include <QWidget>
class MyWidget : public QWidget {
Q_OBJECT
public:
explicit MyWidget(QWidget *parent = nullptr);
};
#endif // MYWIDGET_H
creator/creator.pro
#include "mywidget.h"
#include <QDebug>
#include <QPushButton>
MyWidget::MyWidget(QWidget *parent) : QWidget(parent) {
auto btn = new QPushButton{"diy-widget-lib", this};
connect(btn, &QPushButton::clicked, this,
[]() { qDebug() << "btn clicked"; });
}
*.pro
.qmake.conf
top_srcdir
总工程资源目录top_builddir
总工程构建目录
# 配置全局的变量
top_srcdir=$$PWD
top_builddir=$$shadowed($$PWD)
qtlib.pro
TEMPLATE = subdirs
- 注意,请加上
CONFIG += ordered
,并先添加库目录- 这样可以保证先编译出库,再在app应用中加载库
# 指定pro类型为subdirs
TEMPLATE = subdirs
# 指定子目录
# 先 creator
# 后 user
SUBDIRS += \
creator \
user
# 要求按照顺序进行编译链接
# 目的是先把库编译出来,再在user中使用库
CONFIG += ordered
message("`top_builddir`和`top_srcdir`在`.qmake.conf`文件中定义")
message($$top_builddir)
message($$top_srcdir)
creator/creator.pro
TEMPLATE = lib
- 采用CONFIG选择动静态库
CONFIG += staticlib
CONFIG += dll
QT += core
QT += gui
greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
# 指定为库类型
TEMPLATE = lib
# 静态库 staticlib
# 动态库 dll
CONFIG += staticlib
#CONFIG += dll
HEADERS += \
mywidget.h
SOURCES += \
mywidget.cpp
user/user.pro
TEMPLATE = app
- 这里用到了在
.qmake.conf
中定义的变量 - 为了偷懒,这里直接使用库源码中的头文件
QT += core
QT += gui
greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
TEMPLATE = app
CONFIG += c++11
# 将库路径赋到一个变量上
# 注意静动库的前后缀区别
# 静态库
lib_path = $$top_builddir/creator/$(OBJECTS_DIR)/libcreator.a
# 动态库
#lib_path = $$top_builddir/creator/$(OBJECTS_DIR)/creator.dll
# 链接库
LIBS += $$lib_path
# 每次强制链接静态库
PRE_TARGETDEPS += $$lib_path
# 为了demo方便直接到源文件夹include
INCLUDEPATH += $$top_srcdir/creator
SOURCES += \
main.cpp
END
默认工程
可能在默认的一个库工程中会给出默认的如下代码:
这是qt Creator 默认形式,应该也可行,但没怎么使用过这种形式。
TEMPLATE = lib
DEFINES += UNTITLED2_LIBRARY
#ifndef UNTITLED_GLOBAL_H
#define UNTITLED_GLOBAL_H
#include <QtCore/qglobal.h>
#if defined(UNTITLED_LIBRARY)
# define UNTITLED_EXPORT Q_DECL_EXPORT
#else
# define UNTITLED_EXPORT Q_DECL_IMPORT
#endif
#endif // UNTITLED_GLOBAL_H
#ifndef UNTITLED_H
#define UNTITLED_H
#include "untitled_global.h"
class UNTITLED_EXPORT Untitled
{
public:
Untitled();
};
#endif // UNTITLED_H
链接方式
链接方式其实写法比较自由,上文中是直接将路径和文件合并的书写。
也可以分开来,比如像传统gcc一样的写:
LIBS += -L $$PWD/bin -l xxx
文章来源:https://blog.csdn.net/CUBE_lotus/article/details/135233867
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!