首页 > 其他分享 >Figma 替代品 Penpot 安装和使用教程

Figma 替代品 Penpot 安装和使用教程

时间:2024-08-22 11:49:16浏览次数:6  
标签:Penpot Figma 画板 替代品 创建 组件 设计

在设计领域,Figma 无疑是一个巨人。它彻底改变了设计流程,将协作带到了一个全新的高度。然而,随着 Adobe 收购 Figma 的消息传出,许多设计师和开发者开始担心:Figma 未来会如何演变?那些好用的特性会不会被砍掉?

出于白嫖的本能,大家都想寻找一个强大而可靠的 Figma 替代品。在众多候选者中,有一个名字正在迅速崛起,那就是 Penpot。

Penpot 不仅仅是一个设计工具,它还代表了一种全新的设计理念。作为第一个真正开源的设计和原型工具,Penpot 正在重新定义设计师和开发人员之间的协作方式。它不仅继承了 Figma 的许多优秀特性,还在某些方面超越了 Figma。

本文我们将详细介绍 Penpot 的核心特性、技术架构,以及安装和使用方法。

Penpot 介绍

Penpot 是第一个面向设计和代码协作的开源设计工具。它由西班牙公司 Kaleidos 开发,于 2015 年正式发布。作为一个基于浏览器的设计工具,Penpot 支持矢量图形编辑、原型设计、组件库构建等核心功能,同时还提供了独特的代码协作能力。

Penpot 的核心理念是 “Design with Code in Mind” (以代码为中心的设计)。它使用开放标准 (如 SVG、CSS 和 HTML) 作为底层技术,确保设计输出可以直接被开发者使用。这种方式大大缩短了设计到开发的转换时间,提高了团队整体效率。

截至目前,Penpot 在 GitHub 上已获得接近 32000 颗星,拥有超过 160 名贡献者。

最新发布的 Penpot 2.0 版本带来了一系列重大改进,进一步提升了设计和开发的协作体验:

  1. CSS Grid 布局:引入了强大的 CSS Grid 布局功能,使设计师能够创建更灵活、响应式的布局,同时生成符合现代 Web 标准的代码。
  2. 全新 UI 设计:经过重新设计的用户界面不仅提升了美观度,更重要的是优化了工作流程,提高了操作效率。
  3. 改进的组件系统:新的组件系统使创建、管理和重用设计元素变得更加简单,有助于保持设计的一致性和可维护性。
  4. 性能优化:整体性能得到显著提升,特别是在处理大型复杂项目时,响应更快,操作更流畅。
  5. 增强的可访问性:新版本在可访问性方面做了很多改进,使得更多用户能够方便地使用 Penpot。

Penpot 的技术架构

要充分理解 Penpot 的强大,我们需要深入了解其技术架构。

Penpot 采用典型的 SPA 架构。前端使用 ClojureScript 和 React 框架编写,由静态网络服务器提供服务。它与后端应用程序对话,后端应用程序将数据持久保存在 PostgreSQL 数据库中。

后端使用 Clojure 编写,因此前后端可以很轻松地共享代码和数据结构。最后将代码编译成 JVM 字节码,并在 JVM 环境中运行。

整体架构如下:

下面我们分别来看看各个组件的架构。

后端架构

Penpot 的后端主要使用 Clojure 编写,这是一种运行在 JVM 上的函数式编程语言。后端负责数据的 CRUD 操作、完整性验证以及数据持久化。

主要组件包括:

  • HTTP 服务器:处理 API 请求和路由。
  • RPC 系统:允许前端安全地调用后端函数。
  • 数据库:使用 PostgreSQL 存储核心数据。
  • 文件存储:用于存储媒体附件。
  • 异步任务系统:处理耗时操作,如发送邮件和遥测数据收集。
  • WebSocket:实现实时协作和通知。

前端架构

Penpot 的前端使用 ClojureScript 编写,这是 Clojure 语言编译到 JavaScript 的版本。它采用了 React 框架,通过 rumext 库进行封装。

主要模块包括:

  • 全局状态管理:使用类似 Redux 的事件循环范式。
  • UI 组件:包括仪表板、工作区、查看器等核心功能模块。
  • 渲染引擎:负责将设计转换为 SVG 元素。
  • Web Worker:处理耗时操作,如生成缩略图和维护几何索引。

