百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

2024 最火的5个顶级白板应用,燃爆了!

yuyutoo 2025-01-08 18:28 4 浏览 0 评论

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发!

今天给大家细数 2024 年最火的几个白板应用。话不多说,直接进入正题!

excalidraw

excalidraw 是一款开源的虚拟手绘风格白板, 支持多人协作和端到端加密。

Excalidraw 编辑器(npm 包)支持以下核心特性:

  • 免费且开源
  • 无限的、基于画布的白板
  • ??类似手绘的风格
  • 黑暗模式
  • ?可定制
  • 图片支持
  • 形状库支持
  • 本地化(i18n)支持
  • ? 导出为 PNG、SVG 和剪贴板
  • 开放格式 - 将绘图导出为 .excalidraw json 文件
  • ?? 多种工具 - 矩形、圆形、菱形、箭头、线条、自由绘制、橡皮擦
  • ?? 箭头绑定和标记箭头
  • 支持 撤消 / 重做、 缩放和平移支持

excalidraw.com 上托管的应用程序是用户可以使用 Excalidraw 构建的内容的最小 demo,其源代码也是该存储库的一部分,并且该应用程序具有以下功能:

  • PWA 支持(离线工作)
  • 实时协作
  • 端到端加密
  • 本地优先支持(自动保存到浏览器)
  • 可共享链接(导出到可以与其他人共享的只读链接)

开发者可以通过以下说明将 Excalidraw 集成到自己的 React 应用程序:

npm install react react-dom @excalidraw/excalidraw
// 或者 yarn
yarn add react react-dom @excalidraw/excalidraw

目前 Excalidraw 在 Github 通过 MIT 协议开源,有超过 66.8k 的 star、6k 的 fork、代码贡献者 300+、妥妥的前端顶级开源项目。

tldraw

开发者可以使用 Tldraw React 组件在应用程序中嵌入功能齐全且可扩展的白板。同时,对于多人白板,开发者还可以将组件插入选择的协作后端。

用户可以使用编辑器 API 来创建、更新和删除形状、控制相机或执行其他任何操作;也可以使用自己的自定义形状和自定义工具来扩展 tldraw;甚至使用用户界面覆盖来更改菜单和工具栏的内容,或者隐藏 UI 并将其替换为自己的 UI。

如果想更深入 tldraw,可以使用 TldrawEditor 组件作为更小的引擎,而无需默认的 tldraw 形状或用户界面。tldraw 和 Excalidraw 的最大的区别是,后者 Excalidraw 渲染到 HTML Canvas,而 tldraw 渲染到常规 DOM 树。

import {Tldraw} from '@tldraw/tldraw'
import '@tldraw/tldraw/tldraw.css'

export default function () {
	return (
		<div style={{ position: 'fixed', inset: 0}}>
			<Tldraw />
		</div>
	)
}

目前 tldraw 在 Github 上开源,有超过 30.9k 的 star、1k 的 fork、代码贡献者 150+、妥妥的前端顶级开源项目。

drawio

draw.io 是用于构建图表应用程序的技术堆栈,也是世界上使用最广泛的基于浏览器的终端用户图表软件。

draw.io 是 JGraph Ltd 和 draw.io AG 的注册商标。 JGraph Ltd 是一家在英国注册的公司,draw.io AG 是一家在瑞士注册的公司。 这些公司共同开发并拥有该软件,运营 diagrams.net 和 draw.io 网站,并拥有 diagrams.net 和 draw.io 品牌。

本质上,draw.io 项目是一个可配置的图表 / 白板可视化应用程序。

draw.io 具有以下特点:

  • 支持分享:不用担心许可证或平台就可以工作。
  • 强大的功能:与共享光标实时协作, draw.io 拥有用户对专业绘图工具所期望的一切。
  • 隐私第一:将数据存储在任何用户想要的地方,官方无法访问该数据。

除了运行该项目之外,还在 https://app.diagrams.net 上运行图表界面的生产级部署。

目前 drawio 在 Github 通过 Apache-2.0 协议开源,有超过 37.6k 的 star、7.2k 的 fork、代码贡献者 300+、妥妥的前端顶级开源项目。

konva

Konva 是一个 HTML5 Canvas JavaScript 框架,支持桌面和移动应用程序的高性能动画、过渡、节点嵌套、分层、过滤、缓存、事件处理等等。

开发者可以将事物绘制到舞台上,向其添加事件侦听器、移动、缩放以及独立于其他形状旋转以支持高性能动画,即使应用程序使用数千个形状也是如此。

Konva 适用于所有现代移动和桌面浏览器,浏览器需要能够运行 ES2015 规范中的 javascript 代码。 对于较旧的浏览器,可能需要 polyfill 来弥补缺失的功能。

目前 Konva 不能直接在 IE11 中运行。 为了让它工作,只需要提供一些 polyfill,例如 Array.prototype.find、String.prototype.trimLeft、String.prototype.trimRight、Array.from。

import Konva from 'konva';

const stage = new Konva.Stage({
  width: 500,
  height: 500,
});
// then all regular Konva code will work

目前 konva 在 Github 通过 MIT 协议开源,有超过 10.4k 的 star、1k 的 fork、依赖项目量 48k、代码贡献者 180+、妥妥的前端优质开源项目。

perfect-freehand

perfect-freehand 用于绘制完美的压力感应徒手线条,支持 Figma Plugin、Flutter / Dart、 Python 等。

