All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.openqa.selenium.TakesScreenshot Maven / Gradle / Ivy

Go to download

Selenium automates browsers. That's it! What you do with that power is entirely up to you.

There is a newer version: 4.26.0
Show newest version
// Licensed to the Software Freedom Conservancy (SFC) under one
// or more contributor license agreements.  See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership.  The SFC licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License.  You may obtain a copy of the License at
//
//   http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied.  See the License for the
// specific language governing permissions and limitations
// under the License.
package org.openqa.selenium;

import org.jspecify.annotations.NullMarked;

/**
 * Indicates a driver or an HTML element that can capture a screenshot and store it in different
 * ways.
 *
 * 

Example usage: * *

 * File screenshotFile = ((TakesScreenshot) driver).getScreenshotAs(OutputType.FILE);
 * String screenshotBase64 = ((TakesScreenshot) element).getScreenshotAs(OutputType.BASE64);
 * 
* * @see OutputType */ @NullMarked public interface TakesScreenshot { /** * Capture the screenshot and store it in the specified location. * *

For a W3C-conformant WebDriver or WebElement, this behaves as stated in W3C WebDriver specification. * *

For a non-W3C-conformant WebDriver, this makes a best effort depending on the browser to * return the following in order of preference: * *

    *
  • Entire page *
  • Current window *
  • Visible portion of the current frame *
  • The screenshot of the entire display containing the browser *
* * For a non-W3C-conformant WebElement extending TakesScreenshot, this makes a best effort * depending on the browser to return the following in order of preference: * *
    *
  • The entire content of the HTML element *
  • The visible portion of the HTML element *
* * @param Return type for getScreenshotAs. * @param target target type, @see OutputType * @return Object in which is stored information about the screenshot. * @throws WebDriverException on failure. * @throws UnsupportedOperationException if the underlying implementation does not support * screenshot capturing. */ X getScreenshotAs(OutputType target) throws WebDriverException; }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy