[开源] react-rough-fiber 一个以手绘风格绘制已有 SVG 库的 React 渲染器

2023-04-23 13:34:08 +08:00
 bowen7

介绍

使用 react-rough-fiber ,可以非常方便地集成已有的 SVG 库,将它们渲染成手绘风格的图形

仓库地址

文档地址

它的实现原理是 React Renderer + Rough.js 。如果你对实现的过程有兴趣,可以看看我的这篇 博客

测试用例 涵盖 React 17 & 18

安装

npm i react-rough-fiber react-reconciler

⚠️:如果你使用的是 React 17 ,则需要安装 react-reconciler@0.26.2

使用

最少只需要加三行代码,就可以将 SVG 渲染成手绘风格,一个最基本的演示

import { RoughSVG } from 'react-rough-fiber'
export default function App() {
  return (
    <RoughSVG>
      <svg viewBox="0 0 128 128" width="128" height="128">
        <circle cx={64} cy={64} r={48} stroke="currentColor" fill="#82ca9d" />
      </svg>
    </RoughSVG>
  )
}

与 SVG Icon / SVG Emoji 集成:

与图标库 recharts 集成:

可以传入 Roug.js 配置更改手绘风格。配置支持函数类型,可根据不同形状,返回不同配置

文档中有很多示例:

FAQ

Q: 适用于所有 SVG 库吗

A:并不是。react-rough-fiber 是一个 React renderer ,只适用于用 React 创建的元素。例如 ECharts 等,它们是不基于任何框架的渲染逻辑(比如 ECharts 的 ZRender),所以无法适用 react-rough-fiber

Q:那也无法适用于本地 /网络 SVG 文件?

A:可以使用 SVGR 将本地的 SVG 转化为 React Component ;可以使用 react-inlinesvg 加载 SVG 字符串 /网络 SVG 文件,转换为 React Component. 这里有一个简单的 例子

关于

react-rough-fiber 基于或灵感来自以下开源项目:

如果你发现了任何 Bug ,可以在 Issue 提出;有任何讨论、建议,可以在这里或者 Github Discussions 留言

1849 次点击
所在节点    分享创造
10 条回复
me221
2023-04-23 13:56:36 +08:00
太牛了!
Alexonx
2023-04-23 14:22:42 +08:00
牛批 一直在找一个漂亮的手绘风格的 Icon 库 现在这个渲染器完美解决了 ❤
justin2018
2023-04-23 18:05:46 +08:00
这个好~ 感谢分享
K1W1
2023-04-23 18:21:53 +08:00
牛哇
BaffinLee
2023-04-23 19:24:24 +08:00
awesome!
IamJ
2023-04-23 20:18:58 +08:00
不错,喜欢这风格
Cryse
2023-04-24 03:57:27 +08:00
赞,非常有创意啊
taylorins
2023-04-24 10:23:00 +08:00
小前端路过,好漂亮收藏了!
AlanWang3
2023-04-24 15:49:23 +08:00
赞!我之前也用 roughjs 做过类似的东西,不过做的比较粗糙。https://github.com/3Alan/alan-ui
zephyr1
2023-04-28 09:36:59 +08:00
收藏了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/934759

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX