| // <copyright file="Screenshot.cs" company="WebDriver Committers"> |
| // 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. |
| // </copyright> |
| |
| using System; |
| #if NETCOREAPP2_0 || NETSTANDARD2_0 || NETCOREAPP2_1 || NETSTANDARD2_1 || NET5_0 || NET6_0 |
| #else |
| using System.Drawing; |
| using System.Drawing.Imaging; |
| #endif |
| using System.IO; |
| |
| namespace OpenQA.Selenium |
| { |
| /// <summary> |
| /// File format for saving screenshots. |
| /// </summary> |
| public enum ScreenshotImageFormat |
| { |
| /// <summary> |
| /// W3C Portable Network Graphics image format. |
| /// </summary> |
| Png, |
| |
| /// <summary> |
| /// Joint Photgraphic Experts Group image format. |
| /// </summary> |
| Jpeg, |
| |
| /// <summary> |
| /// Graphics Interchange Format image format. |
| /// </summary> |
| Gif, |
| |
| /// <summary> |
| /// Tagged Image File Format image format. |
| /// </summary> |
| Tiff, |
| |
| /// <summary> |
| /// Bitmap image format. |
| /// </summary> |
| Bmp |
| } |
| |
| /// <summary> |
| /// Represents an image of the page currently loaded in the browser. |
| /// </summary> |
| [Serializable] |
| public class Screenshot : EncodedFile |
| { |
| /// <summary> |
| /// Initializes a new instance of the <see cref="Screenshot"/> class. |
| /// </summary> |
| /// <param name="base64EncodedScreenshot">The image of the page as a Base64-encoded string.</param> |
| public Screenshot(string base64EncodedScreenshot) : base(base64EncodedScreenshot) |
| { |
| } |
| |
| /// <summary> |
| /// Saves the screenshot to a Portable Network Graphics (PNG) file, overwriting the |
| /// file if it already exists. |
| /// </summary> |
| /// <param name="fileName">The full path and file name to save the screenshot to.</param> |
| public override void SaveAsFile(string fileName) |
| { |
| this.SaveAsFile(fileName, ScreenshotImageFormat.Png); |
| } |
| |
| /// <summary> |
| /// Saves the screenshot to a file, overwriting the file if it already exists. |
| /// </summary> |
| /// <param name="fileName">The full path and file name to save the screenshot to.</param> |
| /// <param name="format">A <see cref="ScreenshotImageFormat"/> value indicating the format |
| /// to save the image to.</param> |
| public void SaveAsFile(string fileName, ScreenshotImageFormat format) |
| { |
| #if NETCOREAPP2_0 || NETSTANDARD2_0 || NETCOREAPP2_1 || NETSTANDARD2_1 || NET5_0 || NET6_0 |
| if (format != ScreenshotImageFormat.Png) |
| { |
| throw new WebDriverException(".NET Core does not support image manipulation, so only Portable Network Graphics (PNG) format is supported"); |
| } |
| #endif |
| |
| using (MemoryStream imageStream = new MemoryStream(this.AsByteArray)) |
| { |
| using (FileStream fileStream = new FileStream(fileName, FileMode.Create)) |
| { |
| #if NETCOREAPP2_0 || NETSTANDARD2_0 || NETCOREAPP2_1 || NETSTANDARD2_1 || NET5_0 || NET6_0 |
| imageStream.WriteTo(fileStream); |
| #else |
| using (Image screenshotImage = Image.FromStream(imageStream)) |
| { |
| screenshotImage.Save(fileStream, ConvertScreenshotImageFormat(format)); |
| } |
| #endif |
| } |
| } |
| } |
| |
| #if NETCOREAPP2_0 || NETSTANDARD2_0 || NETCOREAPP2_1 || NETSTANDARD2_1 || NET5_0 || NET6_0 |
| #else |
| private static ImageFormat ConvertScreenshotImageFormat(ScreenshotImageFormat format) |
| { |
| ImageFormat returnedFormat = ImageFormat.Png; |
| switch (format) |
| { |
| case ScreenshotImageFormat.Jpeg: |
| returnedFormat = ImageFormat.Jpeg; |
| break; |
| |
| case ScreenshotImageFormat.Gif: |
| returnedFormat = ImageFormat.Gif; |
| break; |
| |
| case ScreenshotImageFormat.Bmp: |
| returnedFormat = ImageFormat.Bmp; |
| break; |
| |
| case ScreenshotImageFormat.Tiff: |
| returnedFormat = ImageFormat.Tiff; |
| break; |
| } |
| |
| return returnedFormat; |
| } |
| #endif |
| } |
| } |