6d7060ceb5
Cada entity declara su color de linea via parametro opcional. Cuando
alpha==0 el pipeline cae al color global del oscilador (compatibilidad
con el comportamiento anterior).
Defaults::Palette (defaults.hpp):
- SHIP = blanco neutro
- BULLET = verde laser
- PENTAGON = azul "esquivador"
- QUADRAT = rojo "tank"
- MOLINILLO = magenta agresivo
Pipeline:
- linea(): parametro SDL_Color color (default {0,0,0,0}). En .cpp,
fuente del color = color.a>0 ? color : g_current_line_color.
- render_shape(): parametro SDL_Color color que propaga a cada linea
del shape.
- Debris: campo color en la struct; explode() recibe SDL_Color color
y lo guarda en cada fragment; draw() lo pasa a linea().
Aplicacion:
- Ship::draw -> Palette::SHIP.
- Bullet::draw -> Palette::BULLET.
- Enemy::draw -> Palette::{PENTAGON,QUADRAT,MOLINILLO} segun type_.
- CollisionSystem detectBulletEnemy: debris hereda color del enemy.
- GameScene::tocado: debris hereda Palette::SHIP.
Smoke test xvfb OK.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
37 lines
1.5 KiB
C++
37 lines
1.5 KiB
C++
// line_renderer.hpp - Renderizado de líneas vectoriales (SDL3 GPU)
|
||
// © 1999 Visente i Sergi (versión Pascal)
|
||
// © 2025 Port a C++20 con SDL3
|
||
//
|
||
// El dibujo de líneas pasa por el pipeline GPU. Las coordenadas (x1,y1,x2,y2)
|
||
// son lógicas (1280×720); el shader las mapea a NDC y el viewport del SDLManager
|
||
// hace el letterbox a píxeles físicos. El brillo modula el color global de
|
||
// línea (lo gestiona ColorOscillator). El grosor es configurable por línea
|
||
// (parámetro thickness>0) o global (g_current_line_thickness vía setLineThickness).
|
||
|
||
#pragma once
|
||
|
||
#include "core/rendering/render_context.hpp"
|
||
#include <SDL3/SDL.h>
|
||
|
||
namespace Rendering {
|
||
|
||
// Dibuja una línea entre dos puntos en coordenadas lógicas (1280×720).
|
||
// brightness: factor de brillo (0.0..1.0, default 1.0 = brillo máximo).
|
||
// thickness: grosor en píxeles lógicos. Si <= 0 usa g_current_line_thickness.
|
||
// color: si alpha==0, se usa el color global del oscilador; si alpha>0 se
|
||
// usa este color directo (paleta semántica por entidad).
|
||
void linea(Renderer* renderer,
|
||
int x1, int y1, int x2, int y2,
|
||
float brightness = 1.0F,
|
||
float thickness = 0.0F,
|
||
SDL_Color color = {0, 0, 0, 0});
|
||
|
||
// Color global de las líneas (lo actualiza ColorOscillator vía SDLManager).
|
||
void setLineColor(SDL_Color color);
|
||
|
||
// Grosor global por defecto (en píxeles lógicos). Default: 1.5.
|
||
void setLineThickness(float thickness);
|
||
[[nodiscard]] auto getLineThickness() -> float;
|
||
|
||
} // namespace Rendering
|