Skip to content

A Clojure(Script) library that creates a hash-map of image data.

License

Notifications You must be signed in to change notification settings

powernoodle/binnacle

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Binnacle

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.

binnacle

Usage

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]))

Usage in ClojureScript

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"))

License

Copyright © 2017 Powernoodle

Distributed under the Eclipse Public License either version 1.0 or (at your option) any later version.

About

A Clojure(Script) library that creates a hash-map of image data.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published