TkForge
在 Figma 中拖放,轻松创建 Python 图形用户界面
📺 YouTube video: https://youtu.be/lo6Ee_k_zG0
ParthJadhav 已经用 Tkinter Designer 完成了类似的工作,但我喜欢这个概念,并想从头开始做一个类似的东西,甚至做得更好。TkForge 与 Figma API 交互,获取文件的详细信息,并将其转化为代码。首先,它获取文件数据并将其转换为只包含必要细节的格式,然后再将其转换为代码。这个项目花费的时间比我预计的要长很多。
- 超级易用
- 拖放式图形用户界面制作工具
- 支持占位符文本
- 支持多个框架
- 根据背景自动将前景设置为黑色或白色(不一定准确)
加入我们的 Discord 服务器 并发布/查看使用 TkForge 制作的应用程序!
首先,您需要从发布页面下载可执行文件。然后,您需要创建一个 Figma 标记并复制项目的网址。然后,打开应用程序,将令牌和项目的网址粘贴到应用程序中,点击按钮即可启动魔法!🪄
确保您的 Figma 项目使用框架。TkForge 会将框架内的内容转化为可运行的图形用户界面,并忽略任何不在框架内的内容。
在 Figma 项目中,确保为所有元素添加正确的名称。
名称 | Tkinter 元素 | 第 2 个参数(空格后的文本) |
---|---|---|
text (你也可以给它起任何名字) |
canvas text | - |
button |
button | - |
image |
canvas image | 图像文件名 |
textbox |
entry | 占位符文本 |
textarea |
text | 占位符文本 |
spinbox |
spinbox | - |
rectangle |
canvas rectangle | - |
circle |
canvas circle | - |
oval |
canvas oval | - |
line |
canvas line | - |
label |
label | - |
scale |
scale | FROM TO ORIENT |
listbox (使用前请阅读下文) |
listbox | - |
如果任何元素以这些名称开头,那么它将被视为该 Tkinter 元素。例如,"矩形 1"、"矩形"、"矩形"、"RecTanGle 69 "都将被视为矩形。大小写并不重要。
如果以后想更改文本,可以使用标签代替文本。
您可以为图像文件设置一个名称,例如 image myImage
。创建的图像将命名为 myImage.png
。
椭圆形和圆形的作用相同,因此可以任选其一。
支持描边颜色和描边宽度,这意味着如果您在 Figma 中为它们添加了描边,它们在 Tkinter 设计中也会以相同的描边和描边宽度显示。
要添加占位符文本,只需在元素名称后加上空格即可。例如,textbox Hello world
或 textarea Hello world
。要设置占位符文本的颜色,可添加 placeholder_fg="color_here"
。例如
textbox_1 = TkForge_Entry(
placeholder="Code Example",
placeholder_fg="#fff"
)
使用 textbox_1.is_placeholder(False)
来确保插入的文本不会继承占位符的颜色。使用 textbox_1.get_placeholder()
获取占位符文本。在各种情况下,占位符文本可能需要额外处理。
对于标尺元素的 from、to 和 orient 值,可以将它们一个接一个地放在名称后面,中间用空格隔开。例如,如果我想要一个 from=10、to=50 和 orient=HORIZONTAL 的缩放比例,那么我可以使用 scale 10 50
或 scale 10 50 HORIZONTAL
,如果我想要 orient=VERTICAL 的缩放比例,那么我可以使用 scale 10 50 VERTICAL
。
建议避免使用listbox
,因为它会将高度和宽度扭曲几个像素。Figma 单位无法正常工作,因此我不得不用特定的数字来除以这些单位,以接近 Figma 的外观。
如果要从 Python 文件运行,则使用 python tkforge.py YOUR_ARGUMENTS_HERE
。
您可以使用 tkforge --help
获取帮助命令。如果您使用的是 Python 文件,请使用 python tkforge.py --help
。
如果您没有在环境变量中添加 CLI 可执行文件,则可能需要使用 ./tkforge.exe
或类似命令。
下面是一些使用示例:
tkforge --id "my_id" --token "my_token" --out ./app
如果希望在当前目录下输出,可以使用以下任意一条命令:
tkforge --id "my_id" --token "my_token"
tkforge --id "my_id" --token "my_token" --out .
tkforge "my_id" "my_token" output_path
如果希望在当前目录下输出,可以使用以下任意一条命令:
tkforge "my_id" "my_token"
tkforge "my_id" "my_token" .