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

编辑推荐精选

TRAE编程

TRAE编程

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

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

热门AI工具生产力协作转型TraeAI IDE
商汤小浣熊

商汤小浣熊

最强AI数据分析助手

小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。

imini AI

imini AI

像人一样思考的AI智能体

imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。

Keevx

Keevx

AI数字人视频创作平台

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

即梦AI

即梦AI

一站式AI创作平台

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

扣子-AI办公

扣子-AI办公

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

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

蛙蛙写作

蛙蛙写作

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

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

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

问小白

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

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

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

Transly

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

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

讯飞智文

讯飞智文

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

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

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