> ## Documentation Index
> Fetch the complete documentation index at: https://tbd-6fc993ce-mintlify-add-deploy-button-docs-27400.mintlify.site/llms.txt
> Use this file to discover all available pages before exploring further.

# Viewports

> Configure browser viewport size and refresh rate for your automations

Kernel browsers allow you to configure the viewport size and refresh rate when creating a browser session. The viewport configuration determines the initial browser window dimensions and display refresh rate. The refresh rate can be explicitly specified or automatically determined based on the width and height if they match a supported configuration.

## Default viewport

If the `viewport` parameter is omitted when creating a browser, the default configuration is 1920x1080 at 25Hz.

<CodeGroup>
  ```typescript Typescript/Javascript theme={null}
  // Uses default viewport (1920x1080@25Hz)
  const defaultViewport = await kernel.browsers.create();
  ```

  ```python Python theme={null}
  # Uses default viewport (1920x1080@25Hz)
  default_viewport = kernel.browsers.create()
  ```
</CodeGroup>

## Setting viewport configuration

You can configure the viewport when creating a browser by specifying the `viewport` parameter with `width` and `height`. The `refresh_rate` is optional and will be automatically determined from the dimensions if they match a supported configuration:

<CodeGroup>
  ```typescript Typescript/Javascript theme={null}
  import Kernel from '@onkernel/sdk';

  const kernel = new Kernel();

  // Explicitly specify refresh rate
  const kernelBrowser = await kernel.browsers.create({
    viewport: {
      width: 1920,
      height: 1080,
      refresh_rate: 25
    }
  });

  // Auto-determine refresh rate from dimensions (25Hz for 1920x1080)
  const kernelBrowserAuto = await kernel.browsers.create({
    viewport: {
      width: 1920,
      height: 1080
    }
  });
  ```

  ```python Python theme={null}
  from kernel import Kernel

  kernel = Kernel()

  # Explicitly specify refresh rate
  kernel_browser = kernel.browsers.create(
      viewport={
          "width": 1920,
          "height": 1080,
          "refresh_rate": 25
      }
  )

  # Auto-determine refresh rate from dimensions (25Hz for 1920x1080)
  kernel_browser_auto = kernel.browsers.create(
      viewport={
          "width": 1920,
          "height": 1080
      }
  )
  ```
</CodeGroup>

<Note>
  The `refresh_rate` parameter only applies to live view sessions and is ignored for [headless](/browsers/headless) browsers.
</Note>

## Supported viewport configurations

Kernel supports specific viewport configurations. The server will reject unsupported combinations. When you provide width and height without specifying refresh\_rate, it will be automatically determined if the dimensions match one of the supported resolutions exactly. The following resolutions are supported:

| Resolution | Width | Height | Refresh Rate |
| ---------- | ----- | ------ | ------------ |
| QHD        | 2560  | 1440   | 10 Hz        |
| Full HD    | 1920  | 1080   | 25 Hz        |
| WUXGA      | 1920  | 1200   | 25 Hz        |
| WXGA+      | 1440  | 900    | 25 Hz        |
| WXGA       | 1200  | 800    | 25 Hz        |
| XGA        | 1024  | 768    | 60 Hz        |

<Warning>
  Higher resolutions may affect the responsiveness of [live view](/browsers/live-view) browser sessions.
</Warning>

## Example configurations

