Implemented themes
This commit is contained in:
		| @@ -17,7 +17,14 @@ function Controller() | ||||
|     console.log(`${mode}/${cat}/${label} <${accelerator}>`); | ||||
|   } | ||||
|  | ||||
|   this.set = function(mode) | ||||
|   this.add_role = function(mode,cat,label) | ||||
|   { | ||||
|     if(!this.menu[mode]){ this.menu[mode] = {}; } | ||||
|     if(!this.menu[mode][cat]){ this.menu[mode][cat] = {}; } | ||||
|     this.menu[mode][cat][label] = {role:label};     | ||||
|   } | ||||
|  | ||||
|   this.set = function(mode = "default") | ||||
|   { | ||||
|     this.mode = mode; | ||||
|     this.commit(); | ||||
| @@ -31,7 +38,12 @@ function Controller() | ||||
|       var submenu = []; | ||||
|       for(name in m[cat]){ | ||||
|         var option = m[cat][name]; | ||||
|         submenu.push({label:name,accelerator:option.accelerator,click:option.fn}) | ||||
|         if(option.role){ | ||||
|           submenu.push({role:option.role}) | ||||
|         } | ||||
|         else{ | ||||
|           submenu.push({label:name,accelerator:option.accelerator,click:option.fn})   | ||||
|         } | ||||
|       } | ||||
|       f.push({label:cat,submenu:submenu}); | ||||
|     } | ||||
| @@ -76,7 +88,7 @@ function Controller() | ||||
|     for(cat in menu){ | ||||
|       var options = menu[cat]; | ||||
|       for(id in options.submenu){ | ||||
|         var option = options.submenu[id]; | ||||
|         var option = options.submenu[id]; if(option.role){ continue; } | ||||
|         acc.basic = (option.accelerator.toLowerCase() == key.toLowerCase()) ? option.label.toUpperCase().replace("TOGGLE ","").substr(0,8).trim() : acc.basic; | ||||
|         acc.ctrl = (option.accelerator.toLowerCase() == ("CmdOrCtrl+"+key).toLowerCase()) ? option.label.toUpperCase().replace("TOGGLE ","").substr(0,8).trim() : acc.ctrl; | ||||
|       } | ||||
| @@ -97,7 +109,7 @@ function Controller() | ||||
|     {x:540, y:0,   width:60,  height:60, name:"9"}, | ||||
|     {x:600, y:0,   width:60,  height:60, name:"0"}, | ||||
|     {x:660, y:0,   width:60,  height:60, name:"-"}, | ||||
|     {x:720, y:0,   width:60,  height:60, name:"+"}, | ||||
|     {x:720, y:0,   width:60,  height:60, name:"plus"}, | ||||
|     {x:780, y:0,   width:120, height:60, name:"backspace"}, | ||||
|     {x:0,   y:60,  width:90,  height:60, name:"tab"}, | ||||
|     {x:90,  y:60,  width:60,  height:60, name:"q"}, | ||||
|   | ||||
| @@ -120,7 +120,6 @@ function Commander() | ||||
|  | ||||
|   this.activate = function() | ||||
|   { | ||||
|     ronin.cursor.update(); | ||||
|     ronin.commander.autocomplete(); | ||||
|     ronin.commander.show(); | ||||
|     setTimeout(()=>{ronin.commander.focus},100) | ||||
|   | ||||
| @@ -5,13 +5,11 @@ function Cursor(rune) | ||||
|   this.query = null; | ||||
|   this.mode = "vertex"; | ||||
|  | ||||
|   this.color = "#000000" | ||||
|   this.color_alt = "#ffffff" | ||||
|   this.size = 2; | ||||
|   this.pos = {x:0,y:0}; | ||||
|  | ||||
|   this.target = null; | ||||
|  | ||||
|    | ||||
|   this.mouse_pos = function(e) | ||||
|   { | ||||
|     var pos = {x:e.clientX,y:e.clientY}; | ||||
| @@ -30,25 +28,17 @@ function Cursor(rune) | ||||
|     e.preventDefault(); | ||||
|  | ||||
|     var pos = ronin.cursor.mouse_pos(e); | ||||
|     ronin.cursor.pos = pos; | ||||
|  | ||||
|     ronin.commander.blur(); | ||||
|  | ||||
|     // Color Pick | ||||
|     if(ronin.commander.input_el.value == "~"){ | ||||
|       ronin.brush.methods.pick.run({x:pos.x,y:pos.y}) | ||||
|       ronin.commander.input_el.value = ""; | ||||
|       ronin.commander.update(); | ||||
|       return; | ||||
|     } | ||||
|  | ||||
|     ronin.cursor.line.origin = {x:pos.x,y:pos.y}; | ||||
|     ronin.cursor.line.from = {x:pos.x,y:pos.y}; | ||||
|  | ||||
|     // Save original query | ||||
|     ronin.cursor.query = ronin.commander.input_el.value; | ||||
|  | ||||
|     if(ronin.commander.active_module()){ } | ||||
|     if(ronin.commander.active_module()){ /* DO NOTHING */ } | ||||
|     else if(e.shiftKey){ /* DO NOTHING */ } | ||||
|     else if(e.altKey && e.shiftKey){ ronin.brush.methods.pick.run(pos); } | ||||
|     else if(e.altKey){ ronin.brush.erase(ronin.cursor.line); } | ||||
|     else{ ronin.brush.stroke(ronin.cursor.line);   } | ||||
| @@ -69,13 +59,12 @@ function Cursor(rune) | ||||
|  | ||||
|     ronin.cursor.line.to = {x:pos.x,y:pos.y}; | ||||
|  | ||||
|     if(e.altKey && e.shiftKey){ ronin.brush.methods.pick.run(pos); } | ||||
|     if(ronin.commander.active_module()){ ronin.cursor.inject_query(); } | ||||
|     else if(e.altKey && e.shiftKey){ ronin.brush.methods.pick.run(pos); } | ||||
|     else if(e.shiftKey){ ronin.cursor.drag(ronin.cursor.line); } | ||||
|     else if(e.altKey){ ronin.brush.erase(ronin.cursor.line); } | ||||
|     else{ ronin.brush.stroke(ronin.cursor.line); } | ||||
|  | ||||
|     ronin.cursor.inject_query(); | ||||
|      | ||||
|     ronin.cursor.line.from = {x:pos.x,y:pos.y}; | ||||
|   } | ||||
|  | ||||
| @@ -84,7 +73,6 @@ function Cursor(rune) | ||||
|     e.preventDefault(); | ||||
|  | ||||
|     var pos = ronin.cursor.mouse_pos(e); | ||||
|     ronin.cursor.pos = pos; | ||||
|      | ||||
|     ronin.cursor.line.destination = {x:pos.x,y:pos.y}; | ||||
|  | ||||
| @@ -110,14 +98,6 @@ function Cursor(rune) | ||||
|     ronin.cursor.target.context().putImageData(data, offset.x * -2, offset.y * -2); | ||||
|   } | ||||
|  | ||||
|   this.swap_colors = function() | ||||
|   { | ||||
|     var c = this.color_alt | ||||
|     this.color_alt = this.color; | ||||
|     this.color = c; | ||||
|     ronin.commander.update(); | ||||
|   } | ||||
|  | ||||
|   this.swap_layer = function() | ||||
|   { | ||||
|     this.target = this.target.name == "above" ? ronin.layers.below : ronin.layers.above; | ||||
| @@ -195,9 +175,9 @@ function Cursor(rune) | ||||
|     } | ||||
|  | ||||
|     return ` | ||||
|     <t class='frame'>${ronin.frame.width}x${ronin.frame.height}</t> | ||||
|     <t class='frame'>${ronin.frame.width}X${ronin.frame.height} ${(ronin.frame.width/ronin.frame.height).toFixed(2)}:1</t> | ||||
|     <t class='target_${ronin.cursor.target.name}'></t><t class='size ${mode}'>${ronin.cursor.size}</t><t class='zoom'>${ronin.frame.zoom.scale}</t> | ||||
|     <icon class='brush'><icon class='primary' style='background:${ronin.cursor.color}'></icon><icon class='secondary' style='background:${ronin.cursor.color_alt}'></icon></icon>`; | ||||
|     ${ronin.brush.swatch.hint()}`; | ||||
|   } | ||||
|  | ||||
|   function distance_between(a,b) | ||||
|   | ||||
| @@ -11,7 +11,7 @@ function Keyboard() | ||||
|   { | ||||
|     ronin.keyboard.is_down[e.key] = true; | ||||
|  | ||||
|     if(e.key == "Enter"){ | ||||
|     if(ronin.commander.is_focused() && e.key == "Enter"){ | ||||
|       e.preventDefault(); | ||||
|       ronin.commander.validate(); | ||||
|     } | ||||
|   | ||||
							
								
								
									
										31
									
								
								sources/scripts/core/swatch.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								sources/scripts/core/swatch.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| function Swatch() | ||||
| { | ||||
|   this.index = 0; | ||||
|   this.colors = []; | ||||
|    | ||||
|   this.start = function() | ||||
|   { | ||||
|     this.update(); | ||||
|   } | ||||
|    | ||||
|   this.update = function() | ||||
|   { | ||||
|     this.colors = [ronin.theme.active.f_high,ronin.theme.active.f_med,ronin.theme.active.f_low]; | ||||
|   } | ||||
|  | ||||
|   this.swap = function() | ||||
|   { | ||||
|     this.index += 1; | ||||
|   } | ||||
|  | ||||
|   this.color = function(offset = 0) | ||||
|   { | ||||
|     return this.colors[(this.index + offset) % this.colors.length]; | ||||
|   } | ||||
|  | ||||
|   this.hint = function() | ||||
|   { | ||||
|     this.update(); | ||||
|     return `<svg width="20px" height="20px" xmlns="http://www.w3.org/2000/svg" baseProfile="full" version="1.1" id='swatch' style='background-color:${this.color(1)}'><circle cx='10' cy='10' r='${ronin.cursor.size * 0.75}' fill='${this.color()}'/></svg>`; | ||||
|   } | ||||
| } | ||||
| @@ -3,6 +3,7 @@ function Brush() | ||||
|   Module.call(this,"brush"); | ||||
|  | ||||
|   this.speed = 0; | ||||
|   this.swatch = new Swatch(); | ||||
|  | ||||
|   this.pointers = [ | ||||
|     new Pointer({offset:{x:0,y:0}}) | ||||
| @@ -92,11 +93,6 @@ function Pointer(options) | ||||
|     return ronin.brush.thickness(line); | ||||
|   } | ||||
|  | ||||
|   this.color = function(line) | ||||
|   { | ||||
|     return ronin.cursor.color; | ||||
|   } | ||||
|  | ||||
|   this.stroke = function(line,erase = false) | ||||
|   { | ||||
|     var ctx = ronin.cursor.target.context(); | ||||
| @@ -116,7 +112,7 @@ function Pointer(options) | ||||
|     ctx.lineTo((line.to.x * 2) + this.options.offset.x,(line.to.y * 2) + this.options.offset.y); | ||||
|     ctx.lineCap="round"; | ||||
|     ctx.lineWidth = this.thickness(line); | ||||
|     ctx.strokeStyle = ronin.cursor.color; | ||||
|     ctx.strokeStyle = ronin.brush.swatch.color(); | ||||
|     ctx.stroke(); | ||||
|     ctx.closePath(); | ||||
|   } | ||||
|   | ||||
| @@ -8,13 +8,12 @@ function Frame() | ||||
|   this.install = function() | ||||
|   { | ||||
|     ronin.el.appendChild(this.el); | ||||
|     this.el.style.backgroundColor = this.background; | ||||
|   } | ||||
|  | ||||
|   this.methods.new = new Method("new","WxH","New Canvas",function(q){ | ||||
|     ronin.layers.above.clear(); | ||||
|     ronin.layers.below.clear(); | ||||
|     ronin.frame.resize_to({width:930,height:540}); | ||||
|     ronin.frame.resize_to({width:900,height:540}); | ||||
|   }); | ||||
|  | ||||
|   this.width = 400; | ||||
|   | ||||
| @@ -3,6 +3,7 @@ function Ronin() | ||||
|   this.el = document.createElement('yu'); | ||||
|   this.el.id = "ronin"; | ||||
|  | ||||
|   this.theme = new Theme(); | ||||
|   this.controller = new Controller(); | ||||
|  | ||||
|   this.keyboard = new Keyboard(); | ||||
| @@ -41,6 +42,9 @@ function Ronin() | ||||
|    | ||||
|   this.install = function() | ||||
|   { | ||||
|     this.theme.start(); | ||||
|     this.brush.swatch.start(); | ||||
|  | ||||
|     document.body.appendChild(this.el); | ||||
|  | ||||
|     this.frame.width = window.innerWidth; | ||||
| @@ -80,13 +84,21 @@ function Ronin() | ||||
|     this.controller.add("default","File","Save Images(PNGs)",() => { ronin.io.methods.save.run(); },"CmdOrCtrl+S"); | ||||
|     this.controller.add("default","File","Export Image(JPG)",() => { ronin.io.methods.export.run(); },"CmdOrCtrl+E"); | ||||
|  | ||||
|     this.controller.add_role("default","Edit","undo"); | ||||
|     this.controller.add_role("default","Edit","redo"); | ||||
|     this.controller.add_role("default","Edit","cut"); | ||||
|     this.controller.add_role("default","Edit","copy"); | ||||
|     this.controller.add_role("default","Edit","paste"); | ||||
|     this.controller.add_role("default","Edit","delete"); | ||||
|     this.controller.add_role("default","Edit","selectall"); | ||||
|      | ||||
|     this.controller.add("default","Layers","Above Layer",() => { ronin.cursor.select_layer(ronin.layers.above); },"c"); | ||||
|     this.controller.add("default","Layers","Below Layer",() => { ronin.cursor.select_layer(ronin.layers.below); },"z"); | ||||
|     this.controller.add("default","Layers","Toggle Layer",() => { ronin.cursor.swap_layer(); },"x"); | ||||
|     this.controller.add("default","Layers","Toggle Layer",() => { ronin.cursor.brush.swatch.swap(); },"x"); | ||||
|  | ||||
|     this.controller.add("default","Brush","Inc Size",() => { ronin.brush.mod_size(1); },"]"); | ||||
|     this.controller.add("default","Brush","Dec Size",() => { ronin.brush.mod_size(-1); },"["); | ||||
|     this.controller.add("default","Brush","Toggle Color",() => { ronin.cursor.swap_colors(); },"x"); | ||||
|     this.controller.add("default","Brush","Toggle Color",() => { ronin.brush.swatch.swap(); },"x"); | ||||
|  | ||||
|     this.controller.add("default","Commander","Show",() => { ronin.commander.activate(); },"`"); | ||||
|     this.controller.add("default","Commander","Hide",() => { ronin.commander.deactivate(); },"Escape"); | ||||
| @@ -115,11 +127,16 @@ function Ronin() | ||||
|     this.guide.update(); | ||||
|     this.commander.update(); | ||||
|  | ||||
|     this.frame.resize_to({width:930,height:540}); | ||||
|     this.frame.resize_to({width:900,height:540}); | ||||
|  | ||||
|     this.load(); | ||||
|   } | ||||
|  | ||||
|   this.reset = function() | ||||
|   { | ||||
|     this.theme.reset(); | ||||
|   } | ||||
|  | ||||
|   this.load = function(content = this.default()) | ||||
|   { | ||||
|  | ||||
|   | ||||
							
								
								
									
										80
									
								
								sources/scripts/theme.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										80
									
								
								sources/scripts/theme.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,80 @@ | ||||
| function Theme() | ||||
| { | ||||
|   var app = this; | ||||
|  | ||||
|   this.el = document.createElement("style"); | ||||
|   this.el.type = 'text/css'; | ||||
|   this.default = { background: "#222", f_high: "#fff", f_med: "#777", f_low: "#444", f_inv: "#000", b_high: "#000", b_med: "#affec7", b_low: "#000", b_inv: "#affec7" } | ||||
|   this.active = this.default; | ||||
|  | ||||
|   this.start = function() | ||||
|   { | ||||
|     this.load(localStorage.theme ? localStorage.theme : this.default); | ||||
|     window.addEventListener('dragover',this.drag_enter); | ||||
|     window.addEventListener('drop', this.drag); | ||||
|     document.head.appendChild(this.el) | ||||
|   } | ||||
|  | ||||
|   this.load = function(t) | ||||
|   { | ||||
|     var theme = is_json(t) ? JSON.parse(t) : t; | ||||
|  | ||||
|     if(!theme.background){ return; } | ||||
|  | ||||
|     var css = ` | ||||
|     :root { | ||||
|       --background: ${theme.background}; | ||||
|       --f_high: ${theme.f_high}; | ||||
|       --f_med: ${theme.f_med}; | ||||
|       --f_low: ${theme.f_low}; | ||||
|       --f_inv: ${theme.f_inv}; | ||||
|       --b_high: ${theme.b_high}; | ||||
|       --b_med: ${theme.b_med}; | ||||
|       --b_low: ${theme.b_low}; | ||||
|       --b_inv: ${theme.b_inv}; | ||||
|     }`; | ||||
|  | ||||
|     this.active = theme; | ||||
|     this.el.textContent = css; | ||||
|     localStorage.setItem("theme", JSON.stringify(theme)); | ||||
|   } | ||||
|  | ||||
|   this.reset = function() | ||||
|   { | ||||
|     this.load(this.default); | ||||
|   } | ||||
|  | ||||
|   this.drag_enter = function(e) | ||||
|   { | ||||
|     e.stopPropagation(); | ||||
|     e.preventDefault(); | ||||
|     e.dataTransfer.dropEffect = 'copy'; | ||||
|   } | ||||
|  | ||||
|   this.drag = function(e) | ||||
|   { | ||||
|     e.preventDefault(); | ||||
|     e.stopPropagation(); | ||||
|  | ||||
|     var file = e.dataTransfer.files[0]; | ||||
|  | ||||
|     if(!file.name || !file.name.indexOf(".thm") < 0){ console.log("Theme","Not a theme"); return; } | ||||
|  | ||||
|     var reader = new FileReader(); | ||||
|     reader.onload = function(e){ | ||||
|       app.load(e.target.result); | ||||
|     }; | ||||
|     reader.readAsText(file); | ||||
|   } | ||||
|  | ||||
|   function is_json(text) | ||||
|   { | ||||
|     try{ | ||||
|       JSON.parse(text); | ||||
|       return true; | ||||
|     } | ||||
|     catch (error){ | ||||
|       return false; | ||||
|     } | ||||
|   } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user