Transformación de Imágenes Usando IA Sin Salir de Tu Aplicación React

Rate this content
Bookmark

Las bibliotecas de optimización de imágenes abstraen las partes difíciles de trabajar con imágenes para que puedas concentrarte en la implementación. Pero estas herramientas no te permiten hacer transformaciones complejas a tus imágenes existentes. Agregar texto, eliminar fondos distractores, o escalar imágenes a una resolución superior requiere que descargues, transformes y vuelvas a subir tus imágenes. Esta charla explorará el uso de las APIs de imágenes de IA y unpic-image para manejar transformaciones de imágenes complejas dentro de nuestras aplicaciones React. Eliminaremos y reemplazaremos fondos de imágenes y usaremos el recorte facial consciente del contexto para crear diseños responsivos.

This talk has been presented at React Summit US 2023, check out the latest edition of this React Conference.

FAQ

La transformación de imágenes con IA en aplicaciones React implica usar tecnologías avanzadas para modificar y optimizar imágenes automáticamente dentro de la aplicación, sin necesidad de procesos manuales extensos, aprovechando la inteligencia artificial para realizar tareas como eliminación de fondos, recortes faciales y mejora de resolución.

Manejar correctamente las imágenes es crucial porque son una parte integral de la experiencia del usuario y la primera impresión del producto. Un manejo ineficiente puede llevar a problemas como tiempos de carga lentos y uso excesivo de datos, afectando la satisfacción del cliente y la percepción general del producto.

Los desarrolladores pueden simplificar la transformación de imágenes utilizando CDNs de imágenes que manejan automáticamente optimizaciones y transformaciones mediante IA. Esto elimina la necesidad de gestionar manualmente cada cambio y mantenimiento de cachés, permitiendo una integración fácil y eficiente en la aplicación.

El uso de un CDN de imágenes ofrece varios beneficios como la reducción de la sobrecarga de mantenimiento, la optimización automática de imágenes, cumplimiento de las mejores prácticas de manejo de imágenes, y la actualización constante de las funciones sin intervención manual, facilitando así el desarrollo y mantenimiento de aplicaciones.

Algunas transformaciones de IA aplicables mediante un CDN incluyen la eliminación de fondos, el recorte centrado en reconocimiento facial, y la mejora de resolución. Estas transformaciones ayudan a asegurar que las imágenes se ajusten a los estándares de diseño y mejoren la experiencia visual del usuario.

Unpick Image es una biblioteca de optimización de imágenes que se integra con CDNs para manejar transformaciones de imágenes directamente en la nube. En aplicaciones React, se utiliza para simplificar la gestión de imágenes, permitiendo que los desarrolladores implementen fácilmente optimizaciones y transformaciones de IA sin configuraciones complejas.

Luis H. Ball Jr.
Luis H. Ball Jr.
5 min
13 Nov, 2023

Comments

Sign in or register to post your comment.
Video Summary and Transcription
La charla de hoy discute la importancia de transformar imágenes con IA en aplicaciones React y los beneficios de usar CDNs de imágenes. El orador enfatiza la importancia de las imágenes como un componente crucial de los sitios web y la naturaleza que consume tiempo de adoptar las mejores prácticas de imágenes. Proponen la transformación de imágenes en el borde como una alternativa más rápida y fácil. La charla también destaca el uso de la IA en la transformación de imágenes, incluyendo la eliminación de fondos, el recorte de imágenes, y la mejora de imágenes pixeladas en una aplicación Contentful Next JS. La combinación de CDNs de imágenes y parámetros de IA asegura que las imágenes siempre se vean lo mejor posible sin salir de la aplicación React.

1. Introducción a la Transformación de Imágenes

Short description:

Hoy hablaremos sobre la transformación de imágenes con IA en tu aplicación React. Es importante no olvidar las imágenes, ya que son el tejido conectivo de tus sitios. Adoptar las mejores prácticas de imagen lleva tiempo, por lo que podemos explorar la transformación de imágenes en el borde como una alternativa más rápida y fácil.