导出器

Penpot 还包含一个专门的导出器应用,使用无头浏览器 (headless browser) 确保导出结果与屏幕上看到的完全一致。这个组件可以生成位图、PDF 或 SVG 格式的导出文件。

Penpot 的核心功能

了解了 Penpot 的技术架构,我们再来看看它能为设计师和开发人员带来哪些实际的价值:

为设计师打造

  1. 直观的设计界面:Penpot 提供了一个熟悉而强大的设计环境,设计师可以轻松创建复杂的设计。
  2. 响应式设计:借助 CSS Grid 布局,设计师可以轻松创建适应各种屏幕尺寸的设计。
  3. 组件和设计系统:Penpot 的组件系统允许创建可重用的设计元素,极大提高了效率和一致性。
  4. 交互原型:设计师可以添加交互和动画,创建高保真原型。
  5. 实时协作:多个设计师可以同时在一个文件上工作,提高团队效率。

为开发人员设计

  1. 检查模式:开发人员可以轻松获取设计的 CSS、HTML 和 SVG 代码。
  2. 精确规格:Penpot 提供准确的尺寸、颜色和其他设计规格,减少猜测工作。
  3. 设计令牌:开发人员可以直接使用设计中定义的颜色、字体和其他样式变量。
  4. 版本控制:Penpot 支持版本历史,便于跟踪设计变更。
  5. API 和 Webhooks:允许将 Penpot 集成到现有的开发工作流中。

团队协作

  1. 实时评论:团队成员可以直接在设计上添加评论,促进有效沟通。
  2. 权限管理:灵活的权限系统确保正确的人员访问正确的内容。
  3. 共享库:团队可以创建和共享设计资源,保持一致性。
  4. 导出选项:支持多种格式的导出,满足不同场景需求。

安装 Penpot

Penpot 有多种安装方式,有技术能力的同学可以通过 Docker 镜像来部署。需要部署的组件比较多,除了前端、后端和导出器之外,还需要部署两个数据库 PostgreSQL 和 Redis,如果你还想要实现高可用,那么对象存储也是必不可少的。

对于没有技术背景的同学而言,你也不用担心安装问题,Sealos 应用商店提供了一键部署的应用模板,点一下鼠标即可完成部署,非常丝滑。而且不需要再单独购买具有公网 IP 的服务器了,直接按量付费即可。

如果你想快速部署一个 Penpot,又不想陷入繁琐的安装和配置过程,可以试试 Sealos。

直接打开 Penpot 应用模板,然后点击右上角的 “去 Sealos 部署”。

如果您是第一次使用 Sealos,则需要注册登录 Sealos 公有云账号,登录之后会立即跳转到模板的部署页面。

什么都不用填,直接点击右上角的 “部署应用” 开始部署。部署完成后,直接点击前端应用的 “详情” 进入前端应用的详情页面。

等待应用状态变成 running 之后,直接点击外网地址便可打开 Penpot 的 Web 界面。

首先点击 “创建账户” 注册一个账号:

填一下问卷,总共有五步:

填完之后就可以开始正式使用了,你可以选择创建团队,也可以自己独立使用。

除此之外,还有另外一种打开方式,先刷新 Sealos 桌面 (也就是在 cloud.sealos.run 界面刷新浏览器),然后你就会发现 Sealos 桌面多了个图标:

直接点击这个图标就可以打开 Penpot 的 Web 界面。

是不是有点似曾相识?没错,很像 Windows 的快捷方式!

单机操作系统可以这么玩,Sealos 云操作系统当然也可以这么玩。

Penpot 的基本使用

要正式开始使用 Penpot,首先需要了解一些基本概念和操作。

画板

画板是 Penpot 中最基本的容器对象,通常用于创建特定尺寸的设计。你可以根据你的需要,选择一个特定的屏幕或打印用的尺寸。

  • 创建画板:使用工具栏中的画板工具,或按快捷键 B。
  • 选择画板:点击画板名称或 Ctrl/⌘ + 点击画板区域。
  • 设置缩略图:选中画板,右键选择 “Set as thumbnail” 或按 Shift + T。
  • 剪裁内容:画板可以选择是否剪裁其内容。
  • 在查看模式显示:控制画板是否作为单独屏幕在查看模式中显示。

