Langsung ke konten utama
POST
/
v1
/
images
/
generations
curl --request POST \
  --url https://api.apimart.ai/v1/images/generations \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '{
    "model": "gpt-image-2-official",
    "prompt": "An ancient castle beneath a starry sky",
    "size": "16:9",
    "resolution": "2k",
    "quality": "high",
    "n": 1
  }'
{
  "code": 200,
  "data": [
    {
      "status": "submitted",
      "task_id": "task_01KPTXXXXXXXXXXXXXXX"
    }
  ]
}

Documentation Index

Fetch the complete documentation index at: https://docs.apimart.ai/llms.txt

Use this file to discover all available pages before exploring further.

curl --request POST \
  --url https://api.apimart.ai/v1/images/generations \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '{
    "model": "gpt-image-2-official",
    "prompt": "An ancient castle beneath a starry sky",
    "size": "16:9",
    "resolution": "2k",
    "quality": "high",
    "n": 1
  }'
{
  "code": 200,
  "data": [
    {
      "status": "submitted",
      "task_id": "task_01KPTXXXXXXXXXXXXXXX"
    }
  ]
}

Otorisasi

Authorization
string
wajib
Semua endpoint memerlukan autentikasi Bearer TokenDapatkan API Key Anda:Kunjungi halaman manajemen API Key untuk mendapatkan API Key AndaSertakan di header permintaan:
Authorization: Bearer YOUR_API_KEY

Body

model
string
default:"gpt-image-2-official"
wajib
Nama model pembuatan gambarTetap sebagai gpt-image-2-official (model resmi OpenAI gpt-image-2)
prompt
string
wajib
Deskripsi teks untuk pembuatan gambar
  • Mendukung bahasa Inggris dan Mandarin; deskripsi yang terperinci direkomendasikan
  • Moderasi konten / tinjauan keamanan sebelum pengiriman — pelanggaran langsung ditolak
size
string
default:"1:1"
Rasio aspek gambarSecara eksternal menggunakan nilai rasio; secara internal dipetakan ke piksel aktual sesuai resolution.Rasio yang didukung, ditambah auto agar server memilih rasio yang sesuai secara otomatis:
  • auto - Otomatis (server memilih rasio berdasarkan prompt / gambar referensi)
  • 1:1 - Persegi (default, avatar sosial / logo)
  • 3:2 - Lanskap (rasio DSLR umum)
  • 2:3 - Potret (poster vertikal)
  • 4:3 - Lanskap (monitor klasik / slideshow)
  • 3:4 - Potret
  • 5:4 - Lanskap
  • 4:5 - Potret (post vertikal Instagram)
  • 16:9 - Lanskap (thumbnail video layar lebar)
  • 9:16 - Potret (layar penuh ponsel / sampul video pendek)
  • 2:1 - Lanskap (banner web)
  • 1:2 - Potret
  • 3:1 - Lanskap (banner ultra-lebar)
  • 1:3 - Potret (poster ekstra tinggi)
  • 21:9 - Lanskap (ultra-lebar sinematik)
  • 9:21 - Potret
Dimensi piksel juga dapat diteruskan langsung, seperti 1881x836 / 887x1774.
Saat size diatur ke auto, rasio default adalah 1:1.
resolution
string
default:"1k"
Tier resolusi (bidang baru)Mengontrol kejernihan output aktual.
  • 1k - Baseline 1024, hemat biaya untuk penggunaan harian (default)
  • 2k - Baseline 2048, cocok untuk poster / kebutuhan definisi tinggi
  • 4k - Baseline 3840, mendukung 15 rasio pada tabel pemetaan di bawah
4K mendukung 15 rasio dalam tabel pemetaan di bawah; Anda juga dapat meneruskan dimensi piksel dari tabel langsung melalui size.
quality
string
default:"auto"
Kualitas gambar
  • auto - Otomatis (default, biasanya setara dengan low)
  • low - Cepat dan ekonomis, cukup untuk garis besar kasar
  • medium - Seimbang
  • high - Presisi maksimum (4K + high can take >120s)
background
string
default:"auto"
Mode latar belakang
  • auto - Otomatis (default)
  • opaque - Opaque
  • transparent - ⚠️ gpt-image-2-official tidak mendukung latar belakang transparan; sistem akan diam-diam menurunkannya ke auto
moderation
string
default:"auto"
Kekuatan moderasi
  • auto - Kekuatan moderasi default
  • low - Moderasi lebih longgar
output_format
string
default:"png"
Format output
  • png - Default
  • jpeg - File lebih kecil
  • webp - Optimal untuk browser modern
output_compression
integer
Level kompresi output, rentang 0-100
  • Hanya efektif untuk jpeg / webp
n
integer
default:"1"
Jumlah gambar yang akan dibuatRentang: 1 ~ 4
Harus berupa angka murni (misalnya 1), jangan bungkus dengan tanda kutip
image_urls
array
Array URL gambar referensi
mask_url
string
URL gambar mask, digunakan untuk inpainting
  • Harus digunakan bersama image_urls
  1. Pastikan gambar mask memiliki kanal Alpha sebelum mengunggah.
  2. Dimensi gambar mask harus cocok dengan gambar referensi pertama.

Pemetaan Ukuran × Resolusi

size × resolution → piksel aktual OpenAI (15 ratios × 3 tiers):
size1k2k4k
1:11024×10242048×20482880×2880
3:21536×10242048×13603520×2336
2:31024×15361360×20482336×3520
4:31024×7682048×15363312×2480
3:4768×10241536×20482480×3312
5:41280×10242560×20483216×2576
4:51024×12802048×25602576×3216
16:91536×8642048×11523840×2160
9:16864×15361152×20482160×3840
2:12048×10242688×13443840×1920
1:21024×20481344×26881920×3840
3:11881×836 / 1536×5123072×10243840×1280
1:3887×1774 / 512×15361024×30721280×3840
21:92016×8642688×11523840×1648
9:21864×20161152×26881648×3840
Catatan: Beberapa dimensi diperkirakan berdasarkan kelipatan 16 dan batas piksel, seperti 3:2 / 2:3 @ 2K sebesar 2048×1360 dan 21:9 @ 4K sebesar 3840×1648. Gunakan piksel aktual dalam tabel sebagai sumber kebenaran.

Contoh Penggunaan

Text-to-image (permintaan minimal)
{
  "model": "gpt-image-2-official",
  "prompt": "An ancient castle beneath a starry sky"
}
Poster definisi tinggi 2K
{
  "model": "gpt-image-2-official",
  "prompt": "Cyberpunk night scene",
  "size": "16:9",
  "resolution": "2k",
  "quality": "high",
  "output_format": "jpeg",
  "output_compression": 90
}
Wallpaper 4K
{
  "model": "gpt-image-2-official",
  "prompt": "Snow mountain sunrise panorama",
  "size": "16:9",
  "resolution": "4k",
  "quality": "high",
  "n": 1
}
Image-to-image (fusi multi-referensi)
{
  "model": "gpt-image-2-official",
  "prompt": "Fuse the two reference images into a single illustration poster, preserving the main silhouettes",
  "size": "1:1",
  "quality": "high",
  "image_urls": [
    "https://your-cdn.com/input-a.png",
    "https://your-cdn.com/input-b.png"
  ]
}
Inpainting (mask)
{
  "model": "gpt-image-2-official",
  "prompt": "Replace the background with a desert sunset",
  "size": "1:1",
  "quality": "medium",
  "image_urls": ["https://your-cdn.com/photo.png"],
  "mask_url": "https://your-cdn.com/mask.png"
}
Beberapa gambar (n > 1)
{
  "model": "gpt-image-2-official",
  "prompt": "Four minimalist poster variations of a red fox",
  "size": "1:1",
  "quality": "low",
  "n": 4
}
String piksel langsung (lanjutan)
{
  "model": "gpt-image-2-official",
  "prompt": "wide cinematic shot",
  "size": "3840x2160",
  "quality": "high"
}

Respons

code
integer
Kode status respons
data
array
Array data respons

Mengueri Hasil Tugas

Setelah pengiriman berhasil, task_id dikembalikan. Polling status tugas melalui GET /v1/tasks/{task_id}; lihat API Kueri Tugas untuk detail.

Contoh Respons Berhasil

{
  "code": 200,
  "data": {
    "id": "task_01KPTXXXXXXXXXXXXXXX",
    "status": "completed",
    "progress": 100,
    "actual_time": 46,
    "cost": 0.05279,
    "result": {
      "images": [
        {
          "url": [
            "https://upload.apimart.ai/f/image/xxxxxxxx-gpt_image_2_official_task_xxx_0.png"
          ],
          "expires_at": 1776928569
        }
      ]
    }
  }
}
Alur status tugas: submittedin_progresscompleted / failed. Akses gambar: data.result.images[0].url[0].

Rekomendasi Polling

  • Jeda kueri awal: Tunggu 10~20 detik setelah pengiriman sebelum kueri pertama
  • Interval kueri: 3~5 detik direkomendasikan
  • Referensi timeout: high + 2k/4k dapat memakan waktu hingga 130 detik; timeout klien ≥ 180 detik direkomendasikan
  • Kueri batch: Untuk mengueri beberapa tugas sekaligus, gunakan POST /v1/tasks/batch