Muy bien, mi nombre es Luis Paul. Soy un ingeniero de software senior en ImageX. Hoy vamos a hablar sobre la transformación de imágenes con IA sin salir de tu aplicación React. Pero voy a ir rápido porque hay mucho contenido, así que discúlpenme, intentaré ir más despacio.

Primero, un poco de historia. Como desarrolladores, nos encanta lanzar productos. Estamos enfocados en las características, la experiencia del cliente y la satisfacción, como deberíamos estar. Ese es nuestro trabajo. Pero eso hace que sea fácil olvidar las partes que no codificamos, cosas como las imágenes. Así que podrías encontrarte en esta situación en la que lanzaste un producto viral, a la gente le encanta, pero también te están enviando mensajes diciendo, oye, es fantástico pero estás enviando 100 megabytes de imágenes. No hagamos eso. Y tienes que correr y arreglarlo. Por eso es importante no olvidar las imágenes. Son el tejido conectivo de tus sitios. Las imágenes son la forma en que los clientes experimentan tu producto por primera vez y son más importantes de lo que tendemos a darnos cuenta.

Entonces, ¿qué deberíamos hacer al respecto? Deberíamos adoptar las best practices de imagen. Hay un montón de ellas, ¿verdad? Tienes tamaños de fuente, relación de aspecto, cambios de diseño, carga perezosa, etc. Y asegurarte de cumplir con todas ellas lleva tiempo. Por lo tanto, requiere que hagas cosas como generar variantes para todas tus imágenes. ¿Cómo podemos facilitar esto? Así que nos inclinamos a hacer cosas como la transformación de imágenes como un paso de construcción. Pero no es genial. Transformar en el momento de la construcción puede llevar una eternidad. El conjunto de características es más limitado en términos de transformaciones que puedes lograr y tienes que hacer un cuidadoso mantenimiento de tus tooling para hacerlo bien a largo plazo. En resumen, la DX simplemente no es genial.

Entonces, ¿qué más podemos hacer? Podemos hacer cosas como la transformación de imágenes en el borde. Esto es rápido, fácil de integrar en cualquier aplicación. Siempre está actualizado. Puedes crear un nuevo punto de replicación fácilmente y se mantiene actualizado para ti. Pero viene con algo de sobrecarga. Tienes que crear nuevas funciones cada vez que necesitas una nueva transformación, y tienes que hacer cosas como mantener e invalidar cachés, sincronizar el activo generado de vuelta a tu cubo donde viven tus activos.

2. Transformación de Imágenes con CDN y IA

Short description:

Con un CDN de imágenes, puedes encargarte de todo el trabajo pesado y adoptar progresivamente las mejores prácticas. En nuestra aplicación Contentful Next JS, eliminamos fondos, recortamos imágenes usando IA y mejoramos la resolución de imágenes pixeladas. Aprovechamos el CDN de imágenes y los parámetros de IA para asegurar que nuestras imágenes siempre se vean lo mejor posible. Eso es transformar imágenes usando IA sin salir de tu aplicación React.

Y por eso puede volverse un poco complicado, razón por la cual la gente se inclina hacia los CDN de imágenes. Con un CDN de imágenes, puedes encargarte de todo ese trabajo pesado. Y luego puedes adoptarlo progresivamente usando algo como unpick image que se encargará de cumplir con todas estas best practices por ti. Es fantástico porque es de configuración cero con la mayoría de los grandes CDN. Simplemente sueltas la URL de tu imagen que vive en el CDN. Sabe qué hacer. Solo le das un ancho y una altura si lo necesitas. Y eso es prácticamente todo.

En resumen, no necesitas reinventar la rueda para lograr las best practices. Así que echemos un vistazo a cómo podrías usar esto en tus aplicaciones. Vamos a tener una aplicación Contentful Next JS, va a usar una biblioteca de optimization de imágenes. Utilizará un CDN de imágenes para eliminar toda esa sobrecarga y aprovechará los parámetros de IA del CDN para hacer algunas transformaciones divertidas.

