Added layer module options
This commit is contained in:
		| @@ -1,66 +0,0 @@ | ||||
| function FileLoad(rune) | ||||
| { | ||||
|   Module.call(this,rune); | ||||
|    | ||||
|   this.parameters = [Filepath,Position,Rect]; | ||||
|    | ||||
|   this.active = function(cmd) | ||||
|   { | ||||
|     ronin.overlay.clear(); | ||||
|      | ||||
|     if(!cmd.filepath() && !cmd.value()){ ronin.terminal.log(new Log(this,"Missing image path.","error")); return; } | ||||
|      | ||||
|     var position = cmd.position() ? cmd.position() : new Position(); | ||||
|      | ||||
|     base_image = new Image(); | ||||
|     base_image.src = cmd.filepath().path; | ||||
|     base_image.src += '?'+new Date().getTime(); | ||||
|     base_image.crossOrigin = "Anonymous"; | ||||
|      | ||||
|     base_image.onload = function(){ | ||||
|       var width = base_image.naturalWidth; | ||||
|       var height = base_image.naturalHeight; | ||||
|       if(cmd.rect()){ | ||||
|         width = cmd.rect().width; | ||||
|         height = cmd.rect().height; | ||||
|         position.normalize(cmd.rect()); | ||||
|       } | ||||
|       // Scale with only 1 unit | ||||
|       width  = isNaN(width) && height > 0 ? (height*base_image.naturalWidth)/base_image.naturalHeight : width; | ||||
|       height = isNaN(height) && width > 0 ? (width*base_image.naturalHeight)/base_image.naturalWidth : height; | ||||
|        | ||||
|       ronin.surface.context().drawImage(base_image, position.x, position.y, width, height); | ||||
|     } | ||||
|   } | ||||
|    | ||||
|   this.passive = function(cmd) | ||||
|   {     | ||||
|     ronin.overlay.draw(cmd.position(),cmd.rect()); | ||||
|   } | ||||
|  | ||||
|   this.mouse_mode = function() | ||||
|   { | ||||
|     return "Place"; | ||||
|   } | ||||
|  | ||||
|   this.mouse_down = function(position) | ||||
|   { | ||||
|     ronin.overlay.draw(position); | ||||
|     ronin.terminal.input_element.value = "/ "+position.render(); | ||||
|     ronin.terminal.update_hint(); | ||||
|   } | ||||
|    | ||||
|   this.mouse_move = function(position,rect) | ||||
|   { | ||||
|     ronin.overlay.draw(this.mouse_from,rect); | ||||
|     ronin.terminal.input_element.value = "/ "+this.mouse_from.render()+" "+rect.render(); | ||||
|     ronin.terminal.update_hint(); | ||||
|   } | ||||
|    | ||||
|   this.mouse_up = function(position,rect) | ||||
|   { | ||||
|     ronin.overlay.draw(this.mouse_from,rect); | ||||
|     ronin.terminal.input_element.value = "/ "+this.mouse_from.render()+" "+rect.render(); | ||||
|     ronin.terminal.update_hint(); | ||||
|   } | ||||
| } | ||||
| @@ -1,50 +0,0 @@ | ||||
| function FileSave(rune) | ||||
| { | ||||
|   Module.call(this,rune); | ||||
|    | ||||
|   this.parameters = []; | ||||
|   this.variables  = {"format" : "[png/jpg/svg/rin]"}; | ||||
|  | ||||
|   this.docs = "Creates a new window with a image of the resulting canvas in the specified format."; | ||||
|  | ||||
|   this.active = function(cmd) | ||||
|   { | ||||
|     if(!this.layer){ this.create_layer(); } | ||||
|  | ||||
|     var d = null; | ||||
|  | ||||
|     var w = window.open('about:blank','image from canvas'); | ||||
|  | ||||
|     if(cmd.setting("format") && cmd.setting("format").value == "svg"){ | ||||
|       w.document.write("<title>Untitled</title><body>"+ronin.path.create_svg()+"</body>"); | ||||
|     } | ||||
|     else if(cmd.setting("format") && cmd.setting("format").value == "jpg"){ | ||||
|       w.document.write("<title>Untitled</title><body><img src='"+this.merge().element.toDataURL('image/jpeg')+"' width='"+ronin.surface.settings["size"].width+"px' height='"+ronin.surface.settings["size"].height+"px'/></body>"); | ||||
|     } | ||||
|     else if(cmd.setting("format") && cmd.setting("format").value == "rin"){ | ||||
|       var w = window.open('about:blank','source'); | ||||
|       var html = ""; | ||||
|       for (i = 0; i < ronin.terminal.history.length; i++) { html += ronin.terminal.history[i]+";<br />"; } | ||||
|       w.document.write("<title>Source</title><pre>"+html+"</pre>"); | ||||
|     } | ||||
|     else{ | ||||
|       w.document.write("<title>Untitled</title><body><img src='"+this.merge().element.toDataURL('image/png')+"' width='"+ronin.surface.settings["size"].width+"px' height='"+ronin.surface.settings["size"].height+"px'/></body>"); | ||||
|     } | ||||
|      | ||||
|     this.layer.remove(this); | ||||
|   } | ||||
|  | ||||
|   this.merge = function() | ||||
|   { | ||||
|     var a = []; | ||||
|     Object.keys(ronin.surface.layers).forEach(function (key) { | ||||
|       if(!ronin.surface.layers[key].manager){  | ||||
|         a.push(ronin.surface.layers[key]); | ||||
|       }  | ||||
|     }); | ||||
|     for (i = 0; i < a.length; i++) { | ||||
|       this.layer.context().drawImage(a[i].context().canvas,0,0,ronin.surface.settings["size"].width,ronin.surface.settings["size"].height); | ||||
|     } | ||||
|     return this.layer; | ||||
|   } | ||||
| } | ||||
							
								
								
									
										83
									
								
								scripts/modules/source.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										83
									
								
								scripts/modules/source.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,83 @@ | ||||
