SkiaSharp is 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.
Перейти к файлу
Matthew Leibowitz 3d141673c2 Use RGB565 for the GPU to support older GLES #229 2018-01-11 04:26:33 +02:00
binding Update to v1.59.3 2017-12-07 01:24:48 +02:00
cake Use `msbuild /t:restore` instead of `nuget restore` for old msbuild (15.3) 2017-09-27 16:40:22 +02:00
docs updating the docs 2017-12-19 16:01:09 +02:00
externals updated the tools 2017-10-04 01:06:22 +02:00
images Added an icon to the OS X sample 2016-07-29 18:09:17 +02:00
native-builds Use -fvisibility=hidden to avoid possible symbol clashes 2017-09-29 02:57:34 +04:00
nuget Update to v1.59.3 2017-12-07 01:24:48 +02:00
samples Added a sample back for SK3dView 2017-12-07 01:27:03 +02:00
source Use RGB565 for the GPU to support older GLES #229 2018-01-11 04:26:33 +02:00
tests Tests must run on single thread otherwise they hang. Switching to xunit for v1.60. 2017-12-07 16:54:07 +02:00
workbooks Re-applied some of the changes that were not specific to MSBuild 2017-06-24 02:02:42 +02:00
.editorconfig Added .editorconfig 2016-03-01 17:51:01 +03:00
.gitignore updated the build scripts 2017-06-06 04:10:52 +02:00
.gitmodules Use mdoc from source, instead of the binary 2017-05-20 07:23:47 +02:00
Binding.md
CONTRIBUTING.md Create CONTRIBUTING.md 2016-03-01 19:18:14 +02:00
LICENSE.md
Makefile Updates to the documentation bits 2016-10-19 00:50:16 +02:00
README.md Revert back to 1.59.1 so we can patch 2017-09-05 17:28:56 +02:00
bootstrapper.ps1 Use the later (v4.3.0) NuGet 2017-09-06 13:15:01 +02:00
bootstrapper.sh Use the later (v4.3.0) NuGet 2017-09-06 13:15:01 +02:00
build.cake Update to v1.59.3 2017-12-07 01:24:48 +02:00
cake.packages.config Update the build script and dependencies 2017-09-06 13:15:35 +02:00
mono.pub Updated the project files to the new skia location and split the cake script 2016-09-15 03:14:35 +02:00
mono.snk Updated the project files to the new skia location and split the cake script 2016-09-15 03:14:35 +02:00

README.md

SkiaSharp

SkiaSharp SkiaSharp.Views SkiaSharp.Views.Forms
Gitter.im Xamarin Forums
API Docs API Docs
Windows Build Status Linux Build Status Mac Build Status

SkiaSharp is a cross-platform 2D graphics API for .NET platforms based on Google's Skia Graphics Library (https://skia.org/). It provides a comprehensive 2D API that can be used across mobile, server and desktop models to render images.

SkiaSharp provides a PCL and platform-specific bindings for:

  • .NET Core / .NET Standard 1.3
  • Xamarin.Android
  • Xamarin.iOS
  • Xamarin.tvOS
  • Xamarin.Mac
  • Windows Classic Desktop (Windows.Forms / WPF)
  • Windows UWP (Desktop / Mobile / Xbox / HoloLens)

The API Documentation is available on the web to browse.

Using SkiaSharp

SkiaSharp is available as a convenience NuGet package, to use install the package like this:

nuget install SkiaSharp

Make sure the Visual C++ Redistributable for Visual Studio 2015 is installed if this error occurs on Windows:

Unable to load DLL 'libSkiaSharp.dll': The specified module could not be found.

At this point in time, we do not ship a native Linux binary, but you can build your own using the directions below.

Building SkiaSharp

Before building SkiaSharp:

  • Python 2.7 is available in the PATH environment variable on Windows
  • Android NDK r14 is available in the ANDROID_NDK_HOME environment variable on macOS
  • .NET Core is installed on all platforms

First, clone the repository:

$ git clone https://github.com/mono/SkiaSharp.git

Next, set up the submodules:

$ cd SkiaSharp
$ git submodule update --init --recursive

Finally, build everything:

Mac/Linux:

$ ./bootstrapper.sh -t everything

Windows:

> .\bootstrapper.ps1 -Target everything

If you are updating the source using a previous checkout, make sure to run the clean target before building.

New Skia Features Roadmap

Google has created a nice doc with a collection of high level items they have on tap the next 6-12 months. Note it is a living document that changes based on the requirements of the library's users.

Compare Code

Here are some links to show the differences in our code as compared to Google's.

What version are we on? m59
Are we up-to-date with Google? Compare
What have we added? Compare