Improved Widgets
This commit is contained in:
		| @@ -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> | ||||||
|   | |||||||
| @@ -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;} | ||||||
| @@ -26,4 +23,13 @@ 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; } | ||||||
| @@ -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 ; | ||||||
| @@ -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(); | ||||||
| @@ -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(); | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -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 = []; | ||||||
|   | |||||||
| @@ -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"]+"'>●</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"]+"'>●</i> Brush "+ronin.brush.pointers.length+"x "+this.settings["size"]+"<br />";   | ||||||
|  |  | ||||||
|  |     for(id in this.pointers){ | ||||||
|  |       s += this.pointers[id].widget(); | ||||||
|  |     } | ||||||
|  |     return s; | ||||||
|  |  | ||||||
|  |   } | ||||||
| } | } | ||||||
| @@ -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(); | ||||||
|  |   } | ||||||
| } | } | ||||||
| @@ -12,12 +12,9 @@ function Frame(rune) | |||||||
|   this.add_method(new Method("resize",[new Rect().name])); |   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("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; | ||||||
|  |   } | ||||||
| } | } | ||||||
| @@ -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); | ||||||
|   | |||||||
| @@ -72,13 +72,13 @@ 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);  | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -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() | ||||||
|   | |||||||
| @@ -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
									
								
							
							
						
						
									
										59
									
								
								scripts/modules/widget.js
									
									
									
									
									
										Normal 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; | ||||||
|  |   } | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user