TinyEXR.NET 0.0.2-alpha.2

.NET Standard 2.1
This is a prerelease version of TinyEXR.NET.
There is a newer version of this package available.
See the version list below for details.
dotnet add package TinyEXR.NET --version 0.0.2-alpha.2
NuGet\Install-Package TinyEXR.NET -Version 0.0.2-alpha.2
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="TinyEXR.NET" Version="0.0.2-alpha.2" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add TinyEXR.NET --version 0.0.2-alpha.2
#r "nuget: TinyEXR.NET, 0.0.2-alpha.2"
#r directive can be used in F# Interactive, C# scripting and .NET Interactive. Copy this into the interactive tool or source code of the script to reference the package.
// Install TinyEXR.NET as a Cake Addin
#addin nuget:?package=TinyEXR.NET&version=0.0.2-alpha.2&prerelease

// Install TinyEXR.NET as a Cake Tool
#tool nuget:?package=TinyEXR.NET&version=0.0.2-alpha.2&prerelease


TinyEXR.NET is a C# wrapper of single header-only C++ library tinyexr

tinyexr is a portable single header-only C++ library to load and save OpenEXR (.exr) images

The target framework of TinyEXR.NET is .NET Standard 2.1

WARNING: This library is WIP. API is unstable


TinyEXR.NET can be found on NuGet NuGet (← click it !)

Supported Platforms


  • ✅: completed
  • 🚧: work in progress
  • ⌛: planned, not yet started
  • ❌: no plan
Platform State
Windows x64 🚧
Windows x86
Windows arm64
Linux x64
Linux x86
Linux arm64
macOS x64
macOS arm64



Development build


0. Requirements
  • MSVC that supported C++11 (recommend VS2019 or higher)
  • Powershell (>= 3.0)
  • CMake (>= 3.0.0)
  • .NET SDK x64 (>= .NET Core 3.0)
1. Download the code

First, clone this project or download the latest release and unzip.

2. Build native library

Run build_win-x64.ps1

3. Build TinyEXR.NET

You can use dotnet command in TinyEXR.NET folder: dotnet build --configuration Release

Or, you can open TinyEXR.NET/TinyEXR.NET.sln in VS or any other IDE and compile

4. Finish

Finally, we can find NuGet package in TinyEXR.NET\bin\Release. You can use it anywhere


Although tinyexr provides C interface, the MSVC compiler does not export any symbols by default.

So we have to create a C++ project in the folder native to wrap tinyexr API.

I don't know if there is any better way. But it works. 😃

The reason why we only support x64 platform is that I don't know whether the existing code will work properly if we support x86 or other platforms. Specifically, Is the struct layout at C++ side consistent with C# side? I don't have time to solve this problem at present. So I just give up these platform.

Contribution is welcome!


TinyEXR.NET is under MIT license

and wrapped C++ lib tinyexr is under 3-clause BSD

Product Versions
.NET net5.0 net5.0-windows net6.0 net6.0-android net6.0-ios net6.0-maccatalyst net6.0-macos net6.0-tvos net6.0-windows net7.0 net7.0-android net7.0-ios net7.0-maccatalyst net7.0-macos net7.0-tvos net7.0-windows
.NET Core netcoreapp3.0 netcoreapp3.1
.NET Standard netstandard2.1
MonoAndroid monoandroid
MonoMac monomac
MonoTouch monotouch
Tizen tizen60
Xamarin.iOS xamarinios
Xamarin.Mac xamarinmac
Xamarin.TVOS xamarintvos
Xamarin.WatchOS xamarinwatchos
Compatible target framework(s)
Additional computed target framework(s)
Learn more about Target Frameworks and .NET Standard.
  • .NETStandard 2.1

    • No dependencies.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
0.2.3 155 8/19/2022
0.2.2 146 8/16/2022
0.2.1 147 8/15/2022
0.2.0 143 8/14/2022
0.1.1 146 7/24/2022
0.1.0 162 7/15/2022
0.0.2-alpha.2 60 7/14/2022
0.0.2-alpha.1 58 7/14/2022

test nuget