/Eto.Veldrid

A simple test project embedding Veldrid in Eto.Forms

Primary LanguageC#MIT LicenseMIT

Eto.Veldrid

Provides a control to embed the Veldrid graphics library in the Eto.Forms GUI framework. Based on the Veldrid Getting Started tutorial, and integrated into Eto in the vein of etoViewport (thanks Phil!).

Notes

  • Shaders are written in Vulkan-style GLSL, and cross-compiled to the target backend using Veldrid.SPIRV.

  • In Directories.Build.props and .targets you'll find extra properties and targets to clean up the output directories. This is only cosmetic, but Veldrid does pull in its fair share of dependencies, as do .NET Framework versions prior to 4.7.2, and this helps organize things. Feel free to ignore it in your own projects if you disagree.

    • To help the GUI executables find the relocated DLLs, each GUI project has an App.config file with a <probing> element containing a privatePath attribute that allows assemblies to be found in subdirectories. There are no App.config files in .NET Core projects, however, so if you venture off in that direction you'll need to figure that out yourself.
  • All backends have been tested on all platforms that support them, with two exceptions: Vulkan in macOS (it may be technically possible through MoltenVK, but it hasn't been tested just yet) and OpenGLES on any platform. Please feel free to open issues about your experience with any backend or platform, whether that experience is a success or a failure.

Browse the code, fiddle with it to your heart's content, and take advantage of whatever's useful, but please don't take this to be the most efficient, production-quality approach to writing custom Eto controls, using Veldrid, or generally doing modern graphics coding.