csharpc-sharpdotnetxamlavaloniauicross-platformcross-platform-xamlavaloniaguimulti-platformuser-interfacedotnetcore
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
68 lines
2.4 KiB
68 lines
2.4 KiB
// -----------------------------------------------------------------------
|
|
// <copyright file="RenderTargetBitmap.cs" company="Steven Kirk">
|
|
// Copyright 2015 MIT Licence. See licence.md for more information.
|
|
// </copyright>
|
|
// -----------------------------------------------------------------------
|
|
|
|
namespace Perspex.Media.Imaging
|
|
{
|
|
using System;
|
|
using Perspex.Platform;
|
|
using Splat;
|
|
|
|
/// <summary>
|
|
/// A bitmap that holds the rendering of a <see cref="IVisual"/>.
|
|
/// </summary>
|
|
public class RenderTargetBitmap : Bitmap, IDisposable
|
|
{
|
|
/// <summary>
|
|
/// Initializes a new instance of the <see cref="RenderTargetBitmap"/> class.
|
|
/// </summary>
|
|
/// <param name="width">The width of the bitmap.</param>
|
|
/// <param name="height">The height of the bitmap.</param>
|
|
public RenderTargetBitmap(int width, int height)
|
|
: base(CreateImpl(width, height))
|
|
{
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets the platform-specific bitmap implementation.
|
|
/// </summary>
|
|
public new IRenderTargetBitmapImpl PlatformImpl
|
|
{
|
|
get { return (IRenderTargetBitmapImpl)base.PlatformImpl; }
|
|
}
|
|
|
|
/// <summary>
|
|
/// Renders an <see cref="IVisual"/> into the bitmap.
|
|
/// </summary>
|
|
/// <param name="visual">The visual to render.</param>
|
|
/// <remarks>
|
|
/// Before calling this method, ensure that <paramref name="visual"/> has been measured.
|
|
/// </remarks>
|
|
public void Render(IVisual visual)
|
|
{
|
|
this.PlatformImpl.Render(visual);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Disposes of the bitmap.
|
|
/// </summary>
|
|
public void Dispose()
|
|
{
|
|
this.PlatformImpl.Dispose();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Creates a platform-specific imlementation for a <see cref="RenderTargetBitmap"/>.
|
|
/// </summary>
|
|
/// <param name="width">The width of the bitmap.</param>
|
|
/// <param name="height">The height of the bitmap.</param>
|
|
/// <returns>The platform-specific implementation.</returns>
|
|
private static IBitmapImpl CreateImpl(int width, int height)
|
|
{
|
|
IPlatformRenderInterface factory = Locator.Current.GetService<IPlatformRenderInterface>();
|
|
return factory.CreateRenderTargetBitmap(width, height);
|
|
}
|
|
}
|
|
}
|
|
|