<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Lily</title>
    <description>The latest articles on DEV Community by Lily (@abrazos_programacion).</description>
    <link>https://dev.to/abrazos_programacion</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F3912638%2Fe5c4d7f8-fb6a-4eb6-ab41-b94d734d4ae8.jpg</url>
      <title>DEV Community: Lily</title>
      <link>https://dev.to/abrazos_programacion</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/abrazos_programacion"/>
    <language>en</language>
    <item>
      <title>Rompiendo la cuarta pared en Ren'Py: El "Efecto Monika" y la Esfera Matemática (Parte 1)</title>
      <dc:creator>Lily</dc:creator>
      <pubDate>Tue, 02 Jun 2026 03:48:29 +0000</pubDate>
      <link>https://dev.to/abrazos_programacion/rompiendo-la-cuarta-pared-en-renpy-el-efecto-monika-y-la-esfera-matematica-parte-1-chm</link>
      <guid>https://dev.to/abrazos_programacion/rompiendo-la-cuarta-pared-en-renpy-el-efecto-monika-y-la-esfera-matematica-parte-1-chm</guid>
      <description>&lt;p&gt;¿Te acuerdas de la primera vez que jugaste &lt;em&gt;Doki Doki Literature Club&lt;/em&gt; y &lt;strong&gt;Monika te llamó por tu nombre real&lt;/strong&gt;? Ese escalofrío es el resultado de un truco de ingeniería genial. En esta primera entrega de nuestro &lt;strong&gt;&lt;em&gt;Desafío de Construcción Extrema: Edición Ren'Py&lt;/em&gt;&lt;/strong&gt;, vamos a crear una carpa mística donde nuestra adivina, &lt;em&gt;Madame Zora&lt;/em&gt;, usará Python para calcular días de la semana y "hackear" el nombre del sistema operativo del jugador.&lt;/p&gt;

&lt;h2&gt;
  
  
  El Poder Matemático: Adivinar el Día de la Semana 🔮
&lt;/h2&gt;

&lt;p&gt;Detrás de la magia del calendario hay un algoritmo clásico de la matemática (como el de &lt;strong&gt;&lt;em&gt;Doomsday&lt;/em&gt;&lt;/strong&gt;). En lugar de calcularlo a mano, usaremos la &lt;strong&gt;&lt;em&gt;librería nativa datetime de Python dentro de Ren'Py&lt;/em&gt;&lt;/strong&gt; para procesar cualquier fecha que el usuario ingrese por teclado.&lt;/p&gt;

&lt;h2&gt;
  
  
  El Truco de Monika: Leyendo el Sistema 🖥️
&lt;/h2&gt;

&lt;p&gt;Los videojuegos corren sobre un sistema operativo que sabe exactamente quién inició sesión. Con las librerías &lt;em&gt;os&lt;/em&gt; y &lt;em&gt;getpass&lt;/em&gt;, podemos preguntarle a la computadora el &lt;em&gt;nombre del usuario&lt;/em&gt; y guardarlo en una variable secreta.&lt;/p&gt;

&lt;h2&gt;
  
  
  El Código Base (Script.rpy) 📜
&lt;/h2&gt;

&lt;p&gt;Copia y pega este código en tu proyecto de Ren'Py para ver la magia en acción:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight python"&gt;&lt;code&gt;&lt;span class="n"&gt;init&lt;/span&gt; &lt;span class="n"&gt;python&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
    &lt;span class="kn"&gt;import&lt;/span&gt; &lt;span class="n"&gt;datetime&lt;/span&gt;
    &lt;span class="kn"&gt;import&lt;/span&gt; &lt;span class="n"&gt;getpass&lt;/span&gt;
    &lt;span class="kn"&gt;import&lt;/span&gt; &lt;span class="n"&gt;os&lt;/span&gt;

    &lt;span class="c1"&gt;# Función para descifrar el día de la semana
&lt;/span&gt;    &lt;span class="k"&gt;def&lt;/span&gt; &lt;span class="nf"&gt;calcular_dia&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;fecha_texto&lt;/span&gt;&lt;span class="p"&gt;):&lt;/span&gt;
        &lt;span class="k"&gt;try&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
            &lt;span class="n"&gt;fecha_objeto&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;datetime&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;datetime&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;strptime&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;fecha_texto&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;%d/%m/%Y&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
            &lt;span class="n"&gt;numero_dia&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;fecha_objeto&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;weekday&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt;
            &lt;span class="n"&gt;dias_semana&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Lunes&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Martes&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Miércoles&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Jueves&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Viernes&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Sábado&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Domingo&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt;
            &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="n"&gt;dias_semana&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="n"&gt;numero_dia&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt;
        &lt;span class="k"&gt;except&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
            &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="bp"&gt;None&lt;/span&gt; &lt;span class="c1"&gt;# Si el usuario escribe texto inválido, no se rompe el juego
&lt;/span&gt;
    &lt;span class="c1"&gt;# Función para obtener el usuario real de la PC
&lt;/span&gt;    &lt;span class="k"&gt;def&lt;/span&gt; &lt;span class="nf"&gt;obtener_nombre_sistema&lt;/span&gt;&lt;span class="p"&gt;():&lt;/span&gt;
        &lt;span class="k"&gt;try&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
            &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="n"&gt;getpass&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;getuser&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt;
        &lt;span class="k"&gt;except&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
            &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="n"&gt;os&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;environ&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;get&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;USERNAME&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Viajero&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;

