Thermion开源项目教程
2025-04-18 16:53:04作者:胡唯隽
1. 项目目录结构及介绍
Thermion项目是一个为Dart和Flutter提供的跨平台3D渲染工具包。以下是其主要的目录结构及其介绍:
thermion/
├── assets/ # 存放项目资源,如纹理、模型等
├── docs/ # 文档目录,包含项目的文档和示例
├── examples/ # 示例项目,展示如何使用Thermion
├── materials/ # 材料文件,用于定义渲染效果
├── thermion_dart/ # Dart部分的源代码
├── thermion_flutter/ # Flutter部分的源代码
├── .gitignore # Git忽略文件列表
├── CHANGELOG.md # 更新日志
├── LICENSE # 项目许可证信息
├── Makefile # 构建脚本
├── README.md # 项目说明文件
├── docs.json # 文档配置文件
└── melos.yaml # Melos工具的配置文件
assets/:包含项目所需的各种资源,例如模型文件、纹理等。docs/:存放项目的文档,包括API文档和用户指南。examples/:包含了一些示例项目,以展示如何在实际应用中使用Thermion。materials/:包含了用于定义物体材质的文件。thermion_dart/:这里是Dart语言的源代码,包含了Thermion的核心逻辑。thermion_flutter/:包含了用于Flutter的Thermion封装和示例代码。.gitignore:定义了Git应该忽略的文件和目录。CHANGELOG.md:记录了项目的所有更新和改动历史。LICENSE:项目所使用的许可证,本项目采用Apache-2.0。Makefile:用于构建项目或执行特定任务的脚本。README.md:项目的主说明文件,包含了项目的基本信息和如何开始使用。docs.json:文档配置文件,用于定义文档的元数据和生成选项。melos.yaml:Melos工具的配置文件,用于自动化项目维护任务。
2. 项目的启动文件介绍
在examples/目录下,你可以找到使用Thermion的Flutter示例应用。以下是启动一个简单的Flutter应用的基本步骤:
@override
Widget build(BuildContext context) {
return Scaffold(
body: Stack(
children: [
Positioned.fill(
child: ViewerWidget(
assetPath: "assets/cube.glb",
skyboxPath: "assets/default_env_skybox.ktx",
iblPath: "assets/default_env_ibl.ktx",
transformToUnitCube: true,
initialCameraPosition: Vector3(0, 0, 6),
background: Colors.blue,
manipulatorType: ManipulatorType.ORBIT,
onViewerAvailable: (viewer) async {
await Future.delayed(const Duration(seconds: 5));
await viewer.removeSkybox();
},
initial: Container(
color: Colors.red,
),
),
),
],
),
);
}
这段代码创建了一个包含ViewerWidget的Scaffold,这个ViewerWidget负责加载和显示3D模型。
3. 项目的配置文件介绍
melos.yaml 是 Thermion 项目中用于配置 Melos 工具的文件。Melos 是一个用于管理多包 Dart 项目的工具。以下是melos.yaml文件的一个基本示例:
packages:
thermion_dart:
path: thermion_dart
thermion_flutter:
path: thermion_flutter
tasks:
build:
commands:
- pub run build_runner build --delete-conflicting-outputs
description: Build the packages.
test:
commands:
- dart test
description: Run tests for the packages.
在这个配置文件中,定义了项目的包结构以及可执行的任务。packages部分列出了项目中的所有包及其路径,而tasks部分定义了可执行的任务,例如构建(build)和测试(test)。
使用Melos,你可以运行以下命令来执行任务:
melos run build
melos run test
这些命令将执行在melos.yaml中定义的相应任务。
登录后查看全文
热门项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
yuanrongopenYuanrong runtime:openYuanrong 多语言运行时提供函数分布式编程,支持 Python、Java、C++ 语言,实现类单机编程高性能分布式运行。Go051
pc-uishopTNT开源商城系统使用java语言开发,基于SpringBoot架构体系构建的一套b2b2c商城,商城是满足集平台自营和多商户入驻于一体的多商户运营服务系统。包含PC 端、手机端(H5\APP\小程序),系统架构以及实现案例中应满足和未来可能出现的业务系统进行对接。Vue00
ebook-to-mindmapepub、pdf 拆书 AI 总结TSX01
热门内容推荐
最新内容推荐
Degrees of Lewdity中文汉化终极指南:零基础玩家必看的完整教程Unity游戏翻译神器:XUnity Auto Translator 完整使用指南PythonWin7终极指南:在Windows 7上轻松安装Python 3.9+终极macOS键盘定制指南:用Karabiner-Elements提升10倍效率Pandas数据分析实战指南:从零基础到数据处理高手 Qwen3-235B-FP8震撼升级:256K上下文+22B激活参数7步搞定机械键盘PCB设计:从零开始打造你的专属键盘终极WeMod专业版解锁指南:3步免费获取完整高级功能DeepSeek-R1-Distill-Qwen-32B技术揭秘:小模型如何实现大模型性能突破音频修复终极指南:让每一段受损声音重获新生
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
541
3.77 K
Ascend Extension for PyTorch
Python
351
419
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
889
615
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
338
186
openJiuwen agent-studio提供零码、低码可视化开发和工作流编排,模型、知识库、插件等各资源管理能力
TSX
988
253
openGauss kernel ~ openGauss is an open source relational database management system
C++
169
233
暂无简介
Dart
778
194
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
115
141
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.35 K
759