Implemented temporary storage.
This commit is contained in:
		
							
								
								
									
										13
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								README.md
									
									
									
									
									
								
							| @@ -7,24 +7,17 @@ | |||||||
| @ ?                               ; Clear canvas | @ ?                               ; Clear canvas | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ##History* |  | ||||||
| ``` |  | ||||||
| ~                                 ; Keep image progress |  | ||||||
| ~ 3                               ; Keep image progress into temporary memory with id 3 |  | ||||||
| ~ ?                               ; Clear history |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ##Save File | ##Save File | ||||||
| ``` | ``` | ||||||
| $ new_name.jpg                    ; Create a new file with name | $ new_name                        ; Create a new file with name | ||||||
|  | $ 3                               ; Save to temporary storage, accessible with Load | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ##Load File | ##Load File | ||||||
| ``` | ``` | ||||||
| / dir/file_name.jpg 10,10 100x100 ; Load image, at 10,10 with size 100x100 | / dir/file_name.jpg 10,10 100x100 ; Load image, at 10,10 with size 100x100 | ||||||
| / dir/file_name.jpg 10,10 100x    ; Load image, at 10,10 with size 100w and auto height | / dir/file_name.jpg 10,10 100x    ; Load image, at 10,10 with size 100w and auto height | ||||||
| / ~                               ; Load last history id | / 3                               ; Load temporary storage id | ||||||
| / 3                               ; Load history id |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ##Brush(Pointers) | ##Brush(Pointers) | ||||||
|   | |||||||
| @@ -27,7 +27,7 @@ function Commander(element,element_input) | |||||||
|         ronin.canvas.active(cmd); |         ronin.canvas.active(cmd); | ||||||
|         break; |         break; | ||||||
|       case "~": // TODO |       case "~": // TODO | ||||||
|         ronin.history.active(cmd); |         ronin.memory.active(cmd); | ||||||
|         break; |         break; | ||||||
|       case "$": |       case "$": | ||||||
|         ronin.file.save(cmd); |         ronin.file.save(cmd); | ||||||
| @@ -70,8 +70,8 @@ function Commander(element,element_input) | |||||||
|         ronin.module = ronin.canvas; |         ronin.module = ronin.canvas; | ||||||
|         break; |         break; | ||||||
|       case "~": |       case "~": | ||||||
|         ronin.history.passive(this.cmd); |         ronin.memory.passive(this.cmd); | ||||||
|         ronin.module = ronin.history; |         ronin.module = ronin.memory; | ||||||
|         break; |         break; | ||||||
|       case "/": |       case "/": | ||||||
|         ronin.file.passive(this.cmd); |         ronin.file.passive(this.cmd); | ||||||
|   | |||||||
| @@ -51,24 +51,12 @@ function Keyboard() | |||||||
|      |      | ||||||
|     // Passive |     // Passive | ||||||
|     var cmd = commander.element_input.value; |     var cmd = commander.element_input.value; | ||||||
|      |  | ||||||
|     if(cmd.indexOf(";") > 0){ |  | ||||||
|       var cmds = cmd.split(";"); |  | ||||||
|       for (i = 0; i < cmds.length; i++) { |  | ||||||
|         cmd = cmds[i].replace(/^\s+|\s+$/g, ''); |  | ||||||
|     commander.passive(cmd.split(" ")); |     commander.passive(cmd.split(" ")); | ||||||
|       } |  | ||||||
|     } |  | ||||||
|     else{ |  | ||||||
|       commander.passive(cmd.split(" ")); |  | ||||||
|     } |  | ||||||
|      |  | ||||||
|     ronin.hint.update(); |     ronin.hint.update(); | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   this.key_tab = function() |   this.key_tab = function() | ||||||
|   { |   { | ||||||
|     return; |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   this.key_enter = function() |   this.key_enter = function() | ||||||
| @@ -76,11 +64,11 @@ function Keyboard() | |||||||
|     var cmd = commander.element_input.value; |     var cmd = commander.element_input.value; | ||||||
|      |      | ||||||
|     if(cmd.indexOf(";") > 0){ |     if(cmd.indexOf(";") > 0){ | ||||||
|       var cmds = cmd.split(";"); |       var multi = cmd.split(";"); | ||||||
|       for (i = 0; i < cmds.length; i++) { |       if(multi[0]){commander.active(multi[0].split(" "));} | ||||||
|         cmd = cmds[i].replace(/^\s+|\s+$/g, ''); |       if(multi[1]){commander.active(multi[1].split(" "));} | ||||||
|         commander.active(cmd.split(" ")); |       if(multi[2]){commander.active(multi[2].split(" "));} | ||||||
|       } |       if(multi[3]){commander.active(multi[3].split(" "));} | ||||||
|     } |     } | ||||||
|     else{ |     else{ | ||||||
|       commander.active(cmd.split(" ")); |       commander.active(cmd.split(" ")); | ||||||
|   | |||||||
| @@ -37,37 +37,6 @@ function Brush() | |||||||
|     return "Brush: "+hint_value+hint_position+hint_color; |     return "Brush: "+hint_value+hint_position+hint_color; | ||||||
|   } |   } | ||||||
|    |    | ||||||
|   // Commander |  | ||||||
|    |  | ||||||
|   this.settings = function(p) |  | ||||||
|   { |  | ||||||
|     if(p[0]){ this.size = parseInt(p[0]); } |  | ||||||
|     if(p[1]){ this.opacity = parseFloat(p[1]); } |  | ||||||
|     if(p[2]){ this.color = new Color(p[2]); } |  | ||||||
|   } |  | ||||||
|    |  | ||||||
|   this.add = function(p) |  | ||||||
|   { |  | ||||||
|     if(p.length >= 2){ |  | ||||||
|       var position = new Position(parseInt(p[0]),parseInt(p[1])); |  | ||||||
|       var pointer = new Pointer(position); |  | ||||||
|     } |  | ||||||
|      |  | ||||||
|     if(p.length >= 4){ |  | ||||||
|       var mirror = new Position(parseInt(p[2]),parseInt(p[3])); |  | ||||||
|       pointer.mirror = mirror; |  | ||||||
|     } |  | ||||||
|      |  | ||||||
|     this.add_pointer(pointer); |  | ||||||
|   } |  | ||||||
|    |  | ||||||
|   this.remove = function(p) |  | ||||||
|   { |  | ||||||
|     this.remove_pointer(new Position(p[0],p[1])); |  | ||||||
|   } |  | ||||||
|    |  | ||||||
|   // Pointers |  | ||||||
|    |  | ||||||
|   this.pointers = [new Pointer(new Position())]; |   this.pointers = [new Pointer(new Position())]; | ||||||
|    |    | ||||||
|   this.add_pointer = function(pointer) |   this.add_pointer = function(pointer) | ||||||
| @@ -75,16 +44,6 @@ function Brush() | |||||||
|     this.pointers.push(pointer); |     this.pointers.push(pointer); | ||||||
|   } |   } | ||||||
|    |    | ||||||
|   this.remove_pointer = function(target_position) |  | ||||||
|   { |  | ||||||
|     for (i = 0; i < this.pointers.length; i++) { |  | ||||||
|       if(this.pointers[i].offset.is_equal(target_position)){ |  | ||||||
|         this.pointers.splice(i, 1); |  | ||||||
|         break; |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
|    |  | ||||||
|   // Draw |   // Draw | ||||||
|    |    | ||||||
|   this.draw = function(e) |   this.draw = function(e) | ||||||
|   | |||||||
| @@ -2,17 +2,20 @@ function File() | |||||||
| { | { | ||||||
|   Module.call(this); |   Module.call(this); | ||||||
|    |    | ||||||
|  |   this.storage = []; | ||||||
|  |    | ||||||
|   this.active = function(cmd) |   this.active = function(cmd) | ||||||
|   { |   { | ||||||
|     ronin.overlay.clear(); |     ronin.overlay.clear(); | ||||||
|      |      | ||||||
|     if(!cmd.position()){ return; } |     if(!cmd.position()){ return; } | ||||||
|     if(!cmd.rect()){ return; } |     if(!cmd.rect()){ return; } | ||||||
|  |     if(!cmd.path() && !cmd.value()){ return; } | ||||||
|      |      | ||||||
|     var position = cmd.position() ? cmd.position() : new Position(); |     var position = cmd.position() ? cmd.position() : new Position(); | ||||||
|      |      | ||||||
|     base_image = new Image(); |     base_image = new Image(); | ||||||
|     base_image.src = cmd.path(); |     base_image.src = cmd.value() && this.storage[cmd.value()] ? this.storage[cmd.value()] : cmd.path(); | ||||||
|     base_image.onload = function(){ |     base_image.onload = function(){ | ||||||
|       position.normalize(cmd.rect()); |       position.normalize(cmd.rect()); | ||||||
|       context.drawImage(base_image, position.x, position.y, cmd.rect().width, cmd.rect().height); |       context.drawImage(base_image, position.x, position.y, cmd.rect().width, cmd.rect().height); | ||||||
| @@ -21,7 +24,7 @@ function File() | |||||||
|    |    | ||||||
|   this.passive = function(cmd) |   this.passive = function(cmd) | ||||||
|   { |   { | ||||||
|     if(!cmd.path()){ return; } |     if(!cmd.path() && !cmd.value()){ return; } | ||||||
|      |      | ||||||
|     var position = cmd.position() ? cmd.position() : new Position(); |     var position = cmd.position() ? cmd.position() : new Position(); | ||||||
|      |      | ||||||
| @@ -44,8 +47,13 @@ function File() | |||||||
|    |    | ||||||
|   this.save = function(cmd) |   this.save = function(cmd) | ||||||
|   { |   { | ||||||
|  |     if(cmd.value() > 0){ | ||||||
|  |       this.storage[cmd.value()] = canvas.toDataURL("image/png"); | ||||||
|  |     } | ||||||
|  |     else{ | ||||||
|       var d=canvas.toDataURL("image/png"); |       var d=canvas.toDataURL("image/png"); | ||||||
|       var w=window.open('about:blank','image from canvas'); |       var w=window.open('about:blank','image from canvas'); | ||||||
|       w.document.write("<title>"+(cmd.cmd_array[0] ? cmd.cmd_array[0] : "Untitled")+"</title><img src='"+d+"' alt='from canvas'/>"); |       w.document.write("<title>"+(cmd.cmd_array[0] ? cmd.cmd_array[0] : "Untitled")+"</title><img src='"+d+"' alt='from canvas'/>"); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  | } | ||||||
| @@ -1,16 +0,0 @@ | |||||||
| function History(element) |  | ||||||
| { |  | ||||||
|   Module.call(this); |  | ||||||
|    |  | ||||||
|   this.element = element; |  | ||||||
|    |  | ||||||
|   this.active = function(cmd) |  | ||||||
|   { |  | ||||||
|      |  | ||||||
|   } |  | ||||||
|    |  | ||||||
|   this.passive = function(cmd) |  | ||||||
|   { |  | ||||||
|      |  | ||||||
|   } |  | ||||||
| } |  | ||||||
		Reference in New Issue
	
	Block a user