Improved Widgets

This commit is contained in:
Devine Lu Linvega
2017-04-15 11:47:54 -10:00
parent 6084ef4984
commit 3df9b21772
14 changed files with 128 additions and 71 deletions

View File

@@ -28,6 +28,7 @@
<script type="text/javascript" src="scripts/modules/type.js"></script> <script type="text/javascript" src="scripts/modules/type.js"></script>
<script type="text/javascript" src="scripts/modules/render.js"></script> <script type="text/javascript" src="scripts/modules/render.js"></script>
<script type="text/javascript" src="scripts/modules/magnet.js"></script> <script type="text/javascript" src="scripts/modules/magnet.js"></script>
<script type="text/javascript" src="scripts/modules/widget.js"></script>
<script type="text/javascript" src="scripts/filters/filter.js"></script> <script type="text/javascript" src="scripts/filters/filter.js"></script>
<script type="text/javascript" src="scripts/filters/stencil.js"></script> <script type="text/javascript" src="scripts/filters/stencil.js"></script>

View File

@@ -4,9 +4,6 @@ body { margin:0px; padding:0px; overflow:hidden; font-family:"input_mono_medium"
#ronin { width:100%; height:100%; overflow:hidden; background:#111; background-image:url(../media/graphics/grid.svg); background-position: center center; } #ronin { width:100%; height:100%; overflow:hidden; background:#111; background-image:url(../media/graphics/grid.svg); background-position: center center; }
#frame { width:50vw; height:50vh; overflow:hidden; position:fixed; left:50%; top:50%; background:none; border-radius:5px; border:1px solid #333;} #frame { width:50vw; height:50vh; overflow:hidden; position:fixed; left:50%; top:50%; background:none; border-radius:5px; border:1px solid #333;}
#frame > .layer { position:absolute; top:0px; left:0px; width:100%; height:100%;} #frame > .layer { position:absolute; top:0px; left:0px; width:100%; height:100%;}
#frame widget { position: absolute; top:0px; left:0px; line-height: 20px; font-size:10px; z-index:9000; color:white; width:100%; height:100%; }
#frame widget span { display:inline-block; padding:2px 10px; }
#frame widget .cursor { position:absolute; bottom:0px; right:0px; }
#frame.bright widget { color:#000; } #frame.bright widget { color:#000; }
#overlay { position:absolute; z-index:1000;} #overlay { position:absolute; z-index:1000;}
#frame { cursor:none;} #frame { cursor:none;}
@@ -27,3 +24,12 @@ body { margin:0px; padding:0px; overflow:hidden; font-family:"input_mono_medium"
#terminal.hide { height:25px; } #terminal.hide { height:25px; }
#terminal.mini { height:120px; } #terminal.mini { height:120px; }
#terminal.full { height:100vh; } #terminal.full { height:100vh; }
#widget { position: absolute; top:0px; left:0px; line-height: 20px; font-size:10px; z-index:9000; color:white; width:100%; height:100%; }
#widget span { display:inline-block; line-height:15px; padding:0px 5px; vertical-align: top; }
#widget span name { display: block; border-bottom: 1px solid #333; line-height:25px; margin-bottom:5px;}
#widget .cursor { }
#widget li { display:block; }
#widget li.active { color:#72dec2; }
#widget li.inactive { color:#fff; }
#widget li.managed { color:#777; }

View File

@@ -1,3 +1,5 @@
frame.select main ; frame.select main ;
frame.resize 400x400 ; frame.resize 400x400 ;
brush:color #ff00ff ; brush:color #ff0000 ;
brush.add_pointer 1,1 ;
brush.add_pointer 2,2 ;

View File

@@ -35,4 +35,4 @@ ronin.terminal.query("terminal.load default.rin");
ronin.terminal.input_element.focus(); ronin.terminal.input_element.focus();
ronin.terminal.update_hint(); ronin.terminal.update_hint();
ronin.frame.update_widget(); ronin.widget.update();

View File

@@ -12,7 +12,7 @@ function Keyboard()
this.alt_held = true; this.alt_held = true;
} }
ronin.cursor.update(event); ronin.cursor.update(event);
ronin.frame.update_widget(); ronin.widget.update();
ronin.terminal.update_hint(); ronin.terminal.update_hint();
} }
@@ -45,7 +45,7 @@ function Keyboard()
// Passive // Passive
ronin.terminal.passive(ronin.terminal.input_element.value); ronin.terminal.passive(ronin.terminal.input_element.value);
ronin.frame.update_widget(); ronin.widget.update();
ronin.terminal.update_hint(); ronin.terminal.update_hint();
}; };

View File

