Project Icon

blitz

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

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

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

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号