从零搭建CJQT开发环境:从准备到验证的完整指南
准备阶段:环境适配清单
核心价值
仓颉语言绑定库(类似Python的PyQt),实现跨平台GUI开发
技术特性
- 基于QT5.14.2构建,覆盖QWidgets、QCore、QGui模块
- 提供仓颉语言风格API封装,降低Qt使用门槛
- 包含俄罗斯方块、记事本等多场景示例程序
系统与依赖要求
| 项目 | 规格要求 | 验证命令 |
|---|---|---|
| 操作系统 | 64位Windows/Linux | uname -m (Linux) |
| C++编译器 | gcc-mingw64或兼容编译器 | gcc --version |
| Qt版本 | 5.14.2 | qmake --version |
| 仓颉包管理器 | 最新版 | cjpm --version |
🔍 预检查命令:
# Linux用户:检查系统架构和编译器版本
uname -m && gcc --version
# Windows用户:检查系统架构
wmic os get osarchitecture
预期输出:x86_64(Linux)或64位(Windows),gcc版本需≥7.0
常见问题
-
Q:执行gcc命令提示"未找到命令"?
A:Linux用户需安装build-essential包:sudo apt install build-essential;Windows用户需安装MinGW并配置环境变量 -
Q:qmake版本不符?
A:确保安装Qt5.14.2时勾选"Qt 5.14.2 -> GCC 64-bit"组件
获取阶段:项目资源部署
克隆项目仓库
▶️ 执行克隆命令:
git clone https://gitcode.com/Cangjie-TPC/CJQT.git
预期输出:创建CJQT目录并下载项目文件
项目结构概览
核心目录说明:
native/:C++原生代码与编译配置src/:仓颉语言封装源码(core/gui/widgets模块)example/:示例程序集合doc/:文档与资源文件
常见问题
-
Q:克隆速度慢?
A:检查网络连接,或使用国内镜像加速 -
Q:项目文件缺失?
A:执行git status检查是否完整克隆,必要时重新克隆
配置阶段:编译环境搭建
安装Qt5.14.2
▶️ Linux用户执行:
# 下载安装包
wget https://download.qt.io/archive/qt/5.14/5.14.2/qt-opensource-linux-x64-5.14.2.run
# 赋予执行权限
chmod +x qt-opensource-linux-x64-5.14.2.run
# 启动安装程序
./qt-opensource-linux-x64-5.14.2.run
⚙️ 环境变量配置:
# 添加Qt工具链到PATH
export PATH=$PATH:/opt/Qt5.14.2/5.14.2/gcc_64/bin
编译Native库
▶️ 执行编译脚本:
cd CJQT/native
./make.sh
预期输出:在
native/build目录生成libcjqt.so等库文件
⚙️ 配置文件调整:
若修改默认构建目录,需同步更新cjpm.toml:
[native]
nativeQt = "native/build" # 改为实际构建路径
编译CJQT项目
▶️ 执行构建命令:
cd CJQT
cjpm build
预期输出:显示"Build succeeded",生成可执行文件
常见问题
-
Q:编译提示"Qt5Core not found"?
A:检查Qt环境变量配置,或重新运行qmake -query确认安装路径 -
Q:cjpm命令未找到?
A:安装仓颉语言环境并配置PATH:export PATH=$PATH:~/.cangjie/bin
验证阶段:功能测试与示例运行
基础示例验证
▶️ 运行Hello示例:
cd example/hello
./run.sh
预期输出:显示"Hello CJQT"窗口
进阶示例体验

图:CJQT框架实现的QFrame组件演示,展示多色区块布局的GUI界面
场景化示例列表:
- 界面组件:
example/lineEdit(文本输入框)、example/scrollBar(滚动条) - 应用程序:
example/notepad(记事本)、example/tetris(俄罗斯方块)
▶️ 运行俄罗斯方块示例:
cd example/tetris
./run.sh
框架架构确认

图:CJQT框架架构示意图,展示core核心模块与整体框架关系
常见问题
-
Q:运行示例提示"库文件缺失"?
A:将native/build目录添加到系统库路径:export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:../../native/build -
Q:窗口中文显示乱码?
A:检查系统语言环境,确保UTF-8编码:export LANG=en_US.UTF-8
扩展阅读
- API文档:
doc/api/index.html- 完整API参考手册 - 开发指南:
doc/develop/develop.md- 进阶开发教程 - 模块说明:
doc/qt_widgets.md- 组件使用说明
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0152- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
LongCat-Video-Avatar-1.5最新开源LongCat-Video-Avatar 1.5 版本,这是一款经过升级的开源框架,专注于音频驱动人物视频生成的极致实证优化与生产级就绪能力。该版本在 LongCat-Video 基础模型之上构建,可生成高度稳定的商用级虚拟人视频,支持音频-文本转视频(AT2V)、音频-文本-图像转视频(ATI2V)以及视频续播等原生任务,并能无缝兼容单流与多流音频输入。00
auto-devAutoDev 是一个 AI 驱动的辅助编程插件。AutoDev 支持一键生成测试、代码、提交信息等,还能够与您的需求管理系统(例如Jira、Trello、Github Issue 等)直接对接。 在IDE 中,您只需简单点击,AutoDev 会根据您的需求自动为您生成代码。Kotlin03
Intern-S2-PreviewIntern-S2-Preview,这是一款高效的350亿参数科学多模态基础模型。除了常规的参数与数据规模扩展外,Intern-S2-Preview探索了任务扩展:通过提升科学任务的难度、多样性与覆盖范围,进一步释放模型能力。Python00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0112