@@ -19,6 +19,7 @@ function Ronin()
this.overlay = new Overlay("|"); this.overlay = new Overlay("|");
this.terminal = new Terminal(">"); this.terminal = new Terminal(">");
this.cursor = new Cursor("."); this.cursor = new Cursor(".");
this.widget = new Widget("?");
this.modules[this.frame.constructor.name] = this.frame; this.modules[this.frame.constructor.name] = this.frame;
this.modules[this.type.constructor.name] = this.type; this.modules[this.type.constructor.name] = this.type;
@@ -43,6 +44,7 @@ function Ronin()
} }
this.terminal.install(); this.terminal.install();
this.widget.install();
} }
this.cursors = []; this.cursors = [];

View File

@@ -17,7 +17,8 @@ function Brush(rune)
pointer.offset = params.position() ? params.position() : new Position("0,0"); pointer.offset = params.position() ? params.position() : new Position("0,0");
this.pointers.push(pointer); this.pointers.push(pointer);
ronin.terminal.log(new Log(this,"Added pointer at: "+pointer.offset)); ronin.terminal.log(new Log(this,"Added pointer at: "+pointer.offset.render()));
ronin.widget.update();
} }
this.passive = function(cmd) this.passive = function(cmd)
@@ -36,14 +37,14 @@ function Brush(rune)
this.size_up = function() this.size_up = function()
{ {
this.settings["size"] -= this.settings["size"] > 1 ? 1 : 0; this.settings["size"] -= this.settings["size"] > 1 ? 1 : 0;
ronin.frame.update_widget(); ronin.frame.widget.update();
ronin.terminal.log(new Log(this,"Increased pointer size to: "+this.settings["size"])); ronin.terminal.log(new Log(this,"Increased pointer size to: "+this.settings["size"]));
} }
this.size_down = function() this.size_down = function()
{ {
this.settings["size"] += 1; this.settings["size"] += 1;
ronin.frame.update_widget(); ronin.frame.widget.update();
ronin.terminal.log(new Log(this,"Decreased pointer size to: "+this.settings["size"])); ronin.terminal.log(new Log(this,"Decreased pointer size to: "+this.settings["size"]));
} }
@@ -81,7 +82,7 @@ function Brush(rune)
return "Eraser "+this.settings["size"]; return "Eraser "+this.settings["size"];
} }
else{ else{
return "<i style='color:"+this.settings["color"]+"'>&#9679;</i> Brush "+ronin.brush.pointers.length+"x "+this.settings["size"]; return "Brush "+this.settings["size"];
} }
} }
@@ -119,4 +120,15 @@ function Brush(rune)
ronin.brush.pointers[i].stop(); ronin.brush.pointers[i].stop();
} }
} }
this.widget = function()
{
var s = "<i style='color:"+this.settings["color"]+"'>&#9679;</i> Brush "+ronin.brush.pointers.length+"x "+this.settings["size"]+"<br />";
for(id in this.pointers){
s += this.pointers[id].widget();
}
return s;
}
} }

View File

@@ -206,4 +206,9 @@ function Cursor(rune)
ronin.terminal.update_hint(); ronin.terminal.update_hint();
this.mode.mouse_from = null; this.mode.mouse_from = null;
} }
this.widget = function()
{
return this.mode.mouse_mode();
}
} }

View File

@@ -13,11 +13,8 @@ function Frame(rune)
this.add_method(new Method("crop",[new Position().name,new Rect().name])); this.add_method(new Method("crop",[new Position().name,new Rect().name]));
this.add_method(new Method("select",["text"])); this.add_method(new Method("select",["text"]));
this.widget_element = document.createElement("widget");
this.install = function() this.install = function()
{ {
this.element.appendChild(this.widget_element);
this.blink(); this.blink();
} }
@@ -99,42 +96,6 @@ function Frame(rune)
this.element.appendChild(layer.element); this.element.appendChild(layer.element);
} }
this.widget = function()
{
if(!this.active_layer){ return ""; }
return this.rune+" "+this.settings["size"].render();
}
// Widget
this.update_widget = function()
{
if(!this.active_layer){ return; }
var s = "";
s += "<span class='module'>";
for (var key in ronin.modules){
s += ronin.modules[key].widget() ? ronin.modules[key].widget()+" " : "";
}
s += "</span>";
s += "<span class='cursor'>"+ronin.cursor.mode.mouse_mode()+"</span>";
var keys = Object.keys(ronin.frame.layers);
var loc = keys.indexOf(this.active_layer.name);
if(keys.length > 1){
s += "<span class='layer'>"+ronin.frame.active_layer.widget()+"("+(loc+1)+"/"+keys.length+")</span>";
}
else{
s += "<span class='layer'>"+ronin.frame.active_layer.widget()+"</span>";
}
this.widget_element.innerHTML = s;
}
// Commands // Commands
this.layer_up = function() this.layer_up = function()
@@ -177,4 +138,21 @@ function Frame(rune)
this.mouse_up = function(position,rect) this.mouse_up = function(position,rect)
{ {
} }
this.widget = function()
{
var s = "";
for(layer in this.layers){
if(this.active_layer.name == layer){
s += "<li class='active'>"+layer+"</li>";
}
else if(this.layers[layer].manager){
s += "<li class='managed'>"+this.layers[layer].manager.constructor.name+"*</li>";
}
else{
s += "<li class='inactive'>"+layer+"</li>";
}
}
return s;
}
} }

