Matyasf.Perlin
1.2.1
dotnet add package Matyasf.Perlin --version 1.2.1
NuGet\Install-Package Matyasf.Perlin -Version 1.2.1
<PackageReference Include="Matyasf.Perlin" Version="1.2.1" />
paket add Matyasf.Perlin --version 1.2.1
#r "nuget: Matyasf.Perlin, 1.2.1"
// Install Matyasf.Perlin as a Cake Addin #addin nuget:?package=Matyasf.Perlin&version=1.2.1 // Install Matyasf.Perlin as a Cake Tool #tool nuget:?package=Matyasf.Perlin&version=1.2.1
Perlin
Perlin (named from a bird) is a lightweight 2D graphics engine for .NET Core using Veldrid. It's well documented, has a simple architecture and is meant to be more as a base code for your engine than something that does everything out-of-the-box.
Currently its working on Windows, OSX, Linux, in the near future I plan to get it work on Android and iOS.
Features
- Uses the display tree concept (see below) to render your scene.
- Simple text rendering included.
- Mouse and keyboard handling code included.
- Can display parts of image regions as a simple texture atlas support.
- Desktop window management via SDL2.
- Thanks to Veldrid it automatically chooses the ideal rendering backend for your PC (Vulkan/Metal/OpenGL/DirectX..)
- Loads images via ImageSharp, so common formats (jpg, png, bmp, gif) are supported.
The display tree
Perlin puts the objects to render in a display tree similar to other rendering engines (HTML DOM, Android's GUI, Microsoft's WPF,..). The root of the display tree (called Stage
) has children, these can also have children and so on creating a tree data structure. Every object in the display tree is a subclass of DisplayObject, here lie the common properties, like Width
, Height
, Rotation
,... Transformations in the display tree are cumulative, e.g. if you set the transparency/rotation/position/scale of an object its every descendant (child, grandchild,..) will be affected as well.
The Z-order (what is rendered in front of what) is determined based on the position of the display tree. An object will be always behind its children; the order between the children is that the first child will be in the back and the last one in the front.
Getting started
A simple Hello world code that will show a rotating rectangle and a textfield:
using Perlin;
using Perlin.Display;
using SixLabors.Fonts;
using SixLabors.ImageSharp;
using SixLabors.ImageSharp.PixelFormats;
namespace Hello
{
public class HelloWorld
{
public static void Main()
{
new HelloWorld();
}
public HelloWorld()
{
PerlinApp.Start(400, 300, "Hello Perlin!", OnInit);
}
private void OnInit()
{
PerlinApp.Stage.BackgroundColor = new Rgb24(200, 200, 200);
var textField = new TextField(PerlinApp.FontRobotoMono.CreateFont(18));
textField.Text = "Hello world!";
textField.BackgroundColor = Color.Coral;
textField.FontColor = Color.White;
textField.X = 150;
textField.Y = 100;
PerlinApp.Stage.AddChild(textField);
var sp = new Sprite(40, 40, Color.Gold);
sp.X = 50;
sp.Y = 50;
// the EnterFrameEvent fires in each frame
sp.EnterFrameEvent += (target, secs) => sp.Rotation++;
PerlinApp.Stage.AddChild(sp);
}
}
}
License
Copyright 2020- Matyas Forian Szabo and code contributors
Licensed under the Apache License, Version 2.0 (the "License"); you may not use files in this project 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.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
.NET Core | netcoreapp3.1 is compatible. |
-
.NETCoreApp 3.1
- SixLabors.ImageSharp (>= 1.0.1)
- SixLabors.ImageSharp.Drawing (>= 1.0.0-beta0010)
- Veldrid (>= 4.8.0)
- Veldrid.ImageSharp (>= 4.8.0)
- Veldrid.SPIRV (>= 1.0.13)
- Veldrid.StartupUtilities (>= 4.8.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Linux support;
Fix text sometimes getting cropped when autosizing