media_resolution 参数用于确定为媒体输入内容分配的 token 数量上限,从而控制 Gemini API 处理图片、视频和 PDF 文档等媒体输入内容的方式,让您可以在回答质量与延迟时间和费用之间取得平衡。如需了解不同设置、默认值以及它们与令牌的对应关系,请参阅令牌数量部分。
您可以在请求中为各个媒体对象(内容项)配置媒体分辨率(仅限 Gemini 3)。
按内容项设置的媒体分辨率(仅限 Gemini 3)
Gemini 3 可让您为请求中的各个媒体对象设置媒体分辨率,从而实现精细的令牌用量优化。您可以在单个请求中混合使用不同的分辨率级别。例如,为复杂的图表使用高分辨率,为简单的上下文相关图片使用低分辨率。
Python
from google import genai
client = genai.Client()
myfile = client.files.upload(file="path/to/image.jpg")
interaction = client.interactions.create(
model="gemini-3.5-flash",
input=[
{"type": "text", "text": "Describe this image:"},
{
"type": "image",
"uri": myfile.uri,
"mime_type": myfile.mime_type,
"resolution": "high"
}
]
)
print(interaction.output_text)
JavaScript
import { GoogleGenAI } from "@google/genai";
const ai = new GoogleGenAI({});
async function main() {
const myfile = await ai.files.upload({
file: "path/to/image.jpg",
config: { mime_type: "image/jpeg" },
});
const interaction = await ai.interactions.create({
model: "gemini-3.5-flash",
input: [
{ type: "text", text: "Describe this image:" },
{
type: "image",
uri: myfile.uri,
mime_type: myfile.mimeType,
resolution: "high"
}
],
});
console.log(interaction.output_text);
}
await main();
REST
# First upload the file using the Files API, then use the URI:
curl -X POST "https://generativelanguage.googleapis.com/v1beta/interactions" \
-H "x-goog-api-key: $GEMINI_API_KEY" \
-H 'Content-Type: application/json' \
-d '{
"model": "gemini-3.5-flash",
"input": [
{"type": "text", "text": "Describe this image:"},
{
"type": "image",
"uri": "YOUR_FILE_URI",
"mime_type": "image/jpeg",
"resolution": "high"
}
]
}'
可用的分辨率值
Gemini API 为媒体分辨率定义了以下级别:
unspecified:默认设置。此级别的令牌数量在 Gemini 3 与更早的 Gemini 模型之间存在显著差异。low:词元数量较少,因此处理速度更快,费用更低,但细节较少。medium:在细节、费用和延迟之间取得平衡。high:词元数量较多,可为模型提供更多细节,但延迟时间和费用也会增加。ultra_high(仅限每个内容项):最高令牌数,适用于特定使用场景,例如计算机使用。
请注意,high 可为大多数使用场景提供最佳性能。
每个级别生成的 token 的确切数量取决于媒体类型(图片、视频、PDF)和模型版本。
token 数量
下表总结了每个模型系列中每个 media_resolution 值和媒体类型对应的大致 token 数量。
Gemini 3 模型
| MediaResolution | 图片 | 视频 | |
|---|---|---|---|
unspecified(默认) |
1120 | 70 | 560 |
low |
280 | 70 | 280 + 原生文字 |
medium |
560 | 70 | 560 + 原生文字 |
high |
1120 | 280 | 1120 + 原生文本 |
ultra_high |
2240 | 不适用 | 不适用 |
选择合适的分辨率
- 默认 (
unspecified):从默认设置开始。它经过调整,可在大多数常见应用场景中实现质量、延迟时间和费用之间的良好平衡。 low:适用于成本和延迟时间至关重要,而细粒度细节不太重要的场景。medium/high:如果任务需要了解媒体中的复杂细节,请提高分辨率。这对于复杂的视觉分析、图表阅读或理解密集型文档通常是必需的。ultra_high- 仅适用于按内容项设置。建议用于特定使用场景,例如计算机使用场景,或者测试表明其性能明显优于high的场景。- 按内容项控制(Gemini 3):优化令牌使用情况。例如,在包含多张图片的提示中,使用
high表示复杂的图表,使用low或medium表示简单的上下文图片。
推荐设置
下表列出了每种受支持的媒体类型的推荐媒体分辨率设置。
| 媒体类型 | 推荐设置 | 最大token数 | 使用指南 |
|---|---|---|---|
| 图片 | high |
1120 | 建议用于大多数图片分析任务,以确保获得最高质量的结果。 |
medium |
560 | 非常适合文档理解;质量通常在 medium 时达到饱和。将该值增加到 high 很少能提高标准文档的 OCR 结果。 |
|
| 视频(常规) | low(或 medium) |
70(每帧) | 注意:对于视频,low 和 medium 设置的处理方式相同(70 个 token),以优化上下文使用。这对于大多数动作识别和描述任务来说已经足够。 |
| 视频(文字较多) | high |
280(每帧) | 仅当用例涉及读取视频帧中的密集文本 (OCR) 或细微细节时才需要。 |
请务必测试并评估不同分辨率设置对应用的影响,以便在质量、延迟时间和费用之间找到最佳平衡点。
版本兼容性摘要
- 为各个内容项设置
resolution仅适用于 Gemini 3 模型。