色盘

Penpot 提供了强大的颜色管理工具,包括颜色选择器和颜色面板。

颜色选择器

  1. 吸管工具:从视窗中的任何对象拾取颜色。
  2. 颜色配置:在 RGB、色轮或 HSV 之间切换。
  3. 颜色类型:纯色、线性渐变、径向渐变或图像。
  4. 滑块:调整亮度、饱和度或不透明度。
  5. 数值:精确设置红 (R)、绿 (G)、蓝 (B) 和透明度 (A) 值。
  6. :在最近使用的颜色和库之间切换。

颜色面板

  • 可以通过主菜单、工具栏按钮或颜色选择器中的启动器显示/隐藏。
  • 使用菜单在库之间切换。
  • 可以切换大小缩略图大小。

组件

组件是可以在多个文件中重复使用的对象或对象组,有助于保持设计的一致性。

创建组件

  1. 选择一个对象或一组对象。
  2. 按 Ctrl + K 或右键选择 “Create component”。

组件操作

  • 复制组件:创建链接到主组件的组件副本。
  • 复制为主组件:从资产侧边栏复制为新的主组件。
  • 删除主组件:谨慎操作,会同时删除资产库中的组件。
  • 恢复主组件:可以从组件副本恢复已删除的主组件。
  • 组件分组:使用斜杠 (/) 命名或使用 “Group” 选项创建组件组。
  • 查找组件:可以在资产面板和设计视口中查找组件。

组件覆盖

  • 允许在保持与主组件同步的同时修改特定副本。
  • 可以重置覆盖以恢复到主组件状态。

组件交换

允许轻松替换组件副本:

  1. 选择一个组件副本。
  2. 在右侧边栏中点击组件名称启动交换菜单。
  3. 选择要交换的组件并点击。

原型设计

Penpot 允许通过连接画板来创建交互原型,模拟用户如何在屏幕间导航。

连接画板

  1. 打开至少包含两个画板的文件。
  2. 在右侧边栏激活 “Prototype mode”。
  3. 选择触发交互的图层。
  4. 从选中图层拖动连接到目标画板。
  5. 自动创建流程起点。
  6. 在查看模式中启动交互原型。

交互触发器

定义启动交互的用户动作,包括:

  • 点击 (On click)
  • 鼠标进入 (Mouse enter)
  • 鼠标离开 (Mouse leave)
  • 延迟后 (After delay)

交互动作

定义触发交互后发生的事件,包括:

  • 导航到 (Navigate to)
  • 打开叠加层 (Open overlay)
  • 切换叠加层 (Toggle overlay)
  • 关闭叠加层 (Close overlay)
  • 上一屏幕 (Previous screen)
  • 打开 URL(Open URL)

交互动画

定义触发交互时画板之间的过渡效果,包括:

  • 溶解 (Dissolve)
  • 滑动 (Slide)
  • 推送 (Push)

流 (Flows)

允许在同一页面内定义多个起点,以更好地组织和展示原型:

  • 自动创建起点
  • 从原型侧边栏添加起点
  • 从画板菜单添加起点
  • 在查看模式中切换不同流程

固定元素

可以固定对象在滚动时的位置,适用于原型设计中的固定头部、导航栏和浮动按钮等元素。

Figma 导出

Penpot 还提供了一个 Figma 插件,用于将 Figma 设计稿导出,可支持基本形状、面板、组、填充的导出,文本、图像具有基本功能支持。但目前自动布局、组件等关键的的功能都未能得到支持。

总结

虽然目前商业设计软件如 Figma 在市场上占据主导地位,但 Penpot 这样的开源工具正在快速崛起,并可能在未来超越商业软件。开源模式允许更多开发者参与,能够带来更快的创新速度和更强的功能适应性。同时,开源工具的透明性和可定制性,可能更好地满足不同团队的需求,最终成为行业新标准。

标签:Penpot,Figma,画板,替代品,创建,组件,设计
From: https://www.cnblogs.com/ryanyangcs/p/18373553

