编译原理:KDDockWidget是一个C++库,通过shiboken转成python的绑定支持。针对特殊版本,需要在cmake文件中增加一些变量。
注:本次编译,Qt版本统一指定为6.4.2,库支持Qt>5.12或6.2.0以上版本
- 下载仓库 GitHub - KDAB/KDDockWidgets: KDAB's Dock Widget Framework for Qt
- 下载Qt和代码,安装时需要勾选编译环境
- 安装需要的三方库
pip install \ --index-url=https://download.qt.io/official_releases/QtForPython/ \ --trusted-host download.qt.io \ shiboken6==6.4.2 pyside6==6.4.2 shiboken6_generator==6.4.2
- 下载并替换LLVM,参考。 原因:如果是用vs2019编译,无法使用编译后的dll,而且最坑爹的是编译时即使报错完全不会终止。(结果会导致即便编译出dll文件,使用时会一直报找不到模块)
- 下载地址
- 设置环境变量
set "LLVM_INSTALL_DIR=C:\Program Files\LLVM"
- 修改shiboken6_generator的libclang.dll文件,把shiboken6_generator的libclang.dll文件,替换为vs2019下载得libclang.dll
- 修改CMakeLists.txt文件
# 设置编译qt的位置(cmake find_package qt就是通过这里的路径查找的)
set(CMAKE_PREFIX_PATH "D:/software/qt/6.4.2/msvc2019_64")
# 设置python.exe位置(项目一般是.venv/Scripts下)
set(PYTHON_EXECUTABLE "G:/Source/LauncherDemo/.venv/Scripts")
# 配置绑定到的位置(项目一般是.vevn)
set(KDDockWidgets_PYTHON_BINDINGS_INSTALL_PREFIX "G:/Source/LauncherDemo/.venv")
# 找到option(${PROJECT_NAME}_QT6 "Build against Qt 6" OFF),改为ON
option(${PROJECT_NAME}_QT6 "Build against Qt 6" ON)
- 指定python版本,修改python/CMakeLists.txt文件
# 30行修改为3.11(之前是3.7,这里如果不改,就会找到一个本机3.7版本以上的最小版本python
# 不知道为啥上面的PYTHON_EXECUTABLE不生效)
find_package(Python3 3.11 REQUIRED COMPONENTS Interpreter Development)
- 调用cmake生成预安装文件
cmake -DKDDockWidgets_PYTHON_BINDINGS=True -DCMAKE_BUILD_TYPE=Release . --config Release
- 编译 & 安装(安装到c盘,并且安装bindings到python包中)
cmake --build . --target install --config Release
备注:还不支持python qml,Is there a way to use DockWidgetQuick from Python? · Issue #290 · KDAB/KDDockWidgets · GitHub