---
title: P-Image-Try-On | Runware Docs
url: https://runware.ai/docs/models/prunaai-p-image-try-on
description: Virtual try-on image model for dressing a person in one or more reference garments while preserving identity and pose
---
# P-Image-Try-On

P-Image-Try-On is an image editing model from Pruna AI for virtual try-on workflows. It takes a source image of a person together with one or more garment reference images and generates a new image in which the person is realistically dressed in the provided garments. The model is built to preserve identity, pose, body shape, and the overall structure of the original image, making it useful for fashion previews, e-commerce visualization, styling exploration, and other garment-transfer workflows.

- **ID**: `prunaai:p-image@try-on`
- **Status**: live
- **Creator**: Pruna AI
- **Release Date**: June 18, 2026
- **Capabilities**: Image to Image, Edit, Checkpoint

## Pricing

$0.015 for the first garment, $0.008 for each additional one

- **First garment**: `$0.015`
- **2 garments**: `$0.023`
- **3 garments**: `$0.031`

## Request Parameters

**API Options**

Platform-level options for task execution and delivery.

### [taskType](https://runware.ai/docs/models/prunaai-p-image-try-on#request-tasktype)

- **Type**: `string`
- **Required**: true
- **Value**: `imageInference`

Identifier for the type of task being performed

### [taskUUID](https://runware.ai/docs/models/prunaai-p-image-try-on#request-taskuuid)

- **Type**: `string`
- **Required**: true
- **Format**: `UUID v4`

UUID v4 identifier for tracking tasks and matching async responses. Must be unique per task.

### [outputType](https://runware.ai/docs/models/prunaai-p-image-try-on#request-outputtype)

- **Type**: `string`
- **Default**: `URL`

Image output type.

**Allowed values**: `URL` `base64Data` `dataURI`

### [outputFormat](https://runware.ai/docs/models/prunaai-p-image-try-on#request-outputformat)

- **Type**: `string`
- **Default**: `JPG`

Specifies the file format of the generated output. The available values depend on the task type and the specific model's capabilities.

- \`JPG\`: Best for photorealistic images with smaller file sizes (no transparency).
- \`PNG\`: Lossless compression, supports high quality and transparency (alpha channel).
- \`WEBP\`: Modern format providing superior compression and transparency support.

> [!NOTE]
> \*\*Transparency\*\*: If you are using features like background removal or LayerDiffuse that require transparency, you must select a format that supports an alpha channel (e.g., \`PNG\`, \`WEBP\`, \`TIFF\`). \`JPG\` does not support transparency.

**Allowed values**: `JPG` `PNG` `WEBP`

### [outputQuality](https://runware.ai/docs/models/prunaai-p-image-try-on#request-outputquality)

- **Type**: `integer`
- **Min**: `20`
- **Max**: `99`
- **Default**: `95`

Compression quality of the output. Higher values preserve quality but increase file size.

### [webhookURL](https://runware.ai/docs/models/prunaai-p-image-try-on#request-webhookurl)

- **Type**: `string`
- **Format**: `URI`

Specifies a webhook URL where JSON responses will be sent via HTTP POST when generation tasks complete. For batch requests with multiple results, each completed item triggers a separate webhook call as it becomes available.

**Learn more** (1 resource):

- [Webhooks](https://runware.ai/docs/platform/webhooks) (platform)

### [deliveryMethod](https://runware.ai/docs/models/prunaai-p-image-try-on#request-deliverymethod)

- **Type**: `string`
- **Default**: `sync`

Determines how the API delivers task results.

**Allowed values**:

- `sync` Returns complete results directly in the API response.
- `async` Returns an immediate acknowledgment with the task UUID. Poll for results using getResponse.

**Learn more** (1 resource):

- [Task Polling](https://runware.ai/docs/platform/task-polling) (platform)

### [uploadEndpoint](https://runware.ai/docs/models/prunaai-p-image-try-on#request-uploadendpoint)

- **Type**: `string`
- **Format**: `URI`

Specifies a URL where the generated content will be automatically uploaded using the HTTP PUT method. The raw binary data of the media file is sent directly as the request body. For secure uploads to cloud storage, use presigned URLs that include temporary authentication credentials.

**Common use cases:**

- **Cloud storage**: Upload directly to S3 buckets, Google Cloud Storage, or Azure Blob Storage using presigned URLs.
- **CDN integration**: Upload to content delivery networks for immediate distribution.

```text
// S3 presigned URL for secure upload
https://your-bucket.s3.amazonaws.com/generated/content.mp4?X-Amz-Signature=abc123&X-Amz-Expires=3600

