Found a good flow for load:/draw:

This commit is contained in:
Devine Lu Linvega
2017-11-07 11:22:08 +13:00
parent 86bacd5688
commit 1c261cf166
11 changed files with 113 additions and 23 deletions

View File

@@ -56,7 +56,7 @@ app.on('ready', () =>
is_shown = true; is_shown = true;
}) })
// Open the DevTools. // Open the DevTools.
win.webContents.openDevTools() // win.webContents.openDevTools()
}) })
app.on('window-all-closed', () => app.on('window-all-closed', () =>

View File

@@ -11,9 +11,9 @@ yu { display:block; }
#render { z-index:800; position: fixed; } #render { z-index:800; position: fixed; }
#grid { z-index:795;position: fixed; } #grid { z-index:795;position: fixed; }
#ronin { background:#eee; height: 100vh; width:100vw; } #ronin { background:#eee; height: 100vh; width:100vw; }
#commander { position: fixed; bottom:15px; left:5px; width:100vw; height:20px; line-height: 20px; -webkit-user-select: none;-webkit-app-region: drag; z-index:900;} #commander, #hint { position: fixed;bottom: 0px;left: 0px;width: 100vw;line-height: 40px;-webkit-user-select: none;-webkit-app-region: drag;z-index: 900;height: 40px; font-size:11px;}
#commander input { background: transparent;width: calc(100vw - 30px);display: block;line-height: 20px;font-size: 11px;color: black; margin-left:20px; } #commander { z-index: 9000 }
#hint { position: fixed; bottom:15px; left:5px; width:100vw; height:20px; line-height: 20px; font-size: 11px;color: #999; margin-left:20px; } #commander input { background: transparent;width: calc(100vw - 30px);display: block;line-height: 40px;font-size: 11px;color: white; margin-left:20px; }
#hint { background:black; color:#666; padding-left:20px;}
#hint b { font-family: 'input_mono_regular' } #hint b { font-family: 'input_mono_regular' }

View File

@@ -59,6 +59,9 @@ function Cursor(rune)
if(ronin.commander.active_module()){ if(ronin.commander.active_module()){
}
else if(e.shiftKey && e.altKey){
ronin.brush.pick(ronin.cursor.line);
} }
else if(e.altKey){ else if(e.altKey){
ronin.brush.erase(ronin.cursor.line); ronin.brush.erase(ronin.cursor.line);

View File

@@ -43,7 +43,7 @@ function Keyboard()
if(e.key == "o" && (e.ctrlKey || e.metaKey)){ if(e.key == "o" && (e.ctrlKey || e.metaKey)){
e.preventDefault(); e.preventDefault();
ronin.io.load(); ronin.io.methods.import();
} }
if(e.key == "s" && (e.ctrlKey || e.metaKey)){ if(e.key == "s" && (e.ctrlKey || e.metaKey)){

View File

@@ -33,9 +33,9 @@ function Layer()
return this.context().getImageData(x, y, width * 2, height * 2); return this.context().getImageData(x, y, width * 2, height * 2);
} }
this.to_base64 = function() this.to_base64 = function(format = 'png', quality = 0.9)
{ {
return this.el.toDataURL('image/png'); return format == 'png' ? this.el.toDataURL('image/png') : this.el.toDataURL('image/jpeg',0.9);
} }
this.to_img = function() this.to_img = function()
@@ -49,4 +49,20 @@ function Layer()
{ {
this.context().clearRect(0, 0, this.el.width * 2, this.el.height * 2); this.context().clearRect(0, 0, this.el.width * 2, this.el.height * 2);
} }
this.fill = function(color = "red")
{
var ctx = this.context();
ctx.beginPath();
ctx.globalCompositeOperation="source-over";
ctx.moveTo(0,0);
ctx.lineTo(this.el.width,0);
ctx.lineTo(this.el.width,this.el.height);
ctx.lineTo(0,this.el.height);
ctx.lineTo(0,0);
ctx.fillStyle = color;
ctx.fill();
ctx.closePath();
}
} }

View File

@@ -11,6 +11,11 @@ function Module(name,docs = "Missing documentation.")
{ {
var html = ""; var html = "";
for(id in this.methods){
var v = this.methods[id];
html += id+": ";
}
for(setting_id in this.settings){ for(setting_id in this.settings){
var setting_value = this.settings[setting_id]; var setting_value = this.settings[setting_id];
html += setting_id+"="+setting_value+" "; html += setting_id+"="+setting_value+" ";

View File

@@ -97,6 +97,11 @@ function Brush()
ctx.closePath(); ctx.closePath();
} }
this.pick = function(line)
{
var pixel = ronin.render.context().getImageData(line.to.x*2, line.to.y*2, 1, 1).data;
}
this.mod_size = function(mod) this.mod_size = function(mod)
{ {
this.settings.size = clamp(this.settings.size+mod,1,100); this.settings.size = clamp(this.settings.size+mod,1,100);

View File

@@ -41,6 +41,16 @@ function Frame()
ronin.render.context().putImageData(data, 0, 0); ronin.render.context().putImageData(data, 0, 0);
} }
this.methods.clear = function(q)
{
ronin.render.fill("blue");
}
this.methods.fill = function(q)
{
ronin.render.fill(q);
}
this.resize_to = function(size) this.resize_to = function(size)
{ {
ronin.frame.settings.width = size.width; ronin.frame.settings.width = size.width;

View File

@@ -2,7 +2,7 @@ function IO()
{ {
Module.call(this,"io","File import/export tools."); Module.call(this,"io","File import/export tools.");
this.settings = {anchor:{x:0,y:0,width:0,height:0}}; this.settings = {anchor:{x:0,y:0,width:200,height:200}};
this.methods = {}; this.methods = {};
@@ -19,30 +19,63 @@ function IO()
img.src = filepath[0]; img.src = filepath[0];
img.onload = function() { img.onload = function() {
ronin.io.draw_image(img,ronin.commander.query()); ronin.io.draw_image(ronin.render.context(),img,ronin.commander.query());
} }
}); });
} }
this.image = null;
this.methods.load = function(q) this.methods.load = function(q)
{ {
// TODO var filepath = dialog.showOpenDialog({properties: ['openFile']});
if(!filepath){ console.log("Nothing to load"); return; }
fs.readFile(filepath[0], 'utf-8', (err, data) => {
if(err){ alert("An error ocurred reading the file :" + err.message); return; }
var img = new Image();
img.src = filepath[0];
img.onload = function() {
ronin.io.image = img;
ronin.commander.inject("io draw:20,20|100x100");
}
});
}
this.methods.draw = function(q)
{
ronin.io.draw_image(ronin.render.context(),ronin.io.image,ronin.commander.query().methods.draw);
ronin.io.image = null;
ronin.preview.clear();
} }
this.methods.save = function(q) this.methods.save = function(q)
{ {
// TODO // TODO
ronin.io.render();
}
this.preview = function(q)
{
ronin.preview.clear();
if(ronin.commander.query().methods.draw && this.image){
this.draw_image(ronin.preview.context(),this.image,ronin.commander.query().methods.draw);
}
} }
this.render = function() this.render = function()
{ {
var fs = require('fs'); var fs = require('fs');
var data = ronin.render.to_base64().replace(/^data:image\/\w+;base64,/, ""); var data = ronin.render.to_base64('jpg').replace(/^data:image\/\w+;base64,/, "");
var buf = new Buffer(data, 'base64'); var buf = new Buffer(data, 'base64');
dialog.showSaveDialog((fileName) => { dialog.showSaveDialog((fileName) => {
if (fileName === undefined){ return; } if (fileName === undefined){ return; }
fs.writeFile(fileName+'.png', buf); fs.writeFile(fileName+'.jpg', buf);
}); });
} }
@@ -79,24 +112,31 @@ function IO()
var width = parseInt(img.naturalWidth * 0.5); var width = parseInt(img.naturalWidth * 0.5);
var height = parseInt(img.naturalHeight * 0.5); var height = parseInt(img.naturalHeight * 0.5);
if(height > 900){ // if(height > 700){
width *= 0.5; // width *= 0.5;
height *= 0.5; // height *= 0.5;
} // }
// if(height > 1400){
// width *= 0.25;
// height *= 0.25;
// }
ronin.frame.methods.resize({width:parseInt(width),height:parseInt(height)})
img.onload = function() { img.onload = function() {
ronin.render.context().drawImage(img, 0,0,width * 2,height * 2); ronin.render.context().drawImage(img, 0,0,width * 2,height * 2);
} }
} }
this.draw_image = function(img,params) this.draw_image = function(ctx = ronin.preview.context(),img,params)
{ {
var anchor = ronin.io.settings.anchor; var anchor = params ? params : ronin.io.settings.anchor;
console.log("draw",ctx)
var width = parseInt(img.naturalWidth * 0.5); var width = parseInt(img.naturalWidth * 0.5);
var height = parseInt(img.naturalHeight * 0.5); var height = parseInt(img.naturalHeight * 0.5);
var scale = (anchor.width/width) * 2; var scale = (anchor.width/width) * 2;
ronin.render.context().drawImage(img, anchor.x * 2,anchor.y * 2,width * scale,height * scale); ctx.drawImage(img, anchor.x * 2,anchor.y * 2,width * scale,height * scale);
} }
} }

View File

@@ -20,9 +20,20 @@ function Path()
ctx.closePath(); ctx.closePath();
} }
this.methods.fill = function() this.methods.fill = function(q)
{ {
ronin.preview.clear();
var path = ronin.path.create_path(q);
var ctx = ronin.render.context();
ctx.beginPath();
ctx.lineCap = "butt";
ctx.lineWidth = 30;
ctx.fillStyle = "black";
ctx.fill(new Path2D(path));
ctx.closePath();
} }
this.preview = function(q) this.preview = function(q)

View File

@@ -79,6 +79,6 @@ function Ronin()
// this.commander.input_el.value = "path stroke:$+"; // this.commander.input_el.value = "path stroke:$+";
// this.commander.input_el.value = "magnet lock:"; // this.commander.input_el.value = "magnet lock:";
this.commander.inject("line tween:$&$&$>>$&$&$ step->thickness"); // this.commander.inject("line tween:$&$&$>>$&$&$ step->thickness");
} }
} }