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

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

View File

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

View File

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

View File

@@ -17,7 +17,8 @@ function Brush(rune)
pointer.offset = params.position() ? params.position() : new Position("0,0");
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)
@@ -36,14 +37,14 @@ function Brush(rune)
this.size_up = function()
{
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"]));
}
this.size_down = function()
{
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"]));
}
@@ -81,7 +82,7 @@ function Brush(rune)
return "Eraser "+this.settings["size"];
}
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();
}
}
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();
this.mode.mouse_from = null;
}
this.widget = function()
{
return this.mode.mouse_mode();
}
}

View File

@@ -12,12 +12,9 @@ function Frame(rune)
this.add_method(new Method("resize",[new Rect().name]));
this.add_method(new Method("crop",[new Position().name,new Rect().name]));
this.add_method(new Method("select",["text"]));
this.widget_element = document.createElement("widget");
this.install = function()
{
this.element.appendChild(this.widget_element);
this.blink();
}
@@ -99,42 +96,6 @@ function Frame(rune)
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
this.layer_up = function()
@@ -177,4 +138,21 @@ function Frame(rune)
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)
{
return ronin.cursor.draw_pointer_arrow(position);

View File

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

View File

@@ -20,6 +20,7 @@ function Module(rune)
this.create_layer = function()
{
console.info("!!!!",this);
this.layer = new Layer(this.constructor.name+".Preview",this);
this.layer.element.setAttribute("style","z-index:7000");
ronin.frame.add_layer(this.layer);
@@ -43,7 +44,7 @@ function Module(rune)
{
this.settings[name] = value.content.join(" ");
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)
@@ -120,6 +121,7 @@ function Module(rune)
this.key_escape = function()
{
}
this.key_delete = function()

View File

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