相关文章

  • 信创简报:2022年服务器国产化中间件替代品信息一览表(转)
    转载https://www.cnblogs.com/ios9/p/17695864.html#_label0*博客文章部分截图及内容来自于学习的书本及相应培训课程以及网络其他博客,仅做学习讨论之用,不做商业用途。*如有侵权,马上联系我,我立马删除对应链接。*@authorAlan*@[email protected]目录一、JDK/Open......
  • 2024 Selenium10个替代品
     随着自动化测试需求的不断增长,Selenium作为广泛使用的自动化测试工具,虽然功能强大,但也存在一些限制和挑战。在2024年,越来越多的替代工具涌现,它们提供了更高效、更易用的解决方案。那么,哪些替代品值得我们关注呢?  在自动化测试领域,除了Selenium,还有哪些工具能够满足我们的......
  • Figma 替代品 Excalidraw 安装和使用教程
    如今远程办公盛行,一个好用的在线白板工具对于团队协作至关重要。然而,市面上的大多数白板应用要么功能单一,要么操作复杂,难以满足用户的多样化需求。尤其是在进行头脑风暴、流程设计或产品原型绘制时,我们常常会遇到以下痛点:绘图工具不够直观,学习成本高;缺乏协作功能,难以实时沟通;......
  • Figma数值输入框支持拖拽调整功能实现
    最近再研究Figma的一些功能设计,对其中的数值输入框可以直接鼠标拖拽的这个设计印象非常深刻.这里用了其他网友的一张动态截图演示一下效果.实际这个拖拽的功能不止看到的这么简单,在深度研究使用之后,发现这个拖拽可以无限的拖动,当鼠标超出网页后会自动回到另一端然后继......
  • 没有谁 应该是谁的替代品
    没有谁应该是谁的替代品所谓真正的喜欢是不掺杂太多目的性在里面人家过得好自己过得不好人家美貌、富裕就转而去喜欢人家实在太肤浅没有谁应该是谁的替代品 情爱真正的情爱也不应掺杂太多的目的性在里面 社会很现实往往情爱都是掺杂很多目的性在里面男的看重......
  • 免费的Duet扩展屏替代品,ToDesk扩展屏功能详解
    小社长越来越体会到屏幕扩展功能有多香了!平时工作写ppt拿来做素材屏幕,整理修改意见都不需要来回切换页面了,工作效率提升咻咻快!虽然之前用的Duet扩展屏还可以,但价格上稍稍有点超出小社长的心理范围,短短用一个月还好,长期用钱包吃不消啊。所以最近一直在找性价比更高一点的国产扩......
  • 「UCD」浅谈蓝湖Figma交互设计对齐
    在现代数字产品的设计和开发过程中,选择合适的工具对于提高团队效率和保证产品质量至关重要。本文将从开发和设计两个不同的角度,探讨蓝湖和Figma两款流行工具的优势与不足,并提出结论和建议。开发研发视角:蓝湖优点:清晰的设计规范:蓝湖为开发工程师提供了清晰的设计规范,有......
  • 45、k8s-数据存储-配置存储-secret-(用于存储配置信息的-比configMap安全)-密文存储
    作用:用于存储敏感信息、例如密码、密钥、证书等实验:创建secret、再将secret挂载到容器里去、使用容器查看secret存储的信息1、先使用base64对数据进行编码·echo-n'admin'|base64---------------------------YWRtaW4=---------------------------......
  • 44、k8s-数据存储-配置存储-configMap-(用于存储配置信息的)
    概念:ConfigMap是一种比较特殊的存储卷、它主要的作用是用来存储配置信息的其模板如下:1、创建配置卷的yaml文件:vimconfigmap.yaml-------------------------------------------------------apiVersion:v1kind:ConfigMapmetadata:name:configmapnamespace:devdat......
  • TMPG ENC的开源替代品(内容由OpenAI 生成)
    TMPGEnc是一个流行的视频编码软件,但有几个开源替代品非常受欢迎,根据您的需求可能提供更好的功能:HandBrake:这是一个广泛使用的开源视频转码器。它支持多种格式,提供批处理功能,并且有一个用户友好的图形界面。HandBrake适用于大多数视频转换任务,并且可在Windows、Mac和Linux......