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 许可,无任何附加条款或条件。

编辑推荐精选

音述AI

音述AI

全球首个AI音乐社区

音述AI是全球首个AI音乐社区,致力让每个人都能用音乐表达自我。音述AI提供零门槛AI创作工具,独创GETI法则帮助用户精准定义音乐风格,AI润色功能支持自动优化作品质感。音述AI支持交流讨论、二次创作与价值变现。针对中文用户的语言习惯与文化背景进行专门优化,支持国风融合、C-pop等本土音乐标签,让技术更好地承载人文表达。

QoderWork

QoderWork

阿里Qoder团队推出的桌面端AI智能体

QoderWork 是阿里推出的本地优先桌面 AI 智能体,适配 macOS14+/Windows10+,以自然语言交互实现文件管理、数据分析、AI 视觉生成、浏览器自动化等办公任务,自主拆解执行复杂工作流,数据本地运行零上传,技能市场可无限扩展,是高效的 Agentic 生产力办公助手。

lynote.ai

lynote.ai

一站式搞定所有学习需求

不再被海量信息淹没,开始真正理解知识。Lynote 可摘要 YouTube 视频、PDF、文章等内容。即时创建笔记,检测 AI 内容并下载资料,将您的学习效率提升 10 倍。

AniShort

AniShort

为AI短剧协作而生

专为AI短剧协作而生的AniShort正式发布,深度重构AI短剧全流程生产模式,整合创意策划、制作执行、实时协作、在线审片、资产复用等全链路功能,独创无限画布、双轨并行工业化工作流与Ani智能体助手,集成多款主流AI大模型,破解素材零散、版本混乱、沟通低效等行业痛点,助力3人团队效率提升800%,打造标准化、可追溯的AI短剧量产体系,是AI短剧团队协同创作、提升制作效率的核心工具。

seedancetwo2.0

seedancetwo2.0

能听懂你表达的视频模型

Seedance two是基于seedance2.0的中国大模型,支持图像、视频、音频、文本四种模态输入,表达方式更丰富,生成也更可控。

nano-banana纳米香蕉中文站

nano-banana纳米香蕉中文站

国内直接访问,限时3折

输入简单文字,生成想要的图片,纳米香蕉中文站基于 Google 模型的 AI 图片生成网站,支持文字生图、图生图。官网价格限时3折活动

扣子-AI办公

扣子-AI办公

职场AI,就用扣子

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

堆友

堆友

多风格AI绘画神器

堆友平台由阿里巴巴设计团队创建,作为一款AI驱动的设计工具,专为设计师提供一站式增长服务。功能覆盖海量3D素材、AI绘画、实时渲染以及专业抠图,显著提升设计品质和效率。平台不仅提供工具,还是一个促进创意交流和个人发展的空间,界面友好,适合所有级别的设计师和创意工作者。

图像生成热门AI工具AI图像AI反应堆AI工具箱AI绘画GOAI艺术字堆友相机
码上飞

码上飞

零代码AI应用开发平台

零代码AI应用开发平台,用户只需一句话简单描述需求,AI能自动生成小程序、APP或H5网页应用,无需编写代码。

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

下拉加载更多