此版本仍在开发中,尚未被视为稳定版本。最新的快照版本请使用 Spring AI 1.0.0-SNAPSHOT!spring-doc.cn

稳定性 AI 图像生成

Spring AI 支持 Stability AI 的文本到图像生成模型spring-doc.cn

先决条件

您需要使用 Stability AI 创建 API 密钥才能访问他们的 AI 模型,请按照他们的入门文档进行操作。spring-doc.cn

Spring AI 项目定义了一个名为 的配置属性,您应该将其设置为从 Stability AI 获取的值。 导出环境变量是设置该配置属性的一种方法。spring.ai.stabilityai.api-keyAPI Keyspring-doc.cn

export SPRING_AI_STABILITYAI_API_KEY=<INSERT KEY HERE>

自动配置

Spring AI 为 Stability AI Image Generation Client 提供 Spring Boot 自动配置。 要启用它,请将以下依赖项添加到项目的 Maven 文件中:pom.xmlspring-doc.cn

<dependency>
    <groupId>org.springframework.ai</groupId>
    <artifactId>spring-ai-stability-ai-spring-boot-starter</artifactId>
</dependency>

或您的 Gradle 构建文件。build.gradlespring-doc.cn

dependencies {
    implementation 'org.springframework.ai:spring-ai-stability-ai-spring-boot-starter'
}
请参阅 Dependency Management 部分,将 Spring AI BOM 添加到您的构建文件中。

图像生成属性

该前缀用作允许您连接到 Stability AI 的属性前缀。spring.ai.stabilityaispring-doc.cn

财产 描述 违约

spring.ai.stabilityai.base-urlspring-doc.cn

要连接到的 URLspring-doc.cn

api.stability.ai/v1spring-doc.cn

spring.ai.stabilityai.api-keyspring-doc.cn

API 密钥spring-doc.cn

-spring-doc.cn

prefix 是允许您为 Stability AI 配置实现的属性前缀。spring.ai.stabilityai.imageImageModelspring-doc.cn

财产 描述 违约

spring.ai.stabilityai.image.enabledspring-doc.cn

启用 Stability AI 图像模型。spring-doc.cn

spring-doc.cn

spring.ai.stabilityai.image.base-urlspring-doc.cn

可选覆盖spring.ai.openai.base-url以提供特定的 urlspring-doc.cn

api.stability.ai/v1spring-doc.cn

spring.ai.stabilityai.image.api-keyspring-doc.cn

Optional 覆盖 spring.ai.openai.api-key 以提供特定的 api-keyspring-doc.cn

-spring-doc.cn

spring.ai.stabilityai.image.option.nspring-doc.cn

要生成的图像数量。必须介于 1 和 10 之间。spring-doc.cn

1spring-doc.cn

spring.ai.stabilityai.image.option.modelspring-doc.cn

要在 Stability AI 中使用的引擎/模型。模型在 URL 中作为 path 参数传递。spring-doc.cn

stable-diffusion-v1-6spring-doc.cn

spring.ai.stabilityai.image.option.widthspring-doc.cn

要生成的图像的宽度(以像素为单位),增量可被 64 整除。适用特定于引擎的维度验证。spring-doc.cn

512spring-doc.cn

spring.ai.stabilityai.image.option.heightspring-doc.cn

要生成的图像高度(以像素为单位),增量可被 64 整除。适用特定于引擎的维度验证。spring-doc.cn

512spring-doc.cn

spring.ai.stabilityai.image.option.responseFormatspring-doc.cn

返回生成图像的格式。必须是 “application/json” 或 “image/png”。spring-doc.cn

-spring-doc.cn

spring.ai.stabilityai.image.option.cfg_scalespring-doc.cn

扩散过程对提示文本的严格程度。范围:0 到 35。spring-doc.cn

7spring-doc.cn

spring.ai.stabilityai.image.option.clip_guidance_presetspring-doc.cn

传入样式预设以将图像模型引导至特定样式。此样式预设列表可能会发生更改。spring-doc.cn

NONEspring-doc.cn

spring.ai.stabilityai.image.option.samplerspring-doc.cn

用于扩散过程的采样器。如果省略此值,则将自动选择适当的采样器。spring-doc.cn

-spring-doc.cn

spring.ai.stabilityai.image.option.seedspring-doc.cn

随机噪声种子(省略此选项或使用 0 表示随机种子)。有效范围:0 到 4294967295。spring-doc.cn

0spring-doc.cn

spring.ai.stabilityai.image.option.stepsspring-doc.cn

要运行的扩散步骤数。有效范围:10 到 50。spring-doc.cn

30spring-doc.cn

spring.ai.stabilityai.image.option.style_presetspring-doc.cn

传入样式预设以将图像模型引导至特定样式。此样式预设列表可能会发生更改。spring-doc.cn

-spring-doc.cn

运行时选项

StabilityAiImageOptions.java 提供模型配置,例如要使用的模型、样式、大小等。spring-doc.cn

启动时,可以使用构造函数配置默认选项。或者,使用前面描述的属性。StabilityAiImageModel(StabilityAiApi stabilityAiApi, StabilityAiImageOptions options)spring.ai.openai.image.options.*spring-doc.cn

在运行时,您可以通过向调用添加新的、特定于请求的选项来覆盖默认选项。 例如,要覆盖 Stability AI 特定的选项(如质量和要创建的图像数量),请使用以下代码示例:ImagePromptspring-doc.cn

ImageResponse response = stabilityaiImageModel.call(
        new ImagePrompt("A light cream colored mini golden doodle",
        StabilityAiImageOptions.builder()
                .withStylePreset("cinematic")
                .withN(4)
                .withHeight(1024)
                .withWidth(1024).build())

);
除了特定于模型的 StabilityAiImageOptions 之外,您还可以使用通过 ImageOptionsBuilder#builder() 创建的可移植 ImageOptions 实例。