Tabla de contenido:
- Paso 1: componentes
- Paso 2: Conecte el protector de pantalla táctil TFT ILI9341 a Arduino
- Paso 3: Inicie Visuino y agregue TFT Display Shield
- Paso 4: En Visuino: agregar elemento de texto de dibujo para la sombra del texto
- Paso 5: En Visuino: agregar elemento de texto de dibujo para el primer plano del texto
- Paso 6: En Visuino: agregue el elemento de mapa de bits de dibujo para la animación
- Paso 7: En Visuino: agregue pines para las propiedades X e Y del elemento Dibujar mapa de bits
- Paso 8: En Visuino: agregue 2 generadores de seno de enteros y configure el primero
- Paso 9: En Visuino: configure el segundo generador de seno y conecte los generadores de seno a los pines de coordenadas X e Y del mapa de bits
- Paso 10: En Visuino: agregue y conecte los componentes de origen múltiple de inicio y reloj
- Paso 11: Genere, compile y cargue el código Arduino
- Paso 12: Y juega …
2025 Autor: John Day | [email protected]. Última modificación: 2025-01-13 06:57
Los protectores de pantalla táctil TFT basados en ILI9341 son protectores de pantalla de bajo costo muy populares para Arduino. Visuino ha tenido soporte para ellos durante bastante tiempo, pero nunca tuve la oportunidad de escribir un tutorial sobre cómo usarlos. Recientemente, sin embargo, pocas personas hicieron preguntas sobre el uso de pantallas con Visuino, así que decidí hacer un tutorial.
En este tutorial, le mostraré lo fácil que es conectar el Shield a Arduino y programarlo con Visuino para animar un mapa de bits y moverse en la pantalla.
Paso 1: componentes
- Una placa compatible con Arduino Uno (puede que también funcione con Mega, pero todavía no he probado el escudo con él)
- Un protector de pantalla táctil TFT de 2,4 "ILI9341 para Arduino
Paso 2: Conecte el protector de pantalla táctil TFT ILI9341 a Arduino
Conecte el TFT Shield en la parte superior del Arduino Uno como se muestra en las imágenes
Paso 3: Inicie Visuino y agregue TFT Display Shield
Para comenzar a programar el Arduino, necesitará tener el IDE de Arduino instalado desde aquí:
¡Asegúrese de instalar 1.6.7 o superior, de lo contrario, este Instructable no funcionará
Visuino: https://www.visuino.com también necesita estar instalado.
- Inicie Visuino como se muestra en la primera imagen
- Haga clic en el botón "Flecha hacia abajo" del componente Arduino para abrir el menú desplegable (Imagen 1)
- En el menú, seleccione "Agregar escudos …" (Imagen 1)
- En el cuadro de diálogo "Shields", expanda la categoría "Displays" y seleccione "TFT Color Touch Screen Display ILI9341 Shield", luego haga clic en el botón "+" para agregarlo (Imagen 2)
Paso 4: En Visuino: agregar elemento de texto de dibujo para la sombra del texto
A continuación, debemos agregar elementos gráficos para representar texto y mapa de bits. Primero agregaremos elemento gráfico para dibujar la sombra del texto:
- En el Inspector de objetos, haga clic en el botón "…" junto al valor de la propiedad "Elementos" del elemento "Pantalla TFT" (Imagen 1)
- En el editor de elementos, seleccione "Dibujar texto", y luego haga clic en el botón "+" (Imagen 2) para agregar uno (Imagen 3)
- En el Inspector de objetos, establezca el valor de la propiedad "Color" del elemento "Dibujar texto1" en "aclSilver" (Imagen 3)
- En el Inspector de objetos, establezca el valor de la propiedad "Tamaño" del elemento "Dibujar texto1" en "4" (Imagen 4). Esto hace que el texto sea más grande
- En el Inspector de objetos, establezca el valor de la propiedad "Texto" del elemento "Dibujar texto1" en "Visuino" (Imagen 5)
- En el Inspector de objetos, establezca el valor de la propiedad "X" del elemento "Dibujar texto1" en "43" (Imagen 6)
- En el Inspector de objetos, establezca el valor de la propiedad "Y" del elemento "Dibujar texto1" en "278" (Imagen 6)
Paso 5: En Visuino: agregar elemento de texto de dibujo para el primer plano del texto
Ahora agregaremos elemento gráfico para dibujar el texto:
- En el editor de elementos, seleccione "Dibujar texto", y luego haga clic en el botón "+" (Imagen 1) para agregar el segundo (Imagen 2)
- En el Inspector de objetos, establezca el valor de la propiedad "Tamaño" del elemento "Dibujar texto1" en "4" (Imagen 2)
- En el Inspector de objetos, establezca el valor de la propiedad "Texto" del elemento "Dibujar texto1" en "Visuino" (Imagen 3)
- En el Inspector de objetos, establezca el valor de la propiedad "X" del elemento "Dibujar texto1" en "40" (Imagen 4)
- En el Inspector de objetos, establezca el valor de la propiedad "Y" del elemento "Dibujar texto1" en "275" (Imagen 4)
Paso 6: En Visuino: agregue el elemento de mapa de bits de dibujo para la animación
A continuación, agregaremos el elemento gráfico para dibujar el mapa de bits:
- En el editor de elementos, seleccione "Dibujar mapa de bits", y luego haga clic en el botón "+" (Imagen 1) para agregar uno (Imagen 2)
- En el Inspector de objetos, haga clic en el botón "…" junto al valor de la propiedad "Mapa de bits" del elemento "Dibujar mapa de bits1" (Imagen 2) para abrir el "Editor de mapa de bits" (Imagen 3)
- En el "Editor de mapa de bits", haga clic en el botón "Cargar …" (Imagen 3) para abrir el cuadro de diálogo Abrir archivo (Imagen 4)
- En el cuadro de diálogo Abrir archivo, seleccione el mapa de bits que desee dibujar y haga clic en el botón "Abrir" (imagen 4). Si el archivo es demasiado grande, es posible que no quepa en la memoria Arduino. Si se queda sin memoria durante la compilación, es posible que deba seleccionar un mapa de bits más pequeño
- En el "Editor de mapa de bits", haga clic en "Aceptar". botón (Imagen 5) para cerrar el diálogo
Paso 7: En Visuino: agregue pines para las propiedades X e Y del elemento Dibujar mapa de bits
Para animar el mapa de bits, necesitamos controlar su posición X e Y. Para esto agregaremos pines para las propiedades X e Y:
- En el Inspector de objetos, haga clic en el botón "Pin" al frente de la propiedad "X" del elemento "Dibujar Bitmap1" (Imagen 1) y seleccione "Integer SinkPin" (Imagen 2)
- En el Inspector de objetos, haga clic en el botón "Pin" al frente de la propiedad "Y" del elemento "Dibujar Bitmap1" (Imagen 3) y seleccione "Integer SinkPin" (Imagen 4)
Paso 8: En Visuino: agregue 2 generadores de seno de enteros y configure el primero
Usaremos 2 generadores de seno entero para animar el movimiento del mapa de bits:
- Escriba "seno" en el cuadro Filtro de la Caja de herramientas de componentes, luego seleccione el componente "Generador de enteros seno" (Imagen 1) y suelte dos de ellos en el área de diseño
- En el Inspector de objetos, establezca el valor de la propiedad "Amplitud" del componente SineIntegerGenerator1 en "96" (Imagen 2)
- En el Inspector de objetos, establezca el valor de la propiedad "Offset" del componente SineIntegerGenerator1 en "96" (Imagen 3)
- En el Inspector de objetos, establezca el valor de la propiedad "Frecuencia" del componente SineIntegerGenerator1 en "0.2" (Imagen 4)
Paso 9: En Visuino: configure el segundo generador de seno y conecte los generadores de seno a los pines de coordenadas X e Y del mapa de bits
- En el Inspector de objetos, establezca el valor de la propiedad "Amplitud" del componente SineIntegerGenerator2 en "120" (Imagen 1)
- En el Inspector de objetos, establezca el valor de la propiedad "Offset" del componente SineIntegerGenerator2 en "120" (Imagen 2)
- En el Inspector de objetos, establezca el valor de la propiedad "Frecuencia" del componente SineIntegerGenerator2 en "0.03" (Imagen 3)
- Conecte el pin de salida "Out" del componente SineIntegerGenerator1 al pin de entrada "X" del elemento "Shields. TFT Sisplay. Elements. Draw Bitmap1" del componente Arduino (Imagen 4)
- Conecte el pin de salida "Out" del componente SineIntegerGenerator2 al pin de entrada "Y" del elemento "Shields. TFT Display. Elements. Draw Bitmap1" del componente Arduino (Imagen 5)
Paso 10: En Visuino: agregue y conecte los componentes de origen múltiple de inicio y reloj
Para renderizar el mapa de bits cada vez que se actualizan las posiciones X e Y, necesitamos enviar una señal de reloj al elemento "Dibujar mapa de bits1". Para enviar el comando después de que se hayan cambiado las posiciones, necesitamos una forma de sincronizar los eventos. Para esto usaremos el componente Repeat para generar eventos constantemente, y Clock Multi Source para generar 2 eventos en secuencia. El primer evento registrará los generadores de seno para actualizar las posiciones X e Y, y el segundo registrará el "Dibujar mapa de bits1":
- Escriba "repetir" en el cuadro Filtro de la Caja de herramientas de componentes, luego seleccione el componente "Repetir" (Imagen 1) y suéltelo en el área de diseño (Imagen 2)
- Escriba "multi" en el cuadro Filtro de la Caja de herramientas de componentes, luego seleccione el componente "Reloj de múltiples fuentes" (Imagen 2) y suéltelo en el área de diseño (Imagen 3)
- Conecte el pin de salida "Out" del componente Repeat1 al pin de entrada "In" del componente ClockMultiSource1 (Imagen 3)
- Conecte el pin de salida "Pin [0]" de los pines "Out" del componente ClockMultiSource1 al pin de entrada "In" del componente SineIntegerGenerator1 (Imagen 4)
- Conecte el pin de salida "Pin [0]" de los pines "Out" del componente ClockMultiSource2 al pin de entrada "In" del componente SineIntegerGenerator1 (Imagen 5)
- Conecte el pin de salida "Pin [1]" del pin de entrada "Reloj" del elemento "Shields. TFT Display. Elements. Draw Bitmap1" del componente Arduino (Imagen 6)
Paso 11: Genere, compile y cargue el código Arduino
- En Visuino, presione F9 o haga clic en el botón que se muestra en la Imagen 1 para generar el código Arduino y abra el IDE de Arduino
- En el IDE de Arduino, haga clic en el botón Cargar, para compilar y cargar el código (Imagen 2)
Paso 12: Y juega …
¡Felicidades! Has completado el proyecto.
Las imágenes 2, 3, 4 y 5 y el video muestran el proyecto conectado y encendido. Verá el mapa de bits moviéndose alrededor del escudo de pantalla táctil TFT basado en ILI9341 como se ve en el video.
En la Imagen 1 se puede ver el diagrama completo de Visuino. También se adjunta el proyecto Visuino, que creé para este Instructable, y el mapa de bits con el logo de Visuino. Puede descargarlo y abrirlo en Visuino: