很不错的package,希望支持系统环境变量的程序。
谢谢,我刚开始有考虑过用系统命令行,但有些接口的细节没想清楚,用命令行确实更灵活,不需要自己写脚本来包装,我这几天扩展一下
我是在看到你这个package后才想到能不能把drawio自动导出图片,然后查了下drawio还真的支持在命令行导出图片。 我现在的用法是自动添加drawio文件和对应的图片两个链接,画好图后,手动导出图片的。
不知道怎样指定导出图片的路径?
上面这个png在当前org文件所在目录下生成了,但是[[file...png]]
的链接是drawio命令行自动输出,正确的应该是 [[file:20220905_230106.png]]
你这里的写法可以改成以下形式,更精简
#+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 里加上类似某些博客框架中的随机生成文章封面的效果:
-
生成的新图片默认覆盖原图片。上图 gif 中有体现, 每次执行完 org-imagine-view 后覆盖上一个图,这和 org-imagine: 对 org 对象进行可视化的插件 - #10,来自 owensys 提到的需求一样,可以通过
(setq org-imagine-is-overwrite nil)
取消覆盖。 -
自动忽略 ATTR_xxx 属性行,因此可以比较方便设置图片大小,以上 gif 里也有体现。
-
把 view 目录作为 submodule , 使得这个包作为纯粹的 emacs package
-
在 README 加入更详细说明
这个更新真不错,马上来试一试
运行 org-imagine-view
时遇到错误:
path-no-ext?: Symbol’s function definition is void: f-no-ext
查了一下,似乎依赖 f.el 这个包。
感谢,都是这几个月自己用的过程中攒的需求,这两天有空一并加上了
确实,我自己还没在 emacs -q 下测试过 ,以为这个函数是内置的,当前已经加上了,感谢
又发现个小问题:文件名包含空格时执行的命令不正确。
#+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 …
只要有第三方程序能够生成这些图片,都是可以的,org-imagine 只是把写在 org 里的需要可视化的对象的内容(web 链接,文件路径等)传给 #+IMAGINE 后的命令行去执行,然后把命令行把生成的图片链接插入到下方再 preview 出来
我没有用 excalidraw , 不过只要有能根据文件来生成图片第三方工具就行,比如以下