d94dcfb5af
Shader (gioser-shaders):
- 3 cuerpos centrales renderizados realísticamente con interpolación
gradual entre ellos (cross-fade smoothstep):
- render_sun: núcleo gauss + corona pulsante + textura de plasma FBM
(boiling surface).
- render_moon: disco con limb darkening, cráteres + mares (2 octavas
de fbm), terminador móvil (fase lunar), halo azulado en el limb
iluminado.
- render_earth: disco con continentes fbm (rotación lenta), polos
blancos, nubes en otra capa, día/noche en hemisferio iluminado,
halo atmosférico azul (Rayleigh simplificado).
- Uniforms u_body_a, u_body_b (int 0/1/2), u_body_blend (float).
- Cuerpo central se calcula sólo si inside > 0.001 (perf — saltea pixels
fuera de la superficie de la chacana).
- radial_mult atenúa los rayos cuando luna/tierra están activos — el sol
es el único que irradia tan intensamente.
- element_cloud(): aura ancha por cardinal (sigma_along=0.42,
sigma_perp=0.34) con textura fbm animada y modulación por elemento.
- AIRE: corrientes suaves que ondulan horizontalmente.
- FUEGO: lengüetazos rápidos con flicker.
- TIERRA: densidad sólida con variación lenta.
- AGUA: ondulaciones grandes que viajan hacia afuera.
Las nubes cubren todo el cuadrante del cardinal, no solo la punta.
- Helper functions vnoise_c + fbm_c agregadas (necesarias para superficies
realistas de luna/tierra y para nubes elementales).
Renderer (gioser-canvas-web):
- body_state(t) -> (body_a, body_b, blend) state machine:
- BODY_PHASE_SECS = 45 (≈10 pulsos del sol antes de transicionar).
- BODY_TRANSITION_SECS = 4 (cross-fade gradual).
- Total cycle: 147s = sol 45s → trans 4s → luna 45s → trans 4s → tierra 45s → trans 4s.
- Smoothstep cubic en el blend para curva natural (no linear).
- Sube u_body_a/b como int (uniform1i) y u_body_blend como float.
App + contenido:
- index.html: nuevos labels en los 4 tips
- NORTE (aire): SOFTWARE / Tecnología
- ESTE (fuego): QUIÉN SOY / Bitácora
- SUR (tierra): MANIFIESTO / Invariantes
- OESTE (agua): MÍSTICA / Espiritualidad
- Íconos SVG nuevos relacionados al tema:
- aire: chip de circuito con nodos y conexiones
- fuego: libro abierto con líneas
- tierra: hexagrama dentro de círculo (sacred geometry / invariante)
- agua: ojo en triángulo (mística)
- gioser-web src/lib.rs: ensure_page_dom usa nuevos title+tag por elemento.
- 4 md/*.md reescritos con contenido seed para los nuevos temas, con
manifiesto explícito en tierra.md.
Workspace verde + 21 tests.
Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
113 lines
6.2 KiB
HTML
113 lines
6.2 KiB
HTML
<!doctype html>
|
|
<html lang="es">
|
|
<head>
|
|
<meta charset="utf-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1, viewport-fit=cover">
|
|
<title>GioSer · En el centro, el ser</title>
|
|
<link rel="stylesheet" href="./styles.css">
|
|
<link rel="preconnect" href="https://fonts.googleapis.com">
|
|
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
|
|
<link rel="stylesheet" href="https://fonts.googleapis.com/css2?family=Cinzel:wght@500;700&family=Inter:wght@300;500;600&family=JetBrains+Mono:wght@400;600&display=swap">
|
|
</head>
|
|
<body>
|
|
<canvas id="gioser-canvas" aria-hidden="true"></canvas>
|
|
|
|
<main id="tips" aria-label="Cuatro cardinales">
|
|
<!-- NORTE (aire): SOFTWARE · Tecnología — circuito + nodos -->
|
|
<a id="tip-aire" class="tip tip-aire" href="#aire" data-md="./md/aire.md" aria-label="Software · Tecnología">
|
|
<svg viewBox="0 0 48 48" class="tip-glyph" aria-hidden="true">
|
|
<rect x="18" y="18" width="12" height="12" fill="none" stroke="currentColor" stroke-width="1.7" rx="1"/>
|
|
<circle cx="24" cy="24" r="2" fill="currentColor"/>
|
|
<path d="M22 18 V14 M26 18 V14 M22 30 V34 M26 30 V34 M18 22 H14 M18 26 H14 M30 22 H34 M30 26 H34"
|
|
stroke="currentColor" stroke-width="1.4" stroke-linecap="round"/>
|
|
<circle cx="10" cy="10" r="1.6" fill="currentColor" opacity="0.7"/>
|
|
<circle cx="38" cy="10" r="1.6" fill="currentColor" opacity="0.7"/>
|
|
<circle cx="10" cy="38" r="1.6" fill="currentColor" opacity="0.7"/>
|
|
<circle cx="38" cy="38" r="1.6" fill="currentColor" opacity="0.7"/>
|
|
<path d="M11 11 L17 17 M37 11 L31 17 M11 37 L17 31 M37 37 L31 31"
|
|
stroke="currentColor" stroke-width="1.1" opacity="0.45"/>
|
|
</svg>
|
|
<span class="tip-label">SOFTWARE</span>
|
|
<span class="tip-sub">Tecnología</span>
|
|
</a>
|
|
|
|
<!-- ESTE (fuego): QUIÉN SOY · Bitácora — libro abierto -->
|
|
<a id="tip-fuego" class="tip tip-fuego" href="#fuego" data-md="./md/fuego.md" aria-label="Quién Soy · Bitácora">
|
|
<svg viewBox="0 0 48 48" class="tip-glyph" aria-hidden="true">
|
|
<path d="M8 14 L24 18 L40 14 V36 L24 32 L8 36 Z"
|
|
fill="none" stroke="currentColor" stroke-width="1.7" stroke-linejoin="round"/>
|
|
<path d="M24 18 V32" stroke="currentColor" stroke-width="1.5"/>
|
|
<path d="M12 22 H21 M12 26 H21 M12 30 H19" stroke="currentColor" stroke-width="1.1" opacity="0.65" stroke-linecap="round"/>
|
|
<path d="M27 22 H36 M27 26 H36 M29 30 H36" stroke="currentColor" stroke-width="1.1" opacity="0.65" stroke-linecap="round"/>
|
|
</svg>
|
|
<span class="tip-label">QUIÉN SOY</span>
|
|
<span class="tip-sub">Bitácora</span>
|
|
</a>
|
|
|
|
<!-- SUR (tierra): MANIFIESTO · Invariantes — hexagrama + círculo -->
|
|
<a id="tip-tierra" class="tip tip-tierra" href="#tierra" data-md="./md/tierra.md" aria-label="Manifiesto · Invariantes">
|
|
<svg viewBox="0 0 48 48" class="tip-glyph" aria-hidden="true">
|
|
<circle cx="24" cy="24" r="18" fill="none" stroke="currentColor" stroke-width="1.4" opacity="0.55"/>
|
|
<path d="M24 8 L39 32 L9 32 Z" fill="none" stroke="currentColor" stroke-width="1.7" stroke-linejoin="round"/>
|
|
<path d="M24 40 L9 16 L39 16 Z" fill="none" stroke="currentColor" stroke-width="1.5" opacity="0.85" stroke-linejoin="round"/>
|
|
<circle cx="24" cy="24" r="1.8" fill="currentColor"/>
|
|
</svg>
|
|
<span class="tip-label">MANIFIESTO</span>
|
|
<span class="tip-sub">Invariantes</span>
|
|
</a>
|
|
|
|
<!-- OESTE (agua): MÍSTICA · Espiritualidad — ojo en triángulo -->
|
|
<a id="tip-agua" class="tip tip-agua" href="#agua" data-md="./md/agua.md" aria-label="Mística · Espiritualidad">
|
|
<svg viewBox="0 0 48 48" class="tip-glyph" aria-hidden="true">
|
|
<path d="M24 6 L42 40 L6 40 Z" fill="none" stroke="currentColor" stroke-width="1.6" stroke-linejoin="round"/>
|
|
<path d="M13 26 Q24 16 35 26 Q24 34 13 26 Z" fill="none" stroke="currentColor" stroke-width="1.7" stroke-linejoin="round"/>
|
|
<circle cx="24" cy="26" r="3.2" fill="currentColor"/>
|
|
<circle cx="22.5" cy="24.5" r="0.9" fill="rgba(255,255,255,0.55)"/>
|
|
</svg>
|
|
<span class="tip-label">MÍSTICA</span>
|
|
<span class="tip-sub">Espiritualidad</span>
|
|
</a>
|
|
</main>
|
|
|
|
<!-- DECK: contenedor único con strip horizontal. Las páginas se inyectan
|
|
dinámicamente desde WASM. vista-web maneja swipe + snap. -->
|
|
<div id="deck" class="deck vista-deck" aria-hidden="true">
|
|
<div id="deck-strip" class="deck-strip vista-strip" role="region" aria-label="Vistas abiertas"></div>
|
|
</div>
|
|
|
|
<!-- TASKBAR estilo Windows: home + GioSer + tabs + copyleft -->
|
|
<nav class="taskbar" aria-label="Barra de vistas">
|
|
<button class="taskbar-home" data-home aria-label="Volver al home" type="button">
|
|
<svg viewBox="0 0 24 24" class="taskbar-home-glyph" aria-hidden="true">
|
|
<path d="M3 12 L12 3 L21 12" fill="none" stroke="currentColor" stroke-width="1.6" stroke-linejoin="round" stroke-linecap="round"/>
|
|
<path d="M5 11 V20 H10 V14 H14 V20 H19 V11" fill="none" stroke="currentColor" stroke-width="1.6" stroke-linejoin="round"/>
|
|
<circle cx="12" cy="17" r="0.8" fill="currentColor"/>
|
|
</svg>
|
|
</button>
|
|
|
|
<a class="taskbar-brand" data-home href="#home" aria-label="GioSer · home">
|
|
<span>Gio</span><span class="brand-dot">·</span><span>Ser</span>
|
|
</a>
|
|
|
|
<span class="taskbar-divider" aria-hidden="true"></span>
|
|
<ul class="taskbar-list" id="taskbar-list" role="presentation"></ul>
|
|
<span class="taskbar-spacer" aria-hidden="true"></span>
|
|
|
|
<a class="taskbar-credit" href="https://sergio.gioser.net" target="_blank" rel="noopener noreferrer" aria-label="Copyleft sergio arroba gioser punto net">
|
|
<span class="copyleft-mark" aria-hidden="true">©</span>
|
|
<span class="taskbar-credit-text">sergio@gioser.net</span>
|
|
</a>
|
|
</nav>
|
|
|
|
<script type="module">
|
|
import init from "./pkg/gioser_web.js";
|
|
init().catch(err => {
|
|
console.error(err);
|
|
document.body.insertAdjacentHTML("beforeend",
|
|
'<pre style="color:#f59056;position:fixed;left:1rem;bottom:1rem;max-width:90vw;white-space:pre-wrap;font-family:monospace;z-index:9999">' +
|
|
String(err) + '</pre>');
|
|
});
|
|
</script>
|
|
</body>
|
|
</html>
|