mirror of
https://github.com/4yn/slidershim.git
synced 2025-02-02 04:27:58 +01:00
85 lines
2.2 KiB
Svelte
85 lines
2.2 KiB
Svelte
<script lang="ts">
|
|
export let data: Array<number>;
|
|
|
|
let topDatas = Array(16).fill(0);
|
|
let botDatas = Array(16).fill(0);
|
|
let airDatas = Array(6).fill(0);
|
|
let extraDatas = Array(3).fill(0);
|
|
|
|
let ledDatas = Array(16).fill("#ff0");
|
|
let ledDividerDatas = Array(15).fill("#ff0");
|
|
|
|
$: {
|
|
if (data.length === 134) {
|
|
// console.log(data);
|
|
for (let i = 0; i < 16; i++) {
|
|
topDatas[i] = data[i * 2 + 1];
|
|
botDatas[i] = data[i * 2];
|
|
}
|
|
for (let i = 0; i < 6; i++) {
|
|
airDatas[i] = data[32 + i];
|
|
}
|
|
for (let i = 0; i < 3; i++) {
|
|
extraDatas[i] = data[38 + i];
|
|
}
|
|
|
|
for (let i = 0; i < 31; i++) {
|
|
let rgbstr = `rgb(${data[41 + i * 3]}, ${data[42 + i * 3]}, ${
|
|
data[43 + i * 3]
|
|
})`;
|
|
if (i % 2 == 0) {
|
|
ledDatas[i / 2] = rgbstr;
|
|
} else {
|
|
ledDividerDatas[(i - 1) / 2] = rgbstr;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<main class="preview">
|
|
<div class="air">
|
|
{#each airDatas as airData, idx (idx)}
|
|
<div class={`air-data air-data-${airData}`} />
|
|
{/each}
|
|
</div>
|
|
<div class="ground">
|
|
<div class="ground-led">
|
|
<div class="ground-row">
|
|
{#each ledDatas as ledData, idx (idx)}
|
|
<div class={`ground-led-0`} style={`background-color: ${ledData}`} />
|
|
{/each}
|
|
</div>
|
|
</div>
|
|
<div class="ground-led">
|
|
<div class="ground-row ground-row-divider">
|
|
<div class="ground-led-2" />
|
|
{#each ledDividerDatas as ledDividerData, idx (idx)}
|
|
<div
|
|
class="ground-led-1"
|
|
style={`background-color: ${ledDividerData}`}
|
|
/>
|
|
{/each}
|
|
<div class="ground-led-2" />
|
|
</div>
|
|
</div>
|
|
<div class="ground-btn">
|
|
<div class="ground-row">
|
|
{#each topDatas as topData, idx (idx)}
|
|
<div class="ground-data">{topData}</div>
|
|
{/each}
|
|
</div>
|
|
<div class="ground-row">
|
|
{#each botDatas as botData, idx (idx)}
|
|
<div class="ground-data">{botData}</div>
|
|
{/each}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="extra">
|
|
{#each extraDatas as extraData, idx (idx)}
|
|
<div class={`extra-data extra-data-${extraData}`} />
|
|
{/each}
|
|
</div>
|
|
</main>
|