| // <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; |
| using System.Drawing; |
| using System.Drawing.Imaging; |
| using System.IO; |
| |
| namespace OpenQA.Selenium |
| { |
| /// <summary> |
| /// File format for saving screenshots. |
| /// </summary> |
| [Obsolete("Support for decoding/encoding between different image formats is deprecated")] |
| 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> |
| [Obsolete("Support for decoding/encoding between different image formats is deprecated; use SaveAsFile(string fileName) method instead")] |
| public void SaveAsFile(string fileName, ScreenshotImageFormat format) |
| { |
| using (MemoryStream imageStream = new MemoryStream(this.AsByteArray)) |
| { |
| using (FileStream fileStream = new FileStream(fileName, FileMode.Create)) |
| { |
| // Optimization: The byte array is already a PNG, so we can just |
| // write directly to the file. If the user wants to convert to |
| // another image format, we'll allow them to do so, but on certain |
| // framework versions (.NET 6 or above) this is likely to fail at |
| // runtime. It is unclear how many Selenium users are using this |
| // feature to convert the returned screenshot into a different image |
| // format. Future mitigations of this issue would need to take a |
| // dependency on an image processing library like ImageSharp or |
| // similar. |
| if (format == ScreenshotImageFormat.Png) |
| { |
| imageStream.WriteTo(fileStream); |
| } |
| else |
| { |
| using (Image screenshotImage = Image.FromStream(imageStream)) |
| { |
| screenshotImage.Save(fileStream, ConvertScreenshotImageFormat(format)); |
| } |
| } |
| } |
| } |
| } |
| |
| 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; |
| } |
| } |
| } |