// Google Cloud Storage presigned URL
https://storage.googleapis.com/your-bucket/content.jpg?X-Goog-Signature=xyz789

// Custom storage endpoint
https://storage.example.com/uploads/generated-image.jpg
```

The content data will be sent as the request body to the specified URL when generation is complete.

### [safety](https://runware.ai/docs/models/prunaai-p-image-try-on#request-safety)

- **Path**: `safety.checkContent`
- **Type**: `object (1 property)`

Content safety checking configuration for image generation.

#### [checkContent](https://runware.ai/docs/models/prunaai-p-image-try-on#request-safety-checkcontent)

- **Path**: `safety.checkContent`
- **Type**: `boolean`
- **Default**: `false`

Enable or disable content safety checking.

### [ttl](https://runware.ai/docs/models/prunaai-p-image-try-on#request-ttl)

- **Type**: `integer`
- **Min**: `60`

Time-to-live (TTL) in seconds for generated content. Only applies when `outputType` is `URL`.

### [includeCost](https://runware.ai/docs/models/prunaai-p-image-try-on#request-includecost)

- **Type**: `boolean`
- **Default**: `false`

Include task cost in the response.

### [numberResults](https://runware.ai/docs/models/prunaai-p-image-try-on#request-numberresults)

- **Type**: `integer`
- **Min**: `1`
- **Max**: `20`
- **Default**: `1`

Number of results to generate. Each result uses a different seed, producing variations of the same parameters.

**Inputs**

Input resources for the task (images, audio, etc). These must be nested inside the \`inputs\` object.

### [referenceImages](https://runware.ai/docs/models/prunaai-p-image-try-on#request-inputs-referenceimages)

- **Path**: `inputs.referenceImages`
- **Type**: `array of objects (2 properties)`
- **Required**: true

List of reference images (UUID, URL, Data URI, or Base64).

#### [image](https://runware.ai/docs/models/prunaai-p-image-try-on#request-inputs-referenceimages-image)

- **Path**: `inputs.referenceImages.image`
- **Type**: `string`
- **Required**: true

Image input (UUID, URL, Data URI, or Base64).

#### [role](https://runware.ai/docs/models/prunaai-p-image-try-on#request-inputs-referenceimages-role)

- **Path**: `inputs.referenceImages.role`
- **Type**: `string`
- **Required**: true

Role of the image in the virtual try-on process. Use exactly one `person`, one to eleven `garment`, and optionally one `pose`.

**Allowed values**: `person` `garment` `pose`

**Core Parameters**

Primary parameters that define the task output.

### [model](https://runware.ai/docs/models/prunaai-p-image-try-on#request-model)

- **Type**: `string`
- **Required**: true
- **Value**: `prunaai:p-image@try-on`

Identifier of the model to use for generation.

### [positivePrompt](https://runware.ai/docs/models/prunaai-p-image-try-on#request-positiveprompt)

- **Type**: `string`

Experimental guidance for non-flatlay garment images, for example which garment from which image to use.

### [seed](https://runware.ai/docs/models/prunaai-p-image-try-on#request-seed)

- **Type**: `integer`
- **Min**: `0`
- **Max**: `9223372036854776000`

Random seed for reproducible generation. When not provided, a random seed is generated in the unsigned 32-bit range.

**Settings**

Technical parameters to fine-tune the inference process. These must be nested inside the \`settings\` object.

### [preserveInputSize](https://runware.ai/docs/models/prunaai-p-image-try-on#request-settings-preserveinputsize)

- **Path**: `settings.preserveInputSize`
- **Type**: `boolean`
- **Default**: `true`

Return the output at the original input resolution. When disabled, the output keeps the model's internal working resolution, which may differ from the input because inputs are dynamically resized for quality and speed.

### [turbo](https://runware.ai/docs/models/prunaai-p-image-try-on#request-settings-turbo)

- **Path**: `settings.turbo`
- **Type**: `boolean`
- **Default**: `false`

Enable turbo mode for faster generation. May reduce subtle details in complex tasks.

## Response Parameters

### [taskType](https://runware.ai/docs/models/prunaai-p-image-try-on#response-tasktype)

- **Type**: `string`
- **Required**: true
- **Value**: `imageInference`

Identifier for the type of task this response belongs to.

### [taskUUID](https://runware.ai/docs/models/prunaai-p-image-try-on#response-taskuuid)

- **Type**: `string`
- **Required**: true
- **Format**: `UUID v4`

UUID v4 identifier echoed from the original request, used to match async responses to their tasks.

### [imageUUID](https://runware.ai/docs/models/prunaai-p-image-try-on#response-imageuuid)

- **Type**: `string`
- **Required**: true
- **Format**: `UUID v4`

UUID of the output image.

### [imageURL](https://runware.ai/docs/models/prunaai-p-image-try-on#response-imageurl)

- **Type**: `string`
- **Format**: `URI`

URL of the output image.

### [imageBase64Data](https://runware.ai/docs/models/prunaai-p-image-try-on#response-imagebase64data)

- **Type**: `string`

Base64-encoded image data.

### [imageDataURI](https://runware.ai/docs/models/prunaai-p-image-try-on#response-imagedatauri)

- **Type**: `string`
- **Format**: `URI`

Data URI of the output image.

### [seed](https://runware.ai/docs/models/prunaai-p-image-try-on#response-seed)

- **Type**: `integer`

The seed used for generation. If none was provided, shows the randomly generated seed.

### [NSFWContent](https://runware.ai/docs/models/prunaai-p-image-try-on#response-nsfwcontent)

- **Type**: `boolean`

Flag indicating if NSFW content was detected.

### [cost](https://runware.ai/docs/models/prunaai-p-image-try-on#response-cost)

- **Type**: `float`

Task cost in USD. Present when `includeCost` is set to `true` in the request.

## Examples

### Frosted Alpine Techwear Fitting (Image to Image)

![Frosted Alpine Techwear Fitting]()

**Request**:

```json
{
  "taskType": "imageInference",
  "taskUUID": "43d2f08b-5be6-49b0-8b74-ba146e06bbc4",
  "model": "prunaai:p-image@try-on",
  "positivePrompt": "Dress the person in the pearl-white technical ski parka, charcoal snow pants, glacier-blue gloves, and matching neck gaiter. Preserve the person's face, hair, pose, body shape, camera angle, and snowy bridge setting. Keep garment fit realistic with natural folds, correct layering, visible zipper details, and believable winter fabric textures.",
  "seed": 56373,
  "settings": {
    "preserveInputSize": true,
    "turbo": false
  },
  "inputs": {
    "referenceImages": [
      {
        "image": "https://assets.runware.ai/assets/inputs/d7e6aeb3-2238-4d1e-8d52-d822d2420827.jpg",
        "role": "person"
      },
      {
        "image": "https://assets.runware.ai/assets/inputs/4cd8931a-4ea7-45fa-aba4-fc157224cb6b.jpg",
        "role": "garment"
      },
      {
        "image": "https://assets.runware.ai/assets/inputs/820ed186-283e-4504-9bbd-021e7fc85ac2.jpg",
        "role": "garment"
      },
      {
        "image": "https://assets.runware.ai/assets/inputs/7d48cc28-6b82-43b8-8043-9848d7ccee48.jpg",
        "role": "garment"
      }
    ]
  }
}
```

**Response**:

```json
{
  "taskType": "imageInference",
  "taskUUID": "43d2f08b-5be6-49b0-8b74-ba146e06bbc4",
  "imageUUID": "fbc101e4-46e9-45f1-b027-147239ae3d09",
  "imageURL": "https://im.runware.ai/image/os/a02d21/ws/3/ii/fbc101e4-46e9-45f1-b027-147239ae3d09.jpg",
  "seed": 56373,
  "cost": 0.0093
}
```

---

### Glasshouse Linen Suit Fitting (Image to Image)

![Glasshouse Linen Suit Fitting]()

**Request**:

```json
{
  "taskType": "imageInference",
  "taskUUID": "56acf31d-5bbc-4718-a042-4056a5b3e1a4",
  "model": "prunaai:p-image@try-on",
  "positivePrompt": "Dress the person in the saffron linen wrap blazer and ivory pleated trousers from the garment references. Preserve the person’s face, body shape, stance, scale, and the greenhouse walkway setting. Keep realistic fabric drape, natural shadows, accurate sleeve length, clean waistband alignment, and visible linen texture.",
  "seed": 67211,
  "settings": {
    "preserveInputSize": true,
    "turbo": false
  },
  "inputs": {
    "referenceImages": [
      {
        "image": "https://assets.runware.ai/assets/inputs/e7bac837-7af2-456f-a327-8061ec8e4fe4.jpg",
        "role": "person"
      },
      {
        "image": "https://assets.runware.ai/assets/inputs/9fb97d4e-e321-44b0-ac70-de661374dd4f.jpg",
        "role": "garment"
      },
      {
        "image": "https://assets.runware.ai/assets/inputs/7b8904dc-81c3-4c97-a721-8f41f4ae7608.jpg",
        "role": "garment"
      }
    ]
  }
}
```

**Response**:

```json
{
  "taskType": "imageInference",
  "taskUUID": "56acf31d-5bbc-4718-a042-4056a5b3e1a4",
  "imageUUID": "5e72532e-8d56-4177-af70-7163802608ea",
  "imageURL": "https://im.runware.ai/image/os/a05d22/ws/3/ii/5e72532e-8d56-4177-af70-7163802608ea.jpg",
  "seed": 67211,
  "cost": 0.0069
}
```

---

### Copper Canopy Street Styling (Image to Image)

![Copper Canopy Street Styling]()

**Request**:

```json
{
  "taskType": "imageInference",
  "taskUUID": "fcd53d64-371a-4694-acd3-9f1ed71aeca8",
  "model": "prunaai:p-image@try-on",
  "positivePrompt": "Dress the person in the cropped emerald satin bomber jacket from the first garment image and the high-waisted ivory pleated midi skirt from the second garment image. Preserve the person’s face, hairstyle, stance, body proportions, hands, shoes, and the sunlit plaza setting. Render realistic fabric texture, accurate jacket length, clean skirt pleats, natural shadows, believable layering, and seamless fit.",
  "seed": 41825,
  "settings": {
    "preserveInputSize": true,
    "turbo": false
  },
  "inputs": {
    "referenceImages": [
      {
        "image": "https://assets.runware.ai/assets/inputs/a1b98607-71d9-4872-9320-3b5ab8d0655c.jpg",
        "role": "person"
      },
      {
        "image": "https://assets.runware.ai/assets/inputs/b12e5895-9ba1-453f-9f4b-cb4011062fb5.jpg",
        "role": "garment"
      },
      {
        "image": "https://assets.runware.ai/assets/inputs/90ba9775-52fa-42b4-890b-d5a001672c5b.jpg",
        "role": "garment"
      }
    ]
  }
}
```

**Response**:

```json
{
  "taskType": "imageInference",
  "taskUUID": "fcd53d64-371a-4694-acd3-9f1ed71aeca8",
  "imageUUID": "7198fbf0-9f5d-4868-9949-a804964038b6",
  "imageURL": "https://im.runware.ai/image/os/a01d21/ws/3/ii/7198fbf0-9f5d-4868-9949-a804964038b6.jpg",
  "seed": 41825,
  "cost": 0.0069
}
```

---

### Concrete Skatepark Layered Outfit (Image to Image)

![Concrete Skatepark Layered Outfit]()

**Request**:

```json
{
  "taskType": "imageInference",
  "taskUUID": "467d33d4-3bda-4a27-9c08-14202d9bfa2a",
  "model": "prunaai:p-image@try-on",
  "positivePrompt": "Dress the person in the pearlescent cropped puffer jacket from the first garment image and the charcoal asymmetrical pleated cargo skirt from the second garment image. Preserve the person's face, body shape, pose, camera angle, and skatepark setting. Keep fabric volume, quilting, zipper placement, pleats, pockets, and hem structure realistic, with natural shadows and golden-hour outdoor lighting.",
  "seed": 94754,
  "settings": {
    "preserveInputSize": true,
    "turbo": false
  },
  "inputs": {
    "referenceImages": [
      {
        "image": "https://assets.runware.ai/assets/inputs/86efd1d9-8d8e-42d8-8510-a48e7ab04bc7.jpg",
        "role": "person"
      },
      {
        "image": "https://assets.runware.ai/assets/inputs/1b6934b3-d6c1-41dd-b592-a68013b5f41f.jpg",
        "role": "garment"
      },
      {
        "image": "https://assets.runware.ai/assets/inputs/1d8b4a89-4f7c-4784-8f0b-80897d0f348e.jpg",
        "role": "garment"
      }
    ]
  }
}
```

**Response**:

```json
{
  "taskType": "imageInference",
  "taskUUID": "467d33d4-3bda-4a27-9c08-14202d9bfa2a",
  "imageUUID": "4f5c221d-57ef-40f5-941d-37e7fb103853",
  "imageURL": "https://im.runware.ai/image/os/a06dlim3/ws/3/ii/4f5c221d-57ef-40f5-941d-37e7fb103853.jpg",
  "seed": 94754,
  "cost": 0.0069
}
```