&lt;span class="n"&gt;define&lt;/span&gt; &lt;span class="n"&gt;adivina&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nc"&gt;Character&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Madame Zora&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;color&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;#993399&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;

&lt;span class="n"&gt;label&lt;/span&gt; &lt;span class="n"&gt;start&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
    &lt;span class="n"&gt;scene&lt;/span&gt; &lt;span class="n"&gt;bg_tienda_mistica&lt;/span&gt;
    &lt;span class="err"&gt;$&lt;/span&gt; &lt;span class="n"&gt;nombre_real&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nf"&gt;obtener_nombre_sistema&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt;

    &lt;span class="n"&gt;adivina&lt;/span&gt; &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Dime, alma viajera... ¿cómo te llamas en este plano?&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;
    &lt;span class="err"&gt;$&lt;/span&gt; &lt;span class="n"&gt;nombre_juego&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;renpy&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;input&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Introduce tu nombre:&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="p"&gt;).&lt;/span&gt;&lt;span class="nf"&gt;strip&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt;

    &lt;span class="k"&gt;if&lt;/span&gt; &lt;span class="ow"&gt;not&lt;/span&gt; &lt;span class="n"&gt;nombre_juego&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
        &lt;span class="err"&gt;$&lt;/span&gt; &lt;span class="n"&gt;nombre_juego&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Forastero&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;

    &lt;span class="n"&gt;adivina&lt;/span&gt; &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Bien, [nombre_juego]. Ahora dime una fecha importante en formato DD/MM/AAAA.&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;

&lt;span class="n"&gt;label&lt;/span&gt; &lt;span class="n"&gt;pedir_fecha&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
    &lt;span class="err"&gt;$&lt;/span&gt; &lt;span class="n"&gt;fecha_ingresada&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;renpy&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;input&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Fecha (ejemplo: 20/05/1995):&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="p"&gt;).&lt;/span&gt;&lt;span class="nf"&gt;strip&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt;
    &lt;span class="err"&gt;$&lt;/span&gt; &lt;span class="n"&gt;resultado_dia&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nf"&gt;calcular_dia&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;fecha_ingresada&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;

    &lt;span class="k"&gt;if&lt;/span&gt; &lt;span class="n"&gt;resultado_dia&lt;/span&gt; &lt;span class="ow"&gt;is&lt;/span&gt; &lt;span class="bp"&gt;None&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
        &lt;span class="n"&gt;adivina&lt;/span&gt; &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Las brumas están densas... Esa fecha no es válida. Inténtalo de nuevo.&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;
        &lt;span class="n"&gt;jump&lt;/span&gt; &lt;span class="n"&gt;pedir_fecha&lt;/span&gt;

    &lt;span class="n"&gt;adivina&lt;/span&gt; &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;¡La esfera brilla! El día [fecha_ingresada] fue un majestuoso **[resultado_dia]**.&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;
    &lt;span class="n"&gt;adivina&lt;/span&gt; &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Pero mi esfera ve mucho más allá...&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;

    &lt;span class="c1"&gt;# Confrontando al jugador con el truco de Monika
&lt;/span&gt;    &lt;span class="k"&gt;if&lt;/span&gt; &lt;span class="n"&gt;nombre_juego&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;lower&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;==&lt;/span&gt; &lt;span class="n"&gt;nombre_real&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;lower&lt;/span&gt;&lt;span class="p"&gt;():&lt;/span&gt;
        &lt;span class="n"&gt;adivina&lt;/span&gt; &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Veo que eres honesto. Tu espíritu coincide con el nombre de tu máquina: **[nombre_real]**.&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;
    &lt;span class="k"&gt;else&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
        &lt;span class="n"&gt;adivina&lt;/span&gt; &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;Has intentado ocultarte bajo el nombre de &lt;/span&gt;&lt;span class="sh"&gt;'&lt;/span&gt;&lt;span class="s"&gt;[nombre_juego]&lt;/span&gt;&lt;span class="sh"&gt;'&lt;/span&gt;&lt;span class="s"&gt;...&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;
        &lt;span class="n"&gt;adivina&lt;/span&gt; &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;¡Pero a la esfera no se le miente! Tu verdadero nombre en el mundo de metal es... **[nombre_real]**.&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;

    &lt;span class="k"&gt;return&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Visita mi canal de Youtube para más explicación:&lt;br&gt;
  &lt;iframe src="https://www.youtube.com/embed/naubsxwhVxk"&gt;
  &lt;/iframe&gt;
&lt;/p&gt;

</description>
      <category>renpy</category>
      <category>python</category>
      <category>tutorial</category>
      <category>programming</category>
    </item>
    <item>
      <title>Ren'Py: ¡Deja de usar mil "if" para tus Sprites! (image vs. ConditionSwitch)</title>
      <dc:creator>Lily</dc:creator>
      <pubDate>Thu, 14 May 2026 04:46:22 +0000</pubDate>
      <link>https://dev.to/abrazos_programacion/renpy-deja-de-usar-mil-if-para-tus-sprites-image-vs-conditionswitch-521i</link>
      <guid>https://dev.to/abrazos_programacion/renpy-deja-de-usar-mil-if-para-tus-sprites-image-vs-conditionswitch-521i</guid>
      <description>&lt;p&gt;Hola a todos. En el proceso de desarrollo de mi visual novel, "Desafío Extremo de Construcción: Edición Ren'Py", me encontré con un problema común: mi código se estaba llenando de condicionales cada vez que quería mostrar a un personaje con una expresión diferente según las decisiones del jugador.&lt;/p&gt;

&lt;p&gt;Hoy les comparto cómo pasé de un código manual y propenso a errores a uno dinámico y elegante.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;1. El método manual: La sentencia &lt;em&gt;image&lt;/em&gt;&lt;/strong&gt;&lt;br&gt;
Normalmente, definimos una imagen de forma estática. Es sencillo y directo:&lt;/p&gt;

&lt;p&gt;Fragmento de código:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight python"&gt;&lt;code&gt;&lt;span class="n"&gt;image&lt;/span&gt; &lt;span class="n"&gt;lolo_feliz&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;images/lolo/lolo_base_feliz.png&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;


&lt;p&gt;&lt;em&gt;El problema:&lt;/em&gt; Si Lolo (nuestro pragmático constructor) cambia de ánimo basado en una variable, terminamos escribiendo esto en cada parte de la historia:&lt;/p&gt;

&lt;p&gt;Fragmento de código:&lt;br&gt;
&lt;/p&gt;
&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight python"&gt;&lt;code&gt;&lt;span class="k"&gt;if&lt;/span&gt; &lt;span class="n"&gt;puntos_felicidad&lt;/span&gt; &lt;span class="o"&gt;&amp;gt;&lt;/span&gt; &lt;span class="mi"&gt;10&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
    &lt;span class="n"&gt;show&lt;/span&gt; &lt;span class="n"&gt;lolo_feliz&lt;/span&gt;
&lt;span class="k"&gt;else&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
    &lt;span class="n"&gt;show&lt;/span&gt; &lt;span class="n"&gt;lolo_serio&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;


&lt;p&gt;Esto funciona, pero si tienes 50 escenas, &lt;em&gt;¡son 50 bloques de código que mantener!.&lt;/em&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;2. La solución Pro: ConditionSwitch&lt;/strong&gt;&lt;br&gt;
Aquí es donde aplicamos un verdadero "makeover" al código. &lt;em&gt;ConditionSwitch&lt;/em&gt; permite que una sola etiqueta de imagen cambie su contenido automáticamente según el estado de tus variables.&lt;/p&gt;

&lt;p&gt;El código elegante:&lt;br&gt;
    Fragmento de código:&lt;br&gt;
&lt;/p&gt;
&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight python"&gt;&lt;code&gt;&lt;span class="n"&gt;image&lt;/span&gt; &lt;span class="n"&gt;lolo&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nc"&gt;ConditionSwitch&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
    &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;puntos_felicidad &amp;gt; 10&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;images/lolo/lolo_base_feliz.png&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;True&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="sh"&gt;"&lt;/span&gt;&lt;span class="s"&gt;images/lolo/lolo_base_serio.png&lt;/span&gt;&lt;span class="sh"&gt;"&lt;/span&gt; &lt;span class="c1"&gt;# El "True" actúa como un 'else'
&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;


&lt;p&gt;&lt;strong&gt;¿Por qué es mejor?&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;1. Automatización:&lt;/strong&gt; Solo escribes &lt;em&gt;show lolo&lt;/em&gt;. Ren'Py se encarga de revisar qué imagen mostrar en cada momento.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;2. Limpieza:&lt;/strong&gt; Tu script de historia se enfoca en la narrativa, no en la lógica de imágenes.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;3. Escalabilidad:&lt;/strong&gt; Si mañana añades una tercera expresión (por ejemplo, &lt;em&gt;"Lolo enojado"&lt;/em&gt;), solo cambias la definición inicial en una sola línea.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Conclusión y Aprendizaje&lt;/strong&gt;&lt;br&gt;
A veces, por querer avanzar rápido, usamos lo que ya conocemos (como los if/else básicos). Pero detenerse a aprender estas herramientas nos hace mejores desarrolladores.&lt;/p&gt;

&lt;p&gt;¡Espero que este tip les sirva para sus proyectos! Si quieren ver esto en acción, no se pierdan el Short que acabo de subir al canal:   &lt;/p&gt;
&lt;div&gt;
    &lt;iframe src="https://www.youtube.com/embed/-BOkpwKr5sI"&gt;
    &lt;/iframe&gt;
  &lt;/div&gt;


&lt;p&gt;Para más contenido, visita mi canal:&lt;br&gt;
&lt;/p&gt;
&lt;div class="crayons-card c-embed text-styles text-styles--secondary"&gt;
    &lt;div class="c-embed__content"&gt;
        &lt;div class="c-embed__cover"&gt;
          &lt;a href="https://www.youtube.com/@Bonnie-s2w" class="c-link align-middle" rel="noopener noreferrer"&gt;
            &lt;img alt="" src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fyt3.googleusercontent.com%2F9Ylb3Kb41JjqudNI8uC8_n-NNus_mBGMyLOxYpnmqR2HsE3MANtQwdblyNOWPcglQ4EHltB0%3Ds900-c-k-c0x00ffffff-no-rj" height="900" class="m-0" width="900"&gt;
          &lt;/a&gt;
        &lt;/div&gt;
      &lt;div class="c-embed__body"&gt;
        &lt;h2 class="fs-xl lh-tight"&gt;
          &lt;a href="https://www.youtube.com/@Bonnie-s2w" rel="noopener noreferrer" class="c-link"&gt;
            Abrazos de Programación por Lily - YouTube
          &lt;/a&gt;
        &lt;/h2&gt;
          &lt;p class="truncate-at-3"&gt;
            📜 Aviso de Derechos de Autor (Copyright)
© 2026 Abrazos de Programación por Lily. Todos los derechos reservados.

*El contenido de este canal, incluyendo el guion, las animaciones, los guiones de código y la presentación de los personajes (Lala, Marcus, Joy y Lolo), es propiedad intelectual exclusiva de la creadora del canal.*

*¿Qué está permitido?*

Compartir el enlace de los videos en redes sociales o foros educativos.

Utilizar el código y las técnicas explicadas en tus propios proyectos de programación.

*¿Qué NO está permitido?*

*La descarga, copia, reproducción o resubida total o parcial de este contenido en otras plataformas o canales (YouTube, TikTok, Instagram, etc.) con fines comerciales o sin atribución de la fuente original.*

*El uso de nuestros personajes o material gráfico para obras derivadas no autorizadas.*

*Cualquier uso no autorizado será reportado bajo las políticas de derechos de autor y las leyes de propiedad intelectual vigentes.*

          &lt;/p&gt;
        &lt;div class="color-secondary fs-s flex items-center"&gt;
            &lt;img alt="favicon" class="c-embed__favicon m-0 mr-2 radius-0" src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fwww.youtube.com%2Fs%2Fdesktop%2F47009d78%2Fimg%2Ffavicon.ico" width="48" height="48"&gt;
          youtube.com
        &lt;/div&gt;
      &lt;/div&gt;
    &lt;/div&gt;
&lt;/div&gt;



</description>
      <category>renpy</category>
      <category>gamedev</category>
      <category>python</category>
      <category>tutorial</category>
    </item>
    <item>
      <title>De la Idea al Píxel: Cómo Implementar el Acotamiento de Cámara Usando Min y Max en Python</title>
      <dc:creator>Lily</dc:creator>
      <pubDate>Wed, 06 May 2026 01:46:24 +0000</pubDate>
      <link>https://dev.to/abrazos_programacion/de-la-idea-al-pixel-como-implementar-el-acotamiento-de-camara-usando-min-y-max-en-python-3boa</link>
      <guid>https://dev.to/abrazos_programacion/de-la-idea-al-pixel-como-implementar-el-acotamiento-de-camara-usando-min-y-max-en-python-3boa</guid>
      <description>&lt;p&gt;En la primera parte de nuestro tutorial aprendimos a alinear los elementos de nuestro mundo usando operaciones aritméticas básicas. Hoy daremos el siguiente paso lógico y práctico.&lt;/p&gt;

&lt;p&gt;Cuando creamos videojuegos en 2D con mapas basados en cuadrículas (tiles), queremos que la cámara siga al jugador. Pero, &lt;em&gt;¿qué pasa cuando el jugador se acerca a los bordes del nivel?&lt;/em&gt; Sin el control adecuado, la cámara se movería de más, mostrando un fondo vacío o el "vacío" del espacio de la ventana.&lt;/p&gt;

&lt;p&gt;Para solucionar esto de forma elegante, utilizamos una técnica matemática llamada acotamiento o clamping.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;El Reto Espacial&lt;/strong&gt;&lt;br&gt;
Imaginemos que tenemos una pantalla con una resolución fija y un mapa que es mucho más grande que dicha pantalla.&lt;/p&gt;

&lt;p&gt;Para centrar a nuestro personaje, calculamos un desplazamiento &lt;em&gt;(offset)&lt;/em&gt; ideal. Sin embargo, este &lt;em&gt;offset&lt;/em&gt; puede salirse de los límites permitidos. Para evitarlo, encerramos nuestro cálculo entre los valores mínimos y máximos que puede tomar la cámara en el mundo.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;El Modelo Matemático&lt;/strong&gt;&lt;br&gt;
Para acotar el valor de la cámara, combinamos las funciones &lt;em&gt;min()&lt;/em&gt; y &lt;em&gt;max()&lt;/em&gt;. La ecuación general que aplicamos es:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Offset_final = max(Límite_Inferior, min(Límite_Superior, Offset_ideal))&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;&lt;em&gt;Implementación en el Código&lt;/em&gt;&lt;br&gt;
En nuestro script, primero calculamos el tamaño total del mapa en píxeles multiplicando el número de celdas (tiles) por su dimensión:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight python"&gt;&lt;code&gt;&lt;span class="c1"&gt;# El ancho y alto total del mapa en píxeles
&lt;/span&gt;&lt;span class="n"&gt;map_width_pixels&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nf"&gt;len&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;store&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;nivel_mapa&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="mi"&gt;0&lt;/span&gt;&lt;span class="p"&gt;])&lt;/span&gt; &lt;span class="o"&gt;*&lt;/span&gt; &lt;span class="n"&gt;store&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;TILE_SIZE&lt;/span&gt;
&lt;span class="n"&gt;map_height_pixels&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nf"&gt;len&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;store&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;nivel_mapa&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;*&lt;/span&gt; &lt;span class="n"&gt;store&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;TILE_SIZE&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;


&lt;p&gt;Una vez que tenemos el tamaño del mapa, determinamos los límites del desplazamiento. Por ejemplo, en el eje X, el límite superior no puede ser mayor a cero (de lo contrario, veríamos el fondo a la izquierda de nuestro mapa) y el límite inferior se obtiene restando el ancho de la ventana menos el ancho del mapa.&lt;br&gt;
&lt;/p&gt;
&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight python"&gt;&lt;code&gt;&lt;span class="c1"&gt;# Límites del desplazamiento de la cámara para X
&lt;/span&gt;&lt;span class="n"&gt;max_offset_x&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="mi"&gt;0&lt;/span&gt;
&lt;span class="n"&gt;min_offset_x&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;store&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;SCREEN_WIDTH&lt;/span&gt; &lt;span class="o"&gt;-&lt;/span&gt; &lt;span class="n"&gt;map_width_pixels&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;


&lt;p&gt;Finalmente, calculamos la posición ideal para centrar a nuestro personaje y aplicamos la función matemática de acotamiento:&lt;br&gt;
&lt;/p&gt;
&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight python"&gt;&lt;code&gt;&lt;span class="c1"&gt;# Posición ideal de la cámara para centrar a Mario
&lt;/span&gt;&lt;span class="n"&gt;ideal_camera_x_offset&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nf"&gt;int&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;store&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;SCREEN_WIDTH&lt;/span&gt; &lt;span class="o"&gt;/&lt;/span&gt; &lt;span class="mi"&gt;2&lt;/span&gt; &lt;span class="o"&gt;-&lt;/span&gt; &lt;span class="n"&gt;mario_world_center_x&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;


&lt;span class="c1"&gt;# Aplicación del límite
&lt;/span&gt;&lt;span class="n"&gt;store&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;camera_x_offset&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nf"&gt;max&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;min_offset_x&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nf"&gt;min&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;max_offset_x&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;ideal_camera_x_offset&lt;/span&gt;&lt;span class="p"&gt;))&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;


&lt;p&gt;&lt;em&gt;Nota:&lt;/em&gt; Este mismo bloque se aplica para el eje Y, intercambiando las variables correspondientes a la altura.&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Conclusión&lt;/em&gt;&lt;br&gt;
Con estas sencillas líneas de código, hemos logrado un movimiento de cámara fluido, evitando que se muestren áreas fuera de los límites del nivel. ¡Un paso más para lograr que nuestro juego se vea profesional y pulido!&lt;/p&gt;

