The Skia 2D Graphics library from Google exposed to .NET languages and runtimes across the board
Перейти к файлу
Matthew Leibowitz 3579f7a9b0 Update the managed builds with the updated native library 2017-05-06 19:26:17 -04:00
binding Update the managed builds with the updated native library 2017-05-06 19:26:17 -04:00
cake Update the managed builds with the updated native library 2017-05-06 19:26:17 -04:00
docs more docs 2017-05-04 19:29:08 -04:00
externals Update the managed builds with the updated native library 2017-05-06 19:26:17 -04:00
images Added an icon to the OS X sample 2016-07-29 18:09:17 +02:00
native-builds Update the managed builds with the updated native library 2017-05-06 19:26:17 -04:00
nuget Removed the NuGet v3.5 requirement 2017-05-05 15:35:03 +02:00
samples enabling XamlC 2017-05-04 19:28:14 -04:00
source Merge branch 'master' into pr/289 2017-05-03 07:21:06 +02:00
tests Using a font file that can be controlled across platforms 2017-05-01 21:18:07 -04:00
tools Added the initial work for HarfBuzz 2017-04-27 21:35:54 +02:00
workbooks The workbook can use the latest version of the NuGet 2017-05-03 16:25:12 -04:00
.editorconfig Added .editorconfig 2016-03-01 17:51:01 +03:00
.gitignore Cleaning up the repo a bit 2017-04-28 09:56:53 -04:00
.gitmodules moved the externals into an "externals" folder 2016-09-15 00:53:42 +02:00
Binding.md Create Binding.md 2016-02-22 13:42:32 -05:00
CONTRIBUTING.md Create CONTRIBUTING.md 2016-03-01 19:18:14 +02:00
LICENSE.md Adding MIT license file 2016-02-22 11:46:04 -05:00
Makefile Updates to the documentation bits 2016-10-19 00:50:16 +02:00
README.md Updated the readme 2017-03-24 10:41:41 -04:00
bootstrapper.ps1 Windows also cleans up the tools directory now 2017-03-12 15:17:49 +02:00
bootstrapper.sh $? didn't do what I thought it did... 2017-03-22 15:50:24 -04:00
build.cake Merge branch 'master' into pr/289 2017-05-03 07:21:06 +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

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? m57
Are we up-to-date with Google? Compare
What have we added? Compare