<CodeGroup>
  ```typescript Typescript/Javascript theme={null}
  // Full HD (1920x1080) at 25Hz - explicit refresh rate
  const fullHD = await kernel.browsers.create({
    viewport: {
      width: 1920,
      height: 1080,
      refresh_rate: 25
    }
  });

  // Full HD (1920x1080) - auto-determined 25Hz (Default configuration)
  const fullHDAuto = await kernel.browsers.create({
    viewport: {
      width: 1920,
      height: 1080
    }
  });

  // QHD (2560x1440) - auto-determined 10Hz
  // Note: May affect live view responsiveness
  const qhd = await kernel.browsers.create({
    viewport: {
      width: 2560,
      height: 1440
    }
  });

  // XGA (1024x768) - auto-determined 60Hz
  const xga = await kernel.browsers.create({
    viewport: {
      width: 1024,
      height: 768
    }
  });

  // WUXGA (1920x1200) at 25Hz - explicit refresh rate
  const wuxga = await kernel.browsers.create({
    viewport: {
      width: 1920,
      height: 1200,
      refresh_rate: 25
    }
  });
  ```

  ```python Python theme={null}
  # Full HD (1920x1080) at 25Hz - explicit refresh rate
  full_hd = kernel.browsers.create(
      viewport={
          "width": 1920,
          "height": 1080,
          "refresh_rate": 25
      }
  )

  # Full HD (1920x1080) - auto-determined 25Hz (Default configuration)
  full_hd_auto = kernel.browsers.create(
      viewport={
          "width": 1920,
          "height": 1080
      }
  )

  # QHD (2560x1440) - auto-determined 10Hz
  # Note: May affect live view responsiveness
  qhd = kernel.browsers.create(
      viewport={
          "width": 2560,
          "height": 1440
      }
  )

  # XGA (1024x768) - auto-determined 60Hz
  xga = kernel.browsers.create(
      viewport={
          "width": 1024,
          "height": 768
      }
  )

  # WUXGA (1920x1200) at 25Hz - explicit refresh rate
  wuxga = kernel.browsers.create(
      viewport={
          "width": 1920,
          "height": 1200,
          "refresh_rate": 25
      }
  )
  ```
</CodeGroup>

## Viewport constraints

Only the specific viewport configurations listed in the [supported configurations table](#supported-viewport-configurations) above are supported:

* **2560x1440** (QHD) at 10 Hz
* **1920x1080** (Full HD) at 25 Hz
* **1920x1200** (WUXGA) at 25 Hz
* **1440x900** (WXGA+) at 25 Hz
* **1200x800** (WXGA) at 25 Hz
* **1024x768** (XGA) at 60 Hz

When specifying a viewport:

* **Width** and **Height** are required and must match one of the supported configurations exactly
* **Refresh Rate** is optional - if omitted, it will be automatically determined from the width and height combination

<Warning>
  The server will reject any viewport configuration that doesn't exactly match one of the supported combinations listed above.
</Warning>

## Changing viewport after browser creation

You can change the viewport of a browser after it has been created using the [update browser endpoint](/api-reference/browsers/update-browser-session).

<CodeGroup>
  ```typescript Typescript/Javascript theme={null}
  // Create a browser with default viewport
  const kernelBrowser = await kernel.browsers.create();

  // Later, change the viewport
  await kernel.browsers.update(kernelBrowser.session_id, {
    viewport: {
      width: 1024,
      height: 768
    }
  });
  ```

  ```python Python theme={null}
  # Create a browser with default viewport
  kernel_browser = await kernel.browsers.create()

  # Later, change the viewport
  await kernel.browsers.update(kernel_browser.session_id, viewport={"width": 1024, "height": 768})
  ```
</CodeGroup>

<Warning>
  There are important limitations when changing the viewport:

  * **Headful browsers**: You cannot resize the viewport while [live view](/browsers/live-view) is active or while a [replay](/browsers/replays) is actively recording.
  * **Headless browsers**: Changing the viewport triggers a Chromium restart, which may disrupt active CDP connections.
</Warning>

## Considerations

* The viewport configuration is set when the browser is created and applies to the initial browser window
* Higher resolutions (like 2560x1440) may impact the performance and responsiveness of live view sessions
* The viewport size affects how websites render, especially those with responsive designs
* Screenshots taken from the browser will match the configured viewport dimensions
* In [headless mode](/browsers/headless), the viewport width and height still apply for rendering and screenshots, but the `refresh_rate` parameter is ignored
