Inline fixes.
This commit is contained in:
		| @@ -1,7 +1,7 @@ | ||||
| function drawBoxes(inputPixelArray, widthPixels, heightPixels) { | ||||
|   | ||||
|     // Get a reference to the canvas element | ||||
|     var canvas = document.getElementById('pixelCanvas'); | ||||
|     var canvas = gId('pixelCanvas'); | ||||
|  | ||||
|     // Get the canvas context | ||||
|     var ctx = canvas.getContext('2d'); | ||||
| @@ -60,7 +60,7 @@ function drawBoxes(inputPixelArray, widthPixels, heightPixels) { | ||||
| } | ||||
|  | ||||
| function drawBackground() { | ||||
|   const grid = document.createElement("div"); | ||||
|   const grid = cE("div"); | ||||
|   grid.id = "grid"; | ||||
|   grid.classList.add("grid-class"); | ||||
|   grid.style.cssText = ""; | ||||
| @@ -69,23 +69,23 @@ function drawBackground() { | ||||
|   const boxCount = Math.ceil(window.innerWidth / boxSize) * Math.ceil(window.innerHeight / boxSize);; | ||||
|  | ||||
|   for (let i = 0; i < boxCount; i++) { | ||||
|   const box = document.createElement("div"); | ||||
|   box.classList.add("box"); | ||||
|   box.style.backgroundColor = getRandomColor(); | ||||
|   grid.appendChild(box); | ||||
|     const box = cE("div"); | ||||
|     box.classList.add("box"); | ||||
|     box.style.backgroundColor = getRandomColor(); | ||||
|     grid.appendChild(box); | ||||
|   } | ||||
|   grid.style.zIndex = -1; | ||||
|   document.body.appendChild(grid); | ||||
|   d.body.appendChild(grid); | ||||
| } | ||||
|  | ||||
| function getRandomColor() { | ||||
|   const letters = "0123456789ABCDEF"; | ||||
|   let color = "rgba("; | ||||
|   for (let i = 0; i < 3; i++) { | ||||
|   color += Math.floor(Math.random() * 256) + ","; | ||||
|     color += Math.floor(Math.random() * 256) + ","; | ||||
|   } | ||||
|   color += "0.05)"; | ||||
|   return color; | ||||
| } | ||||
|  | ||||
|   window.drawBackground = drawBackground; | ||||
| window.drawBackground = drawBackground; | ||||
|   | ||||
| @@ -1,30 +1,30 @@ | ||||
| function getPixelRGBValues(base64Image) { | ||||
|   httpArray = []; | ||||
|   fileJSON = JSONledStringStart + document.getElementById('brightnessNumber').value + JSONledStringMid1 + document.getElementById('targetSegment').value + JSONledStringMid2; | ||||
|   fileJSON = JSONledStringStart + gId('brightnessNumber').value + JSONledStringMid1 + gId('targetSegment').value + JSONledStringMid2; | ||||
|  | ||||
|   //const copyJSONledbutton = document.getElementById('copyJSONledbutton'); | ||||
|   const JSONled = document.getElementById('JSONled'); | ||||
|   const maxNoOfColorsInCommandSting = document.getElementById('colorLimitNumber').value; | ||||
|   //const copyJSONledbutton = gId('copyJSONledbutton'); | ||||
|   const JSONled = gId('JSONled'); | ||||
|   const maxNoOfColorsInCommandSting = gId('colorLimitNumber').value; | ||||
|    | ||||
|   let hybridAddressing = false; | ||||
|   let selectedIndex = -1; | ||||
|  | ||||
|   let selector = document.getElementById("formatSelector"); | ||||
|   let selector = gId("formatSelector"); | ||||
|   selectedIndex = selector.selectedIndex; | ||||
|   const formatSelection = selector.options[selectedIndex].value; | ||||
|  | ||||
|   selector = document.getElementById("ledSetupSelector"); | ||||
|   selector = gId("ledSetupSelector"); | ||||
|   selectedIndex = selector.selectedIndex; | ||||
|   const ledSetupSelection = selector.options[selectedIndex].value; | ||||
|  | ||||
|   selector = document.getElementById("colorFormatSelector"); | ||||
|   selector = gId("colorFormatSelector"); | ||||
|   selectedIndex = selector.selectedIndex; | ||||
|   let hexValueCheck = true; | ||||
|   if (selector.options[selectedIndex].value == 'dec'){ | ||||
|     hexValueCheck = false | ||||
|   } | ||||
|  | ||||
|   selector = document.getElementById("addressingSelector"); | ||||
|   selector = gId("addressingSelector"); | ||||
|   selectedIndex = selector.selectedIndex; | ||||
|   let segmentValueCheck = true; //If Range or Hybrid | ||||
|   if (selector.options[selectedIndex].value == 'single'){ | ||||
| @@ -50,7 +50,7 @@ function getPixelRGBValues(base64Image) { | ||||
|   let imageInfo = ''; | ||||
|    | ||||
|   // Create an off-screen canvas | ||||
|   var canvas = document.createElement('canvas'); | ||||
|   var canvas = cE('canvas'); | ||||
|   var context = canvas.getContext('2d'); | ||||
|  | ||||
|   // Create an image element and set its src to the base64 image | ||||
| @@ -60,10 +60,10 @@ function getPixelRGBValues(base64Image) { | ||||
|   // Wait for the image to load before drawing it onto the canvas | ||||
|   image.onload = function() { | ||||
|      | ||||
|     let scalePath = document.getElementById("scalePath"); | ||||
|     let scalePath = gId("scaleDiv").children[1].children[0]; | ||||
|     let color = scalePath.getAttribute("fill"); | ||||
|     let sizeX = document.getElementById("sizeX").value; | ||||
|     let sizeY = document.getElementById("sizeY").value; | ||||
|     let sizeX = gId("sizeX").value; | ||||
|     let sizeY = gId("sizeY").value; | ||||
|  | ||||
|     if (color != accentColor || sizeX < 1 || sizeY < 1){ | ||||
|       //image will not be rezised Set desitred size to original size | ||||
| @@ -258,10 +258,10 @@ function getPixelRGBValues(base64Image) { | ||||
|  | ||||
|     //For evry commandString in the  array | ||||
|     for (let i = 0; i < commandArray.length; i++) { | ||||
|       let thisJSONledString = JSONledStringStart + document.getElementById('brightnessNumber').value + JSONledStringMid1 + document.getElementById('targetSegment').value + JSONledStringMid2 + commandArray[i] + JSONledStringEnd; | ||||
|       let thisJSONledString = JSONledStringStart + gId('brightnessNumber').value + JSONledStringMid1 + gId('targetSegment').value + JSONledStringMid2 + commandArray[i] + JSONledStringEnd; | ||||
|       httpArray.push(thisJSONledString); | ||||
|  | ||||
|       let thiscurlString = curlStart + document.getElementById('curlUrl').value + curlMid1 + thisJSONledString + curlEnd; | ||||
|       let thiscurlString = curlStart + gId('curlUrl').value + curlMid1 + thisJSONledString + curlEnd; | ||||
|  | ||||
|       //Aggregated Strings That should be returned to the user | ||||
|       if (i > 0){ | ||||
| @@ -273,7 +273,7 @@ function getPixelRGBValues(base64Image) { | ||||
|     } | ||||
|  | ||||
|      | ||||
|     haString = haStart + document.getElementById('haID').value + haMid1 + document.getElementById('haName').value + haMid2 + document.getElementById('haUID').value + haMid3 +curlString + haMid3 + document.getElementById('curlUrl').value + haEnd; | ||||
|     haString = haStart + gId('haID').value + haMid1 + gId('haName').value + haMid2 + gId('haUID').value + haMid3 +curlString + haMid3 + gId('curlUrl').value + haEnd; | ||||
|  | ||||
|     if (formatSelection == 'wled'){ | ||||
|       JSONled.value = JSONledString; | ||||
| @@ -287,8 +287,8 @@ function getPixelRGBValues(base64Image) { | ||||
|      | ||||
|     fileJSON = fileJSON + JSONledStringEnd; | ||||
|  | ||||
|     let infoDiv = document.getElementById('image-info'); | ||||
|     let canvasDiv = document.getElementById('image-info'); | ||||
|     let infoDiv = gId('image-info'); | ||||
|     let canvasDiv = gId('image-info'); | ||||
|     if (hasTransparency){ | ||||
|       imageInfo = imageInfo + '<p><b>WARNING!</b> Transparency info detected in image. Transparency (alpha) has been ignored. To ensure you get the result you desire, use only solid colors in your image.</p>' | ||||
|     } | ||||
|   | ||||
| @@ -1,10 +1,10 @@ | ||||
|  | ||||
| .box { | ||||
|   border: 2px solid white; | ||||
|   border: 2px solid #fff; | ||||
| } | ||||
| body { | ||||
|   font-family: 'Arcade', Arial, sans-serif; | ||||
|   background-color: #151515; | ||||
|   background-color: #111; | ||||
| } | ||||
|  | ||||
| .top-part { | ||||
| @@ -19,7 +19,7 @@ body { | ||||
| } | ||||
| h1 { | ||||
|   font-size: 2.3em; | ||||
|   color: rgb(126, 76, 128); | ||||
|   color: #ddd; | ||||
|   margin: 1px 0; | ||||
|   font-family: 'Arcade', Arial, sans-serif; | ||||
|   line-height: 0.5; | ||||
| @@ -27,7 +27,7 @@ h1 { | ||||
| } | ||||
| h2 { | ||||
|   font-size: 1.1em; | ||||
|   color: rgba(126, 76, 128, 0.61); | ||||
|   color: rgba(221, 221, 221, 0.61); | ||||
|   margin: 1px 0; | ||||
|   font-family: 'Arcade', Arial, sans-serif; | ||||
|   line-height: 0.5; | ||||
| @@ -35,7 +35,7 @@ h2 { | ||||
| } | ||||
| h3 { | ||||
|   font-size: 0.7em; | ||||
|   color: rgba(126, 76, 128, 0.61); | ||||
|   color: rgba(221, 221, 221, 0.61); | ||||
|   margin: 1px 0; | ||||
|   font-family: 'Arcade', Arial, sans-serif; | ||||
|   line-height: 1.4; | ||||
| @@ -46,8 +46,8 @@ h3 { | ||||
| } | ||||
|  | ||||
| p { | ||||
|   font-size: 1.2em; | ||||
|   color: rgb(119, 119, 119); | ||||
|   font-size: 1em; | ||||
|   color: #777; | ||||
|   line-height: 1.5; | ||||
|   font-family: 'Arcade', Arial, sans-serif; | ||||
| } | ||||
| @@ -69,13 +69,12 @@ p { | ||||
| #drop-zone { | ||||
|   display: block; | ||||
|   width: 100%-40px; | ||||
|   border: 3px dashed #7E4C80; | ||||
|   border: 3px dashed #ddd; | ||||
|   border-radius: 0px; | ||||
|   text-align: center; | ||||
|   padding: 20px; | ||||
|   margin: 0px; | ||||
|   cursor: pointer; | ||||
|    | ||||
|   font-family: 'Arcade', Arial, sans-serif; | ||||
|   font-size: 15px; | ||||
|   color: #777; | ||||
| @@ -86,37 +85,55 @@ p { | ||||
| } | ||||
|  | ||||
| * select { | ||||
|   background-color: #333333; | ||||
|   color: #C0C0C0; | ||||
|   border: 1px solid #C0C0C0; | ||||
|   background-color: #222; | ||||
|   color: #ddd; | ||||
|   border: 1px solid #333; | ||||
|   margin-top: 0.5em; | ||||
|   margin-bottom: 0.5em; | ||||
|   padding: 0em; | ||||
|   padding: 0 8px; | ||||
|   width: 100%; | ||||
|   height: 27px; | ||||
|   height: 32px; | ||||
|   font-size: 15px; | ||||
|   color: rgb(119, 119, 119); | ||||
|   border-radius: 0; | ||||
|   border-radius: 14px; | ||||
| } | ||||
|  | ||||
| * input[type=range] { | ||||
|   -webkit-appearance:none; | ||||
|   flex-grow: 1; | ||||
|   border-radius: 0px; | ||||
|   background: linear-gradient(to right, #333333 0%, #333333 100%); | ||||
|   color: #C0C0C0; | ||||
|   border: 1px solid #C0C0C0;  | ||||
|   margin-top: 0.5em;  | ||||
|   margin-left: 0em;      | ||||
| 	-webkit-appearance: none; | ||||
| 	width: 250px; | ||||
| 	padding: 0; | ||||
| 	margin: 0 8px 0 0; | ||||
| 	background-color: transparent; | ||||
| 	cursor: pointer; | ||||
|   background: linear-gradient(to right, #bbb 50%, #333 50%); | ||||
| } | ||||
|  | ||||
| input[type="range"]::-webkit-slider-thumb{ | ||||
|   -webkit-appearance:none; | ||||
|   width: 25px; | ||||
|   height:25px; | ||||
|   background:#7E4C80; | ||||
|   position:relative; | ||||
|   z-index:3; | ||||
| input[type=range]:focus { | ||||
| 	outline: none; | ||||
| } | ||||
| input[type=range]::-webkit-slider-runnable-track { | ||||
| 	height: 30px; | ||||
| 	cursor: pointer; | ||||
| 	background: transparent; | ||||
| } | ||||
| input[type=range]::-webkit-slider-thumb { | ||||
| 	height: 16px; | ||||
| 	width: 16px; | ||||
| 	border-radius: 50%; | ||||
| 	background: #fff; | ||||
| 	cursor: pointer; | ||||
| 	-webkit-appearance: none; | ||||
| 	margin-top: 7px; | ||||
| } | ||||
| input[type=range]::-moz-range-track { | ||||
| 	height: 30px; | ||||
| 	background-color: rgba(0, 0, 0, 0); | ||||
| } | ||||
| input[type=range]::-moz-range-thumb { | ||||
| 	border: 0px solid rgba(0, 0, 0, 0); | ||||
| 	height: 16px; | ||||
| 	width: 16px; | ||||
| 	border-radius: 50%; | ||||
| 	background: #fff; | ||||
| } | ||||
|  | ||||
| .rangeNumber{ | ||||
| @@ -125,8 +142,8 @@ input[type="range"]::-webkit-slider-thumb{ | ||||
| } | ||||
|  | ||||
| .fullTextField[type=text] { | ||||
|   background-color: #333333; | ||||
|   border: 1px solid #C0C0C0; | ||||
|   background-color: #222; | ||||
|   border: 1px solid #333; | ||||
|   padding-inline-start: 5px; | ||||
|   margin-top: 10px; | ||||
|   width: 100%; | ||||
| @@ -134,29 +151,30 @@ input[type="range"]::-webkit-slider-thumb{ | ||||
|   border-radius: 0px; | ||||
|   font-family: 'Arcade', Arial, sans-serif; | ||||
|   font-size: 15px; | ||||
|   color: rgb(119, 119, 119); | ||||
|   color: #ddd; | ||||
|   border-radius: 7px; | ||||
| } | ||||
|  | ||||
| * input[type=submit] { | ||||
|   background-color: #333333; | ||||
|   border: 1px solid #C0C0C0; | ||||
|   background-color: #222; | ||||
|   border: 1px solid #333; | ||||
|   padding: 0.5em; | ||||
|   width: 100%; | ||||
|   border-radius: 0px; | ||||
|   border-radius: 24px; | ||||
|   font-family: 'Arcade', Arial, sans-serif; | ||||
|   font-size: 1.3em; | ||||
|   color: rgb(119, 119, 119); | ||||
|   color: #ddd; | ||||
| } | ||||
|  | ||||
| * button { | ||||
|   background-color: #333333; | ||||
|   border: 1px solid #C0C0C0; | ||||
|   background-color: #222; | ||||
|   border: 1px solid #333; | ||||
|   padding-inline: 5px; | ||||
|   width: 100%; | ||||
|   border-radius: 0px; | ||||
|   border-radius: 24px; | ||||
|   font-family: 'Arcade', Arial, sans-serif; | ||||
|   font-size: 1em; | ||||
|   color: rgb(119, 119, 119); | ||||
|   color: #ddd; | ||||
|   display: flex; | ||||
|   align-items: center; | ||||
|   justify-content: center; | ||||
| @@ -167,14 +185,14 @@ textarea { | ||||
|   grid-row: 1 / 2; | ||||
|   width: 100%; | ||||
|   height: 200px; | ||||
|   background-color: #333333; | ||||
|   border: 1px solid #C0C0C0; | ||||
|    | ||||
|   color: #777; | ||||
|   background-color: #222; | ||||
|   border: 1px solid #333; | ||||
|   color: #ddd; | ||||
| } | ||||
| .hide { | ||||
|     display: none; | ||||
| } | ||||
| /* | ||||
| .grids-class{ | ||||
|   position: fixed; | ||||
|   top: 0; | ||||
| @@ -186,18 +204,20 @@ textarea { | ||||
|   grid-template-rows: repeat(auto-fill, 20px); | ||||
|   grid-gap: 0px; | ||||
| } | ||||
| */ | ||||
| .svg-icon { | ||||
|   vertical-align: middle; | ||||
| } | ||||
| /* | ||||
| .buttondiv-class { | ||||
|   flex: 1; | ||||
|   display: inline-block; | ||||
| } | ||||
|  | ||||
| .buttondivmid-class { | ||||
|   width: 10px; | ||||
|   display: inline-block; | ||||
| } | ||||
| */ | ||||
| #image-container { | ||||
|   display: grid; | ||||
|   grid-template-rows: 1fr 1fr; | ||||
| @@ -231,36 +251,36 @@ textarea { | ||||
| } | ||||
| .sizeInputFields{ | ||||
|   width: 50px; | ||||
|   background-color: #333333; | ||||
|   border: 1px solid #C0C0C0; | ||||
|   background-color: #222; | ||||
|   border: 1px solid #333; | ||||
|   padding-inline-start: 5px; | ||||
|   margin-top: -5px; | ||||
|   height: 24px; | ||||
|   border-radius: 0px; | ||||
|   border-radius: 7px; | ||||
|   font-family: 'Arcade', Arial, sans-serif; | ||||
|   font-size: 15px; | ||||
|   color: rgb(119, 119, 119); | ||||
|   color: #ddd; | ||||
| } | ||||
| a:link { | ||||
|   color: rgba(126, 76, 128, 0.61); | ||||
|   color: rgba(221, 221, 221, 0.61); | ||||
|   background-color: transparent; | ||||
|   text-decoration: none; | ||||
| } | ||||
|  | ||||
| a:visited { | ||||
|   color: rgba(126, 76, 128, 0.61); | ||||
|   color: rgba(221, 221, 221, 0.61); | ||||
|   background-color: transparent; | ||||
|   text-decoration: none; | ||||
| } | ||||
|  | ||||
| a:hover { | ||||
|   color: rgb(126, 76, 128); | ||||
|   color: #ddd; | ||||
|   background-color: transparent; | ||||
|   text-decoration: none; | ||||
| } | ||||
|  | ||||
| a:active { | ||||
|   color: rgba(126, 76, 128, 0.61); | ||||
|   color: rgba(221, 221, 221, 0.61); | ||||
|   background-color: transparent; | ||||
|   text-decoration: none; | ||||
| } | ||||
| @@ -7,22 +7,22 @@ | ||||
|     <title>WLED Pixel Art Converter</title> | ||||
|     <link rel="stylesheet" href="pixart.css"> | ||||
|     <link rel="shortcut icon" href="favicon-16x16.png"> | ||||
|     <script type="text/javascript"> | ||||
|       var d = document; | ||||
|       function gId(e) {return d.getElementById(e);} | ||||
|       function cE(e) {return d.createElement(e);} | ||||
|     </script> | ||||
|   </head> | ||||
|   <body> | ||||
|     <body> | ||||
|       <div class="top-part" > | ||||
|         <div style="display: flex; justify-content: center;"> | ||||
|           <h1 style="display: flex; align-items: center;"> | ||||
|             <svg style="width:36px;height:36px" id="logomatrix" viewBox="0 0 24 24"> | ||||
|               <path fill="#7e4c80" d="M6,5 a2,2 0 1,0 4,0 a2,2 0 1,0 -4,0" id="sc1"/> | ||||
|               <path fill="#7e4c80" d="M12,5 a2,2 0 1,0 4,0 a2,2 0 1,0 -4,0" id="sc2"/> | ||||
|               <path fill="#7e4c80" d="M18,5 a2,2 0 1,0 4,0 a2,2 0 1,0 -4,0" id="sc3"/> | ||||
|               <path fill="#7e4c80" d="M6,11 a2,2 0 1,0 4,0 a2,2 0 1,0 -4,0" id="sc4"/> | ||||
|               <path fill="#7e4c80" d="M12,11 a2,2 0 1,0 4,0 a2,2 0 1,0 -4,0" id="sc5"/> | ||||
|               <path fill="#7e4c80" d="M18,11 a2,2 0 1,0 4,0 a2,2 0 1,0 -4,0" id="sc6"/> | ||||
|               <path fill="#7e4c80" d="M6,17 a2,2 0 1,0 4,0 a2,2 0 1,0 -4,0" id="sc7"/> | ||||
|               <path fill="#7e4c80" d="M12,17 a2,2 0 1,0 4,0 a2,2 0 1,0 -4,0" id="sc8"/> | ||||
|               <path fill="#7e4c80" d="M18,17 a2,2 0 1,0 4,0 a2,2 0 1,0 -4,0" id="sc9"/> | ||||
|             <svg style="width:36px;height:36px;margin-right:6px;" viewBox="0 0 32 32"> | ||||
|               <rect style="fill:#003FFF" x="6" y="22" width="8" height="4"/> | ||||
|               <rect style="fill:#003FFF" x="14" y="14" width="4" height="8"/> | ||||
|               <rect style="fill:#003FFF" x="18" y="10" width="4" height="8"/> | ||||
|               <rect style="fill:#003FFF" x="22" y="6" width="8" height="4"/> | ||||
|             </svg> | ||||
|             WLED Pixel Art Converter | ||||
|           </h1> | ||||
| @@ -82,8 +82,8 @@ | ||||
|                 <label for="brightnessNumber">Brightness:</label> | ||||
|               </td> | ||||
|               <td style="vertical-align: middle; display: flex; align-items: center;"> | ||||
|                 <input type="range" id="brightnessNumber" min="1" max="255" value="255"> | ||||
|                 <span id="brightnessValue">255</span> | ||||
|                 <input type="range" id="brightnessNumber" min="1" max="255" value="128"> | ||||
|                 <span id="brightnessValue">128</span> | ||||
|               </td> | ||||
|             </tr> | ||||
|             <tr> | ||||
| @@ -141,12 +141,11 @@ | ||||
|             <tr> | ||||
|               <td style="vertical-align: middle;"> | ||||
|                 <div id="scaleDiv"> | ||||
|                   <svg id="scaleToggle" style="width:36px;height:36px" viewBox="0 0 24 24" onclick="switchScale()"> | ||||
|                     <path id="scaleTogglePath" fill="currentColor" d="M17,7H7A5,5 0 0,0 2,12A5,5 0 0,0 7,17H17A5,5 0 0,0 22,12A5,5 0 0,0 17,7M7,15A3,3 0 0,1 4,12A3,3 0 0,1 7,9A3,3 0 0,1 10,12A3,3 0 0,1 7,15Z" /> | ||||
|                   <svg style="width:36px;height:36px" viewBox="0 0 24 24" onclick="switchScale()"> | ||||
|                     <path fill="currentColor" d="M17,7H7A5,5 0 0,0 2,12A5,5 0 0,0 7,17H17A5,5 0 0,0 22,12A5,5 0 0,0 17,7M7,15A3,3 0 0,1 4,12A3,3 0 0,1 7,9A3,3 0 0,1 10,12A3,3 0 0,1 7,15Z" /> | ||||
|                   </svg> | ||||
|                       | ||||
|                   <svg id="scaleSvg" style="width:36px;height:36px" viewBox="0 0 24 24" onclick="switchScale()"> | ||||
|                     <path id="scalePath" fill="currentColor" d="M21,15H23V17H21V15M21,11H23V13H21V11M23,19H21V21C22,21 23,20 23,19M13,3H15V5H13V3M21,7H23V9H21V7M21,3V5H23C23,4 22,3 21,3M1,7H3V9H1V7M17,3H19V5H17V3M17,19H19V21H17V19M3,3C2,3 1,4 1,5H3V3M9,3H11V5H9V3M5,3H7V5H5V3M1,11V19A2,2 0 0,0 3,21H15V11H1M3,19L5.5,15.79L7.29,17.94L9.79,14.72L13,19H3Z" /> | ||||
|                   <svg style="width:36px;height:36px;margin-left:20px;" viewBox="0 0 24 24" onclick="switchScale()"> | ||||
|                     <path fill="currentColor" d="M21,15H23V17H21V15M21,11H23V13H21V11M23,19H21V21C22,21 23,20 23,19M13,3H15V5H13V3M21,7H23V9H21V7M21,3V5H23C23,4 22,3 21,3M1,7H3V9H1V7M17,3H19V5H17V3M17,19H19V21H17V19M3,3C2,3 1,4 1,5H3V3M9,3H11V5H9V3M5,3H7V5H5V3M1,11V19A2,2 0 0,0 3,21H15V11H1M3,19L5.5,15.79L7.29,17.94L9.79,14.72L13,19H3Z" /> | ||||
|                   </svg> | ||||
|                 </div> | ||||
|               </td> | ||||
| @@ -173,8 +172,7 @@ | ||||
|         <p> | ||||
|           <input type="file" id="file-picker" style="display: none;"> | ||||
|           <div style="width: 100%; text-align: center;"> | ||||
|             <img id="preview" style="display: block; margin: 0 auto;"> | ||||
|             <img id="newimage" style="display: block; margin: 0 auto;"><br> | ||||
|             <img id="preview" style="display: none; margin: 0 auto;"> | ||||
|           </div> | ||||
|            | ||||
|           <div id="submitConvertDiv" style="display: none;"> | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| //Start up code | ||||
| document.getElementById('curlUrl').value = location.host; | ||||
| gId('curlUrl').value = location.host; | ||||
|  | ||||
| let devMode = false; | ||||
| const urlParams = new URLSearchParams(window.location.search); | ||||
| @@ -9,15 +9,15 @@ if(urlParams.has('dev')){ | ||||
| if(devMode){ | ||||
|   console.log('Developer mode active. Experimental and unstable functions active.') | ||||
| } else{ | ||||
| console.log('Developer mode inactive. Append "?dev" to the URL.') | ||||
|   console.log('Developer mode inactive. Append "?dev" to the URL.') | ||||
| } | ||||
|  | ||||
| if(devMode){ | ||||
|   document.getElementById("fileJSONledbutton").style.display = 'buttonclass' | ||||
|   document.getElementById("gap2").style.display = 'gap' | ||||
|   gId("fileJSONledbutton").style.display = 'buttonclass' | ||||
|   gId("gap2").style.display = 'gap' | ||||
| } else { | ||||
|   document.getElementById("fileJSONledbutton").style.display = 'none' | ||||
|   document.getElementById("gap2").style.display = 'none' | ||||
|   gId("fileJSONledbutton").style.display = 'none' | ||||
|   gId("gap2").style.display = 'none' | ||||
| } | ||||
|  | ||||
|  | ||||
| @@ -28,45 +28,41 @@ let fileJSON = ''; | ||||
| //On submit button pressed ======================= | ||||
|  | ||||
|  | ||||
| document.getElementById("convertbutton").addEventListener("click", function() { | ||||
|    | ||||
|   let base64Image = document.getElementById('preview').src; | ||||
| gId("convertbutton").addEventListener("click", () => { | ||||
|   let base64Image = gId('preview').src; | ||||
|   if (isValidBase64Gif(base64Image)) { | ||||
|     document.getElementById('image').src = base64Image; | ||||
|     gId('image').src = base64Image; | ||||
|     getPixelRGBValues(base64Image); | ||||
|     document.getElementById('image-container').style.display = "block" | ||||
|     document.getElementById("button-container").style.display = ""; | ||||
|  | ||||
|   }  | ||||
|   else { | ||||
|     let infoDiv = document.getElementById('image-info'); | ||||
|     let imageInfo = '<p><b>WARNING!</b> File does not appear to be a valid image</p>' | ||||
|     gId('image-container').style.display = "block"; | ||||
|     gId("button-container").style.display = ""; | ||||
|   } else { | ||||
|     let infoDiv = gId('image-info'); | ||||
|     let imageInfo = '<p><b>WARNING!</b> File does not appear to be a valid image</p>'; | ||||
|     infoDiv.innerHTML = imageInfo; | ||||
|     infoDiv.style.display = "block" | ||||
|     document.getElementById('image-container').style.display = "none"; | ||||
|     document.getElementById('JSONled').value = ''; | ||||
|     console.log("The string '" + base64Image + "' is not a valid base64 image."); | ||||
|     infoDiv.style.display = "block"; | ||||
|     gId('image-container').style.display = "none"; | ||||
|     gId('JSONled').value = ''; | ||||
|     if (devMode) console.log("The string '" + base64Image + "' is not a valid base64 image."); | ||||
|   } | ||||
|  | ||||
| }); | ||||
|  | ||||
| // Code for copying the generated string to clipboard | ||||
|  | ||||
| copyJSONledbutton.addEventListener('click', async () => { | ||||
|   let JSONled = document.getElementById('JSONled'); | ||||
| gId("copyJSONledbutton").addEventListener('click', async () => { | ||||
|   let JSONled = gId('JSONled'); | ||||
|   JSONled.select(); | ||||
|   try { | ||||
|     await navigator.clipboard.writeText(JSONled.value); | ||||
|   } catch (err) { | ||||
|     try { | ||||
|       await document.execCommand("copy"); | ||||
|       await d.execCommand("copy"); | ||||
|     } catch (err) { | ||||
|       console.error('Failed to copy text: ', err); | ||||
|     } | ||||
|   } | ||||
| }); | ||||
|  | ||||
| sendJSONledbutton.addEventListener('click', async () => { | ||||
| gId("sendJSONledbutton").addEventListener('click', async () => { | ||||
|   if (window.location.protocol === "https:") { | ||||
|     alert('Will only be available when served over http (or WLED is run over https)'); | ||||
|   } else { | ||||
| @@ -74,12 +70,12 @@ sendJSONledbutton.addEventListener('click', async () => { | ||||
|   } | ||||
| }); | ||||
|  | ||||
| fileJSONledbutton.addEventListener('click', async () => { | ||||
| gId("fileJSONledbutton").addEventListener('click', async () => { | ||||
|   if (window.location.protocol === "https:") { | ||||
|     alert('Will only be available when served over http (or WLED is run over https)'); | ||||
|   } else { | ||||
|     let JSONFileName = 'TheName.json' | ||||
|     let urlString = 'http://'+document.getElementById('curlUrl').value+'/upload' | ||||
|     let JSONFileName = 'TheName.json'; | ||||
|     let urlString = 'http://'+gId('curlUrl').value+'/upload'; | ||||
|  | ||||
|     sendAsFile(fileJSON, JSONFileName, urlString); | ||||
|   } | ||||
| @@ -88,9 +84,9 @@ fileJSONledbutton.addEventListener('click', async () => { | ||||
| async function postPixels() { | ||||
|   for (let i of httpArray) { | ||||
|     try { | ||||
|       console.log(i); | ||||
|       console.log(i.length); | ||||
|       const response = await fetch('http://'+document.getElementById('curlUrl').value+'/json/state', { | ||||
|       if (devMode) console.log(i); | ||||
|       if (devMode) console.log(i.length); | ||||
|       const response = await fetch('http://'+gId('curlUrl').value+'/json/state', { | ||||
|         method: 'POST', | ||||
|         headers: { | ||||
|           'Content-Type': 'application/json' | ||||
| @@ -99,16 +95,16 @@ async function postPixels() { | ||||
|         body: i | ||||
|       }); | ||||
|       const data = await response.json(); | ||||
|       console.log(data); | ||||
|       if (devMode) console.log(data); | ||||
|     } catch (error) { | ||||
|       console.error(error); | ||||
|     } | ||||
|   } | ||||
| } | ||||
| //File uploader code | ||||
| const dropZone = document.getElementById('drop-zone'); | ||||
| const filePicker = document.getElementById('file-picker'); | ||||
| const preview = document.getElementById('preview'); | ||||
| const dropZone = gId('drop-zone'); | ||||
| const filePicker = gId('file-picker'); | ||||
| const preview = gId('preview'); | ||||
|  | ||||
| // Listen for dragenter, dragover, and drop events | ||||
| dropZone.addEventListener('dragenter', dragEnter); | ||||
| @@ -159,10 +155,11 @@ function filePicked(e) { | ||||
| function updatePreview(file) { | ||||
|   // Use FileReader to read the file | ||||
|   const reader = new FileReader(); | ||||
|   reader.onload = function() { | ||||
|   reader.onload = () => { | ||||
|     // Update the preview image | ||||
|     preview.src = reader.result; | ||||
|     document.getElementById("submitConvertDiv").style.display = ""; | ||||
|     gId("submitConvertDiv").style.display = ""; | ||||
|     gId("preview").style.display = ""; | ||||
|   }; | ||||
|   reader.readAsDataURL(file); | ||||
| } | ||||
| @@ -178,46 +175,52 @@ function isValidBase64Gif(string) { | ||||
|   //REMOVED, Any image appear to work as long as it can be drawn to the canvas. Leaving code in for future use, possibly | ||||
|   if (1==1 || base64gifPattern.test(string) || base64pngPattern.test(string) || base64jpgPattern.test(string) || base64webpPattern.test(string)) { | ||||
|     return true; | ||||
|   } | ||||
|   else { | ||||
|   } else { | ||||
|     //Not OK | ||||
|     return false; | ||||
|   } | ||||
| } | ||||
|  | ||||
| document.getElementById("brightnessNumber").oninput = function() { | ||||
|   document.getElementById("brightnessValue").textContent = this.value; | ||||
| gId("brightnessNumber").oninput = () => { | ||||
|   let bn = gId("brightnessNumber"); | ||||
|   gId("brightnessValue").textContent = bn.value; | ||||
|   let perc = parseInt(bn.value)*100/255; | ||||
|   var val = `linear-gradient(90deg, #bbb ${perc}%, #333 ${perc}%)`; | ||||
|   bn.style.backgroundImage = val; | ||||
| } | ||||
|  | ||||
| document.getElementById("colorLimitNumber").oninput = function() { | ||||
|   document.getElementById("colorLimitValue").textContent = this.value; | ||||
| gId("colorLimitNumber").oninput = () => { | ||||
|   let cln = gId("colorLimitNumber"); | ||||
|   gId("colorLimitValue").textContent = cln.value; | ||||
|   let perc = parseInt(cln.value)*100/512; | ||||
|   var val = `linear-gradient(90deg, #bbb ${perc}%, #333 ${perc}%)`; | ||||
|   cln.style.backgroundImage = val; | ||||
| } | ||||
|  | ||||
| var formatSelector = document.getElementById("formatSelector"); | ||||
| var hideableRows = document.querySelectorAll(".ha-hide"); | ||||
| var hideableRows = d.querySelectorAll(".ha-hide"); | ||||
| for (var i = 0; i < hideableRows.length; i++) { | ||||
|     hideableRows[i].classList.add("hide"); | ||||
|   hideableRows[i].classList.add("hide"); | ||||
| } | ||||
| formatSelector.addEventListener("change", function() { | ||||
|      for (var i = 0; i < hideableRows.length; i++) { | ||||
|          hideableRows[i].classList.toggle("hide", this.value !== "ha"); | ||||
|      } | ||||
|  }); | ||||
| gId("formatSelector").addEventListener("change", () => { | ||||
|   for (var i = 0; i < hideableRows.length; i++) { | ||||
|     hideableRows[i].classList.toggle("hide", gId("formatSelector").value !== "ha"); | ||||
|   } | ||||
| }); | ||||
|  | ||||
| function switchScale() { | ||||
|   let scalePath = document.getElementById("scalePath"); | ||||
|   let scaleTogglePath = document.getElementById("scaleTogglePath"); | ||||
|   let scalePath = gId("scaleDiv").children[1].children[0] | ||||
|   let scaleTogglePath = gId("scaleDiv").children[0].children[0] | ||||
|   let color = scalePath.getAttribute("fill"); | ||||
|   let d = '' | ||||
|   let d = ''; | ||||
|   if (color === accentColor) { | ||||
|     color = accentTextColor; | ||||
|     d = scaleToggleOffd | ||||
|     document.getElementById("sizeDiv").style.display = "none"; | ||||
|     d = scaleToggleOffd; | ||||
|     gId("sizeDiv").style.display = "none"; | ||||
|     // Set values to actual XY of image, if possible | ||||
|   } else { | ||||
|     color = accentColor; | ||||
|     d = scaleToggleOnd | ||||
|     document.getElementById("sizeDiv").style.display = ""; | ||||
|     d = scaleToggleOnd; | ||||
|     gId("sizeDiv").style.display = ""; | ||||
|   } | ||||
|   scalePath.setAttribute("fill", color); | ||||
|   scaleTogglePath.setAttribute("fill", color); | ||||
| @@ -228,20 +231,22 @@ function switchScale() { | ||||
| function sendAsFile(jsonStringInput, fileName, urlString) { | ||||
|   //var jsonString = JSON.stringify({name: "value"}); | ||||
|   var file = new Blob([jsonStringInput], {type: 'application/json'}); | ||||
|   console.log(jsonStringInput) | ||||
|   console.log(fileName); | ||||
|   console.log(urlString); | ||||
|    | ||||
|   if (devMode) { | ||||
|     console.log(jsonStringInput); | ||||
|     console.log(fileName); | ||||
|     console.log(urlString); | ||||
|   } | ||||
|  | ||||
|   var formData = new FormData(); | ||||
|   formData.append('file', file, fileName); | ||||
|  | ||||
|   var xhr = new XMLHttpRequest(); | ||||
|   xhr.open('POST', urlString, true); | ||||
|   xhr.onload = function() { | ||||
|   xhr.onload = () => { | ||||
|     if (xhr.status === 200) { | ||||
|       console.log('File uploaded successfully!'); | ||||
|       if (devMode) console.log('File uploaded successfully!'); | ||||
|     } else { | ||||
|       console.log('File upload failed!'); | ||||
|       if (devMode) console.log('File upload failed!'); | ||||
|     } | ||||
|   }; | ||||
|   xhr.send(formData); | ||||
| @@ -250,71 +255,40 @@ function sendAsFile(jsonStringInput, fileName, urlString) { | ||||
| function generateSegmentOptions(array) { | ||||
|   //This function is prepared for a name property on each segment for easier selection | ||||
|   //Currently the name is generated generically based on index | ||||
|   var select = document.getElementById("targetSegment"); | ||||
|   var select = gId("targetSegment"); | ||||
|   select.innerHTML = ""; | ||||
|   for (var i = 0; i < array.length; i++) { | ||||
|       var option = document.createElement("option"); | ||||
|       option.value = array[i].value; | ||||
|       option.text = array[i].text; | ||||
|       select.appendChild(option); | ||||
|       if(i === 0) { | ||||
|         option.selected = true; | ||||
|       } | ||||
|     var option = cE("option"); | ||||
|     option.value = array[i].value; | ||||
|     option.text = array[i].text; | ||||
|     select.appendChild(option); | ||||
|     if(i === 0) { | ||||
|       option.selected = true; | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| //Initial population of segment selection | ||||
| function generateSegmentArray(noOfSegments) { | ||||
|   var arr = []; | ||||
|   for (var i = 0; i < noOfSegments; i++) { | ||||
|       arr.push({ | ||||
|           value: i, | ||||
|           text: "Segment index " + i | ||||
|       }); | ||||
|     arr.push({ | ||||
|       value: i, | ||||
|       text: "Segment index " + i | ||||
|     }); | ||||
|   } | ||||
|   return arr; | ||||
| } | ||||
|  | ||||
|  | ||||
| //Animate matrix | ||||
| var matrixcircles = document.querySelectorAll("#logomatrix path"); | ||||
| var intervalId; | ||||
| // Function that changes the color of a random circle to a lighter purple | ||||
| function changeColorOfDot() { | ||||
|   // Get a random number between 0 and the number of circles | ||||
|   var randomIndex = Math.floor(Math.random() * matrixcircles.length); | ||||
|   // Get the circle at the random index | ||||
|   var randomCircle = matrixcircles[randomIndex]; | ||||
|  | ||||
|    | ||||
|   // Store the current fill color | ||||
|   var currentColor = randomCircle.getAttribute("fill"); | ||||
|   // Change the color of the circle | ||||
|   randomCircle.setAttribute("fill", "#bb8fbc"); | ||||
|   setTimeout(() => { | ||||
|     randomCircle.setAttribute("fill", currentColor); | ||||
|     clearInterval(intervalId); | ||||
|     intervalId = setInterval(changeColorOfDot, randomInterval()); | ||||
|   }, 500); | ||||
| } | ||||
|  | ||||
| function randomInterval() { | ||||
|   var interval = Math.floor(Math.random() * (5 - 1 + 1)) + 1; | ||||
|   return interval * 1000; | ||||
| } | ||||
|  | ||||
| // call the function changeColorOfDot every 10 seconds | ||||
| intervalId = setInterval(changeColorOfDot, randomInterval()); | ||||
|  | ||||
| var segmentData = generateSegmentArray(10); | ||||
|  | ||||
| generateSegmentOptions(segmentData); | ||||
|  | ||||
| document.getElementById("fileJSONledbutton").innerHTML =  | ||||
| gId("fileJSONledbutton").innerHTML =  | ||||
| '<svg style="width:36px;height:36px" viewBox="0 0 24 24"><path fill="currentColor" d="M20 18H4V8H20M20 6H12L10 4H4A2 2 0 0 0 2 6V18A2 2 0 0 0 4 20H20A2 2 0 0 0 22 18V8A2 2 0 0 0 20 6M16 17H14V13H11L15 9L19 13H16Z" /></svg>  File to device' | ||||
|  document.getElementById("convertbutton").innerHTML =  | ||||
|  '<svg style="width:36px;height:36px" viewBox="0 0 24 24"><path fill="currentColor" d="M12,6V9L16,5L12,1V4A8,8 0 0,0 4,12C4,13.57 4.46,15.03 5.24,16.26L6.7,14.8C6.25,13.97 6,13 6,12A6,6 0 0,1 12,6M18.76,7.74L17.3,9.2C17.74,10.04 18,11 18,12A6,6 0 0,1 12,18V15L8,19L12,23V20A8,8 0 0,0 20,12C20,10.43 19.54,8.97 18.76,7.74Z" /> </svg>  Convert to WLED JSON ';  | ||||
|  document.getElementById("copyJSONledbutton").innerHTML =  | ||||
|  '<svg class="svg-icon" style="width:36px;height:36px" viewBox="0 0 24 24"> <path fill="currentColor" d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z" /> </svg>  Copy to clipboard';  | ||||
|  document.getElementById("sendJSONledbutton").innerHTML =  | ||||
| gId("convertbutton").innerHTML =  | ||||
| '<svg style="width:36px;height:36px" viewBox="0 0 24 24"><path fill="currentColor" d="M12,6V9L16,5L12,1V4A8,8 0 0,0 4,12C4,13.57 4.46,15.03 5.24,16.26L6.7,14.8C6.25,13.97 6,13 6,12A6,6 0 0,1 12,6M18.76,7.74L17.3,9.2C17.74,10.04 18,11 18,12A6,6 0 0,1 12,18V15L8,19L12,23V20A8,8 0 0,0 20,12C20,10.43 19.54,8.97 18.76,7.74Z" /> </svg>  Convert to WLED JSON ';  | ||||
| gId("copyJSONledbutton").innerHTML =  | ||||
| '<svg class="svg-icon" style="width:36px;height:36px" viewBox="0 0 24 24"> <path fill="currentColor" d="M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z" /> </svg>  Copy to clipboard';  | ||||
| gId("sendJSONledbutton").innerHTML =  | ||||
| '<svg class="svg-icon" style="width:36px;height:36px" viewBox="0 0 24 24"> <path fill="currentColor" d="M6.5 20Q4.22 20 2.61 18.43 1 16.85 1 14.58 1 12.63 2.17 11.1 3.35 9.57 5.25 9.15 5.88 6.85 7.75 5.43 9.63 4 12 4 14.93 4 16.96 6.04 19 8.07 19 11 20.73 11.2 21.86 12.5 23 13.78 23 15.5 23 17.38 21.69 18.69 20.38 20 18.5 20H13Q12.18 20 11.59 19.41 11 18.83 11 18V12.85L9.4 14.4L8 13L12 9L16 13L14.6 14.4L13 12.85V18H18.5Q19.55 18 20.27 17.27 21 16.55 21 15.5 21 14.45 20.27 13.73 19.55 13 18.5 13H17V11Q17 8.93 15.54 7.46 14.08 6 12 6 9.93 6 8.46 7.46 7 8.93 7 11H6.5Q5.05 11 4.03 12.03 3 13.05 3 14.5 3 15.95 4.03 17 5.05 18 6.5 18H9V20M12 13Z" /> </svg>  Send to device'; | ||||
| @@ -17,7 +17,7 @@ const JSONledStringMid2 = ',"i":['; | ||||
| // const JSONledShortStringMid1 = '"seg":{"i":['; | ||||
| const JSONledStringEnd = ']}}'; | ||||
|  | ||||
| var accentColor = '#7E4C80'; | ||||
| var accentColor = '#eee'; | ||||
| var accentTextColor = '#777'; | ||||
|  | ||||
| var scaleToggleOffd = "M17,7H7A5,5 0 0,0 2,12A5,5 0 0,0 7,17H17A5,5 0 0,0 22,12A5,5 0 0,0 17,7M7,15A3,3 0 0,1 4,12A3,3 0 0,1 7,9A3,3 0 0,1 10,12A3,3 0 0,1 7,15Z"; | ||||
|   | ||||
							
								
								
									
										1011
									
								
								wled00/html_pixart.h
									
									
									
									
									
								
							
							
						
						
									
										1011
									
								
								wled00/html_pixart.h
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
		Reference in New Issue
	
	Block a user
	 Blaz Kristan
					Blaz Kristan