Skip to content

Releases: mono/SkiaSharp

Version 2.80.3 (Preview Build 18)

10 Nov 11:57
b43c95f
Compare
Choose a tag to compare
Pre-release

What's Changed

New Contributors

Full Changelog: v2.80.2...v2.80.3-preview.18

Version 2.80.2

12 Sep 00:08
2019706
Compare
Choose a tag to compare

SkiaSharp

A cross-platform 2D graphics API for .NET platforms based on Google's Skia Graphics Library. It provides a comprehensive 2D API that can be used across mobile, server and desktop models to render images.

Changes

  • Added several memory debugging members to GRContext and the new SKGraphics and SKTraceMemoryDump
  • Fixed origin parameter is ignored in SKSurface.Create [Ziriax]
  • Fixed the exception when creating SKData from a non-seekable stream
  • Fixed the NullReferenceException in SKCanvas.DrawTextOnPath [Ziriax]
  • Fixed the issues where the "no dependencies" builds were still using dependencies
  • Added a replacement method for some obsoleted members
  • Fixed an issue when encoding a subset of some images
  • Fixed a few text rendering issues and crashes
  • Fixed the issue where the native binaries would not reach the final app when only referenced as a transitive dependency
  • Fixed the DllNotFoundException when running in ASP.NET
  • Fixed the invalid interop on WASM for some methods
  • Fixed an issue with layering in SKCanvas.DrawPoint
  • Fixed the issue where encoding an image subset sometimes encoded the entire original image

Maintainence

  • Passing --configuration=debug to the bootstrapper now generates a debug build
  • Update samples and package versions

Known Issues

  • Not quite an issue, but still something to be aware of: microsoft/microsoft-ui-xaml#1446

    API __CxxFrameHandler4 in vcruntime140_1_app.dll is not supported for this application type. libGLESv2.dll calls this API.
    API __CxxFrameHandler4 in vcruntime140_1_app.dll is not supported for this application type. libSkiaSharp.dll calls this API.

Links

NuGet | Code Diff | Project | Milestone | Changelog | CI | Release CI

SkiaSharp.Views

A set of pre-prepared UI views, panels and surfaces for drawing. One of these views can be added to the view hierarchy, and then be used for drawing without the need for complex setup. There is also a set of extension methods for converting to/from SkiaSharp and native types.

Changes

  • Added extension methods to convert between the native colors and SKColorF

Links

NuGet | Changelog

SkiaSharp.Views.Forms

A set of pre-prepared views for Xamarin.Forms, for fully cross-platform drawing code. There are views for both CPU and GPU backends, along with extension methods for converting to/from SkiaSharp and Xamarin.Forms types. Currently available for iOS, Android, UWP, macOS (preview) and Tizen (preview).

Changes

  • Some performance improvements for Forms
  • Added extension methods to convert between the Xamarin.Forms Color and SKColorF

Links

NuGet | Changelog

SkiaSharp.Views.Uno

A set of pre-prepared views for Uno Platform, for fully cross-platform drawing code. Current support is just a CPU surface for Android, iOS and macOS, with WASM support under way in a PR (#1333). GPU surfaces are also coming soon.

Changes

Links

NuGet | Changelog

HarfBuzzSharp

A library for text shaping, which is the process of converting Unicode text to glyph indices and positions.

Changes

  • Fixed the issue where the native binaries would not reach the final app when only referenced as a transitive dependency

Links

NuGet | Changelog

Additional Platforms

Linux

Because we love everyone in the Linux world just as well as the Microsoft and the Xamarin worlds, we have also included some pre-built Linux native binaries in a new, separate package (see #312):

SkiaSharp.NativeAssets.Linux

If you happen to be on an environment that does not have the ability to install any of the required dependencies, such as FontConfig, you can also try out the build that does not have any dependencies other that the core system libraries:

SkiaSharp.NativeAssets.Linux.NoDependencies

At the current time, these packages support several platforms/architectures/distributions.

The base platforms are:

  • Debian x64, ARM and ARM64
  • Alpine x64

However, these binaries are known to work on many other platforms:

  • Red Hat Enterprise Linux
  • CentOS
  • Raspberry Pi
  • Many Musl distributions
  • Most Debian-based distros

More builds can be requested by leaving a comment on #453, but you can easily build your own binaries by following this guide.

NuGet

Windows Nano Server

We know the .NET Core containers are very cool to use, so we now have support for using the default Windows .NET Core Docker images (see #676):

SkiaSharp.NativeAssets.NanoServer

It is not quite perfect just yet, so the app project needs a little help (see NuGet/Home#8894):

<PackageReference Include="SkiaSharp" ExcludeAssets="native" />
<PackageReference Include="SkiaSharp.NativeAssets.NanoServer" />

NuGet

Web Assembly (WASM)

Because the .NET platform and tooling for web assembly is still evolving, we can't yet commit to a final packaging format. However, this does not mean that we cannot at least help get you started.

To do this, we have pre-built a native static library for WASM that can be manually linked, or linked using a framework tooling such as Uno. This library can be found in a new package that provides a path to the actual static library (#1389):

SkiaSharp.NativeAssets.WebAssembly

NuGet

Samples

There are a large set of samples that show many different features of SkiaSharp. They are broken up into two main groups:

  • Basic - these are minimal samples that show just what is needed to use SkiaSharp
  • Gallery - these are comprehensive samples that show off new, or exciting features of SkiaSharp

All the samples that have been built and tested for this version of SkiaSharp can be downloaded in the "Assets" links.

Version 2.80.2 (Preview Build 36)

03 Sep 02:39
0ab468b
Compare
Choose a tag to compare

Version 2.80.2 (Preview Build 33)

25 Aug 20:48
d0562fc
Compare
Choose a tag to compare

Version 2.80.2 (Preview Build 19)

04 Aug 19:40
d8502c8
Compare
Choose a tag to compare

Version 2.80.2 (Preview Build 18)

02 Aug 23:17
b5c12d6
Compare
Choose a tag to compare

Version 2.80.2 (Preview Build 9)

27 Jul 19:43
b3f5975
Compare
Choose a tag to compare

Version 2.80.1

14 Jul 07:33
0b32522
Compare
Choose a tag to compare

SkiaSharp

A cross-platform 2D graphics API for .NET platforms based on Google's Skia Graphics Library. It provides a comprehensive 2D API that can be used across mobile, server and desktop models to render images.

Changes

  • [BUG] SKTypeface.GetGlyphs has changed meaning in v2.80 (#1398)

Known Issues

  • Not quite an issue, but still something to be aware of: microsoft/microsoft-ui-xaml#1446

    API __CxxFrameHandler4 in vcruntime140_1_app.dll is not supported for this application type. libGLESv2.dll calls this API.
    API __CxxFrameHandler4 in vcruntime140_1_app.dll is not supported for this application type. libSkiaSharp.dll calls this API.

Links

NuGet | Code Diff | Project | Milestone | Changelog | CI | Release CI

SkiaSharp.Views.Uno

A set of pre-prepared views for Uno Platform, for fully cross-platform drawing code. Current support is just a CPU surface for Android, iOS and macOS, with WASM support under way in a PR (#1333). GPU surfaces are also coming soon.

Changes

Links

NuGet | Changelog

Samples

There are a large set of samples that show many different features of SkiaSharp. They are broken up into two main groups:

  • Basic - these are minimal samples that show just what is needed to use SkiaSharp
  • Gallery - these are comprehensive samples that show off new, or exciting features of SkiaSharp

All the samples that have been built and tested for this version of SkiaSharp can be downloaded in the "Assets" links.

Version 2.80.0

09 Jul 01:59
364f92e
Compare
Choose a tag to compare

SkiaSharp

A cross-platform 2D graphics API for .NET platforms based on Google's Skia Graphics Library. It provides a comprehensive 2D API that can be used across mobile, server and desktop models to render images.

Major Changes

  • Brand new skia version: milestone 80
    • All native changelogs [here][change-skia]
  • ARM64 support for Windows
    • This includes both UWP and Win32 platforms
  • ARM / ARM64 support for Linux
    • This means Raspberry Pi!
  • Alpine / musl support for Linux
    • This includes both the standard and no-dependency builds
  • WASM static library (experimental)
    • This is just the native .a file for now that has to be manually (or using a framework tooling such as Uno) linked.
    • There is a helper package SkiaSharp.NativeAssets.WebAssembly that will provide a path to the actual static library (#1389)
  • Support for Vulkan backends [@tuccio] [@MarchingCube]
    • Supported on Android, Windows and Linux
    • New GRVkBackendContext, GRVkImageInfo and more types
  • SKColorSpace and related types have been reworked
    • New type for accessing transfer functions and ICC profiles
    • Removing usage of SKMatrix44 since it is going to be obsolete soon
  • Text processing has been entirely re-written to use the new SKFont type under the hood
    • SKFont is a text-related subset of SKPaint
    • APIs based on Span<T> for almost zero-allocation processing
    • SKTextBlob and SKTextBlobBuilder now focus on glyphs and only expose convenience members for text
  • Native libSkiaSharp for all platforms are no longer embedded in the dlls
    • Improves build performance
    • Allows for better control when excluding native assets

Changes

  • Unifying some APIs
    • Moving from SKEncoding to SKTextEncoding
    • Moving away from GRPixelConfig to SKColorType
  • Improved the way GPU types are created and used
    • GRContext and GRGlInterface have been streamlined
  • Several color space related types have been deprecated in favor of improved types
  • SKCanvas.DrawTextOnPath now has support for not warping characters [@Ziriax]
    • Native support was dropped in skia, but we now also have a better implementation
  • SKPaint now supports getting and setting SKColorF (with or without a color space)
  • SKPath.ToWinding() can be used to convert the current path to a path that has a winding fill type
  • .NET Framework apps now properly load the 32/64 bit libraries, as well as support ARM
  • Several SKImageFilter factory methods now have additional overloads
  • Managed library now knows what version of the native library it supports, and will throw if an invalid library is used (#1252)

Maintainence

  • Brand new images! Sharper than skia, if I say so myself...
  • Minimum version of Windows for UWP is now 10.0.16299
  • Minimum version of .NET Framework for is now 4.6.2
  • Native artifacts for libSkiaSharp are no longer embedded into the managed .dlls
    • Build performance improvement
    • Easier to control
  • Samples updated to more modern libraries and code
  • Added code coverage to the build system

Known Issues

  • Not quite an issue, but still something to be aware of: microsoft/microsoft-ui-xaml#1446

    API __CxxFrameHandler4 in vcruntime140_1_app.dll is not supported for this application type. libGLESv2.dll calls this API.
    API __CxxFrameHandler4 in vcruntime140_1_app.dll is not supported for this application type. libSkiaSharp.dll calls this API.

Links

NuGet | Code Diff | Project | Milestone | [Changelog][change-skiasharp] | [CI][ci] | [Release CI][release-ci]

SkiaSharp.Views

A set of pre-prepared UI views, panels and surfaces for drawing. One of these views can be added to the view hierarchy, and then be used for drawing without the need for complex setup. There is also a set of extension methods for converting to/from SkiaSharp and native types.

Changes

  • None yet

Links

NuGet | [Changelog][change-views]

SkiaSharp.Views.Forms

A set of pre-prepared views for Xamarin.Forms, for fully cross-platform drawing code. There are views for both CPU and GPU backends, along with extension methods for converting to/from SkiaSharp and Xamarin.Forms types. Currently available for iOS, Android, UWP, macOS (preview) and Tizen (preview).

Changes

  • Minimum version of Xamarin.Forms is now 4.5+

Links

NuGet | [Changelog][change-forms]

HarfBuzzSharp

A library for text shaping, which is the process of converting Unicode text to glyph indices and positions.

Changes

  • None

Links

NuGet | [Changelog][change-harfbuzz]

SkiaSharp.HarfBuzz (preview)

Support for text shaping using the HarfBuzz text shaping library. This package adds the SKShaper type that can shape a string, returning the codepoints and their positions.

This package also adds some extension methods to SKCanvas to make drawing shaped text easier. These methods include DrawShapedText and it's overloads.

Changes

  • New overloads for SKCanvas.DrawShapedText to make simple cases easier

Links

NuGet | [Changelog][change-skiaharf]

SkiaSharp.Vulkan.SharpVk (preview)

Because working with pointers is not nice, especially when you have an already perfectly good Vulkan API from [SharpVk][sharpvk], we have a package that provides a way to use that library with our library.

Changes

  • Added GRSharpVkBackendContext to directly use SharpVk objects to construct the GRVkBackendContext
  • Added extensions methods for GRVkExtensions to make initialization easier when using SharpVk objects

Links

NuGet | [Changelog][change-skiasvk]

Additional Platforms

Linux

Because we love everyone in the Linux world just as well as the Microsoft and the Xamarin worlds, we have also included some pre-built Linux native binaries in a new, separate package (see #312):

SkiaSharp.NativeAssets.Linux

If you happen to be on an environment that does not have the ability to install any of the required dependencies, such as FontConfig, you can also try out the build that does not have any dependencies other that the core system libraries:

SkiaSharp.NativeAssets.Linux.NoDependencies

At the current time, these packages support several platforms/architectures/distributions.

The base platforms are:

  • Debian x64, ARM and ARM64
  • Alpine x64

However, these binaries are known to work on many other platforms:

  • Red Hat Enterprise Linux
  • CentOS
  • Raspberry Pi
  • Many Musl distributions
  • Most Debian-based distros

More builds can be requested by leaving a comment on #453, but you can easily build your own binaries by following this guide.

NuGet

Windows Nano Server

We know the .NET Core containers are very cool to use, so we now have support for using the default Windows .NET Core Docker images (see #676):

SkiaSharp.NativeAssets.NanoServer

It is not quite perfect just yet, so the app project needs a little help (see NuGet/Home#8894):

<PackageReference Include="SkiaSharp" ExcludeAssets="native" />
<PackageReference Include="SkiaSharp.NativeAssets.NanoServer" />

NuGet

Web Assembly (WASM)

Because the .NET platform and tooling for web assembly is still evolving, we can't yet commit to a final packaging format. However, this does not mean that we cannot at least help get you started.

To do this, we have pre-built a native static library for WASM that can be manually linked, or linked using a framework tooling such as Uno. This library can be found in a new package that provides a path to the actual static library (#1389):

SkiaSharp.NativeAssets.WebAssembly

[NuGet][nuget-wasm]

Samples

There are a large set of samples that show many different features of SkiaSharp. They are broken up into two main groups:

  • Basic - these are minimal samples that show just what is needed to use SkiaSharp
  • Gallery - these are comprehensive samples that show off new, or exciting features of SkiaSharp

All the samples that have been built and tested for this version of SkiaSharp can be downloaded in the "Assets" links.

[nuget-wasm...

Read more

Version 2.80.0 (Preview Build 33)

01 Jul 04:38
35a7522
Compare
Choose a tag to compare
Pre-release