从零搭建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 StartedRust098- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
MiMo-V2.5-ProMiMo-V2.5-Pro作为旗舰模型,擅⻓处理复杂Agent任务,单次任务可完成近千次⼯具调⽤与⼗余轮上 下⽂压缩。Python00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
Kimi-K2.6Kimi K2.6 是一款开源的原生多模态智能体模型,在长程编码、编码驱动设计、主动自主执行以及群体任务编排等实用能力方面实现了显著提升。Python00
MiniMax-M2.7MiniMax-M2.7 是我们首个深度参与自身进化过程的模型。M2.7 具备构建复杂智能体应用框架的能力,能够借助智能体团队、复杂技能以及动态工具搜索,完成高度精细的生产力任务。Python00