Improved Widgets
This commit is contained in:
		| @@ -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"]+"'>●</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"]+"'>●</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(); | ||||
|     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("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; | ||||
|   } | ||||
| } | ||||
| @@ -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); | ||||
|   | ||||
| @@ -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);  | ||||
|   } | ||||
|  | ||||
|   | ||||
| @@ -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() | ||||
|   | ||||
| @@ -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
									
								
							
							
						
						
									
										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