View File

@@ -131,17 +131,6 @@ function Layer(name,manager = null)
// //
this.widget = function()
{
var e_name = this.name;
var e_class = "";
if(ronin.frame.active_layer.name == this.name){ e_class += "highlight "; }
if(this.manager != null){ e_class += "managed "; }
return "<span class='"+e_class+"'>"+e_name+"</span>";
}
this.mouse_pointer = function(position) this.mouse_pointer = function(position)
{ {
return ronin.cursor.draw_pointer_arrow(position); return ronin.cursor.draw_pointer_arrow(position);

View File

@@ -72,12 +72,12 @@ function Magnet(rune)
this.update_mouse = function(position) this.update_mouse = function(position)
{ {
if(!this.layer){ this.create_layer(); } if(this.settings["grid"].width > 4 || this.settings["grid"].height > 4){
if(!this.layer){ this.create_layer(); }
this.layer.clear(); this.layer.clear();
this.draw_helper(position);
this.draw_helper(position); this.draw_grid(this.settings["grid"],this.settings["marker"]);
this.draw_grid(this.settings["grid"],this.settings["marker"]); }
return this.magnetic_position(position); return this.magnetic_position(position);
} }

View File

@@ -20,6 +20,7 @@ function Module(rune)
this.create_layer = function() this.create_layer = function()
{ {
console.info("!!!!",this);
this.layer = new Layer(this.constructor.name+".Preview",this); this.layer = new Layer(this.constructor.name+".Preview",this);
this.layer.element.setAttribute("style","z-index:7000"); this.layer.element.setAttribute("style","z-index:7000");
ronin.frame.add_layer(this.layer); ronin.frame.add_layer(this.layer);
@@ -43,7 +44,7 @@ function Module(rune)
{ {
this.settings[name] = value.content.join(" "); this.settings[name] = value.content.join(" ");
ronin.terminal.log(new Log(this,"Updated setting: "+name+", to "+this.settings[name])); ronin.terminal.log(new Log(this,"Updated setting: "+name+", to "+this.settings[name]));
ronin.frame.update_widget(); ronin.widget.update();
} }
this.add_method = function(method) this.add_method = function(method)
@@ -120,6 +121,7 @@ function Module(rune)
this.key_escape = function() this.key_escape = function()
{ {
} }
this.key_delete = function() this.key_delete = function()

View File

@@ -94,8 +94,9 @@ function Terminal(rune)
this.query = function(input_str) this.query = function(input_str)
{ {
if(input_str.trim() == ""){ return; }
if(this.locks.length > 0){ console.warn("Trying: "+input_str+", Locked: ",this.locks); return; } if(this.locks.length > 0){ console.warn("Trying: "+input_str+", Locked: ",this.locks); return; }
console.warn(input_str);
this.lock("query"); this.lock("query");
this.input_element.value = ""; this.input_element.value = "";

59
scripts/modules/widget.js Normal file
View File

@@ -0,0 +1,59 @@
function Widget(rune)
{
Module.call(this,rune);
this.element = document.createElement("div");
this.element.setAttribute("id","widget");
this.install = function()
{
ronin.element.appendChild(this.element);
}
this.update = function()
{
var s = "";
for (var key in ronin.modules){
s += ronin.modules[key].widget() ? "<span class='"+key+"'><name>"+key+"</name>"+ronin.modules[key].widget()+"</span> " : "";
}
this.element.innerHTML = s;
}
// this.widget = function()
// {
// if(!this.active_layer){ return ""; }
// return this.rune+" "+this.settings["size"].render();
// }
// // Widget
this.update_widget = function()
{
if(!this.active_layer){ return; }
var s = "";
s += "<span class='module'>";
for (var key in ronin.modules){
s += ronin.modules[key].widget() ? ronin.modules[key].widget()+" " : "";
}
s += "</span>";
s += "<span class='cursor'>"+ronin.cursor.mode.mouse_mode()+"</span>";
var keys = Object.keys(ronin.frame.layers);
var loc = keys.indexOf(this.active_layer.name);
if(keys.length > 1){
s += "<span class='layer'>"+ronin.frame.active_layer.widget()+"("+(loc+1)+"/"+keys.length+")</span>";
}
else{
s += "<span class='layer'>"+ronin.frame.active_layer.widget()+"</span>";
}
this.widget_element.innerHTML = s;
}
}