&lt;p&gt;Si no leíste la primera parte del tutorial: &lt;/p&gt;
&lt;div class="ltag__link--embedded"&gt;
  &lt;div class="crayons-story "&gt;
  &lt;a href="https://dev.to/abrazos_programacion/de-la-grilla-a-la-pantalla-como-centrar-y-alinear-sprites-con-aritmetica-basica-1nbc" class="crayons-story__hidden-navigation-link"&gt;De la Grilla a la Pantalla: Cómo Centrar y Alinear Sprites con Aritmética Básica.&lt;/a&gt;


  &lt;div class="crayons-story__body crayons-story__body-full_post"&gt;
    &lt;div class="crayons-story__top"&gt;
      &lt;div class="crayons-story__meta"&gt;
        &lt;div class="crayons-story__author-pic"&gt;

          &lt;a href="/abrazos_programacion" class="crayons-avatar  crayons-avatar--l  "&gt;
            &lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F3912638%2Fe5c4d7f8-fb6a-4eb6-ab41-b94d734d4ae8.jpg" alt="abrazos_programacion profile" class="crayons-avatar__image" width="527" height="534"&gt;
          &lt;/a&gt;
        &lt;/div&gt;
        &lt;div&gt;
          &lt;div&gt;
            &lt;a href="/abrazos_programacion" class="crayons-story__secondary fw-medium m:hidden"&gt;
              Lily
            &lt;/a&gt;
            &lt;div class="profile-preview-card relative mb-4 s:mb-0 fw-medium hidden m:inline-block"&gt;
              
                Lily
                
              
              &lt;div id="story-author-preview-content-3617810" class="profile-preview-card__content crayons-dropdown branded-7 p-4 pt-0"&gt;
                &lt;div class="gap-4 grid"&gt;
                  &lt;div class="-mt-4"&gt;
                    &lt;a href="/abrazos_programacion" class="flex"&gt;
                      &lt;span class="crayons-avatar crayons-avatar--xl mr-2 shrink-0"&gt;
                        &lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F3912638%2Fe5c4d7f8-fb6a-4eb6-ab41-b94d734d4ae8.jpg" class="crayons-avatar__image" alt="" width="527" height="534"&gt;
                      &lt;/span&gt;
                      &lt;span class="crayons-link crayons-subtitle-2 mt-5"&gt;Lily&lt;/span&gt;
                    &lt;/a&gt;
                  &lt;/div&gt;
                  &lt;div class="print-hidden"&gt;
                    
                      Follow
                    
                  &lt;/div&gt;
                  &lt;div class="author-preview-metadata-container"&gt;&lt;/div&gt;
                &lt;/div&gt;
              &lt;/div&gt;
            &lt;/div&gt;

          &lt;/div&gt;
          &lt;a href="https://dev.to/abrazos_programacion/de-la-grilla-a-la-pantalla-como-centrar-y-alinear-sprites-con-aritmetica-basica-1nbc" class="crayons-story__tertiary fs-xs"&gt;&lt;time&gt;May 6&lt;/time&gt;&lt;span class="time-ago-indicator-initial-placeholder"&gt;&lt;/span&gt;&lt;/a&gt;
        &lt;/div&gt;
      &lt;/div&gt;

    &lt;/div&gt;

    &lt;div class="crayons-story__indention"&gt;
      &lt;h2 class="crayons-story__title crayons-story__title-full_post"&gt;
        &lt;a href="https://dev.to/abrazos_programacion/de-la-grilla-a-la-pantalla-como-centrar-y-alinear-sprites-con-aritmetica-basica-1nbc" id="article-link-3617810"&gt;
          De la Grilla a la Pantalla: Cómo Centrar y Alinear Sprites con Aritmética Básica.
        &lt;/a&gt;
      &lt;/h2&gt;
        &lt;div class="crayons-story__tags"&gt;
            &lt;a class="crayons-tag  crayons-tag--monochrome " href="/t/renpy"&gt;&lt;span class="crayons-tag__prefix"&gt;#&lt;/span&gt;renpy&lt;/a&gt;
            &lt;a class="crayons-tag  crayons-tag--monochrome " href="/t/python"&gt;&lt;span class="crayons-tag__prefix"&gt;#&lt;/span&gt;python&lt;/a&gt;
            &lt;a class="crayons-tag  crayons-tag--monochrome " href="/t/gamedev"&gt;&lt;span class="crayons-tag__prefix"&gt;#&lt;/span&gt;gamedev&lt;/a&gt;
            &lt;a class="crayons-tag  crayons-tag--monochrome " href="/t/tutorial"&gt;&lt;span class="crayons-tag__prefix"&gt;#&lt;/span&gt;tutorial&lt;/a&gt;
        &lt;/div&gt;
      &lt;div class="crayons-story__bottom"&gt;
        &lt;div class="crayons-story__details"&gt;
            &lt;a href="https://dev.to/abrazos_programacion/de-la-grilla-a-la-pantalla-como-centrar-y-alinear-sprites-con-aritmetica-basica-1nbc#comments" class="crayons-btn crayons-btn--s crayons-btn--ghost crayons-btn--icon-left flex items-center"&gt;
              Comments


              &lt;span class="hidden s:inline"&gt;Add Comment&lt;/span&gt;
            &lt;/a&gt;
        &lt;/div&gt;
        &lt;div class="crayons-story__save"&gt;
          &lt;small class="crayons-story__tertiary fs-xs mr-2"&gt;
            3 min read
          &lt;/small&gt;
            
              &lt;span class="bm-initial"&gt;
                

              &lt;/span&gt;
              &lt;span class="bm-success"&gt;
                

              &lt;/span&gt;
            
        &lt;/div&gt;
      &lt;/div&gt;
    &lt;/div&gt;
  &lt;/div&gt;
&lt;/div&gt;


&lt;/div&gt;
&lt;br&gt;
 

&lt;p&gt;Ejemplo de nuestro video explicando este proceso:&lt;br&gt;
(Próximamente en Youtube).&lt;br&gt;
Por mientras, puedes visitar mi canal para aprender Ren'Py: &lt;/p&gt;
&lt;div class="crayons-card c-embed text-styles text-styles--secondary"&gt;
    &lt;div class="c-embed__content"&gt;
        &lt;div class="c-embed__cover"&gt;
          &lt;a href="https://www.youtube.com/@Bonnie-s2w" class="c-link align-middle" rel="noopener noreferrer"&gt;
            &lt;img alt="" src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fyt3.googleusercontent.com%2F9Ylb3Kb41JjqudNI8uC8_n-NNus_mBGMyLOxYpnmqR2HsE3MANtQwdblyNOWPcglQ4EHltB0%3Ds900-c-k-c0x00ffffff-no-rj" height="900" class="m-0" width="900"&gt;
          &lt;/a&gt;
        &lt;/div&gt;
      &lt;div class="c-embed__body"&gt;
        &lt;h2 class="fs-xl lh-tight"&gt;
          &lt;a href="https://www.youtube.com/@Bonnie-s2w" rel="noopener noreferrer" class="c-link"&gt;
            Coding Cuddles - YouTube
          &lt;/a&gt;
        &lt;/h2&gt;
          &lt;p class="truncate-at-3"&gt;
            Turn your stories into video games! 🎮✨

Have you ever dreamed of creating your own visual novel or an amazing game, but the code intimidates you a little? You're in the right place!

Here, we demystify programming. With Ren'Py and Python, we'll learn from scratch (yes, from "Hello World") to creating amazing mechanics, vibrant characters, and unique systems. No boring language, just lots of patience and, above all, tons of fun!