Entonces, primero, vamos a eliminar fondos usando IA. Queremos hacer cumplir cierta consistencia en nuestro sitio, asegurarnos de que las cosas coincidan con nuestros diseños. Así que aquí tenemos nuestra aplicación Contentful Next JS. Tiene una imagen de héroe. Queremos eliminar el fondo. Todo lo que necesitamos hacer, usando el CDN, es usar su parámetro de eliminación de fondo, guardar, y al agregar eso a la URL, tendremos un fondo eliminado. Fue rápido, fácil, sin dolor, gracias a usar Unpick Image en el CDN. Sigamos adelante. Tenemos algunos recortes faciales de IA que queremos hacer. Queremos asegurarnos de que las imágenes siempre estén enfocadas en lo que es realmente relevante y centrado. Así que veamos cómo podemos hacer eso. Tenemos una imagen aquí, y tenemos a alguien caminando por el pasillo, pero realmente no podemos ver la cara de esta persona, y nos gustaría, así que, ¿por qué no la recortamos alrededor de la cara de esta persona? La forma en que hacemos eso es agregando algunos parámetros a la URL. Configuraremos Frick crop, agregaremos algunas dimensiones de ancho y altura. Y una vez que hemos hecho eso, ahora también queremos asegurarnos de que usamos algún reconocimiento facial para centrar automáticamente la cara del sujeto en la imagen. Fácil. Y ahora, lo último que queremos hacer, es mejorar la resolución. Este es mi favorito personal, es como un truco de magia. Puedes agregar algo de definición a las imágenes pixeladas, vas a aumentar la densidad de píxeles, y vas a hacer cosas como, ya sabes, mejorar la iluminación y el contraste. Entonces, si pensamos en nuestra aplicación Contentful NxJS, podemos tener un componente de imagen, que todas nuestras imágenes usen, pero tal vez tenemos mucho contenido generado por los usuarios, se pone un poco complicado, ¿verdad? No todos tienen lo último y lo mejor, tienen contenido antiguo, queremos mejorar su resolución. Lo que tenemos que hacer en este caso es agregar el parámetro de mejora de resolución, guardarlo, y así, con el upscale equals true en nuestra URL de imagen, nuestra imagen se mejora automáticamente y ese carrusel se ve genial. Así que, para resumir, ¿qué hicimos? Hablamos mucho sobre muchas cosas. Hicimos una aplicación Contentful NxJS, usamos una biblioteca de optimization de imágenes llamada Unpick Image, y luego usamos un CDN de imágenes para eliminar toda esa desagradable sobrecarga de tener que invalidar cachés o almacenar imágenes en la cloud y finalmente, aprovechamos ese CDN para usar algunos parámetros de IA como el recorte de reconocimiento facial, como la eliminación de fondos, como la mejora de resolución y asegurarnos de que nuestras imágenes siempre se vean lo mejor posible cuando se muestran. Eso es transformar imágenes usando IA sin salir de tu aplicación React y estoy suficientemente sin aliento. Muchas gracias a todos. No duden en hacer preguntas.

Check out more articles and videos

We constantly think of articles and videos that might spark Git people interest / skill us up or help building a stellar career

