
/g,">").replace(/"/g,""").replace(/'/g,"'")}let s={},c=[];function d(e,n,t){s={...s,dynamic:e,core:n,leinProject:t}}function p(){c=["wh","with-style"]}window.onload=()=>{let{dynamic:n,core:t,leinProject:r}=s;if(n&&(document.getElementById("code-dynamic").innerHTML=l(n)),t&&(document.getElementById("code-core").innerHTML=l(t)),r&&(document.getElementById("code-lein-project").innerHTML=l(r)),c){let e={wh:';; Copyright (c) 2016 Tyler Hobbs\n;; MIT License\n;; https://github.com/thobbs/genartlib/\n(defn h\n "Returns a given percentage of the height Quil-specific."\n ([] (h 1.0))\n ([percentage] (* (height) percentage)))\n\n;; Copyright (c) 2016 Tyler Hobbs\n;; MIT License\n;; https://github.com/thobbs/genartlib/\n(defn w\n "Returns a given percentage of the width. Quil-specific."\n ([] (w 1.0))\n ([percentage] (* (width) percentage)))\n',"with-style":"(defmacro with-style [& body]\n `(do\n (q/push-style)\n (try\n ~@body\n (finally (q/pop-style)))))\n"},n=c.map(n=>e[n]).join("\n");document.getElementById("code-helpers").innerHTML=l(n)}e(i).addPlugin((0,o.number)()),e(i).highlightAll()}}),o("2tEiH",function(e,t){n(e.exports,"number",()=>r);let r=e=>({"after:highlightElement":({el:e,result:n,text:t})=>{let r=n.value.split("\n");r.pop();let i=r.length.toString().length,a=r.map((e,n)=>{let t=(n+1).toString().padStart(i);return`${e}`}).join("\n");e.innerHTML=a}})}),a("d3dEA"),a("7Y8VX");var l=a("gUHNU");(0,l.make)("(ns sketch.dynamic\n (:require ; [clojure.java.shell :refer [sh]]\n [genartlib.algebra :as gala]\n ; [genartlib.curves :refer :all]\n ; [genartlib.geometry :refer :all]\n ; [genartlib.random :refer :all]\n ; [kdtree :as kd]\n [artlib.color.dictionary :as colord]\n [artlib.geometry.jts :as jts]\n [artlib.quil.global :refer :all]\n [genartlib.util :refer [w h]]\n [quil.core :as q])\n (:import \n (org.locationtech.jts.triangulate VoronoiDiagramBuilder)\n (org.locationtech.jts.geom Coordinate GeometryFactory)))\n\n(let [color-dict (colord/init)\n palette (colord/get-combination-hsb color-dict :303)\n factory (new GeometryFactory)\n seeds (take 100 (repeatedly (fn [] [(rand) (rand)])))\n [points polys] (loop [points seeds n 200]\n (let [voronoi-builder (doto \n (new VoronoiDiagramBuilder)\n (.setSites (map (fn [[x y]] (new Coordinate x y)) points)))\n diagram (.getDiagram voronoi-builder factory)\n geoms (->> (.getNumGeometries diagram)\n (range)\n (map #(.getGeometryN diagram %)))\n centroids (->> geoms\n (map #(.getCentroid %))\n (map (fn [point] [(.getX point) (.getY point)])))\n points (->> geoms\n (map #(.getUserData %))\n (map (fn [coord] [(.getX coord) (.getY coord)])))\n polys (map jts/Geometry->points geoms)\n new-points (map (fn [[px py] [cx cy]]\n (let [dir (gala/angle px py cx cy)\n dis (q/dist px py cx cy)\n amt 0.001]\n (if (> (abs (- dis amt)) 1e-2)\n [(+ px (* amt (Math/cos dir)))\n (+ py (* amt (Math/sin dir)))]\n [px py])))\n points centroids)\n new-points (filter (fn [[x y]]\n (and (> 1.2 x -0.2)\n (> 1.2 y -0.2)))\n new-points)]\n (if (> n 0)\n (recur new-points (dec n))\n [new-points polys])))]\n (defn draw [state]\n (q/background 0 0 100)\n\n (let [frame (:frame state)\n f (/ frame 300)]\n (doseq [poly (->> polys\n (sort (fn [a b]\n (let [[ax ay] (jts/centroid a)\n [bx by] (jts/centroid b)\n a ax\n b bx]\n (compare a b))))\n reverse)]\n (doseq [[idx smaller] (->> poly\n (iterate #(jts/buffer-poly % -0.006))\n (take 5)\n #_reverse\n (map-indexed vector))]\n (let [[x y] (first smaller)\n n (+ (int (* 5 (q/noise (* x 15) (* y 15)))) idx)\n is-last? (= (mod idx 3) 0)]\n (with-style\n (q/stroke 0 0 80)\n (q/stroke-weight (w 0.002))\n (apply q/fill (nth (cycle palette) n))\n (q/begin-shape)\n (doseq [[x y] smaller]\n (q/vertex (w x) (h y)))\n (q/end-shape)))))\n \n (with-style\n (q/stroke-weight (w 0.002))\n (q/stroke 0 0 50 0.03)\n (doseq [x (range 0 1 0.001)]\n (let [x (gauss x 0.005)]\n (q/line (w x) (h 0) (w x) (h 1))))\n (doseq [y (range 0 1 0.001)]\n (let [y (gauss y 0.005)]\n (q/line (w 0) (h y) (w 1) (h y))))))))\n",'(ns sketch.core\n (:require [artlib.quil.middleware :refer [animation-mode]]\n [clojure.core.matrix :refer [set-current-implementation]]\n [quil.middleware :as qm]\n [sketch.dynamic :as dynamic]\n [quil.core :as q]))\n\n(set-current-implementation :vectorz)\n(println)\n\n(q/defsketch example\n :title "genuary-2024-01-09"\n :setup (fn [] {})\n :draw dynamic/draw\n :update identity\n :size [1080 1080]\n :animation {:render? true :dirname "1"}\n :middleware [qm/fun-mode animation-mode])\n\n','(defproject genuary-2025-01-09 "0.1.0-SNAPSHOT"\n :description "FIXME: write description"\n :url "https://example.com/FIXME"\n :license {:name "Apache License, Version 2.0"\n :url "https://www.apache.org/licenses/LICENSE-2.0.html"}\n :dependencies [[org.clojure/clojure "1.11.1"]\n [com.dedovic/artlib-core "0.0.11"]\n [com.dedovic/easings-clj "0.1.0"]\n [genartlib/genartlib "1.0.0"]] ; utility functions\n :jvm-opts ["-Xms4000m" "-Xmx4000M" ; 4GB heap size\n "-server"\n "-Dsun.java2d.uiScale=1.0"] ; adjust scaling for high DPI displays\n :source-paths ["src/clj"]\n :java-source-paths ["src/java"]\n :resource-paths ["resources"])\n'),(0,l.withDefaultHelpers)();
dynamic.clj
core.clj
helpers
project.clj