Subscribe and let's start writing the code for your next big hit. Your developer adventure starts today! 🚀

❤️███████▓▒ IMPORTANT NOTICE ░▒▓████████❤️
"This tutorial has been a labor of love. I've used AI tools (Google AI/Gemini) to bring my protagonist's voice to life and generate visual and audio resources that allow me to focus on what I love most: teaching you programming. AI is my assistant, but the heart and structure of this course are my own. Thank you for being part of this dream!"
          &lt;/p&gt;
        &lt;div class="color-secondary fs-s flex items-center"&gt;
            &lt;img alt="favicon" class="c-embed__favicon m-0 mr-2 radius-0" src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fwww.youtube.com%2Fs%2Fdesktop%2F2279fdfc%2Fimg%2Ffavicon.ico" width="48" height="48"&gt;
          youtube.com
        &lt;/div&gt;
      &lt;/div&gt;
    &lt;/div&gt;
&lt;/div&gt;


&lt;p&gt;Si te ha resultado útil este artículo, recuerda dejar tu reacción y compartirlo. ¡Nos vemos en el próximo tutorial!&lt;/p&gt;

</description>
      <category>renpy</category>
      <category>gamedev</category>
      <category>python</category>
      <category>tutorial</category>
    </item>
    <item>
      <title>De la Grilla a la Pantalla: Cómo Centrar y Alinear Sprites con Aritmética Básica.</title>
      <dc:creator>Lily</dc:creator>
      <pubDate>Wed, 06 May 2026 01:32:38 +0000</pubDate>
      <link>https://dev.to/abrazos_programacion/de-la-grilla-a-la-pantalla-como-centrar-y-alinear-sprites-con-aritmetica-basica-1nbc</link>
      <guid>https://dev.to/abrazos_programacion/de-la-grilla-a-la-pantalla-como-centrar-y-alinear-sprites-con-aritmetica-basica-1nbc</guid>
      <description>&lt;p&gt;¡Hola a todos! Bienvenidos a un nuevo tutorial de desarrollo de videojuegos. Si estás dando tus primeros pasos creando un juego basado en rejillas o tiles (como los clásicos juegos de plataformas o RPG de tablero), tarde o temprano te enfrentarás a un problema muy común: &lt;em&gt;¿cómo hacer que tu personaje quede perfectamente centrado en su celda y no flotando en una esquina?&lt;/em&gt;&lt;/p&gt;

&lt;p&gt;Hoy vamos a desmitificar la fórmula matemática detrás de la alineación de objetos en pantalla usando aritmética que ya conoces: multiplicar, dividir y sumar.&lt;/p&gt;

&lt;p&gt;&lt;em&gt;El Sistema de Coordenadas: Lógica vs. Píxeles.&lt;/em&gt;&lt;br&gt;
Cuando diseñamos un mapa en un array o matriz, nuestro juego piensa en "coordenadas lógicas" (bloques enteros):&lt;/p&gt;

&lt;p&gt;El jugador está en la columna &lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;X = 0, fila Y = 10.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Sin embargo, el motor gráfico de tu pantalla no entiende de &lt;em&gt;"bloques"&lt;/em&gt;, sino de &lt;em&gt;píxeles&lt;/em&gt;. Para poder dibujar a nuestro personaje, necesitamos traducir esa  posición lógica a coordenadas reales de pantalla.&lt;/p&gt;

&lt;p&gt;Para esta conversión, necesitamos conocer una variable clave: el tamaño de nuestro tile (en nuestro proyecto, TILE_SIZE = 90 píxeles).&lt;/p&gt;
&lt;h3&gt;
  
  
  Paso 1: La Conversión Básica (El Desplazamiento)
&lt;/h3&gt;

&lt;p&gt;La primera ecuación intuitiva que se nos viene a la mente para calcular la posición en píxeles es multiplicar la coordenada de la grilla por el tamaño del tile:&lt;br&gt;
`&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Posición_píxeles = Posición_grilla x Tamaño_del_Tile&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Si Mario está en la columna 0 de la grilla:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Posición = 0 x 90 = 0 (Píxel 0)&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Si se mueve a la columna 3:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Posición = 3 x 90 = 270 (Píxel 270)&lt;br&gt;
`&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;&lt;em&gt;El problema:&lt;/em&gt; Esta ecuación calcula la esquina superior izquierda de la celda. Si dibujas el personaje usando este punto de referencia, tu sprite quedará alineado al borde del bloque, dando la sensación de que flota o está descuadrado respecto al entorno.&lt;/p&gt;
&lt;h2&gt;
  
  
  Paso 2: La Magia de la Alineación (Encontrar el Centro)
&lt;/h2&gt;

