”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 使用 ReactJS 构建免费的 AI 图像生成器

使用 ReactJS 构建免费的 AI 图像生成器

发布于2024-11-08
浏览:502

开发者们大家好,
今天,我将向您展示如何使用 ReactJS 创建图像生成器,并且完全可以免费使用,这要感谢黑森林实验室和 Together AI。

第 1 步:设置项目

在本教程中,我们将使用 Vite 来初始化应用程序并使用 Shadcn 来初始化 UI。我假设您已经设置了项目并安装了 Shadcn。

第 2 步:安装 Together AI 软件包

我们需要安装Together AI包来访问免费的Flux模型来生成图像。
在终端中运行以下命令

npm i together-ai

第 3 步:构建用户界面

现在,让我们为我们的应用程序创建 UI。以下是图像生成器组件的完整代码。它包括提示的文本输入。用于选择宽高比的下拉菜单。
请记住,我们需要使用“black-forest-labs/FLUX.1-schnell-Free”,因为它是免费的。

import { useRef, useState } from "react";
import Together from "together-ai";
import { ImagesResponse } from "together-ai";
import { Button } from "@/components/ui/button";
import {
  Select,
  SelectContent,
  SelectItem,
  SelectTrigger,
  SelectValue,
} from "@/components/ui/select";
import { Textarea } from "@/components/ui/textarea";
import { motion } from "framer-motion";
import { Separator } from "@/components/ui/separator";
import { DownloadIcon } from "@radix-ui/react-icons";
import { save } from "@tauri-apps/plugin-dialog";
import { writeFile } from "@tauri-apps/plugin-fs";

function App() {
  const [input, setInput] = useState("");
  const [imageUrl, setImageUrl] = useState("");
  const [ratio, setRatio] = useState("9:16");
  const [isLoading, setIsLoading] = useState(false);
  const [downloading, setDownloading] = useState(false);
  const imageRef = useRef(null);

  const hRatio = ratio.split(":").map(Number)[0];
  const vRatio = ratio.split(":").map(Number)[1];

  const width = hRatio === 1 ? 512 : hRatio * 64;
  const height = vRatio === 1 ? 512 : vRatio * 64;

  const together = new Together({
    apiKey: import.meta.env.VITE_TOGETHER_API_KEY,
  });

  const handleGenerateImage = async () => {
    setIsLoading(true);

    try {
      console.log(width, height);
      const response: ImagesResponse = await together.images.create({
        model: "black-forest-labs/FLUX.1-schnell-Free",
        prompt: input,
        width: width,
        height: height,
        // @ts-expect-error response_format is not defined in the type
        response_format: "b64_json",
      });

      const base64Image = response.data[0].b64_json;
      const dataUrl = `data:image/png;base64,${base64Image}`;
      setImageUrl(dataUrl);
    } catch (error) {
      console.error("Error generating image:", error);
      // You might want to add some error handling UI here
    } finally {
      setIsLoading(false);
    }
  };

  const handleDownloadImage = async () => {
    if (imageUrl) {
      setDownloading(true);
      try {
        // Remove the data URL prefix
        const base64Data = imageUrl.replace(/^data:image\/\w ;base64,/, "");

        // Convert base64 to binary
        const imageBuffer = Uint8Array.from(atob(base64Data), (c) =>
          c.charCodeAt(0)
        );

        // Open a save dialog
        const filePath = await save({
          filters: [
            {
              name: "Image",
              extensions: ["png"],
            },
          ],
        });

        if (filePath) {
          // Write the file
          await writeFile(filePath, imageBuffer);
          console.log("File saved successfully");
        }
      } catch (error) {
        console.error("Error saving image:", error);
      } finally {
        setDownloading(false);
      }
    }
  };

  return (
    

AI Image Generator for "Thảo"

Generated Image

{imageUrl ? ( Generated
) : (

Your generated image will appear here

)}
); } export default App;

Build a Free AI Image Generator with ReactJS

Build a Free AI Image Generator with ReactJS

