org-imagine: 对 org 对象进行可视化的插件

很不错的package,希望支持系统环境变量的程序。

1 个赞

谢谢,我刚开始有考虑过用系统命令行,但有些接口的细节没想清楚,用命令行确实更灵活,不需要自己写脚本来包装,我这几天扩展一下

我是在看到你这个package后才想到能不能把drawio自动导出图片,然后查了下drawio还真的支持在命令行导出图片。 我现在的用法是自动添加drawio文件和对应的图片两个链接,画好图后,手动导出图片的。

1 个赞

我刚做了一次提交,应该支持系统命令了,解释如下,可能会有些小 bug,欢迎指出🙏🏻

1 个赞

不知道怎样指定导出图片的路径?

上面这个png在当前org文件所在目录下生成了,但是 [[file...png]] 的链接是drawio命令行自动输出,正确的应该是 [[file:20220905_230106.png]]

通过%{./xxx.png} 参数可以显示图片了,不过发现另一个问题,多次执行 org-imagine-view 后会添加多个图片链接。

2 个赞

你这里的写法可以改成以下形式,更精简

#+IMAGINE: draw.io.exe -x -f png -o %{%o.png} %f

%o.png 会替换成 org-imagine 自动生成的文件名(包括时间戳),当然除非确实想自己取名并维护这个图片文件, 那么还可以用以下写法

#+IMAGINE: draw.io.exe -x -f png -o %{./20220905_230104.png} %f

每次执行生成一个新图片链接是设计上的安排,因为有些场景会需要多个图片,比如每天对 drawio 文件执行一次 org-imagine-view,这样可以保存每天的设计的快照。如果不需要的话,就是手动删除一行的成本,或者马上执行一次 undo,因此不对图片链接进行覆盖。

当积累的图片快照多了,可以执行 org-imagine-clear-cache 来删除那些没有被当前项目目录里的 org 文件引用的图片文件,前提是这些文件都在 org-imagine-cache-dir 里,默认是 ./.org-imagine/ 目录,用 %o.png 的话自动就保存在这。(这个命令依赖 projectile 和 grep)

好的。明白了。

最近做了一些更新:

  • 异步执行图片生成命令
  • 支持 http 和 https 开头的来自网页的链接,这样用 wget 就可以直接下载网页图片,做笔记比较方便(和 org-download 类似,但直接保留了图片原始链接在 org 里),还可以在 org 里加上类似某些博客框架中的随机生成文章封面的效果:

output-2022-12-02-18:32:37

  • 生成的新图片默认覆盖原图片。上图 gif 中有体现, 每次执行完 org-imagine-view 后覆盖上一个图,这和 org-imagine: 对 org 对象进行可视化的插件 - #10,来自 owensys 提到的需求一样,可以通过 (setq org-imagine-is-overwrite nil) 取消覆盖。

  • 自动忽略 ATTR_xxx 属性行,因此可以比较方便设置图片大小,以上 gif 里也有体现。

  • 把 view 目录作为 submodule , 使得这个包作为纯粹的 emacs package

  • 在 README 加入更详细说明

2 个赞

这个更新真不错,马上来试一试

运行 org-imagine-view 时遇到错误:

path-no-ext?: Symbol’s function definition is void: f-no-ext

查了一下,似乎依赖 f.el 这个包。

感谢,都是这几个月自己用的过程中攒的需求,这两天有空一并加上了 :grinning:

确实,我自己还没在 emacs -q 下测试过 :sweat:,以为这个函数是内置的,当前已经加上了,感谢

又发现个小问题:文件名包含空格时执行的命令不正确。

#+imagine: pdfsnap.py -s 600
[[pdf:1 2.pdf::1]]
[[file:pdftoppm version 22.11.0
Copyright 2005-2022 The Poppler Developers - http://poppler.freedesktop.org
Copyright 1996-2011, 2022 Glyph & Cog, LLC
Usage: pdftoppm [options] [PDF-file [PPM-file-prefix]]
  -f <int>                                 : first page to print
  -l <int>                                 : last page to print
  -o                                       : print only odd pages
  -e                                       : print only even pages
  -singlefile                              : write only the first page and do not add digits
  -scale-dimension-before-rotation         : for rotated pdf, resize dimensions before the rotation
  -r <fp>                                  : resolution, in DPI (default is 150)
  -rx <fp>                                 : X resolution, in DPI (default is 150)
  -ry <fp>                                 : Y resolution, in DPI (default is 150)
  -scale-to <int>                          : scales each page to fit within scale-to*scale-to pixel box
  -scale-to-x <int>]]

这里文件 1 2.pdf 是存在的,如果将其重命名为 1.pdf 可以正确输出图片。

Very very good!

这个很不错,有点像include 的多协议支持,做成API应该可以扩充到支持很多的场境吗?比如 网页截取、office 文档、视频截屏什么 的

有把 手绘的 excalidraw 文件 转成图片, 来看吗?

谢谢,栓q :joy:

只要有第三方程序能够生成这些图片,都是可以的,org-imagine 只是把写在 org 里的需要可视化的对象的内容(web 链接,文件路径等)传给 #+IMAGINE 后的命令行去执行,然后把命令行把生成的图片链接插入到下方再 preview 出来

我没有用 excalidraw , 不过只要有能根据文件来生成图片第三方工具就行,比如以下