Druid - 强大的Defold UI组件框架
项目介绍
Druid 是一个强大的 Defold UI 组件框架,旨在帮助开发者创建令人惊叹且可定制的图形用户界面(GUI)。通过利用一系列内置组件或轻松设计自己的游戏特定组件,Druid 使开发者能够快速构建复杂的 UI 系统。
Druid 提供了丰富的组件库,包括按钮、文本、滚动条、输入框等,支持自定义组件的创建,并且提供了详细的 API 文档和示例,方便开发者快速上手和深入使用。
项目快速启动
1. 安装依赖
首先,你需要将 Druid 扩展集成到你的 Defold 项目中。打开你的游戏项目文件,并在 dependencies 字段下添加以下行:
dependencies = {
"https://github.com/Insality/druid/archive/refs/tags/0.11.0.zip"
}
2. 创建 Druid 实例
在你的脚本中,引入 Druid 模块并创建一个 Druid 实例。以下是一个简单的示例,展示了如何创建一个按钮并处理点击事件。
local druid = require("druid.druid")
local function on_button_callback(self)
print("按钮被点击了!")
end
function init(self)
self.druid = druid.new(self)
self.button = self.druid:new_button("button_node_name", on_button_callback)
end
function final(self)
self.druid:final()
end
function update(self, dt)
self.druid:update(dt)
end
function on_message(self, message_id, message, sender)
self.druid:on_message(message_id, message, sender)
end
function on_input(self, action_id, action)
return self.druid:on_input(action_id, action)
end
3. 运行项目
保存并运行你的项目,你应该能够看到按钮并处理点击事件。
应用案例和最佳实践
1. 创建自定义组件
Druid 支持创建自定义组件,这使得开发者可以根据游戏的具体需求设计独特的 UI 元素。以下是一个简单的自定义组件示例:
local custom_component = {}
function custom_component.new(self, node_name)
local instance = {
node = gui.get_node(node_name)
}
return instance
end
function custom_component.update(self, dt)
-- 自定义组件的更新逻辑
end
function custom_component.on_input(self, action_id, action)
-- 自定义组件的输入处理逻辑
end
-- 注册自定义组件
druid.register("custom_component", custom_component)
2. 使用扩展组件
Druid 提供了一些扩展组件,如数据列表(Data List)和动态网格(Dynamic Grid),这些组件可以帮助开发者更高效地管理复杂的 UI 布局。
local data_list = require("druid.extended.data_list")
druid.register("data_list", data_list)
function init(self)
self.druid = druid.new(self)
self.data_list = self.druid:new_data_list("data_list_node_name")
end
典型生态项目
1. Defold 引擎
Druid 是基于 Defold 引擎开发的,Defold 是一个免费的开源游戏引擎,适用于 2D 和 3D 游戏开发。Defold 提供了强大的工具和 API,支持跨平台开发,包括移动设备、桌面和网页。
2. EmmyLua
Druid 提供了 EmmyLua 注解,支持在 IDE 中实现自动补全功能。EmmyLua 是一个用于 Lua 的代码提示和静态分析工具,可以帮助开发者更高效地编写 Lua 代码。
3. GitHub 社区
Druid 项目托管在 GitHub 上,开发者可以通过 GitHub 社区获取最新的更新、提交问题和贡献代码。GitHub 社区是一个活跃的开源社区,提供了丰富的资源和支持。
通过以上步骤,你可以快速上手并深入使用 Druid,创建出功能强大且美观的 UI 系统。
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00- QQwen3-Coder-Next2026年2月4日,正式发布的Qwen3-Coder-Next,一款专为编码智能体和本地开发场景设计的开源语言模型。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
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
Baichuan-M3-235BBaichuan-M3 是百川智能推出的新一代医疗增强型大型语言模型,是继 Baichuan-M2 之后的又一重要里程碑。Python00
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00