diff --git a/.gitignore b/.gitignore index 48b0632..e9f74f3 100644 --- a/.gitignore +++ b/.gitignore @@ -4,3 +4,4 @@ elm.js index.html _site .sass-cache +_example diff --git a/Makefile b/Makefile index b2d8bac..6d83d9c 100644 --- a/Makefile +++ b/Makefile @@ -1,28 +1,44 @@ PICO_8_PALETTE_MAP_ELM=src/Elmo8/Textures/Pico8PaletteMap.elm PICO_8_PALETTE_MAP_PNG=palettes/pico-8-palette-map.png + PICO_8_FONT_ELM=src/Elmo8/Textures/Pico8Font.elm PICO_8_FONT_PNG=font/pico-8_regular_8.png + CONVERTER=tools/convert_to_data_uri.py + SOURCES=$(shell find examples src -name '*.elm') .PHONY: all -all: $(PICO_8_PALETTE_MAP_ELM) $(PICO_8_FONT_ELM) +all: $(PICO_8_PALETTE_MAP_ELM) $(PICO_8_FONT_ELM) examples $(PICO_8_PALETTE_MAP_ELM): Makefile $(CONVERTER) $(PICO_8_PALETTE_MAP_PNG) + mkdir -p src/Elmo8/Textures python3 $(CONVERTER) \ Elmo8.Textures.Pico8PaletteMap \ pico8PaletteMapDataUri \ image/png \ $(PICO_8_PALETTE_MAP_PNG) \ $(PICO_8_PALETTE_MAP_ELM) + elm format --yes $(PICO_8_PALETTE_MAP_ELM) $(PICO_8_FONT_ELM): Makefile $(CONVERTER) $(PICO_8_FONT_PNG) + mkdir -p src/Elmo8/Textures python3 $(CONVERTER) \ Elmo8.Textures.Pico8Font \ pico8FontDataUri \ image/png \ $(PICO_8_FONT_PNG) \ $(PICO_8_FONT_ELM) + elm format --yes $(PICO_8_FONT_ELM) + +.PHONY: examples +examples: + mkdir -p _example + elm make --output _example/examples.js examples/*.elm + cp examples/*.png _example/ + mkdir -p assets + cp $(PICO_8_PALETTE_MAP_PNG) assets/ + cp $(PICO_8_FONT_PNG) assets/ documentation.json: $(SOURCES) elm make --docs=documentation.json --warn @@ -34,3 +50,4 @@ format: .PHONY: upgrade upgrade: elm upgrade + diff --git a/assets/pico-8-palette-map.png b/assets/pico-8-palette-map.png new file mode 100644 index 0000000..2d3136d Binary files /dev/null and b/assets/pico-8-palette-map.png differ diff --git a/assets/pico-8_regular_8.png b/assets/pico-8_regular_8.png new file mode 100644 index 0000000..066b329 Binary files /dev/null and b/assets/pico-8_regular_8.png differ diff --git a/elm-package.json b/elm-package.json index 08542c6..d6f2d34 100644 --- a/elm-package.json +++ b/elm-package.json @@ -17,7 +17,8 @@ "elm-lang/animation-frame": "1.0.1 <= v < 2.0.0", "elm-lang/core": "5.0.0 <= v < 6.0.0", "elm-lang/html": "2.0.0 <= v < 3.0.0", - "elm-lang/window": "1.0.1 <= v < 2.0.0" + "elm-lang/window": "1.0.1 <= v < 2.0.0", + "nphollon/update-clock": "1.0.3 <= v < 2.0.0" }, "elm-version": "0.18.0 <= v < 0.19.0" } diff --git a/src/Elmo8/Assets.elm b/src/Elmo8/Assets.elm new file mode 100644 index 0000000..327605b --- /dev/null +++ b/src/Elmo8/Assets.elm @@ -0,0 +1,28 @@ +module Elmo8.Assets exposing (..) + +import WebGL +import Task + + +type alias URL = + String + + +{-| Try multiple sources to load texture + +Give a list of URLs to try, e.g.: + +- data url (not always available due to CORS) +- relative url (loads from same place as code) +- fallback CDN (will work except when there are network issues, least prefereble) + +-} +loadWebglTextureWithFallbacks : List URL -> Task.Task WebGL.Error WebGL.Texture +loadWebglTextureWithFallbacks urls = + case urls of + [] -> + Task.fail WebGL.Error + + url :: remainingUrls -> + WebGL.loadTexture url + |> Task.onError (\_ -> loadWebglTextureWithFallbacks remainingUrls) diff --git a/src/Elmo8/Layers/Common.elm b/src/Elmo8/Layers/Common.elm index 8f8dbe3..7a6b956 100644 --- a/src/Elmo8/Layers/Common.elm +++ b/src/Elmo8/Layers/Common.elm @@ -12,11 +12,21 @@ import Math.Matrix4 exposing (Mat4, makeOrtho2D) -- TODO: configure this at app startup, with sensible defaults +pico8FontRelativeUri : String +pico8FontRelativeUri = + "/assets/pico-8_regular_8.png" + + pico8FontUri : String pico8FontUri = "http://elmo-8.twomeylee.name/assets/pico-8_regular_8.png" +pico8PaletteMapRelativeUri : String +pico8PaletteMapRelativeUri = + "/assets/pico-8-palette-map.png" + + pico8PaletteMapUri : String pico8PaletteMapUri = "http://elmo-8.twomeylee.name/assets/pico-8-palette-map.png" diff --git a/src/Elmo8/Layers/Pixels.elm b/src/Elmo8/Layers/Pixels.elm index cd360ad..eaab7dc 100644 --- a/src/Elmo8/Layers/Pixels.elm +++ b/src/Elmo8/Layers/Pixels.elm @@ -11,7 +11,9 @@ import Math.Vector2 exposing (Vec2, vec2, fromTuple) import Math.Matrix4 exposing (Mat4, makeOrtho2D) import Task import WebGL -import Elmo8.Layers.Common exposing (CanvasSize, Vertex, makeProjectionMatrix, pico8PaletteMapUri) +import Elmo8.Assets +import Elmo8.Layers.Common exposing (CanvasSize, Vertex, makeProjectionMatrix, pico8PaletteMapUri, pico8PaletteMapRelativeUri) +import Elmo8.Textures.Pico8PaletteMap exposing (pico8PaletteMapDataUri) type alias X = @@ -97,7 +99,7 @@ init canvasSize = , paletteSize = vec2 16.0 16.0 , projectionMatrix = makeProjectionMatrix } - ! [ WebGL.loadTexture pico8PaletteMapUri + ! [ Elmo8.Assets.loadWebglTextureWithFallbacks [ pico8PaletteMapDataUri, pico8PaletteMapRelativeUri, pico8PaletteMapUri ] |> Task.attempt (\result -> case result of diff --git a/src/Elmo8/Layers/Text.elm b/src/Elmo8/Layers/Text.elm index 0abc75c..9cc1133 100644 --- a/src/Elmo8/Layers/Text.elm +++ b/src/Elmo8/Layers/Text.elm @@ -6,7 +6,10 @@ import Math.Matrix4 exposing (Mat4, makeOrtho2D) import String import Task import WebGL +import Elmo8.Assets import Elmo8.Layers.Common exposing (CanvasSize, Vertex, makeProjectionMatrix, pico8FontUri, pico8PaletteMapUri) +import Elmo8.Textures.Pico8Font exposing (pico8FontDataUri) +import Elmo8.Textures.Pico8PaletteMap exposing (pico8PaletteMapDataUri) -- TODO: represent more of the metrics for better layout. @@ -68,7 +71,7 @@ init canvasSize = , maybePaletteTexture = Nothing , paletteTextureSize = vec2 16.0 16.0 } - ! [ WebGL.loadTexture pico8FontUri + ! [ Elmo8.Assets.loadWebglTextureWithFallbacks [ pico8FontDataUri, "/assets/pico-8_regular_8.png", pico8FontUri ] |> Task.attempt (\result -> case result of @@ -78,7 +81,7 @@ init canvasSize = Ok val -> TextureLoad val ) - , WebGL.loadTexture pico8PaletteMapUri + , Elmo8.Assets.loadWebglTextureWithFallbacks [ pico8PaletteMapDataUri, "/assets/pico-8-palette-map.png", pico8PaletteMapUri ] |> Task.attempt (\result -> case result of diff --git a/src/Elmo8/Pico8.elm b/src/Elmo8/Pico8.elm index 61f8ab3..3fa15ec 100644 --- a/src/Elmo8/Pico8.elm +++ b/src/Elmo8/Pico8.elm @@ -37,6 +37,8 @@ Even if a function has the full PICO-8 function signature note all flags might b The PICO-8 has a fairly snazzy palette of 16 colours, identified by an int from 0 to 15. You can also use these handy identifiers. +You can view the palette (and download appropriate palettes for your apps) here: http://www.romanzolotarev.com/pico-8-color-palette/ + @docs black, darkblue, darkpurple, darkgreen, brown, darkgrey, lightgrey, white, red, orange, yellow, green, blue, indigo, pink, peach -} diff --git a/src/Elmo8/Textures/Pico8Font.elm b/src/Elmo8/Textures/Pico8Font.elm new file mode 100644 index 0000000..440e088 --- /dev/null +++ b/src/Elmo8/Textures/Pico8Font.elm @@ -0,0 +1,8 @@ +module Elmo8.Textures.Pico8Font exposing (..) + +-- Generated from pico-8_regular_8.png + + +pico8FontDataUri : String +pico8FontDataUri = + "" diff --git a/src/Elmo8/Textures/Pico8PaletteMap.elm b/src/Elmo8/Textures/Pico8PaletteMap.elm new file mode 100644 index 0000000..9915d62 --- /dev/null +++ b/src/Elmo8/Textures/Pico8PaletteMap.elm @@ -0,0 +1,8 @@ +module Elmo8.Textures.Pico8PaletteMap exposing (..) + +-- Generated from pico-8-palette-map.png + + +pico8PaletteMapDataUri : String +pico8PaletteMapDataUri = + ""