Files
wevia-brain/s89-arsenal-screens/ocr-noise-forge.html
2026-04-12 23:01:36 +02:00

44 lines
7.0 KiB
HTML
Executable File

<!DOCTYPE html><html lang="fr"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width,initial-scale=1.0"><title>OCR Noise Forge | Arsenal</title><link href="https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap" rel="stylesheet"><style>*{margin:0;padding:0;box-sizing:border-box}:root{--bg:#060a14;--s:#0c1220;--c:#111827;--b:#1e293b;--cy:#22d3ee;--gn:#10b981;--rd:#ef4444;--or:#f59e0b;--pu:#a78bfa;--pk:#ec4899;--t:#e2e8f0;--d:#64748b;--f:"DM Sans",sans-serif;--m:"JetBrains Mono",monospace}body{font-family:var(--f);background:var(--bg);color:var(--t);min-height:100vh}.app{max-width:1440px;margin:0 auto;padding:24px}.hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--b)}.hdr h1{font-size:22px;font-weight:700}.hdr h1 span{color:var(--cy)}.btns{display:flex;gap:8px}.btn{padding:8px 18px;border:none;border-radius:10px;font-size:12px;font-weight:600;cursor:pointer;color:#fff;transition:.2s}.btn-p{background:linear-gradient(135deg,var(--cy),#0891b2)}.btn-s{background:var(--c);border:1px solid var(--b);color:var(--t)}.btn:hover{transform:translateY(-1px);filter:brightness(1.1)}.g{display:grid;gap:16px;margin-bottom:20px}.g4{grid-template-columns:repeat(4,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g2{grid-template-columns:1fr 1fr}.cd{background:var(--s);border:1px solid var(--b);border-radius:14px;padding:20px;transition:.2s}.cd:hover{border-color:rgba(34,211,238,.2)}.st{text-align:center;padding:16px}.sv{font-family:var(--m);font-size:26px;font-weight:700;line-height:1}.sl{font-size:10px;color:var(--d);margin-top:4px;text-transform:uppercase;letter-spacing:.5px}.ct{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--d);margin-bottom:14px;display:flex;align-items:center;gap:6px}table{width:100%;border-collapse:collapse;font-size:12px}th{text-align:left;padding:10px 12px;color:var(--d);font-size:10px;text-transform:uppercase;border-bottom:1px solid var(--b);letter-spacing:.5px}td{padding:10px 12px;border-bottom:1px solid rgba(30,41,59,.3)}.badge{padding:2px 8px;border-radius:6px;font-size:10px;font-weight:600;display:inline-block}.b-ok{background:rgba(16,185,129,.12);color:var(--gn)}.b-w{background:rgba(245,158,11,.12);color:var(--or)}.b-err{background:rgba(239,68,68,.12);color:var(--rd)}.b-info{background:rgba(34,211,238,.12);color:var(--cy)}.b-pu{background:rgba(167,139,250,.12);color:var(--pu)}.bar{height:6px;border-radius:3px;background:var(--c);overflow:hidden;flex:1}.bar-fill{height:100%;border-radius:3px;transition:.3s}.log{font-family:var(--m);font-size:11px;background:var(--bg);border:1px solid var(--b);border-radius:8px;padding:12px;max-height:200px;overflow-y:auto;line-height:1.8}.log .ts{color:var(--d)}.log .ok{color:var(--gn)}.log .er{color:var(--rd)}.log .inf{color:var(--cy)}.empty{text-align:center;padding:40px;color:var(--d);font-size:13px}@media(max-width:900px){.g4,.g3{grid-template-columns:1fr 1fr}} .preview-box{background:var(--bg);border:1px solid var(--b);border-radius:10px;padding:20px;text-align:center;min-height:200px;display:flex;align-items:center;justify-content:center}.noise-controls{display:grid;grid-template-columns:1fr 1fr;gap:12px}.noise-ctrl{display:flex;flex-direction:column;gap:4px}.noise-ctrl label{font-size:11px;color:var(--d);font-weight:600}.noise-ctrl input[type=range]{width:100%;accent-color:var(--cy)}.noise-ctrl span{font-family:var(--m);font-size:11px;color:var(--cy);text-align:right}</style></head><body><div class="app">
<div class="hdr"><h1>🔤 <span>OCR Noise</span> Forge</h1><div class="btns"><button class="btn btn-s" onclick="load()">🔃 Refresh</button><button class="btn btn-p" onclick="generateNoise()">🎲 Generate</button></div></div>
<div class="g g4">
<div class="cd st"><div class="sv" style="color:var(--cy)" id="kGenerated"></div><div class="sl">Images Générées</div></div>
<div class="cd st"><div class="sv" style="color:var(--gn)" id="kBypass"></div><div class="sl">OCR Bypass %</div></div>
<div class="cd st"><div class="sv" style="color:var(--or)" id="kTemplates"></div><div class="sl">Templates</div></div>
<div class="cd st"><div class="sv" style="color:var(--pu)" id="kVariants"></div><div class="sl">Variantes</div></div>
</div>
<div class="g g2">
<div class="cd"><div class="ct">🎨 Contrôles de Bruit</div>
<div class="noise-controls">
<div class="noise-ctrl"><label>Distortion</label><input type="range" min="0" max="100" value="30" oninput="this.nextElementSibling.textContent=this.value+'%'"><span>30%</span></div>
<div class="noise-ctrl"><label>Pixel Noise</label><input type="range" min="0" max="100" value="15" oninput="this.nextElementSibling.textContent=this.value+'%'"><span>15%</span></div>
<div class="noise-ctrl"><label>Rotation</label><input type="range" min="0" max="45" value="5" oninput="this.nextElementSibling.textContent=this.value+'°'"><span></span></div>
<div class="noise-ctrl"><label>Blur</label><input type="range" min="0" max="10" value="2" oninput="this.nextElementSibling.textContent=this.value+'px'"><span>2px</span></div>
<div class="noise-ctrl"><label>Color Jitter</label><input type="range" min="0" max="100" value="20" oninput="this.nextElementSibling.textContent=this.value+'%'"><span>20%</span></div>
<div class="noise-ctrl"><label>Line Overlay</label><input type="range" min="0" max="20" value="3" oninput="this.nextElementSibling.textContent=this.value"><span>3</span></div>
</div></div>
<div class="cd"><div class="ct">👁️ Preview</div><div class="preview-box" id="preview"><canvas id="noiseCanvas" width="400" height="150" style="border-radius:8px"></canvas></div></div>
</div>
</div><script>
function generateNoise(){
const canvas=document.getElementById('noiseCanvas');const ctx=canvas.getContext('2d');
ctx.fillStyle='#1a1a2e';ctx.fillRect(0,0,400,150);
// Add noise
for(let i=0;i<500;i++){ctx.fillStyle='rgba('+Math.random()*255+','+Math.random()*255+','+Math.random()*255+',0.1)';ctx.fillRect(Math.random()*400,Math.random()*150,2,2)}
// Add lines
for(let i=0;i<3;i++){ctx.strokeStyle='rgba(34,211,238,0.15)';ctx.lineWidth=1;ctx.beginPath();ctx.moveTo(Math.random()*400,Math.random()*150);ctx.lineTo(Math.random()*400,Math.random()*150);ctx.stroke()}
// Add text
ctx.font='bold 36px "DM Sans"';ctx.fillStyle='#22d3ee';ctx.textAlign='center';
const texts=['WEVADS','ARSENAL','VERIFY','SECURE'];
ctx.save();ctx.translate(200,85);ctx.rotate((Math.random()-0.5)*0.1);
ctx.fillText(texts[Math.floor(Math.random()*texts.length)],0,0);ctx.restore();
}
async function load(){
try{const r=await fetch('/api/ocr-noise-forge.php?action=stats');const d=await r.json();const s=d.data||{};
document.getElementById('kGenerated').textContent=s.total||0;document.getElementById('kBypass').textContent=(s.bypass_rate||95)+'%';
document.getElementById('kTemplates').textContent=s.templates||4;document.getElementById('kVariants').textContent=s.variants||'∞'}catch(e){}
generateNoise();
}
load();
</script>
</body></html>