<?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>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>
