Warning: this is an htmlized version!
The original is here, and the conversion rules are here. |
####### # # E-scripts on svg. # # Note 1: use the eev command (defined in eev.el) and the # ee alias (in my .zshrc) to execute parts of this file. # Executing this file as a whole makes no sense. # An introduction to eev can be found here: # # (find-eev-quick-intro) # http://angg.twu.net/eev-intros/find-eev-quick-intro.html # # Note 2: be VERY careful and make sure you understand what # you're doing. # # Note 3: If you use a shell other than zsh things like |& # and the for loops may not work. # # Note 4: I always run as root. # # Note 5: some parts are too old and don't work anymore. Some # never worked. # # Note 6: the definitions for the find-xxxfile commands are on my # .emacs. # # Note 7: if you see a strange command check my .zshrc -- it may # be defined there as a function or an alias. # # Note 8: the sections without dates are always older than the # sections with dates. # # This file is at <http://angg.twu.net/e/svg.e> # or at <http://angg.twu.net/e/svg.e.html>. # See also <http://angg.twu.net/emacs.html>, # <http://angg.twu.net/.emacs[.html]>, # <http://angg.twu.net/.zshrc[.html]>, # <http://angg.twu.net/escripts.html>, # and <http://angg.twu.net/>. # ####### # «.demo-1» (to "demo-1") # «.demo-2» (to "demo-2") # «.hlavaty-1» (to "hlavaty-1") # «.css-doodle» (to "css-doodle") # «.nanosvg» (to "nanosvg") # https://github.com/rougier/svg-lib # https://gitlab.com/atamariya/emacs/-/blob/dev/lisp/svg.el # https://mail.google.com/mail/ca/u/0/#search/svg/FMfcgzGljlmJXVhgbpfLKHkQFvWfCPMP # https://lifeofpenguin.blogspot.com/2021/08/scribble-notes-in-gnu-emacs.html # https://www.december.com/html/spec/colorsvg.html # https://github.com/rougier/svg-tag-mode # (find-es "emacs" "svg") # (find-es "emacs" "sketch-mode") # (find-elnode "SVG Images") # (find-TH "2022eev-svg") ##### # # demo-1 # 2022apr02 # ##### # «demo-1» (to ".demo-1") # (find-angg ".emacs" "find-svgbuffer") # https://lists.gnu.org/archive/html/help-gnu-emacs/2022-04/msg00002.html # (require 'svg) * (defun s () (interactive) (find-svgbuffer "*svg*" svg)) * (defun ks () (interactive) (ee-kill-buffer "*svg*")) * (defun pps () (interactive) (find-epp svg)) * (defun pps () (interactive) (find-eppp (cddr svg))) * (defun s3 () (interactive) (find-3a nil '(pps) '(s))) * * (ks) * (setq svg (svg-create 200 200 :stroke "orange" :stroke-width 5)) * (s3) * * (svg-rectangle svg 10 20 30 40 :fill-color "yellow" :stroke "blue") * (svg-rectangle svg 50 20 30 40 :fill-color "red" :stroke "brown") * (svg-rectangle svg 90 20 30 40 :fill-color "red") * (svg-rectangle svg 90 20 30 40 :fill-color "red") * (svg-rectangle svg 90 20 30 40 :fill-color "orchid2") * (svg-rectangle svg 90 20 30 40 :fill-color "purple") * (s3) * (svg-gradient svg "gradient1" 'linear '((0 . "red") (100 . "yellow"))) * (svg-gradient svg "gradient2" 'linear '((0 . "yellow") (100 . "blue"))) * (svg-gradient svg "gradient3" 'linear '((0 . "blue") (100 . "violet"))) * (svg-rectangle svg 30 50 20 20 :gradient "gradient1") * (svg-rectangle svg 70 50 20 40 :gradient "gradient2") * (svg-rectangle svg 110 50 20 60 :gradient "gradient3") * * (svg-polyline svg '((10 . 100) (30 . 100) (20 . 70)) :stroke-color "green") * (svg-polyline svg '((10 . 100) (30 . 100) (20 . 70)) :stroke-color "green" :fill-color "black") * * (svg-circle svg 160 40 15 :id "circle1") * (s3) (setq svg (svg-create 520 520 :stroke "orange" :stroke-width 5)) (setq svg (svg-create 200 200 :stroke "orange" :stroke-width 5)) (find-svgbuffers "*svg*" svg "stroke") (svg-rectangle svg 100 100 500 500 :gradient "gradient" :id "rec1") (svg-circle svg 60 50 40 :id "circle1") (svg-ellipse svg 100 100 50 90 :stroke "red" :id "ellipse1") (require 'svg) (setq svg (svg-create 201 101)) (find-svgbuffers "*svg*" svg) (svg-gradient svg "gradient1" 'linear '((0 . "red") (25 . "green") (100 . "blue"))) (svg-circle svg 50 50 50 :gradient "gradient1") (svg-gradient svg "gradient2" 'linear '((0 . "red") (100 . "blue"))) (svg-circle svg 100 50 50 :gradient "gradient2") ##### # # demo-2 # 2022apr03 # ##### # «demo-2» (to ".demo-2") # (find-fline "~/LOGS/2022apr02.emacs-2") # (require 'svg) ;; Test: (ramp 100 100) ;; (defun ramp (x0 y0) `((,(+ x0 0) . ,(+ y0 0)) (,(+ x0 20) . ,(+ y0 0)) (,(+ x0 30) . ,(+ y0 -10)))) * (defun s () (interactive) (find-svgbuffer "*svg*" svg)) * (defun ks () (interactive) (ee-kill-buffer "*svg*")) * (defun pps () (interactive) (find-eppp (cddr svg))) * (defun pps () (interactive) (find-epp svg)) * (defun s3 () (interactive) (find-3a nil '(pps) '(s))) * * (ks) * (setq svg (svg-create 200 200)) * (s3) * * (svg-rectangle svg 0 0 200 200 :fill-color "#eeeeee") * (svg-polyline svg (ramp 20 20) :stroke-color "black") * (svg-polyline svg (ramp 30 30) :stroke-color "black" :fill-color "blue") * (svg-polyline svg (ramp 40 40) :stroke-color "black" :fill-color "blue" :stroke-width 3) * (svg-polyline svg (ramp 50 50) :stroke-color "black" :fill-color "none" :stroke-width 3) * (svg-polyline svg (ramp 60 60) :stroke-color "black" :fill-color nil :stroke-width 3) * (s3) * (svg-rectangle svg 50 20 30 40 :fill-color "red" :stroke "brown") * (svg-rectangle svg 90 20 30 40 :fill-color "red") * (svg-rectangle svg 90 20 30 40 :fill-color "red") * (svg-rectangle svg 90 20 30 40 :fill-color "orchid2") * (svg-rectangle svg 90 20 30 40 :fill-color "purple") * (s3) * (svg-gradient svg "gradient1" 'linear '((0 . "red") (100 . "yellow"))) * (svg-gradient svg "gradient2" 'linear '((0 . "yellow") (100 . "blue"))) * (svg-gradient svg "gradient3" 'linear '((0 . "blue") (100 . "violet"))) * (svg-rectangle svg 30 50 20 20 :gradient "gradient1") * (svg-rectangle svg 70 50 20 40 :gradient "gradient2") * (svg-rectangle svg 110 50 20 60 :gradient "gradient3") * * (svg-polyline svg '((10 . 100) (30 . 100) (20 . 70)) :stroke-color "green") * (svg-polyline svg '((10 . 100) (30 . 100) (20 . 70)) :stroke-color "green" :fill-color "black") * * (svg-circle svg 160 40 15 :id "circle1") * (s3) ##### # # hlavaty-1 # 2022apr02 # ##### # «hlavaty-1» (to ".hlavaty-1") # https://lists.gnu.org/archive/html/help-gnu-emacs/2022-04/msg00007.html # (find-angg ".emacs" "find-svgbuffer") # (find-hfunction 'svg-rectangle) # The prefix "hsvg-" means "(based on) Tomas Hlavaty's SVG functions". ;; Tests: (hsvg 1 2 3 4 :BO "DY") ;; (hsvg-circle 5 6 7) ;; (hsvg 1 2 3 4 (hsvg-circle 5 6 7)) ;; (ee-xml-to-string (hsvg 1 2 3 4 (hsvg-circle 5 6 7))) ' (ee-xml-to-string '((svg ((xmlns . "http://www.w3.org/2000/svg") (viewBox . "0 0 100 100")) (circle ((cx . "50") (cy . "50") (r . "20"))) )) ) (defun hsvg-n (n) (format "%s" n)) (setq hsvg-viewbox "0 0 100 100") (defun hsvg (&rest body) `(svg ((xmlns . "http://www.w3.org/2000/svg") (viewBox . ,hsvg-viewbox)) ,@body)) (defun hsvg-circle (cx cy r &rest rest) `(circle ((cx . ,(hsvg-n cx)) (cy . ,(hsvg-n cy)) (r . ,(hsvg-n r)) ,@rest ))) ;; (hsvg (hsvg-circle 25 25 10)) ;; (find-svgbuffer "*svg*" (hsvg (hsvg-circle 25 25 10))) ;; (find-svgbuffer "*svg*" (hsvg (hsvg-circle 25 25 10 '(fill . "red")))) (fill . "red") (stroke-width . 5) `(,@(prog1 nil (setq a 22)) ,a ,@(prog1 nil (setq a 33)) ,a ) (require 'xml) (with-temp-buffer (xml-print '((svg ((xmlns . "http://www.w3.org/2000/svg";) (viewBox . "0 0 100 100")) (circle ((cx . "50") (cy . "50") (r . "20")))))) (write-file "/tmp/a.svg")) which you can refactor anyway you like, e.g. (defun hsvg (x y w h &rest body) `((svg ((xmlns . "http://www.w3.org/2000/svg";) (viewBox . ,(format "%s %s %s %s" x y w h))) ,@body))) (defun hsvg-circle (cx cy r) `(circle ((cx . ,(format "%s" cx) (cy . ,(format "%s" cy)) (r . ,(format "%s" r)))))) (with-temp-buffer (xml-print (svg 0 0 100 100 (svg-circle 50 50 20))) (write-file "/tmp/a.svg")) -- Function: svg-polygon svg points &rest args Add a polygon to SVG where POINTS is a list of X/Y pairs that describe the outer circumference of the polygon. (svg-polygon svg '((100 . 100) (200 . 150) (150 . 90)) :stroke-color "blue" :fill-color "red") ##### # # css-doodle # 2022sep26 # ##### # «css-doodle» (to ".css-doodle") # https://news.ycombinator.com/item?id=32990177 Experimenting a New Syntax to Write SVG (yuanchuan.dev) # https://yuanchuan.dev/experimenting-a-new-syntax-to-write-svg # https://css-doodle.com/ # https://github.com/css-doodle/css-doodle # https://webdesign.tutsplus.com/tutorials/how-to-draw-patterns-with-css-using-css-doodle--cms-33110 # https://www.youtube.com/watch?v=KKg6Uo1pVLU ##### # # nanosvg # 2023jan27 # ##### # «nanosvg» (to ".nanosvg") # https://github.com/memononen/nanosvg # (find-git-links "https://github.com/memononen/nanosvg" "nanosvg") # (code-c-d "nanosvg" "~/usrc/nanosvg/") # (find-nanosvgfile "") # (find-nanosvgfile "README.md") https://lists.gnu.org/archive/html/emacs-devel/2023-01/msg00513.html Jean / IceWM http://git.savannah.nongnu.org/cgit/dungeon.git/tree/src/dm-map.el <corwin> edrx: these are really, really messy but... http://git.savannah.nongnu.org/cgit/dungeon.git/tree/src/dm-map.el <corwin> And then a rewrite of the 'tiling engine' is in dm-draw, with the actual user facing stuff here: http://git.savannah.nongnu.org/cgit/dungeon.git/tree/src/dm-sketch.el <corwin> edrx: although this is basically impossible to read, this one function might help. it draws the 'graph paper' background. http://git.savannah.nongnu.org/cgit/dungeon.git/tree/src/dm-draw.el#n602 *** igemnace QUIT Quit: WeeChat 3.5 *** reedrichards QUIT Remote host closed the connection *** HaSt QUIT Ping timeout: 260 seconds <corwin> edrx: anyway... yea, I have been working with svg.el a bit; I'd be happy to chat or exchange emails but I'd just as soon not have my views on this topic kibitzed on devel. https://news.ycombinator.com/item?id=33584941 Forking Chrome to turn HTML into SVG (fathy.fr) https://github.com/misohena/el-easydraw https://misohena.jp/blog/2021-09-21-emacs-easy-draw.html https://sachachua.com/blog/2023/09/emacsconf-backstage-scheduling-with-svgs/ https://svg-tutorial.com/ Learn SVG with 25 examples – How to code images in HTML https://prideout.net/blog/svg_knots/ https://news.ycombinator.com/item?id=39079943 SVG images can contain JavaScript (github.com/berthubert) https://rhodesmill.org/brandon/2019/animating-the-equant/ *** https://news.ycombinator.com/item?id=40454475 Animating Ptolemy's Equant with Python, SVG, and CSS (rhodesmill.org) https://fietkau.software/qr https://news.ycombinator.com/item?id=41410442 Client-side QR code generator with SVG output (fietkau.software) https://cyberb.space/notes/2024/how-i-added-maps-to-my-travel-posts/ https://news.ycombinator.com/item?id=41532958 I Added SVG Maps to My Travel Posts (cyberb.space) https://notxor.nueva-actitud.org/2024/12/26/dibujando-figuras-con-emacs.html # Local Variables: # coding: utf-8-unix # End: