Merge branch 'refactor/remove-dead-oscillator-code': neteja del ColorOscillator (ara via shader)
This commit is contained in:
@@ -14,8 +14,8 @@ namespace Defaults::Hud {
|
|||||||
|
|
||||||
// Colors per segment del marcador. Jerarquia per funció (score/vides/nivell)
|
// Colors per segment del marcador. Jerarquia per funció (score/vides/nivell)
|
||||||
// + diferenciació de jugador (P1 blanc vs P2 rosa) sense xocar amb els
|
// + diferenciació de jugador (P1 blanc vs P2 rosa) sense xocar amb els
|
||||||
// colors d'enemics (cyan/roig). Si alpha=255 desactiva l'oscil·lador global
|
// colors d'enemics (cyan/roig). Amb alpha=255 el line_renderer usa el color
|
||||||
// i mostra el color estable (en lloc del pulse verd genèric).
|
// directament sense caure al fallback verd (Rendering::DEFAULT_LINE_COLOR).
|
||||||
namespace Colors {
|
namespace Colors {
|
||||||
constexpr SDL_Color SCORE_P1 = {.r = 255, .g = 255, .b = 255, .a = 255}; // blanc
|
constexpr SDL_Color SCORE_P1 = {.r = 255, .g = 255, .b = 255, .a = 255}; // blanc
|
||||||
constexpr SDL_Color SCORE_P2 = {.r = 255, .g = 130, .b = 200, .a = 255}; // rosa magenta
|
constexpr SDL_Color SCORE_P2 = {.r = 255, .g = 130, .b = 200, .a = 255}; // rosa magenta
|
||||||
|
|||||||
@@ -6,8 +6,8 @@
|
|||||||
#include <SDL3/SDL.h>
|
#include <SDL3/SDL.h>
|
||||||
|
|
||||||
// Paleta semántica por tipo de entidad. Si una entity declara color, lo
|
// Paleta semántica por tipo de entidad. Si una entity declara color, lo
|
||||||
// pasa al pipeline con alpha=255 (sentinela "color válido"); si no, se
|
// pasa al pipeline con alpha=255 (sentinela "color válido"); si no,
|
||||||
// usa el color global del oscilador (g_current_line_color).
|
// line_renderer::linea() cau a DEFAULT_LINE_COLOR (verd fòsfor fallback).
|
||||||
namespace Defaults::Palette {
|
namespace Defaults::Palette {
|
||||||
|
|
||||||
// Paleta neon: pujada lleugera dels canals secundaris per millorar la
|
// Paleta neon: pujada lleugera dels canals secundaris per millorar la
|
||||||
|
|||||||
@@ -51,12 +51,12 @@ namespace Graphics {
|
|||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
// Lerp de l'oscil·lador (color base actual) cap a un color "flash" en
|
// Lerp del color base verd fòsfor cap a un color "flash" en funció de
|
||||||
// funció de f ∈ [0, 1]. Retorna sempre amb alpha>0 perquè el line_renderer
|
// f ∈ [0, 1]. Retorna sempre amb alpha>0 perquè el line_renderer l'usi
|
||||||
// l'use directament (sense barrejar amb el global).
|
// directament (sense caure al fallback DEFAULT_LINE_COLOR).
|
||||||
auto lerpColor(SDL_Color flash, float f) -> SDL_Color {
|
auto lerpColor(SDL_Color flash, float f) -> SDL_Color {
|
||||||
const float CLAMPED = std::clamp(f, 0.0F, 1.0F);
|
const float CLAMPED = std::clamp(f, 0.0F, 1.0F);
|
||||||
const SDL_Color BASE = Rendering::getLineColor();
|
constexpr SDL_Color BASE = Rendering::DEFAULT_LINE_COLOR;
|
||||||
const auto LERP_U8 = [&](unsigned char a, unsigned char b) {
|
const auto LERP_U8 = [&](unsigned char a, unsigned char b) {
|
||||||
const float OUT = (static_cast<float>(a) * (1.0F - CLAMPED)) + (static_cast<float>(b) * CLAMPED);
|
const float OUT = (static_cast<float>(a) * (1.0F - CLAMPED)) + (static_cast<float>(b) * CLAMPED);
|
||||||
return static_cast<unsigned char>(OUT);
|
return static_cast<unsigned char>(OUT);
|
||||||
|
|||||||
@@ -26,7 +26,7 @@ namespace Graphics {
|
|||||||
// - scale: factor de scale (1.0 = 20×40 px por carácter)
|
// - scale: factor de scale (1.0 = 20×40 px por carácter)
|
||||||
// - spacing: espacio entre caracteres en píxeles (a scale 1.0)
|
// - spacing: espacio entre caracteres en píxeles (a scale 1.0)
|
||||||
// - brightness: factor de brightness (0.0-1.0, default 1.0 = màxima brightness)
|
// - brightness: factor de brightness (0.0-1.0, default 1.0 = màxima brightness)
|
||||||
// - color: color RGBA explícit; si alpha==0 (default) s'usa l'oscil·lador global
|
// - color: color RGBA explícit; si alpha==0 (default) es fa fallback a Rendering::DEFAULT_LINE_COLOR
|
||||||
void render(const std::string& text, const Vec2& position, float scale = 1.0F, float spacing = 2.0F, float brightness = 1.0F, SDL_Color color = {0, 0, 0, 0}) const;
|
void render(const std::string& text, const Vec2& position, float scale = 1.0F, float spacing = 2.0F, float brightness = 1.0F, SDL_Color color = {0, 0, 0, 0}) const;
|
||||||
|
|
||||||
// Renderizar string centrado en un punto
|
// Renderizar string centrado en un punto
|
||||||
@@ -35,7 +35,7 @@ namespace Graphics {
|
|||||||
// - scale: factor de scale (1.0 = 20×40 px por carácter)
|
// - scale: factor de scale (1.0 = 20×40 px por carácter)
|
||||||
// - spacing: espacio entre caracteres en píxeles (a scale 1.0)
|
// - spacing: espacio entre caracteres en píxeles (a scale 1.0)
|
||||||
// - brightness: factor de brightness (0.0-1.0, default 1.0 = màxima brightness)
|
// - brightness: factor de brightness (0.0-1.0, default 1.0 = màxima brightness)
|
||||||
// - color: color RGBA explícit; si alpha==0 (default) s'usa l'oscil·lador global
|
// - color: color RGBA explícit; si alpha==0 (default) es fa fallback a Rendering::DEFAULT_LINE_COLOR
|
||||||
void renderCentered(const std::string& text, const Vec2& centre_point, float scale = 1.0F, float spacing = 2.0F, float brightness = 1.0F, SDL_Color color = {0, 0, 0, 0}) const;
|
void renderCentered(const std::string& text, const Vec2& centre_point, float scale = 1.0F, float spacing = 2.0F, float brightness = 1.0F, SDL_Color color = {0, 0, 0, 0}) const;
|
||||||
|
|
||||||
// Calcular ancho total de un string (útil para centrado).
|
// Calcular ancho total de un string (útil para centrado).
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
// Mesh3D = llista de vèrtexs Vec3 + llista d'arestes (parells d'índexs).
|
// Mesh3D = llista de vèrtexs Vec3 + llista d'arestes (parells d'índexs).
|
||||||
// drawWireframe() aplica una Transform3D al mesh, projecta amb Camera3D i
|
// drawWireframe() aplica una Transform3D al mesh, projecta amb Camera3D i
|
||||||
// emet cada aresta com una línia 2D pel pipeline `Rendering::linea` (mateix
|
// emet cada aresta com una línia 2D pel pipeline `Rendering::linea` (mateix
|
||||||
// pipeline que la resta del joc: glow verd via ColorOscillator si color.a==0).
|
// pipeline que la resta del joc: verd fòsfor via Rendering::DEFAULT_LINE_COLOR si color.a==0).
|
||||||
//
|
//
|
||||||
// Sense depth buffer: el caller és responsable d'ordenar els meshos per
|
// Sense depth buffer: el caller és responsable d'ordenar els meshos per
|
||||||
// profunditat decreixent si vol oclusió coherent (la pipeline és LINE_LIST
|
// profunditat decreixent si vol oclusió coherent (la pipeline és LINE_LIST
|
||||||
|
|||||||
@@ -8,11 +8,6 @@
|
|||||||
|
|
||||||
namespace Rendering {
|
namespace Rendering {
|
||||||
|
|
||||||
// Color global compartido para líneas sin paleta propia (HUD, debug, texto
|
|
||||||
// genérico). Equivale al "color máximo" de la antigua oscilación CPU: verde
|
|
||||||
// fósforo CRT. El pulso de brillo lo aplica ahora el shader de postpro.
|
|
||||||
SDL_Color g_current_line_color = {100, 255, 100, 255};
|
|
||||||
|
|
||||||
// Grosor global por defecto. Configurable via setLineThickness.
|
// Grosor global por defecto. Configurable via setLineThickness.
|
||||||
float g_current_line_thickness = Defaults::Rendering::LINE_THICKNESS_DEFAULT;
|
float g_current_line_thickness = Defaults::Rendering::LINE_THICKNESS_DEFAULT;
|
||||||
|
|
||||||
@@ -36,8 +31,8 @@ namespace Rendering {
|
|||||||
const auto FX2 = static_cast<float>(x2);
|
const auto FX2 = static_cast<float>(x2);
|
||||||
const auto FY2 = static_cast<float>(y2);
|
const auto FY2 = static_cast<float>(y2);
|
||||||
|
|
||||||
// color.alpha==0 → usar color global (verde fósforo). alpha>0 → color directo.
|
// color.alpha==0 → fallback a DEFAULT_LINE_COLOR (verd fòsfor). alpha>0 → color directo.
|
||||||
const SDL_Color SOURCE = (color.a > 0) ? color : g_current_line_color;
|
const SDL_Color SOURCE = (color.a > 0) ? color : DEFAULT_LINE_COLOR;
|
||||||
const float R = (static_cast<float>(SOURCE.r) * brightness) / 255.0F;
|
const float R = (static_cast<float>(SOURCE.r) * brightness) / 255.0F;
|
||||||
const float G = (static_cast<float>(SOURCE.g) * brightness) / 255.0F;
|
const float G = (static_cast<float>(SOURCE.g) * brightness) / 255.0F;
|
||||||
const float B = (static_cast<float>(SOURCE.b) * brightness) / 255.0F;
|
const float B = (static_cast<float>(SOURCE.b) * brightness) / 255.0F;
|
||||||
@@ -68,10 +63,6 @@ namespace Rendering {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void setLineColor(SDL_Color color) { g_current_line_color = color; }
|
|
||||||
|
|
||||||
auto getLineColor() -> SDL_Color { return g_current_line_color; }
|
|
||||||
|
|
||||||
void setLineThickness(float thickness) {
|
void setLineThickness(float thickness) {
|
||||||
if (thickness > 0.0F) {
|
if (thickness > 0.0F) {
|
||||||
g_current_line_thickness = thickness;
|
g_current_line_thickness = thickness;
|
||||||
|
|||||||
@@ -3,9 +3,10 @@
|
|||||||
//
|
//
|
||||||
// El dibujo de líneas pasa por el pipeline GPU. Las coordenadas (x1,y1,x2,y2)
|
// 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
|
// 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
|
// hace el letterbox a píxeles físicos. El pulse de brillo lo aplica el shader
|
||||||
// línea (lo gestiona ColorOscillator). El grosor es configurable por línea
|
// de postpro (ya no hi ha un ColorOscillator a CPU). El grosor es configurable
|
||||||
// (parámetro thickness>0) o global (g_current_line_thickness vía setLineThickness).
|
// per línia (parámetro thickness>0) o global (g_current_line_thickness vía
|
||||||
|
// setLineThickness).
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
@@ -15,12 +16,17 @@
|
|||||||
|
|
||||||
namespace Rendering {
|
namespace Rendering {
|
||||||
|
|
||||||
|
// Color verd fòsfor CRT per defecte: s'usa quan el caller passa color amb
|
||||||
|
// alpha==0 (sentinella "sense color propi"). Constant immutable: la
|
||||||
|
// semàntica de "color global" ja no existeix (era de l'antic ColorOscillator).
|
||||||
|
constexpr SDL_Color DEFAULT_LINE_COLOR = {.r = 100, .g = 255, .b = 100, .a = 255};
|
||||||
|
|
||||||
// Dibuja una línea entre dos puntos en coordenadas lógicas (1280×720).
|
// 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).
|
// brightness: factor de brillo (0.0..1.0, default 1.0 = brillo máximo).
|
||||||
// Pre-multiplica el RGB del color (color dim sobre fons negre).
|
// Pre-multiplica el RGB del color (color dim sobre fons negre).
|
||||||
// thickness: grosor en píxeles lógicos. Si <= 0 usa g_current_line_thickness.
|
// 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
|
// color: si alpha==0, se usa DEFAULT_LINE_COLOR (verd fòsfor fallback);
|
||||||
// usa este color directo (paleta semántica por entidad).
|
// si alpha>0 se usa este color directo (paleta semántica por entidad).
|
||||||
// alpha: alpha que arriba al GPU (default 1.0 = opac, behavior original).
|
// alpha: alpha que arriba al GPU (default 1.0 = opac, behavior original).
|
||||||
// Valors <1.0 fan que la línia es barregi de veritat sobre el dest
|
// Valors <1.0 fan que la línia es barregi de veritat sobre el dest
|
||||||
// en comptes de sobrepintar-lo (útil per halos translúcids).
|
// en comptes de sobrepintar-lo (útil per halos translúcids).
|
||||||
@@ -49,10 +55,6 @@ namespace Rendering {
|
|||||||
SDL_Color color = {0, 0, 0, 0},
|
SDL_Color color = {0, 0, 0, 0},
|
||||||
SDL_Color glow_color = {0, 0, 0, 0});
|
SDL_Color glow_color = {0, 0, 0, 0});
|
||||||
|
|
||||||
// Color global de las líneas (lo actualiza ColorOscillator vía SDLManager).
|
|
||||||
void setLineColor(SDL_Color color);
|
|
||||||
[[nodiscard]] auto getLineColor() -> SDL_Color;
|
|
||||||
|
|
||||||
// Grosor global por defecto (en píxeles lógicos). Default: 1.5.
|
// Grosor global por defecto (en píxeles lógicos). Default: 1.5.
|
||||||
void setLineThickness(float thickness);
|
void setLineThickness(float thickness);
|
||||||
[[nodiscard]] auto getLineThickness() -> float;
|
[[nodiscard]] auto getLineThickness() -> float;
|
||||||
|
|||||||
Reference in New Issue
Block a user