&lt;p&gt;Para que el personaje se ubique exactamente en el centro geométrico del bloque, debemos aplicar un desfase o ajuste. &lt;em&gt;¿Cómo encontramos el punto medio de cualquier objeto?&lt;/em&gt; Dividiéndolo entre 2.&lt;br&gt;
Sumando la mitad del tamaño de nuestro tile a la ecuación anterior, logramos el centrado perfecto:&lt;br&gt;
`&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Centro = (Posición_grilla x Tamaño_del_Tile) + (Tamaño_del_Tile / 2)&lt;br&gt;
`&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;&lt;em&gt;Traduciendo la matemática a código (Python/Ren'Py):&lt;/em&gt; En nuestro código, el cálculo del centro del mundo para Mario se escribe de la siguiente manera:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight python"&gt;&lt;code&gt;&lt;span class="c1"&gt;# Posición central de Mario en el mundo en píxeles
&lt;/span&gt;&lt;span class="n"&gt;mario_world_center_x&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;store&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;mario_pos_x&lt;/span&gt; &lt;span class="o"&gt;*&lt;/span&gt; &lt;span class="n"&gt;store&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;TILE_SIZE&lt;/span&gt; &lt;span class="o"&gt;+&lt;/span&gt; &lt;span class="n"&gt;store&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;TILE_SIZE&lt;/span&gt; &lt;span class="o"&gt;/&lt;/span&gt; &lt;span class="mi"&gt;2&lt;/span&gt;
&lt;span class="n"&gt;mario_world_center_y&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;store&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;mario_pos_y&lt;/span&gt; &lt;span class="o"&gt;*&lt;/span&gt; &lt;span class="n"&gt;store&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;TILE_SIZE&lt;/span&gt; &lt;span class="o"&gt;+&lt;/span&gt; &lt;span class="n"&gt;store&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="n"&gt;TILE_SIZE&lt;/span&gt; &lt;span class="o"&gt;/&lt;/span&gt; &lt;span class="mi"&gt;2&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;


&lt;p&gt;Si nuestro TILE_SIZE es de 90 píxeles, el programa calcula la esquina del bloque y le suma exactamente 45 píxeles de ajuste. ¡De esta manera, el punto de registro del personaje coincide siempre con el corazón geométrico de su celda!&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Conclusión&lt;/em&gt;&lt;br&gt;
Como puedes ver, no necesitas fórmulas físicas súper complejas para empezar a estructurar la lógica espacial de tu juego. Con una simple multiplicación y una división básica, lograste que tu entorno visual responda de forma simétrica y profesional.&lt;/p&gt;

&lt;p&gt;En el próximo tutorial, utilizaremos este centro que acabamos de calcular para enseñarle a la cámara cómo seguir al jugador sin salirse de los límites del mapa.&lt;/p&gt;

&lt;p&gt;¡Si te ha servido esta explicación, deja tu reacción y escribe en los comentarios qué otra lógica matemática te gustaría desglosar!&lt;br&gt;
Puedes visitar mi canal de Youtube para aprender acerca de Ren`Py: &lt;br&gt;
&lt;/p&gt;
&lt;div class="crayons-card c-embed text-styles text-styles--secondary"&gt;
    &lt;div class="c-embed__content"&gt;
        &lt;div class="c-embed__cover"&gt;
          &lt;a href="https://www.youtube.com/@Bonnie-s2w" class="c-link align-middle" rel="noopener noreferrer"&gt;
            &lt;img alt="" src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fyt3.googleusercontent.com%2F9Ylb3Kb41JjqudNI8uC8_n-NNus_mBGMyLOxYpnmqR2HsE3MANtQwdblyNOWPcglQ4EHltB0%3Ds900-c-k-c0x00ffffff-no-rj" height="900" class="m-0" width="900"&gt;
          &lt;/a&gt;
        &lt;/div&gt;
      &lt;div class="c-embed__body"&gt;
        &lt;h2 class="fs-xl lh-tight"&gt;
          &lt;a href="https://www.youtube.com/@Bonnie-s2w" rel="noopener noreferrer" class="c-link"&gt;
            Coding Cuddles - YouTube
          &lt;/a&gt;
        &lt;/h2&gt;
          &lt;p class="truncate-at-3"&gt;
            Turn your stories into video games! 🎮✨

Have you ever dreamed of creating your own visual novel or an amazing game, but the code intimidates you a little? You're in the right place!

Here, we demystify programming. With Ren'Py and Python, we'll learn from scratch (yes, from "Hello World") to creating amazing mechanics, vibrant characters, and unique systems. No boring language, just lots of patience and, above all, tons of fun!

Subscribe and let's start writing the code for your next big hit. Your developer adventure starts today! 🚀

❤️███████▓▒ IMPORTANT NOTICE ░▒▓████████❤️
"This tutorial has been a labor of love. I've used AI tools (Google AI/Gemini) to bring my protagonist's voice to life and generate visual and audio resources that allow me to focus on what I love most: teaching you programming. AI is my assistant, but the heart and structure of this course are my own. Thank you for being part of this dream!"
          &lt;/p&gt;
        &lt;div class="color-secondary fs-s flex items-center"&gt;
            &lt;img alt="favicon" class="c-embed__favicon m-0 mr-2 radius-0" src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fwww.youtube.com%2Fs%2Fdesktop%2F2279fdfc%2Fimg%2Ffavicon.ico" width="48" height="48"&gt;
          youtube.com
        &lt;/div&gt;
      &lt;/div&gt;
    &lt;/div&gt;
&lt;/div&gt;



</description>
      <category>renpy</category>
      <category>python</category>
      <category>gamedev</category>
      <category>tutorial</category>
    </item>
  </channel>
</rss>
