blitz

blitz

基于Rust的原生HTML/CSS渲染器

Blitz是一个基于Rust的原生HTML/CSS渲染器,为Dioxus Native项目提供支持。它集成了Stylo进行CSS解析、Vello和WGPU进行渲染、Taffy处理布局,支持现代HTML/CSS特性。Blitz具有HTML和Dioxus两种前端接口,适合开发轻量级、高性能的原生应用界面。虽然不包含完整的浏览器功能,但支持自定义组件和无障碍访问,是一个专注于核心渲染功能的解决方案。

BlitzHTML渲染器CSS渲染器Dioxus网页渲染Github开源项目

Blitz:轻量级、模块化、可扩展的网页渲染器

Blitz 是一个为支持"Dioxus Native"项目而构建的"原生"HTML/CSS 渲染器。它实际上是一个轻量级的 WebView,但将 JavaScript 引擎替换为原生 Rust API,允许 Rust 的响应式/状态管理库(如 Dioxus)直接与之交互。

Dioxus Discord 的 #native 频道与我们交流

目前有两个前端:

  • HTML/markdown 前端,可以渲染 HTML 字符串。这对于预览 HTML 和/或 markdown 文件很有用,但目前缺乏交互性。
  • Dioxus 前端,可以渲染 Dioxus VirtualDom。通过 Dioxus 的事件处理,它支持完整的交互功能。

Blitz 基于以下技术构建:

  • Stylo(Firefox 的并行浏览器级 CSS 引擎)用于 CSS 解析
  • Vello + WGPU 用于渲染
  • Taffy 用于盒级布局
  • Parley 用于文本/行内级布局
  • AccessKit 用于无障碍功能
  • Winit 用于窗口管理和输入处理

注意:此仓库包含使用 Stylo 的 Blitz 新版本。旧版本的源代码仍可在 legacy 分支上找到,但不再积极开发。

截图

Dioxus 渲染器:

截图

HTML 渲染器(渲染 google.com):

截图

试用

  1. 克隆此仓库
  2. 运行示例:
    • cargo run --example google
    • cargo run --example url https://myurl.com
    • 其他可用示例
    • 添加 --release 以获得更好的运行时性能
  3. Ctrl/Cmd + + / Ctrl/Cmd + - 更改缩放,按 F1 显示布局矩形

目标

Blitz 旨在渲染 HTML 和 CSS - 我们想支持浏览器的全部功能(或者至少我们希望所有这些"额外"功能都是可选的)。我们认为,对于渲染 HTML/CSS 的基本用例来说,浏览器过于臃肿。

我们打算支持:

  • 现代 HTML 布局(flexbox、grid、table、block、inline、absolute/fixed 等)
  • 高级 CSS(复杂选择器、媒体查询、CSS 变量)
  • HTML 表单控件
  • 使用 AccessKit 实现无障碍功能
  • 通过自定义小部件实现可扩展性

值得注意的是,我们提供 WebRTC、WebSocket、蓝牙、localStorage 等功能。在原生应用中,许多这样的功能可以使用常规的 Rust crate 来实现,不需要与渲染器耦合。

我们目前还没有为其他语言(JavaScript、Python 等)提供 Blitz 绑定,但欢迎这方面的贡献。

架构

Blitz 分为几个部分:

  • blitz-dom:核心 DOM 抽象,包括样式解析和布局,但不包括绘制/渲染。结合了 Stylo 和 Taffy 的优点,允许您构建可扩展的类 DOM 结构。
  • blitz:为 blitz-dom 添加基于 Vello/WGPU 的渲染器
  • dioxus-blitz:Blitz 的 Dioxus 集成层。使用 Blitz 渲染您的 Dioxus 应用。目前 dioxus-blitz 还包含 HTML 渲染器,但将来可能会拆分为单独的包。

状态

Blitz 目前处于实验阶段。我们正在积极努力使其达到可用状态,但我们目前不建议用它构建应用程序。

待办事项

  • 核心 DOM 树抽象
  • 使用 html5ever 解析样式
  • 为 html5ever 文档计算样式
  • 使用 Taffy 计算布局
  • 使用 WGPU 渲染

渲染

  • 渲染到窗口
  • 渲染到图像
  • 渐变
  • 边框/轮廓
  • 光栅图像(png、jpeg 等)
  • 缩放
  • SVG
    • 外部 SVG(基本支持)
    • 内联 SVG
  • 阴影
  • 动画/过渡
  • 标准表单控件(复选框/下拉菜单/滑块等)
  • 自定义小部件
  • 阴影元素

布局

  • 内联(部分支持 - 实现仍不成熟)
  • 块级
  • Flexbox
  • Grid
    • 命名网格线
    • 子网格
  • 表格
  • Z-index
  • 其他 CSS 功能
    • box-sizing: content-box
    • calc()
    • position: static
    • direction: rtl
    • transform

文本

  • 字体加载
    • 系统字体加载
    • Web 字体加载
  • 文本
    • 字形/双向文本
    • 布局/换行
    • 字体大小/行高
    • 文本颜色
    • 粗体/斜体
    • 下划线/删除线
  • 文本选择

输入

  • 滚动
    • 根视图
    • 任何 overflow: scroll 元素
  • 悬停检测
  • 点击处理
  • 文本输入

性能

  • 热重载
  • 滚动时无需重新解析样式和布局
  • 样式缓存
  • 布局缓存

其他

  • 多窗口
  • 无障碍树
  • 焦点
  • 开发者工具
  • 上下文菜单钩子
  • use_wgpu_context() 以获取元素作为任意渲染表面

许可证

本项目采用 Apache 2.0 和 MIT 双重许可

除非您明确声明,否则您有意提交以包含在 stylo-dioxus 中的任何贡献都应按 MIT 许可,无任何附加条款或条件。

编辑推荐精选

Keevx

Keevx

AI数字人视频创作平台

Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。

即梦AI

即梦AI

一站式AI创作平台

提供 AI 驱动的图片、视频生成及数字人等功能,助力创意创作

扣子-AI办公

扣子-AI办公

AI办公助手,复杂任务高效处理

AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!

TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
蛙蛙写作

蛙蛙写作

AI小说写作助手,一站式润色、改写、扩写

蛙蛙写作—国内先进的AI写作平台,涵盖小说、学术、社交媒体等多场景。提供续写、改写、润色等功能,助力创作者高效优化写作流程。界面简洁,功能全面,适合各类写作者提升内容品质和工作效率。

AI辅助写作AI工具蛙蛙写作AI写作工具学术助手办公助手营销助手AI助手
问小白

问小白

全能AI智能助手,随时解答生活与工作的多样问题

问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。

热门AI助手AI对话AI工具聊天机器人
Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

下拉加载更多