Building a Multimodal App with Gemini AI: An Educational Guide
Introduction to Gemini AI and Multimodal Models
Welcome to this comprehensive guide on developing applications using Gemini AI, Google’s powerful multimodal model. In this educational resource, you will learn step-by-step how to build an application capable of analyzing images and answering questions about their content. This course, developed by Ana Kubo, will take you from understanding the fundamentals of Gemini to implementing a fully functional image-query application. This educational initiative is made possible through a grant from Google, ensuring high-quality, accessible learning.
This guide will focus on utilizing the Gemini multimodal model to create an application that allows users to upload images and pose questions about them. For instance, if a user uploads a picture of an octopus wearing a hat, the application should be able to answer questions like “What is the creature in the picture wearing?” with a text response such as “hat.” Furthermore, we will incorporate a feature that suggests random questions, such as “Does the image have puppies?” to inspire user interaction.
Throughout this guide, we will cover a range of topics, including:
- Understanding Gemini AI and its capabilities.
- Setting up your development environment and necessary tools.
- Authentication and accessing the Gemini API.
- Exploring the different Gemini models available.
- Building a practical application that can “see” images and answer questions.
Let’s begin our journey into the world of Gemini AI and multimodal application development!
What is Gemini? Understanding Multimodal Generative AI
In simple terms, Gemini represents a suite of multimodal generative AI models developed by Google.
Multimodal: Refers to the ability of a system to process and understand multiple types of data input, such as text and images, simultaneously. In the context of AI, it means the model can handle and integrate information from various modalities.
Generative AI models: A type of artificial intelligence model that can generate new content, such as text, images, or code. These models learn patterns from existing data and use this knowledge to create original outputs.
Gemini models are designed to accept both text and image inputs, depending on the specific model variation chosen, and produce text-based responses. This capability opens up exciting possibilities for interacting with AI in intuitive and versatile ways.
Consider these examples to illustrate Gemini’s functionality:
- Text-based Prompts: You can provide a text prompt like “What day of the week is it today?” and Gemini will respond with text, such as “It is Wednesday.”
- Image-based Prompts: You can input an image, for example, a picture of a cat wearing a hat, and ask “What’s in the photo?” Gemini can analyze the image and provide a text response describing the content, such as “a cat wearing a hat.”
Interacting with Gemini: Gemini App and Gemini API
There are two primary ways to interact with Gemini models: through the Gemini app and through the Gemini API.
Gemini App
The Gemini app provides a user-friendly UI (User Interface) for direct interaction with Gemini models.
UI (User Interface): The visual part of an application or system that allows users to interact with it. It includes elements like buttons, menus, and input fields, designed to make the system easy to use.
Using the Gemini app, you can:
- Type text prompts and receive text responses, engaging in conversational exchanges.
- Upload images and ask questions about them, leveraging Gemini’s multimodal capabilities.
- Review your chat history, allowing for context-aware conversations where the model remembers previous interactions.
Chat history: A record of past conversations with an AI model. This history allows the model to understand the context of current prompts and provide more relevant and coherent responses in ongoing interactions.
Gemini API
For developers who want to integrate Gemini’s capabilities into their own applications, the Gemini API (Application Programming Interface) is the key.
API (Application Programming Interface): A set of rules and specifications that software programs can follow to communicate with each other. APIs allow developers to use functionalities of one application within another, enabling integration and interoperability.
The Gemini API allows you to programmatically access Gemini models and replicate the functionalities available in the Gemini app. This includes:
- 
Text-to-Text Interactions: Sending text prompts and receiving text responses using the generateContentmethod.generateContentmethod: A function provided by the Gemini API that allows developers to send prompts (text or images) to a Gemini model and receive generated text responses. It is the core method for interacting with Gemini’s generative capabilities.
- 
Multimodal Prompts: Utilizing the generateContentmethod with the Gemini provision model (specifically, the Gemini Flash model in this guide) to input both text and images as prompts and receive text-based answers. This enables building applications like the image-query app we are developing.Gemini provision model: Refers to specific variations or versions of the Gemini model that are made available for developers through the API. In this context, “Gemini Flash” is highlighted as the model being used for its balance of speed and capability. 
- 
Multi-turn Conversations: Building applications that can maintain conversational context, remembering previous interactions within a session. 
- 
Advanced Configuration: Customizing model behavior and parameters for specific application needs. 
- 
Embeddings (Advanced Topic): For more advanced use cases, Gemini offers the ability to create embeddings using the embedding-001model and theembedContentmethod.Embeddings: Numerical representations of data, like text or images, in a vector space. These representations capture the semantic meaning of the data and are useful for tasks like semantic search, clustering, and recommendation systems. Creating embeddings allows for advanced semantic analysis, but is beyond the scope of this introductory guide. 
While other Gemini models and methods exist, this guide will primarily focus on the Gemini Flash model and the generateContent method for building our image-query application.
In Summary: Gemini is a powerful suite of multimodal generative AI models accessible through both a user-friendly app and a developer-focused API. The API empowers developers to integrate Gemini’s text and image understanding capabilities into custom applications.
Getting Started: Accessing the Gemini App and API
Accessing the Gemini App
To begin exploring Gemini, navigate to gemini.com. The webpage interface may evolve over time, so be aware of potential changes if you are viewing this guide in the future.
- 
Sign In: Click the “Sign In” button. 
- 
Google Account: You will be prompted to sign in using your Google account. Proceed to log in with your Google credentials. 
- 
Gemini Dashboard: Upon successful login, you will be directed to the Gemini app dashboard. Dashboard: A central interface that provides an overview and access to the main features and functionalities of an application or system. In the Gemini app, the dashboard is the primary screen for interacting with the model. 
From the dashboard, you can start interacting with Gemini immediately. You can type text prompts, select from pre-made questions, or upload images to begin exploring its capabilities.
Accessing the Gemini API and Obtaining an API Key
To utilize Gemini in your own applications, you need to access the Gemini API and obtain an API key.
API key: A unique identifier that authenticates a user or application when making requests to an API. It serves as a security measure, verifying that the request is authorized and allowing the API provider to track usage.
- 
Navigate to API Documentation: Go to ai.google.dev/gemini-api/docs. This page provides comprehensive API documentation for the Gemini API. API documentation: A set of documents that describe how to use an API. It includes details about available endpoints, methods, parameters, request formats, and response structures, guiding developers on how to interact with the API effectively. 
- 
Get an API Key: In the left-hand menu of the API documentation, select “Get an API key.” 
- 
AI Studio: Clicking “Get an API key” will redirect you to AI Studio (aistudio.google.com). AI Studio: Google’s platform for developing and experimenting with AI models, including Gemini. It provides tools for generating API keys, managing projects, and exploring AI functionalities. 
- 
Create API Key: In AI Studio, click “Get API key.” If this is your first time, you may be prompted to create an API key in a new project. Follow the on-screen instructions to create a new project and generate your API key. 
- 
Copy and Secure Your API Key: Once generated, your API key will be displayed. Copy this key and store it securely. 
Important Security Considerations for API Keys:
- 
Keep Your API Key Secret: Never share your API key publicly or embed it directly in client-side code. Client-side code: Code that runs in the user’s web browser, as opposed to server-side code which runs on a server. Exposing API keys in client-side code is a security risk because it is easily accessible to anyone inspecting the webpage’s source code. 
- 
Security Risks of Exposure: If your API key is compromised, others could use it in their own projects, potentially depleting your free tokens or incurring unexpected charges if you have a credit card linked to your account. Free tokens: A limited amount of usage credits provided by API providers, often for free, to allow developers to explore and test their APIs. Once the free tokens are exhausted, further usage may require payment. Credit card bill: Charges incurred when API usage exceeds free token limits and is billed to a linked credit card. 
- 
Secure API Key Management: To use your API key safely in applications, especially web applications, it is crucial to route API requests through your own backend server. Backend server: The server-side portion of a web application that handles data processing, business logic, and database interactions. It runs on a server and is not directly accessible to users, making it a secure place to store API keys. On your backend server, you should securely load your API key from: - 
An environment variable. 
- 
A Key Management Service. 
 Environment variable: A variable whose value is set outside the application code, typically in the operating system environment. They are often used to store configuration settings and secrets like API keys, keeping them separate from the codebase. Key Management Service (KMS): A secure system for managing cryptographic keys and sensitive data, like API keys. KMS solutions provide features like encryption, access control, and auditing to protect keys from unauthorized access and misuse. 
