Trying to fix the (rescale) async issue
This commit is contained in:
		| @@ -62,13 +62,14 @@ npm start | |||||||
| - `(range start end ~step)`  | - `(range start end ~step)`  | ||||||
| - `(get item key)` Gets an object's parameter with name. | - `(get item key)` Gets an object's parameter with name. | ||||||
| - `(set item key val)` Sets an object's parameter with name as value. | - `(set item key val)` Sets an object's parameter with name as value. | ||||||
|  | - `(of h ...keys)`  | ||||||
| - `(frame)` Returns a rect of the frame. | - `(frame)` Returns a rect of the frame. | ||||||
| - `(center)` Returns a position of the center of the frame. | - `(center)` Returns a position of the center of the frame. | ||||||
| - `(scale rect w h)`  | - `(scale rect w h)`  | ||||||
| - `(resize ~w ~h)`  | - `(resize w h)` Resizes the canvas to target w and h, returns the rect. | ||||||
|  | - `(rescale w h)` Rescales the canvas to target ratio of w and h, returns the rect. | ||||||
| - `(crop rect)`  | - `(crop rect)`  | ||||||
| - `(clone a b)`  | - `(clone a b)`  | ||||||
| - `(of h ...keys)`  |  | ||||||
| - `(theme variable ~el)`  | - `(theme variable ~el)`  | ||||||
| - `(gradient [x1 y1 x2 y2] ~colors 'black'])`  | - `(gradient [x1 y1 x2 y2] ~colors 'black'])`  | ||||||
| - `(pixels rect fn q)`  | - `(pixels rect fn q)`  | ||||||
| @@ -79,10 +80,9 @@ npm start | |||||||
| - `(open path)` Imports a graphic file and resizes the frame. | - `(open path)` Imports a graphic file and resizes the frame. | ||||||
| - `(folder ~path)` Returns the content of a folder path. | - `(folder ~path)` Returns the content of a folder path. | ||||||
| - `(exit ~force)` Exits Ronin. | - `(exit ~force)` Exits Ronin. | ||||||
| - `(ronin)`  |  | ||||||
| - `(time)` Returns timestamp in milliseconds. | - `(time)` Returns timestamp in milliseconds. | ||||||
| - `(animate ~play)` Toggles animation. | - `(animate ~play)` Toggles animation. | ||||||
| - `(js)`  | - `(js)` Javascript interop. | ||||||
| - `(test name a b)`  | - `(test name a b)`  | ||||||
|  |  | ||||||
| ## Extras | ## Extras | ||||||
|   | |||||||
| @@ -212,6 +212,12 @@ function Library (ronin) { | |||||||
|     return item[key] |     return item[key] | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   this.of = (h, ...keys) => { | ||||||
|  |     return keys.reduce((acc, key) => { | ||||||
|  |       return acc[key] | ||||||
|  |     }, h) | ||||||
|  |   } | ||||||
|  |  | ||||||
|   // Frame |   // Frame | ||||||
|  |  | ||||||
|   this.frame = () => { // Returns a rect of the frame. |   this.frame = () => { // Returns a rect of the frame. | ||||||
| @@ -227,8 +233,18 @@ function Library (ronin) { | |||||||
|     return { x: rect.x, y: rect.y, w: rect.w * w, h: rect.h * h } |     return { x: rect.x, y: rect.y, w: rect.w * w, h: rect.h * h } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   this.resize = async (w = 1, h = 1) => { |   this.resize = async (w, h) => { // Resizes the canvas to target w and h, returns the rect. | ||||||
|     const rect = w <= 1 || h <= 1 ? { x: 0, y: 0, w: this.frame().w * w, h: this.frame().h * h } : { x: 0, y: 0, w, h } |     const rect = { x: 0, y: 0, w, h } | ||||||
|  |     const a = document.createElement('img') | ||||||
|  |     const b = document.createElement('img') | ||||||
|  |     a.src = ronin.surface.el.toDataURL() | ||||||
|  |     ronin.surface.resizeImage(a, b) | ||||||
|  |     ronin.surface.resize(rect, true) | ||||||
|  |     return ronin.surface.draw(b, rect) | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   this.rescale = async (w, h) => { // Rescales the canvas to target ratio of w and h, returns the rect. | ||||||
|  |     const rect = { x: 0, y: 0, w: this.frame().w * w, h: this.frame().h * h } | ||||||
|     const a = document.createElement('img') |     const a = document.createElement('img') | ||||||
|     const b = document.createElement('img') |     const b = document.createElement('img') | ||||||
|     a.src = ronin.surface.el.toDataURL() |     a.src = ronin.surface.el.toDataURL() | ||||||
| @@ -241,21 +257,11 @@ function Library (ronin) { | |||||||
|     return ronin.surface.crop(rect) |     return ronin.surface.crop(rect) | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // Copy/Paste |  | ||||||
|  |  | ||||||
|   this.clone = (a, b) => { |   this.clone = (a, b) => { | ||||||
|     ronin.surface.clone(a, b) |     ronin.surface.clone(a, b) | ||||||
|     return [a, b] |     return [a, b] | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // TODO: Should remove (of) for (get)? |  | ||||||
|  |  | ||||||
|   this.of = (h, ...keys) => { |  | ||||||
|     return keys.reduce((acc, key) => { |  | ||||||
|       return acc[key] |  | ||||||
|     }, h) |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   this.theme = (variable, el = document.documentElement) => { |   this.theme = (variable, el = document.documentElement) => { | ||||||
|     // ex. (theme "f_main") -> :root { --f_main: "#fff" } |     // ex. (theme "f_main") -> :root { --f_main: "#fff" } | ||||||
|     return getComputedStyle(el).getPropertyValue(`--${variable}`) |     return getComputedStyle(el).getPropertyValue(`--${variable}`) | ||||||
| @@ -316,10 +322,6 @@ function Library (ronin) { | |||||||
|     ronin.source.quit(force) |     ronin.source.quit(force) | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // Client |  | ||||||
|   this.ronin = ronin |  | ||||||
|  |  | ||||||
|   // Livecoding |  | ||||||
|   this.time = () => { // Returns timestamp in milliseconds. |   this.time = () => { // Returns timestamp in milliseconds. | ||||||
|     return Date.now |     return Date.now | ||||||
|   } |   } | ||||||
| @@ -328,8 +330,9 @@ function Library (ronin) { | |||||||
|     ronin.animate(play) |     ronin.animate(play) | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // javascript interop |   this.js = () => { // Javascript interop. | ||||||
|   this.js = window |     return window | ||||||
|  |   } | ||||||
|  |  | ||||||
|   this.test = (name, a, b) => { |   this.test = (name, a, b) => { | ||||||
|     if (`${a}` !== `${b}`) { |     if (`${a}` !== `${b}`) { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user