Construyendo un Asistente AI Activado por Voz con Javascript
JSNation 2023JSNation 2023
21 min
Construyendo un Asistente AI Activado por Voz con Javascript
Top Content
This Talk discusses building a voice-activated AI assistant using web APIs and JavaScript. It covers using the Web Speech API for speech recognition and the speech synthesis API for text to speech. The speaker demonstrates how to communicate with the Open AI API and handle the response. The Talk also explores enabling speech recognition and addressing the user. The speaker concludes by mentioning the possibility of creating a product out of the project and using Tauri for native desktop-like experiences.
IA y Desarrollo Web: ¿Exageración o Realidad?
JSNation 2023JSNation 2023
24 min
IA y Desarrollo Web: ¿Exageración o Realidad?
Top Content
This talk explores the use of AI in web development, including tools like GitHub Copilot and Fig for CLI commands. AI can generate boilerplate code, provide context-aware solutions, and generate dummy data. It can also assist with CSS selectors and regexes, and be integrated into applications. AI is used to enhance the podcast experience by transcribing episodes and providing JSON data. The talk also discusses formatting AI output, crafting requests, and analyzing embeddings for similarity.
El Ascenso del Ingeniero de IA
React Summit US 2023React Summit US 2023
30 min
El Ascenso del Ingeniero de IA
The rise of AI engineers is driven by the demand for AI and the emergence of ML research and engineering organizations. Start-ups are leveraging AI through APIs, resulting in a time-to-market advantage. The future of AI engineering holds promising results, with a focus on AI UX and the role of AI agents. Equity in AI and the central problems of AI engineering require collective efforts to address. The day-to-day life of an AI engineer involves working on products or infrastructure and dealing with specialties and tools specific to the field.
Aplicaciones Web del Futuro con Web AI
JSNation 2024JSNation 2024
32 min
Aplicaciones Web del Futuro con Web AI
Web AI in JavaScript allows for running machine learning models client-side in a web browser, offering advantages such as privacy, offline capabilities, low latency, and cost savings. Various AI models can be used for tasks like background blur, text toxicity detection, 3D data extraction, face mesh recognition, hand tracking, pose detection, and body segmentation. JavaScript libraries like MediaPipe LLM inference API and Visual Blocks facilitate the use of AI models. Web AI is in its early stages but has the potential to revolutionize web experiences and improve accessibility.
El Flujo de Trabajo del Desarrollador Asistido por IA: Construye Más Rápido e Inteligente Hoy
JSNation US 2024JSNation US 2024
31 min
El Flujo de Trabajo del Desarrollador Asistido por IA: Construye Más Rápido e Inteligente Hoy
AI is transforming software engineering by using agents to help with coding. Agents can autonomously complete tasks and make decisions based on data. Collaborative AI and automation are opening new possibilities in code generation. Bolt is a powerful tool for troubleshooting, bug fixing, and authentication. Code generation tools like Copilot and Cursor provide support for selecting models and codebase awareness. Cline is a useful extension for website inspection and testing. Guidelines for coding with agents include defining requirements, choosing the right model, and frequent testing. Clear and concise instructions are crucial in AI-generated code. Experienced engineers are still necessary in understanding architecture and problem-solving. Energy consumption insights and sustainability are discussed in the Talk.
Cobertura de código con IA
TestJS Summit 2023TestJS Summit 2023
8 min
Cobertura de código con IA
Codium is a generative AI assistant for software development that offers code explanation, test generation, and collaboration features. It can generate tests for a GraphQL API in VS Code, improve code coverage, and even document tests. Codium allows analyzing specific code lines, generating tests based on existing ones, and answering code-related questions. It can also provide suggestions for code improvement, help with code refactoring, and assist with writing commit messages.

Workshops on related topic

IA a demanda: IA sin servidor
DevOps.js Conf 2024DevOps.js Conf 2024
163 min
IA a demanda: IA sin servidor
Top Content
Featured WorkshopFree
Nathan Disidore
Nathan Disidore
En esta masterclass, discutimos los méritos de la arquitectura sin servidor y cómo se puede aplicar al espacio de la IA. Exploraremos opciones para construir aplicaciones RAG sin servidor para un enfoque más lambda-esque a la IA. A continuación, nos pondremos manos a la obra y construiremos una aplicación CRUD de muestra que te permite almacenar información y consultarla utilizando un LLM con Workers AI, Vectorize, D1 y Cloudflare Workers.
AI para Desarrolladores de React
React Advanced 2024React Advanced 2024
142 min
AI para Desarrolladores de React
Featured Workshop
Eve Porcello
Eve Porcello
El conocimiento de las herramientas de AI es fundamental para preparar el futuro de las carreras de los desarrolladores de React, y la suite de herramientas de AI de Vercel es una vía de acceso accesible. En este curso, examinaremos más de cerca el Vercel AI SDK y cómo esto puede ayudar a los desarrolladores de React a construir interfaces de transmisión con JavaScript y Next.js. También incorporaremos APIs de terceros adicionales para construir y desplegar una aplicación de visualización de música.
Temas:- Creación de un Proyecto de React con Next.js- Elección de un LLM- Personalización de Interfaces de Transmisión- Construcción de Rutas- Creación y Generación de Componentes - Uso de Hooks (useChat, useCompletion, useActions, etc)
Aprovechando LLMs para Construir Experiencias de IA Intuitivas con JavaScript
JSNation 2024JSNation 2024
108 min
Aprovechando LLMs para Construir Experiencias de IA Intuitivas con JavaScript
Featured Workshop
Roy Derks
Shivay Lamba
2 authors
Hoy en día, todos los desarrolladores están utilizando LLMs en diferentes formas y variantes, desde ChatGPT hasta asistentes de código como GitHub CoPilot. Siguiendo esto, muchos productos han introducido capacidades de IA integradas, y en este masterclass haremos que los LLMs sean comprensibles para los desarrolladores web. Y nos adentraremos en la codificación de tu propia aplicación impulsada por IA. No se necesita experiencia previa en trabajar con LLMs o aprendizaje automático. En su lugar, utilizaremos tecnologías web como JavaScript, React que ya conoces y amas, al mismo tiempo que aprendemos sobre algunas nuevas bibliotecas como OpenAI, Transformers.js
Masterclass: Qué son y cómo aprovechar los LLMs
React Summit 2024React Summit 2024
66 min
Masterclass: Qué son y cómo aprovechar los LLMs
Featured Workshop
Nathan Marrs
Haris Rozajac
2 authors
Únete a Nathan en esta sesión práctica donde primero aprenderás a alto nivel qué son los modelos de lenguaje grandes (LLMs) y cómo funcionan. Luego sumérgete en un ejercicio de codificación interactivo donde implementarás la funcionalidad de LLM en una aplicación de ejemplo básica. Durante este ejercicio, adquirirás habilidades clave para trabajar con LLMs en tus propias aplicaciones, como la ingeniería de indicaciones y la exposición a la API de OpenAI.
Después de esta sesión, tendrás una idea de qué son los LLMs y cómo se pueden utilizar prácticamente para mejorar tus propias aplicaciones.
Tabla de contenidos:- Demostración interactiva de la implementación de funciones básicas impulsadas por LLM en una aplicación de demostración- Discutir cómo decidir dónde aprovechar los LLMs en un producto- Lecciones aprendidas sobre la integración con OpenAI / descripción general de la API de OpenAI- Mejores prácticas para la ingeniería de indicaciones- Desafíos comunes específicos de React (gestión de estado :D / buenas prácticas de UX)
Trabajando con OpenAI y la Ingeniería de Prompts para Desarrolladores de React
React Advanced 2023React Advanced 2023
98 min
Trabajando con OpenAI y la Ingeniería de Prompts para Desarrolladores de React
Top Content
Workshop
Richard Moss
Richard Moss
En esta masterclass daremos un recorrido por la IA aplicada desde la perspectiva de los desarrolladores de front end, enfocándonos en las mejores prácticas emergentes cuando se trata de trabajar con LLMs para construir grandes productos. Esta masterclass se basa en los aprendizajes obtenidos al trabajar con la API de OpenAI desde su debut en noviembre pasado para construir un MVP funcional que se convirtió en PowerModeAI (una herramienta de creación de ideas y presentaciones orientada al cliente).
En la masterclass habrá una mezcla de presentación y ejercicios prácticos para cubrir temas que incluyen:
- Fundamentos de GPT- Trampas de los LLMs- Mejores prácticas y técnicas de ingeniería de prompts- Uso efectivo del playground- Instalación y configuración del SDK de OpenAI- Enfoques para trabajar con la API y la gestión de prompts- Implementación de la API para construir una aplicación orientada al cliente potenciada por IA- Ajuste fino y embeddings- Mejores prácticas emergentes en LLMOps
Construyendo Aplicaciones AI para la Web
React Day Berlin 2023React Day Berlin 2023
98 min
Construyendo Aplicaciones AI para la Web
Workshop
Roy Derks
Roy Derks
Hoy en día, cada desarrollador está utilizando LLMs en diferentes formas y figuras. Muchos productos han introducido capacidades AI incorporadas, y en esta masterclass aprenderás cómo construir tu propia aplicación AI. No se necesita experiencia en la construcción de LLMs o en el aprendizaje automático. En cambio, utilizaremos tecnologías web como JavaScript, React y GraphQL que ya conoces y amas.