- 
By following these security best practices, you can ensure the safe and responsible use of your Gemini API key.
Recap of Gemini API Capabilities and Course Focus
As a recap, the Gemini API provides access to Google’s generative AI models, enabling a range of functionalities:
- Text-only input and text output using the generateContentmethod.
- Text and/or image input and text output using the generateContentmethod with the Gemini Flash model. This supports multimodal prompts and responses.
- Building multi-turn conversations with Gemini models, maintaining context across interactions.
- Creating embeddings using the embedding-001model andembedContentmethod for advanced semantic tasks (beyond the scope of this guide).
Focus of this Course:
In this course, we will concentrate on utilizing the Gemini Flash model to build our image-query application. We will specifically focus on prompting Gemini with text and/or images and receiving text-based responses.
Setting Up Your Development Environment
Before we begin building our application, ensure you have the necessary tools and environment set up.
Prerequisites:
- 
Node.js (Version 18 or higher): Node.js is a JavaScript runtime environment that allows you to run JavaScript code outside of a web browser. We will be using Node.js for our backend development. Download and install Node.js from nodejs.org. Node.js: A JavaScript runtime environment that executes JavaScript code server-side. It’s built on Chrome’s V8 JavaScript engine and enables developers to use JavaScript for backend development, creating web servers and network applications. 
- 
npm (Node Package Manager): npm is the default package manager for Node.js. It is used to install and manage project dependencies (libraries and tools). npm is typically installed automatically with Node.js. npm (Node Package Manager): A package manager for Node.js that allows developers to easily install, share, and manage project dependencies (libraries and tools). It simplifies the process of incorporating external modules into Node.js projects. 
- 
Gemini SDK (Software Development Kit): The Gemini SDK provides libraries and tools specifically designed to interact with the Gemini API from your Node.js application. We will install this shortly. SDK (Software Development Kit): A collection of software development tools in one installable package. SDKs often include libraries, documentation, code samples, processes, and guides that aid developers in creating software applications for a specific platform or API. In this case, the Gemini SDK facilitates interaction with the Gemini API. 
Verifying Node.js and npm Installation:
Open your terminal or command prompt and run the following commands to verify that Node.js and npm are installed correctly and are the required versions:
node -v
npm -vEnsure that the Node.js version is 18 or higher.
Installing the Gemini SDK:
We will install the Gemini SDK as a project dependency in the next step when we set up our project.
With Node.js and npm installed, you are now ready to set up your project and begin building the image-query application with Gemini AI!
Project Setup: Creating a React Application
For this project, we will use React, a popular JavaScript library for building user interfaces. We will create a React application to handle the frontend user interface and interact with our backend server, which will communicate with the Gemini API.
Creating a React Application:
- 
Open your terminal or command prompt. 
- 
Navigate to your desired project directory. Use the cdcommand to change directories to where you want to create your project.
- 
Use create-react-app: Run the following command to create a new React application named “react-gemini-vision-app”:npx create-react-app react-gemini-vision-appnpx create-react-app: A command-line tool used to quickly set up a new React project with a pre-configured development environment. It automates the process of setting up build tools, project structure, and basic configurations, allowing developers to start building React applications immediately.This command uses npx, the Node Package Runner, to executecreate-react-app, which sets up a new React project with all the necessary configurations and dependencies.
- 
Navigate into the Project Directory: Once the project is created, navigate into the newly created directory: cd react-gemini-vision-app
Project File Structure and Cleanup:
The create-react-app tool generates a project with a predefined file structure.  Let’s examine and clean up some of the default files:
- 
srcdirectory: This directory contains the source code for your React application.- 
App.js: The main component of your React application.
- 
index.js: The entry point of your React application, responsible for rendering theAppcomponent.
- 
index.css: CSS file for global styles.
- 
App.css: CSS file for styling theAppcomponent.
- 
App.test.js: File for unit testing theAppcomponent.
- 
logo.svg: React logo (we won’t need this).
- 
reportWebVitals.jsandsetupTests.js: Files related to web vitals reporting and test setup (we won’t need these for this basic project).
 source directory: In software development, particularly in web projects, thesrcdirectory typically houses all the source code files – including code written by developers, assets, and components – which form the core of the application.We will delete some of the default files to simplify our project structure: - 
Delete the following files from the srcdirectory:- logo.svg
- reportWebVitals.js
- setupTests.js
- App.test.js
- App.css
 
- 
Modify index.js: Opensrc/index.jsand remove the lines that importreportWebVitalsand callreportWebVitals(). Also, remove the import forlogo.svg.
- 
Modify App.js: Opensrc/App.js. Delete all the boilerplate code inside theAppcomponent function and the import forApp.css. Modify the component to be a functional expression for cleaner syntax.Functional expression: In JavaScript, a way to define a function using a concise syntax. In React, functional components are often written as functional expressions, emphasizing their role in rendering UI based on props. Your App.jsshould now look similar to this:import React from 'react'; import './index.css'; function App() { return ( <div className="app"> {/* Your application content will go here */} </div> ); } export default App;
- 
Modify index.css: Opensrc/index.cssand delete all the default styles. We will add our custom styles later.
- 
Modify index.html: Openpublic/index.htmland remove any unnecessary content within the<head>and<body>sections if desired. Ensure the basic structure with<div id="root"></div>remains.
 
- 
With the project set up and cleaned, we are ready to start building the backend and frontend components of our image-query application. We will begin by setting up the backend server in the next section.
