Added (ronin) object, renamed animation function to .animate()
This commit is contained in:
		| @@ -4,7 +4,6 @@ function Commander (ronin) { | ||||
|   this._input = document.createElement('textarea') | ||||
|   this._status = document.createElement('div') | ||||
|   this._status.id = 'status' | ||||
|   this.isAnimated = false | ||||
|  | ||||
|   this.install = function (host) { | ||||
|     this.el.appendChild(this._input) | ||||
| @@ -23,16 +22,10 @@ function Commander (ronin) { | ||||
|  | ||||
|   this.run = (txt = this._input.value) => { | ||||
|     if (txt.indexOf('$') > -1) { ronin.log('Present: $'); return } | ||||
|     !this.isAnimated && console.log('========') | ||||
|     ronin.surface.maximize() | ||||
|     const inter = new Lisp(txt, ronin.library) | ||||
|     inter.toPixels() | ||||
|     this.isAnimated && requestAnimationFrame(() => this.run(txt)) | ||||
|   } | ||||
|  | ||||
|   this.toggleAnimation = () => { | ||||
|     this.isAnimated = !this.isAnimated | ||||
|     this.run(this._input.value) | ||||
|     ronin.always && requestAnimationFrame(() => this.run(txt)) | ||||
|   } | ||||
|  | ||||
|   this.load = function (txt) { | ||||
|   | ||||
| @@ -82,14 +82,14 @@ function Library (ronin) { | ||||
|   this._filter = (fn, arr) => { | ||||
|     return arr.filter(fn) | ||||
|   } | ||||
|   this.filter= (fn, arr) => { | ||||
|    const list = Array.from(arr); | ||||
|    return Promise.all(list.map((element, index) => fn(element, index, list))) | ||||
|      .then(result => { | ||||
|        return list.filter((_, index) => { | ||||
|          return result[index]; | ||||
|        }); | ||||
|     }); | ||||
|   this.filter = (fn, arr) => { | ||||
|     const list = Array.from(arr) | ||||
|     return Promise.all(list.map((element, index) => fn(element, index, list))) | ||||
|       .then(result => { | ||||
|         return list.filter((_, index) => { | ||||
|           return result[index] | ||||
|         }) | ||||
|       }) | ||||
|   } | ||||
|  | ||||
|   this.reduce = (fn, arr, acc = 0) => { | ||||
| @@ -193,7 +193,16 @@ function Library (ronin) { | ||||
|     return rect | ||||
|   } | ||||
|  | ||||
|   // | ||||
|   this.get = (item, key) => { | ||||
|     return item[key] | ||||
|   } | ||||
|  | ||||
|   this.set = (item, key, val) => { | ||||
|     item[key] = val | ||||
|     return item[key] | ||||
|   } | ||||
|  | ||||
|   // TODO: Should remove (of) for (get)? | ||||
|  | ||||
|   this.of = (h, ...keys) => { | ||||
|     return keys.reduce((acc, key) => { | ||||
| @@ -315,9 +324,11 @@ function Library (ronin) { | ||||
|   } | ||||
|  | ||||
|   // Livecoding | ||||
|  | ||||
|   this.time = Date.now | ||||
|  | ||||
|   // javascript interop | ||||
|   this.js = window | ||||
|  | ||||
|   // Client | ||||
|   this.ronin = ronin | ||||
| } | ||||
|   | ||||
| @@ -21,6 +21,10 @@ function Ronin () { | ||||
|   this.surface = new Surface(this) | ||||
|   this.library = new Library(this) | ||||
|  | ||||
|   // Parameters | ||||
|  | ||||
|   this.always = false | ||||
|  | ||||
|   this.install = function (host = document.body) { | ||||
|     this._wrapper = document.createElement('div') | ||||
|     this._wrapper.id = 'wrapper' | ||||
| @@ -56,6 +60,11 @@ function Ronin () { | ||||
|  | ||||
|   } | ||||
|  | ||||
|   this.animate = (b = true) => { | ||||
|     this.always = b | ||||
|     this.commander.run() | ||||
|   } | ||||
|  | ||||
|   // Zoom | ||||
|  | ||||
|   this.modZoom = function (mod = 0, set = false) { | ||||
|   | ||||
| @@ -123,11 +123,11 @@ function Surface (ronin) { | ||||
|   this.draw = function (img, rect = this.getFrame()) { | ||||
|     return new Promise(resolve => { | ||||
|       img.onload = () => { | ||||
|       ronin.log(`Draw ${img.width}x${img.height}`) | ||||
|       this.context.drawImage(img, rect.x, rect.y, rect.w, rect.h) // no strect: img.height * (rect.w / img.width) | ||||
|       resolve() | ||||
|     } | ||||
|     }); | ||||
|         ronin.log(`Draw ${img.width}x${img.height}`) | ||||
|         this.context.drawImage(img, rect.x, rect.y, rect.w, rect.h) // no strect: img.height * (rect.w / img.width) | ||||
|         resolve() | ||||
|       } | ||||
|     }) | ||||
|   } | ||||
|  | ||||
|   this.crop = function (rect) { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user