Inline fixes.
This commit is contained in:
parent
2b8d8d4e9c
commit
c692cc6a70
@ -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
Loading…
Reference in New Issue
Block a user