perfect-freehand 包导出一个名为 getStroke 的函数,该函数将根据点数组生成多边形的点。为了完成这项工作,getStroke 首先根据输入点(灰色)创建一组样条点(红色),然后创建轮廓点(蓝色)。 开发者还可以使用喜欢的技术以任何喜欢的方式渲染结果。

import {getStroke} from 'perfect-freehand'

const inputPoints = [
  [0, 0],
  [10, 5],
  [20, 8],
  // ...
]

const outlinePoints = getStroke(inputPoints)

目前 perfect-freehand 在 Github 通过 MIT 协议开源,有超过 4.2k 的 star、1k 的 fork、依赖项目量 4k、代码贡献者 30+、妥妥的前端优质开源项目。

本文总结

本文主要和大家介绍 2024 年最火的几个白板应用,包括:excalidraw、tldraw、drawio、konva、perfect-freehand。因为篇幅问题,关于每一个白板应用的只是做了一个简短的介绍,但是文末的参考资料提供了大量优秀文档以供学习,如果有兴趣可以自行阅读。如果大家有什么疑问欢迎在评论区留言。

参考资料

https://github.com/excalidraw/excalidraw

https://github.com/tldraw/tldraw

https://www.youtube.com/watch?v=Lj9QZOPPy3I

https://github.com/jgraph/drawio

https://www.drawio.com/

https://www.youtube.com/watch?app=desktop&v=WbPhV1dyva4

相关推荐

当 Linux 根分区 (/) 已满时如何释放空间?

根分区(/)是Linux文件系统的核心,包含操作系统核心文件、配置文件、日志文件、缓存和用户数据等。当根分区满载时,系统可能出现无法写入新文件、应用程序崩溃甚至无法启动的情况。常见原因包括:...

玩转 Linux 之:磁盘分区、挂载知多少?

今天来聊聊linux下磁盘分区、挂载的问题,篇幅所限,不会聊的太底层,纯当科普!!1、Linux分区简介1.1主分区vs扩展分区硬盘分区表中最多能存储四个分区,但我们实际使用时一般只分为两...

Linux 文件搜索神器 find 实战详解,建议收藏

在Linux系统使用中,作为一个管理员,我希望能查找系统中所有的大小超过200M文件,查看近7天系统中哪些文件被修改过,找出所有子目录中的可执行文件,这些任务需求...

Linux 操作系统磁盘操作(linux 磁盘命令)

一、文档介绍本文档描述Linux操作系统下多种场景下的磁盘操作情况。二、名词解释...

Win10新版19603推送:一键清理磁盘空间、首次集成Linux文件管理器

继上周四的Build19592后,微软今晨面向快速通道的Insider会员推送Windows10新预览版,操作系统版本号Build19603。除了一些常规修复,本次更新还带了不少新功能,一起来了...

Android 16允许Linux终端使用手机全部存储空间

IT之家4月20日消息,谷歌Pixel手机正朝着成为强大便携式计算设备的目标迈进。2025年3月的更新中,Linux终端应用的推出为这一转变奠定了重要基础。该应用允许兼容的安卓设备...

Linux 系统管理大容量磁盘(2TB+)操作指南

对于容量超过2TB的磁盘,传统MBR分区表的32位寻址机制存在限制(最大支持2.2TB)。需采用GPT(GUIDPartitionTable)分区方案,其支持64位寻址,理论上限为9.4ZB(9....

Linux 服务器上查看磁盘类型的方法

方法1:使用lsblk命令lsblk输出说明:TYPE列显示设备类型,如disk(物理磁盘)、part(分区)、rom(只读存储)等。...

ESXI7虚机上的Ubuntu Linux 22.04 LVM空间扩容操作记录

本人在实际的使用中经常遇到Vmware上安装的Linux虚机的LVM扩容情况,最终实现lv的扩容,大多数情况因为虚机都是有备用或者可停机的情况,一般情况下通过添加一块物理盘再加入vg,然后扩容lv来实...

5.4K Star很容易!Windows读取Linux磁盘格式工具

[开源日记],分享10k+Star的优质开源项目...

Linux 文件系统监控:用脚本自动化磁盘空间管理

在Linux系统中,文件系统监控是一项非常重要的任务,它可以帮助我们及时发现磁盘空间不足的问题,避免因磁盘满而导致的系统服务不可用。通过编写脚本自动化磁盘空间管理,我们可以更加高效地处理这一问题。下面...

Linux磁盘管理LVM实战(linux实验磁盘管理)

LVM(逻辑卷管理器,LogicalVolumeManager)是一种在Linux系统中用于灵活管理磁盘空间的技术,通过将物理磁盘抽象为逻辑卷,实现动态调整存储容量、跨磁盘扩展等功能。本章节...

Linux查看文件大小:`ls`和`du`为何结果不同?一文讲透原理!

Linux查看文件大小:ls和du为何结果不同?一文讲透原理!在Linux运维中,查看文件大小是日常高频操作。但你是否遇到过以下困惑?...

使用 df 命令检查服务器磁盘满了,但用 du 命令发现实际小于磁盘容量

在Linux系统中,管理员或开发者经常会遇到一个令人困惑的问题:使用...

Linux磁盘爆满紧急救援指南:5步清理释放50GB+小白也能轻松搞定

“服务器卡死?网站崩溃?当Linux系统弹出‘Nospaceleft’的红色警报,别慌!本文手把手教你从‘删库到跑路’进阶为‘磁盘清理大师’,5个关键步骤+30条救命命令,快速释放磁盘空间,拯救你...

取消回复欢迎 发表评论: