Binnacle contains all of your assets within a hash-map in an effort to make all assets immediately available and minimize requests to the server.
Texture atlases are nice and also solve this problem, but are problematic in finding the optimal packing algorithm and make manipulating a specific image in the pack especially difficult. Encoding assets as data we pay a small price in increased payload to the client for the trade-off of being able to manipulate SVGs within the client without the need to store multiple colour variants of the same image.
Place all of your assets that you want to package into the assets hash-map in a directory somewhere accessible in your project (i.e. "resources/assets").
Currently supported file types:
- png
- jpg
- gif
- woff
(ns example.app
(:require [binnacle.core :as binnacle]))
(def assets
(binnacle/assets "resources/assets/"))
=> {:resources {:assets {:logo.png "BASE64_ENCODED_DATA..."
:logo.svg [:svg...]}
(binnacle/data-url assets [:resources :assets :logo.png])
=> "_ENCODED_DATA..."
(binnacle/data-url assets [:resources :assets :logo.svg])
=> "data:image/svg+xml;utf8,%3Csvg%20..."
SVG files are represented as Hiccup data structures for easy manipulation such as changing the fill colour.
(update-in assets [:resources :flux.svg]
(fn [[tag attrs & children]]
[tag (assoc attrs :fill "red") children]))
With the help of a macro, you can make the asset hash-map available in ClojureScript as well so you can interactively manipulate SVGs in the browser.
(ns example.app
(:require [binnacle.core :as binnacle])
#?(:cljs (:require-macros
[example.app :refer [assets*]])))
#?(:clj
(defmacro assets*
[path]
(binnacle/assets path)))
(def assets (assets* "resources/assets"))
Copyright © 2017 Powernoodle
Distributed under the Eclipse Public License either version 1.0 or (at your option) any later version.