Added (poly)

This commit is contained in:
Devine Lu Linvega
2019-08-01 11:39:30 +09:00
parent 215911cc41
commit 19ee5b726b
6 changed files with 83 additions and 50 deletions

View File

@@ -38,7 +38,7 @@ Ronin helpers are keywords that facilitates adding coordinates from the canvas i
## Library ## Library
- `(import path shape)` Imports a graphic file with format. - `(import path shape ~alpha)` Imports a graphic file with format.
- `(export path ~format ~quality)` Exports a graphic file with format. - `(export path ~format ~quality)` Exports a graphic file with format.
- `(open path ~ratio)` Imports a graphic file and resizes the frame. - `(open path ~ratio)` Imports a graphic file and resizes the frame.
- `(move x y)` - `(move x y)`
@@ -55,6 +55,7 @@ Ronin helpers are keywords that facilitates adding coordinates from the canvas i
- `(circle cx cy r)` Returns a circle shape. - `(circle cx cy r)` Returns a circle shape.
- `(ellipse cx cy rx ry)` Returns a ellipse shape. - `(ellipse cx cy rx ry)` Returns a ellipse shape.
- `(line ax ay bx by)` Returns a line shape. - `(line ax ay bx by)` Returns a line shape.
- `(poly ...pos)` Returns a poly shape.
- `(text x y p t ~a ~f)` Returns a text shape. - `(text x y p t ~a ~f)` Returns a text shape.
- `(svg x y d)` Returns a svg shape. - `(svg x y d)` Returns a svg shape.
- `(color r g b ~a)` Returns a color object. - `(color r g b ~a)` Returns a color object.
@@ -68,7 +69,7 @@ Ronin helpers are keywords that facilitates adding coordinates from the canvas i
- `(hsla h s l ~a)` Defines a color h from 0 to 360, s and l from 0 to 100, a from 0 to 1 - `(hsla h s l ~a)` Defines a color h from 0 to 360, s and l from 0 to 100, a from 0 to 1
- `(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.
- `(resize w h ~fit)` Resizes the canvas to target w and h, returns the rect. - `(resize ~w)` 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. - `(rescale w h)` Rescales the canvas to target ratio of w and h, returns the rect.
- `(crop rect)` Crop canvas to rect. - `(crop rect)` Crop canvas to rect.
- `(clone a b)` - `(clone a b)`
@@ -126,9 +127,9 @@ Ronin helpers are keywords that facilitates adding coordinates from the canvas i
- `(keys item)` Returns a list of the object's keys - `(keys item)` Returns a list of the object's keys
- `(values item)` Returns a list of the object's values - `(values item)` Returns a list of the object's values
- `(convolve kernel ~rect)` - `(convolve kernel ~rect)`
- `(blur)` - `(blur)` Returns the blur kernel.
- `(sharpen)` - `(sharpen)` Returns the sharpen kernel.
- `(edge)` - `(edge)` Returns the edge kernel.
- `(dir ~path)` Returns the content of a directory. - `(dir ~path)` Returns the content of a directory.
- `(file ~path)` Returns the content of a file. - `(file ~path)` Returns the content of a file.
- `(dirpath ~path)` Returns the path of a directory. - `(dirpath ~path)` Returns the path of a directory.

View File

@@ -43,6 +43,7 @@
ronin.controller.addRole('default', 'Edit', 'delete') ronin.controller.addRole('default', 'Edit', 'delete')
ronin.controller.addRole('default', 'Edit', 'selectall') ronin.controller.addRole('default', 'Edit', 'selectall')
ronin.controller.add("default","Edit","Re-Indent",() => { ronin.commander.reindent() },"CmdOrCtrl+Shift+I") ronin.controller.add("default","Edit","Re-Indent",() => { ronin.commander.reindent() },"CmdOrCtrl+Shift+I")
ronin.controller.add("default","Edit","Clean",() => { ronin.commander.cleanup() },"Escape")
ronin.controller.add("default","View","Zoom In",() => { ronin.modZoom(0.25) },"CmdOrCtrl+=") ronin.controller.add("default","View","Zoom In",() => { ronin.modZoom(0.25) },"CmdOrCtrl+=")
ronin.controller.add("default","View","Zoom Out",() => { ronin.modZoom(-0.25) },"CmdOrCtrl+-") ronin.controller.add("default","View","Zoom Out",() => { ronin.modZoom(-0.25) },"CmdOrCtrl+-")
ronin.controller.add("default","View","Zoom Reset",() => { ronin.modZoom(1,true) },"CmdOrCtrl+0") ronin.controller.add("default","View","Zoom Reset",() => { ronin.modZoom(1,true) },"CmdOrCtrl+0")

View File

@@ -36,7 +36,7 @@ function Commander (ronin) {
} }
this.run = (txt = this._input.value) => { this.run = (txt = this._input.value) => {
if (this._input.value.indexOf('$') > -1) { console.warn('$ is present.'); return } if (this._input.value.indexOf('$') > -1) { txt = this.clean(txt) }
ronin.bindings = {} ronin.bindings = {}
if (this._input.value.trim() === '') { if (this._input.value.trim() === '') {
ronin.surface.maximize() ronin.surface.maximize()
@@ -77,6 +77,20 @@ function Commander (ronin) {
this._input.value = val.trim() this._input.value = val.trim()
} }
this.clean = function (input) {
const keywords = ['$pos+', '$pos', '$rect', '$line', '$x', '$y', '$xy']
for (word of keywords) {
input = input.replace(word, '').trim()
}
return input
}
this.cleanup = function () {
this._input.value = this.clean(this._input.value)
this.reindent()
this.run()
}
this.setStatus = function (msg) { this.setStatus = function (msg) {
// Logs // Logs
if (msg && msg !== this._log.textContent) { if (msg && msg !== this._log.textContent) {
@@ -137,34 +151,26 @@ function Commander (ronin) {
this.commit = function (shape, end = false, run = false) { this.commit = function (shape, end = false, run = false) {
if (this.cache.indexOf('$') < 0) { return } if (this.cache.indexOf('$') < 0) { return }
const segs = this.cache.split('$') const segs = this.cache.split('$')
const seg = segs[1] const words = segs[1].split(' ')
const words = seg.split(' ') const word = words[0].replace(/[^0-9a-z]/gi, '')
const word = words[0] const append = words[0].indexOf('+') > -1
if (word.substr(0, 4) === 'rect' && shape.rect) {
const rect = shape.rect if (word === 'drag') {
this._input.value = this.cache.replace('$rect', `(rect ${rect.x} ${rect.y} ${rect.w} ${rect.h})`) this.cache = this.cache.replace('$drag', `(drag $rect $line)`)
} else if (word.substr(0, 3) === 'pos' && shape.pos) { } else if (word === 'view') {
const pos = shape.pos this.cache = this.cache.replace('$view', `(drag $rect $rect)`)
this._input.value = this.cache.replace('$pos', `(pos ${pos.x} ${pos.y})`) } else if (word === 'poly') {
} else if (word.substr(0, 4) === 'line' && shape.line) { this.cache = this.cache.replace('$poly', `(poly $pos+)`)
const line = shape.line
this._input.value = this.cache.replace('$line', `(line ${line.a.x} ${line.a.y} ${line.b.x} ${line.b.y})`)
} else if (word.substr(0, 6) === 'circle' && shape.circle) {
const circle = shape.circle
this._input.value = this.cache.replace('$circle', `(circle ${circle.cx} ${circle.cy} ${circle.r.toFixed(2)})`)
} else if (word.substr(0, 4) === 'drag' && shape.line) {
const rect = shape.rect
this._input.value = this.cache.replace('$drag', `(drag (rect ${rect.x} ${rect.y} ${rect.w} ${rect.h}) $line)`)
} else if (word.substr(0, 4) === 'view' && shape.line) {
const rect = shape.rect
this._input.value = this.cache.replace('$view', `(view (rect ${rect.x} ${rect.y} ${rect.w} ${rect.h}) $rect)`)
} else if (word.substr(0, 2) === 'xy' && shape.x) {
this._input.value = this.cache.replace('$xy', `${shape.x} ${shape.y}`)
} else if (word.substr(0, 1) === 'x' && shape.x) {
this._input.value = this.cache.replace('$x', `${shape.x}`)
} else if (word.substr(0, 1) === 'y' && shape.y) {
this._input.value = this.cache.replace('$y', `${shape.y}`)
} }
if (shape[word]) {
if (append) {
this._input.value = this.cache.replace('$' + word + '+', this.template(shape[word], word) + ' $' + word + '+')
} else {
this._input.value = this.cache.replace('$' + word, this.template(shape[word], word))
}
}
if (end === true) { if (end === true) {
this.cache = this._input.value this.cache = this._input.value
} }
@@ -173,6 +179,15 @@ function Commander (ronin) {
} }
} }
this.template = function (shape, word) {
if (word === 'rect') { return `(rect ${shape.x} ${shape.y} ${shape.w} ${shape.h})` }
if (word === 'pos') { return `(pos ${shape.x} ${shape.y})` }
if (word === 'line') { return `(line ${shape.a.x} ${shape.a.y} ${shape.b.x} ${shape.b.y})` }
if (word === 'circle') { return `(circle ${shape.cx} ${shape.cy} ${shape.r})` }
if (word === 'x' || word === 'y' || word === 'xy') { return `${shape}` }
return ''
}
// Display // Display
this.show = function (expand = false) { this.show = function (expand = false) {
@@ -237,7 +252,7 @@ function Commander (ronin) {
// Splash // Splash
this.splash = `; welcome to ronin - v2.23 this.splash = `; welcome to ronin - v2.24
(clear) (clear)
(def frame-rect (def frame-rect
(frame)) (frame))

View File

@@ -63,7 +63,7 @@ function Library (ronin) {
} }
this.rect = (x, y, w, h) => { // Returns a rect shape. this.rect = (x, y, w, h) => { // Returns a rect shape.
return { x, y, w, h } return { x, y, w, h, pos: { x, y }, size: { w, h } }
} }
this.circle = (cx, cy, r) => { // Returns a circle shape. this.circle = (cx, cy, r) => { // Returns a circle shape.
@@ -78,6 +78,10 @@ function Library (ronin) {
return { a: this.pos(ax, ay), b: this.pos(bx, by) } return { a: this.pos(ax, ay), b: this.pos(bx, by) }
} }
this.poly = (...pos) => { // Returns a poly shape.
return pos
}
this.text = (x, y, p, t, a = 'left', f = 'Arial') => { // Returns a text shape. this.text = (x, y, p, t, a = 'left', f = 'Arial') => { // Returns a text shape.
return { x, y, p, t, a, f } return { x, y, p, t, a, f }
} }
@@ -88,7 +92,7 @@ function Library (ronin) {
this.color = (r, g, b, a = 1) => { // Returns a color object. this.color = (r, g, b, a = 1) => { // Returns a color object.
const hex = '#' + ('0' + parseInt(r, 10).toString(16)).slice(-2) + ('0' + parseInt(g, 10).toString(16)).slice(-2) + ('0' + parseInt(b, 10).toString(16)).slice(-2) const hex = '#' + ('0' + parseInt(r, 10).toString(16)).slice(-2) + ('0' + parseInt(g, 10).toString(16)).slice(-2) + ('0' + parseInt(b, 10).toString(16)).slice(-2)
return { r, g, b, a, hex, toString: () => { return hex }, 0: r, 1: g, 2: b, 3: a } return { r, g, b, a, hex, toString: () => { return `rgba(${r},${g},${b},${a})` }, 0: r, 1: g, 2: b, 3: a }
} }
this.offset = (a, b) => { // Offsets pos a with pos b, returns a. this.offset = (a, b) => { // Offsets pos a with pos b, returns a.
@@ -488,17 +492,23 @@ function Library (ronin) {
return rect return rect
} }
this.blur = [[1, 2, 1], this.blur = () => { // Returns the blur kernel.
[2, 4, 2], return [[1, 2, 1],
[1, 2, 2]] [2, 4, 2],
[1, 2, 2]]
}
this.sharpen = [[ 0, -1, 0], this.sharpen = () => { // Returns the sharpen kernel.
[-1, 5, -1], return [[ 0, -1, 0],
[ 0, -1, 0]] [-1, 5, -1],
[ 0, -1, 0]]
}
this.edge = [[-1, -1, -1], this.edge = () => { // Returns the edge kernel.
[-1, 9, -1], return [[-1, -1, -1],
[-1, -1, -1]] [-1, 9, -1],
[-1, -1, -1]]
}
// File System // File System

View File

@@ -144,6 +144,7 @@ function Ronin () {
if (!this.mouseOrigin) { return } if (!this.mouseOrigin) { return }
const x = position.x const x = position.x
const y = position.y const y = position.y
const xy = x + ' ' + y
const pos = { x, y } const pos = { x, y }
const rect = { const rect = {
x: this.mouseOrigin.x, x: this.mouseOrigin.x,
@@ -159,10 +160,10 @@ function Ronin () {
const circle = { const circle = {
cx: this.mouseOrigin.x, cx: this.mouseOrigin.x,
cy: this.mouseOrigin.y, cy: this.mouseOrigin.y,
r: d, r: d.toFixed(2),
edge: { x: rect.x - rect.w, y: rect.y - rect.h, w: rect.w * 2, h: rect.h * 2 } edge: { x: rect.x - rect.w, y: rect.y - rect.h, w: rect.w * 2, h: rect.h * 2 }
} }
return { x, y, d, line, rect, pos, circle, type, 'is-down': type !== 'mouse-up' ? true : null } return { x, y, xy, d, line, rect, pos, circle, type, 'is-down': type !== 'mouse-up' ? true : null }
} }
// Zoom // Zoom

View File

@@ -111,8 +111,12 @@ function Surface (ronin) {
} }
this.traceLine = function (line, context) { this.traceLine = function (line, context) {
context.moveTo(line.a.x, line.a.y) const positions = Object.values(line)
context.lineTo(line.b.x, line.b.y) const origin = positions.pop()
context.moveTo(origin.x, origin.y)
for (pos of positions) {
context.lineTo(pos.x, pos.y)
}
} }
this.tracePos = function (pos, context, radius = 7.5) { this.tracePos = function (pos, context, radius = 7.5) {
@@ -315,7 +319,8 @@ function Surface (ronin) {
return !isNaN(shape.x) && !isNaN(shape.y) && shape.p && shape.t && shape.f && shape.a return !isNaN(shape.x) && !isNaN(shape.y) && shape.p && shape.t && shape.f && shape.a
} }
function isLine (shape) { function isLine (shape) {
return shape.a && !isNaN(shape.a.x) && !isNaN(shape.a.y) && shape.b && !isNaN(shape.b.x) && !isNaN(shape.b.y) const positions = Object.values(shape)
return !isNaN(positions[0].x) && !isNaN(positions[0].y) && !isNaN(positions[1].x) && !isNaN(positions[1].y)
} }
function fitRect (image, container) { function fitRect (image, container) {