最后的想法

通过此设置,您现在拥有一个简单的 ReactJS 应用程序,可以生成和下载 AI 生成的图像。
感谢您的阅读!如果您觉得这篇文章有趣,请不要犹豫,点个赞。快乐编码!

版本声明 本文转载于:https://dev.to/nhd2106/image-generator-app-for-free-2p0d?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如何从 Java WebDriver 执行 JavaScript 代码?
    如何从 Java WebDriver 执行 JavaScript 代码?
    从Java执行WebDriver JavaScript:增强指南问题中提到的命令./go webdriverjs是一个shell命令设计在特定文件夹中设置并初始化 WebDriverJs 环境。但是,需要注意的是,WebDriverJs 是一种语言绑定,它支持 JavaScript 测试,而不是从 ...
    编程 发布于2024-11-08
  • 为我的 D&D 表构建自定义 Stream Deck:使用自定义 SDK 解决游戏手柄集成问题
    为我的 D&D 表构建自定义 Stream Deck:使用自定义 SDK 解决游戏手柄集成问题
    作为一名热情的龙与地下城玩家和技术爱好者,我决定通过创建一个带有嵌入式屏幕的定制咖啡桌来提升我的游戏设置。该桌子显示地图、代币、播放音效,甚至为玩家展示艺术品。所有这一切都通过一个名为 Foundry VTT 的强大平台运行,该平台与 Roll20 类似,但具有更好的定价模型和广泛的开放模块系统。它...
    编程 发布于2024-11-08
  • 如何在 PHP 中高效计算两个日期之间的月份数?
    如何在 PHP 中高效计算两个日期之间的月份数?
    有效查找日期之间的月份计数一个常见的编程挑战是确定两个日期之间的月份数。在 PHP 中,有多种方法可以解决这个问题。使用 DateTime 类 (PHP >= 5.3):PHP 5.3 中引入的 DateTime 类提供了方便的方法用于日期操作。计算月份差异:$d1 = new DateTime(&...
    编程 发布于2024-11-08
  • Bootstrap:创建和自定义导航栏
    Bootstrap:创建和自定义导航栏
    介绍 Bootstrap 是一个开源框架,广泛用于 Web 开发,用于创建响应式且适合移动设备的网站。 Bootstrap 的关键组件之一是导航栏,它是一个水平导航栏,用于组织和导航网站的内容。在本文中,我们将讨论使用 Bootstrap 创建和自定义导航栏的优点和缺点及其功能。 ...
    编程 发布于2024-11-08
  • 将 WebSocket 与 Python 结合使用
    将 WebSocket 与 Python 结合使用
    什么是 WebSocket? WebSocket 是一种支持浏览器和服务器之间实时、双向通信的协议。传统的 HTTP 通信涉及客户端发送请求和服务器响应以交换数据。相比之下,使用 WebSocket,一旦建立了初始连接,客户端和服务器都可以相互发送和接收消息,而无需重复建立新连接。...
    编程 发布于2024-11-08
  • 如何在 PHP 中从子域中提取域名?
    如何在 PHP 中从子域中提取域名?
    在 PHP 中从子域中提取域名在当代 Web 开发中,必须解析和检索域名,甚至是从子域中解析和检索域名。一个简单的示例可能包括诸如“here.example.com”或“example.org”之类的域名。为了满足这一需求,我们提出了一个全面的 PHP 函数,旨在从任何给定的输入中提取根域名。结合使...
    编程 发布于2024-11-08
  • 如何在多线程编程中连接向量以获得最佳效率?
    如何在多线程编程中连接向量以获得最佳效率?
    连接向量:深入分析在多线程编程中,合并结果是一个常见的挑战。这通常涉及将多个向量组合成单个综合向量。让我们探索连接向量以获得最大效率的最佳方法。最佳连接方法为了高效的向量连接,最佳实践是利用保留和插入方法:AB.reserve(A.size() B.size()); // Preallocate...
    编程 发布于2024-11-08
  • 如何优化FastAPI以实现高效的JSON数据返回?
    如何优化FastAPI以实现高效的JSON数据返回?
    FastAPI 返回大型 JSON 数据的优化通过 FastAPI 返回大量 JSON 数据集可能是一项耗时的任务。为了解决这个瓶颈,我们探索提高性能的替代方法。识别瓶颈:使用 json.dumps 将 Parquet 文件解析为 JSON 的初始方法( ) 和 json.loads() 效率低下。...
    编程 发布于2024-11-08
  • React:状态 X 派生状态
    React:状态 X 派生状态
    什么是派生状态?考虑文本的一种状态,然后考虑大写文本的另一种状态。 导出状态 function Foo() { const [text, setText] = useState('hello, za warudo!'); const [uppercaseText, s...
    编程 发布于2024-11-08
  • 如何使用自定义用户类型将 PostgreSQL JSON 列映射到 Hibernate 实体?
    如何使用自定义用户类型将 PostgreSQL JSON 列映射到 Hibernate 实体?
    将 PostgreSQL JSON 列映射到 Hibernate 实体使用 PostgreSQL 数据库时,经常会遇到以 JSON 格式存储数据的列。为了使用 Hibernate 有效地将这些列映射到 Java 实体,选择适当的数据类型至关重要。在这种情况下,当前的问题围绕着将 PostgreSQL...
    编程 发布于2024-11-08
  • 确保整个团队的 Node.js 版本一致
    确保整个团队的 Node.js 版本一致
    .nvmrc 和 package.json 综合指南 在当今动态的开发环境中,跨不同项目管理多个 Node.js 版本通常是一项复杂且容易出错的任务。 Node.js 版本不一致可能会导致许多问题,从意外行为到应用程序完全失败。 利用 .nvmrc 文件进行版本控制 在项目中保持一致...
    编程 发布于2024-11-08
  • 何时在 JavaScript Promise 中使用 Promise.reject 与 Throw?
    何时在 JavaScript Promise 中使用 Promise.reject 与 Throw?
    JavaScript Promise:Reject 与 Throw 之谜使用 JavaScript Promise 时,开发人员经常面临一个困境:他们是否应该使用 Promise .reject 或者只是抛出一个错误?虽然这两种方法具有相似的目的,但关于它们的差异和潜在优势仍然存在混淆。探索相似之处...
    编程 发布于2024-11-08
  • 构建 Chrome 扩展:快速概述
    构建 Chrome 扩展:快速概述
    模组——修改? 如果您喜欢游戏,您就会知道没有什么比玩模组游戏更好的了。这是您最喜欢的游戏,但具有额外的功能、功能和乐趣。现在,想象一下为您的网络浏览体验带来同样的兴奋。这正是浏览器扩展的作用——它们就像浏览器的模组,以您从未想过的方式增强浏览器的功能。 通过 Chrome 扩展程序,您可以调整浏览...
    编程 发布于2024-11-08
  • 如何使用 CSS 设置表格列宽?
    如何使用 CSS 设置表格列宽?
    设置表格列宽表格通常用于呈现表格数据,但调整列宽对于确保可读性和正确性至关重要结盟。在本文中,我们将探讨如何使用 CSS 设置表格列的宽度。使用 CSS 宽度属性的方法表格列的宽度可以使用 col 元素的 width 属性进行设置。宽度值可以以像素为单位指定(例如 width: 200px;),也可...
    编程 发布于2024-11-08
  • 如何从 Python 中的嵌套函数访问非局部变量?
    如何从 Python 中的嵌套函数访问非局部变量?
    访问嵌套函数作用域中的非局部变量在 Python 中,嵌套函数作用域提供对封闭作用域的访问。但是,尝试修改嵌套函数内封闭范围内的变量可能会导致 UnboundLocalError。要解决此问题,您有多种选择:1。使用 'nonlocal' 关键字 (Python 3 ):对于 Pyt...
    编程 发布于2024-11-08

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3