Corregidos ~2570 issues automáticamente con clang-tidy --fix-errors más ajustes manuales posteriores: - modernize: designated-initializers, trailing-return-type, use-auto, avoid-c-arrays (→ std::array<>), use-ranges, use-emplace, deprecated-headers, use-equals-default, pass-by-value, return-braced-init-list, use-default-member-init - readability: math-missing-parentheses, implicit-bool-conversion, braces-around-statements, isolate-declaration, use-std-min-max, identifier-naming, else-after-return, redundant-casting, convert-member-functions-to-static, make-member-function-const, static-accessed-through-instance - performance: avoid-endl, unnecessary-value-param, type-promotion, inefficient-vector-operation - dead code: XOR_KEY (orphan tras eliminar encryptData/decryptData), dead stores en engine.cpp y png_shape.cpp - NOLINT justificado en 10 funciones con alta complejidad cognitiva (initialize, render, main, processEvents, update×3, performDemoAction, randomizeOnDemoStart, renderDebugHUD, AppLogo::update) Compilación: gcc -Wall sin warnings. clang-tidy: 0 issues. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
65 lines
2.5 KiB
C++
65 lines
2.5 KiB
C++
#pragma once
|
|
|
|
#include <SDL3/SDL_render.h> // Para SDL_Renderer, SDL_Texture
|
|
#include <SDL3/SDL_video.h> // Para SDL_DisplayID, SDL_GetDisplays
|
|
|
|
#include <string> // Para std::string
|
|
|
|
/**
|
|
* @brief Helper class para pre-escalar logos usando stb_image_resize2
|
|
*
|
|
* Proporciona funciones para:
|
|
* - Detectar resolución nativa del monitor
|
|
* - Cargar PNG y escalar a tamaño específico con algoritmos de alta calidad
|
|
* - Crear texturas SDL desde buffers escalados
|
|
*
|
|
* Usado por AppLogo para pre-generar versiones de logos al tamaño exacto
|
|
* de pantalla, eliminando el escalado dinámico de SDL y mejorando calidad visual.
|
|
*/
|
|
class LogoScaler {
|
|
public:
|
|
/**
|
|
* @brief Detecta la resolución nativa del monitor principal
|
|
*
|
|
* @param native_width [out] Ancho nativo del display en píxeles
|
|
* @param native_height [out] Alto nativo del display en píxeles
|
|
* @return true si se pudo detectar, false si hubo error
|
|
*/
|
|
static bool detectNativeResolution(int& native_width, int& native_height);
|
|
|
|
/**
|
|
* @brief Carga un PNG y lo escala al tamaño especificado
|
|
*
|
|
* Usa stb_image para cargar y stb_image_resize2 para escalar con
|
|
* algoritmo Mitchell (balance calidad/velocidad) en espacio sRGB.
|
|
*
|
|
* @param path Ruta al archivo PNG (ej: "data/logo/logo.png")
|
|
* @param target_width Ancho destino en píxeles
|
|
* @param target_height Alto destino en píxeles
|
|
* @param out_width [out] Ancho real de la imagen escalada
|
|
* @param out_height [out] Alto real de la imagen escalada
|
|
* @return Buffer RGBA (4 bytes por píxel) o nullptr si falla
|
|
* IMPORTANTE: El caller debe liberar con free() cuando termine
|
|
*/
|
|
static unsigned char* loadAndScale(const std::string& path,
|
|
int target_width,
|
|
int target_height,
|
|
int& out_width,
|
|
int& out_height);
|
|
|
|
/**
|
|
* @brief Crea una textura SDL desde un buffer RGBA
|
|
*
|
|
* @param renderer Renderizador SDL activo
|
|
* @param data Buffer RGBA (4 bytes por píxel)
|
|
* @param width Ancho del buffer en píxeles
|
|
* @param height Alto del buffer en píxeles
|
|
* @return Textura SDL creada o nullptr si falla
|
|
* IMPORTANTE: El caller debe destruir con SDL_DestroyTexture()
|
|
*/
|
|
static SDL_Texture* createTextureFromBuffer(SDL_Renderer* renderer,
|
|
unsigned char* data,
|
|
int width,
|
|
int height);
|
|
};
|