| function Source(rune) | ||||
| { | ||||
|   Module.call(this,rune); | ||||
|    | ||||
|   this.parameters = [Filepath,Position,Rect]; | ||||
|  | ||||
|   this.add_method(new Method("save",["name"],"Add point")); | ||||
|   this.add_method(new Method("load",["path","position","rect"]),"Add point"); | ||||
|    | ||||
|   this.load = function(params,preview = false) // source.load ../assets/todo.jpg 200x200 40,40 | ||||
|   { | ||||
|     if(!params.filepath() || !params.rect() || !params.position()){ ronin.terminal.log(new Log(this,"Missing image path.","error")); return; } | ||||
|  | ||||
|     console.log("OK"); | ||||
|  | ||||
|     ronin.overlay.get_layer(true).clear(); | ||||
|     ronin.overlay.draw_rect(params.position(),params.rect()); | ||||
|  | ||||
|     var position = params.position() ? params.position() : new Position(); | ||||
|      | ||||
|     base_image = new Image(); | ||||
|     base_image.src = params.filepath().path; | ||||
|     base_image.src += '?'+new Date().getTime(); | ||||
|     base_image.crossOrigin = "Anonymous"; | ||||
|      | ||||
|     base_image.onload = function(){ | ||||
|       var width = base_image.naturalWidth; | ||||
|       var height = base_image.naturalHeight; | ||||
|       if(params.rect()){ | ||||
|         width = params.rect().width; | ||||
|         height = params.rect().height; | ||||
|         position.normalize(params.rect()); | ||||
|       } | ||||
|       // Scale with only 1 unit | ||||
|       width  = isNaN(width) && height > 0 ? (height*base_image.naturalWidth)/base_image.naturalHeight : width; | ||||
|       height = isNaN(height) && width > 0 ? (width*base_image.naturalHeight)/base_image.naturalWidth : height; | ||||
|        | ||||
|       ronin.surface.context().drawImage(base_image, position.x, position.y, width, height); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   this.save = function(params,preview = false) | ||||
|   { | ||||
|     if(preview){ return; } | ||||
|     if(!this.layer){ this.create_layer(); } | ||||
|  | ||||
|     var d = null; | ||||
|  | ||||
|     var w = window.open('about:blank','image from canvas'); | ||||
|  | ||||
|     if(params.setting("format") && params.setting("format").value == "svg"){ | ||||
|       w.document.write("<title>Untitled</title><body>"+ronin.path.create_svg()+"</body>"); | ||||
|     } | ||||
|     else if(params.setting("format") && params.setting("format").value == "jpg"){ | ||||
|       w.document.write("<title>Untitled</title><body><img src='"+this.merge().element.toDataURL('image/jpeg')+"' width='"+ronin.surface.settings["size"].width+"px' height='"+ronin.surface.settings["size"].height+"px'/></body>"); | ||||
|     } | ||||
|     else if(params.setting("format") && params.setting("format").value == "rin"){ | ||||
|       var w = window.open('about:blank','source'); | ||||
|       var html = ""; | ||||
|       for (i = 0; i < ronin.terminal.history.length; i++) { html += ronin.terminal.history[i]+";<br />"; } | ||||
|       w.document.write("<title>Source</title><pre>"+html+"</pre>"); | ||||
|     } | ||||
|     else{ | ||||
|       console.log("!!") | ||||
|       w.document.write("<title>Untitled</title><body><img src='"+this.merge().element.toDataURL('image/png')+"' width='"+ronin.surface.settings["size"].width+"px' height='"+ronin.surface.settings["size"].height+"px'/></body>"); | ||||
|     } | ||||
|      | ||||
|     this.layer.remove(this); | ||||
|   } | ||||
|  | ||||
|   this.merge = function() | ||||
|   { | ||||
|     var a = []; | ||||
|     for(layer_name in ronin.surface.layers){ | ||||
|       if(ronin.surface.layers[layer_name].manager){ continue; } | ||||
|       a.push(ronin.surface.layers[layer_name]); | ||||
|     } | ||||
|     for (i = 0; i < a.length; i++) { | ||||
|       this.layer.context().drawImage(a[i].context().canvas,0,0,ronin.surface.settings["size"].width,ronin.surface.settings["size"].height); | ||||
|     } | ||||
|     return this.layer; | ||||
|   } | ||||
| } | ||||
| @@ -60,6 +60,8 @@ function Surface(rune) | ||||
|       this.add_layer(new Layer(layer_name)); | ||||
|     } | ||||
|     this.select_layer(this.layers[layer_name]); | ||||
|     ronin.modules["layer"] = this.layers[layer_name]; | ||||
|     ronin.layer = this.layers[layer_name]; | ||||
|   } | ||||
|  | ||||
|   // Misc | ||||
|   | ||||
| @@ -2,6 +2,8 @@ function Layer(name,manager = null) | ||||
| { | ||||
|   Module.call(this,"#"); | ||||
|  | ||||
|   this.add_method(new Method("fill",["color","position","rect"],"Add position")); | ||||
|  | ||||
|   this.name = name; | ||||
|   this.rune = "#"; | ||||
|   this.manager = manager; | ||||
| @@ -9,6 +11,21 @@ function Layer(name,manager = null) | ||||
|   this.element.setAttribute("id","_"+name); | ||||
|   this.element.setAttribute("class","layer"); | ||||
|  | ||||
|   this.fill = function(params,preview = false) | ||||
|   { | ||||
|     if(preview){ return; } | ||||
|     if(!params.color()){ return; } | ||||
|  | ||||
|     this.context().beginPath(); | ||||
|     this.context().rect(0, 0, this.element.width, this.element.height); | ||||
|     this.context().fillStyle = params.color().hex; | ||||
|     this.context().fill(); | ||||
|     ronin.terminal.log(new Log(this,"Filled layer: "+params.color().hex));  | ||||
|     this.element.style.border = "1px solid "+params.color().hex; | ||||
|     this.element.setAttribute("class",params.color().style()); | ||||
|  | ||||
|   } | ||||
|  | ||||
|   this.resize = function(rect) | ||||
|   { | ||||
|     ronin.terminal.log(new Log(this,"Resize "+this.name+" to "+rect.render())); | ||||
| @@ -23,17 +40,6 @@ function Layer(name,manager = null) | ||||
|     this.context().scale(2,2); | ||||
|   } | ||||
|  | ||||
|   this.fill = function(color) | ||||
|   { | ||||
|     this.context().beginPath(); | ||||
|     this.context().rect(0, 0, this.active_layer.element.width, this.active_layer.element.height); | ||||
|     this.context().fillStyle = cmd.color().hex; | ||||
|     this.context().fill(); | ||||
|     ronin.terminal.log(new Log(this,"Filled layer: "+cmd.color().hex));  | ||||
|     this.element.style.border = "1px solid "+cmd.color().hex; | ||||
|     this.element.setAttribute("class",cmd.color().style()); | ||||
|   } | ||||
|  | ||||
|   this.clear = function() | ||||
|   { | ||||
|     this.context().clearRect(0, 0, this.element.width, this.element.height); | ||||
|   | ||||
| @@ -10,13 +10,11 @@ function Type(rune) | ||||
|   { | ||||
|     if(!this.layer){ this.create_layer(); this.layer.is_blinking = true; } | ||||
|  | ||||
|     var command = new Command(params); | ||||
|  | ||||
|     this.layer.clear(); | ||||
|  | ||||
|     var text = "Hello there.".replace("_"," "); | ||||
|     var position = command.position() ? command.position() : new Position(40,80); | ||||
|     var color = new Color("#ffffff"); | ||||
|     var text = "Hello.".replace("_"," "); | ||||
|     var position = params.position() ? params.position() : new Position(40,80); | ||||
|     var color = params.color() ? params.color() :new Color("#ffffff"); | ||||
|     var size = 40; | ||||
|     var font = "Georgia"; | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user