Compare commits
9 Commits
Author | SHA1 | Date | |
---|---|---|---|
b7983c96b2 | |||
cb75b7c244 | |||
6ffcd38cbc | |||
09b5238b24 | |||
7157db6bd0 | |||
df61cdc5aa | |||
50c37e58fc | |||
8e8c86b2c1 | |||
ff83cb20f9 |
@ -5,9 +5,10 @@ project(rf_stbi LANGUAGES C VERSION 1.0)
|
|||||||
if (NOT ("${CMAKE_SYSTEM_NAME}" STREQUAL "Darwin"))
|
if (NOT ("${CMAKE_SYSTEM_NAME}" STREQUAL "Darwin"))
|
||||||
add_compile_options(-static-libgcc -static-libstdc++ -fno-exceptions)
|
add_compile_options(-static-libgcc -static-libstdc++ -fno-exceptions)
|
||||||
endif()
|
endif()
|
||||||
|
add_compile_options(-O3)
|
||||||
|
|
||||||
add_library(stbi SHARED "rf_stbi.c")
|
add_library(stbi SHARED "rf_stbi.c")
|
||||||
install(
|
install(
|
||||||
TARGETS stbi
|
TARGETS stbi
|
||||||
RUNTIME DESTINATION .
|
RUNTIME DESTINATION .
|
||||||
LIBRARY DESTINATION .)
|
LIBRARY DESTINATION .)
|
||||||
|
@ -1,12 +0,0 @@
|
|||||||
using System;
|
|
||||||
|
|
||||||
namespace Quik.Stb
|
|
||||||
{
|
|
||||||
[AttributeUsage(System.AttributeTargets.All, Inherited = false, AllowMultiple = true)]
|
|
||||||
internal sealed class NativeTypeNameAttribute : System.Attribute
|
|
||||||
{
|
|
||||||
public NativeTypeNameAttribute(string typename)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,19 +1,20 @@
|
|||||||
<Project Sdk="Microsoft.NET.Sdk">
|
<Project Sdk="Microsoft.NET.Sdk">
|
||||||
|
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<TargetFramework>net6.0</TargetFramework>
|
<TargetFrameworks>net6.0;net8.0</TargetFrameworks>
|
||||||
<Nullable>enable</Nullable>
|
<Nullable>enable</Nullable>
|
||||||
<LangVersion>latest</LangVersion>
|
<LangVersion>latest</LangVersion>
|
||||||
<AllowUnsafeBlocks>True</AllowUnsafeBlocks>
|
<AllowUnsafeBlocks>True</AllowUnsafeBlocks>
|
||||||
<RuntimeIdentifiers>linux-arm;linux-arm64;linux-x64;win-x86;win-x64;osx-arm64;osx-x64</RuntimeIdentifiers>
|
<RuntimeIdentifiers>linux-arm;linux-arm64;linux-x64;win-x86;win-x64;osx-arm64;osx-x64</RuntimeIdentifiers>
|
||||||
<RootNamespace>ReFuel.Stb</RootNamespace>
|
<RootNamespace>ReFuel.Stb</RootNamespace>
|
||||||
|
<Optimize>true</Optimize>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<!-- Nuget Properties. -->
|
<!-- Nuget Properties. -->
|
||||||
<GeneratePackageOnBuild>True</GeneratePackageOnBuild>
|
<GeneratePackageOnBuild>True</GeneratePackageOnBuild>
|
||||||
<PackageId>ReFuel.StbImage</PackageId>
|
<PackageId>ReFuel.StbImage</PackageId>
|
||||||
<Version>2.0</Version>
|
<Version>2.1.0</Version>
|
||||||
<Authors>STBI Authors, H. Utku Maden</Authors>
|
<Authors>STBI Authors, H. Utku Maden</Authors>
|
||||||
<Description>
|
<Description>
|
||||||
A C# wrapper for the ubiquitous stb_image.h and stb_image_write.h library.
|
A C# wrapper for the ubiquitous stb_image.h and stb_image_write.h library.
|
||||||
@ -25,7 +26,15 @@
|
|||||||
<RepositoryUrl>https://git.mixedup.dev/ReFuel/ReFuel.StbImage</RepositoryUrl>
|
<RepositoryUrl>https://git.mixedup.dev/ReFuel/ReFuel.StbImage</RepositoryUrl>
|
||||||
<RepositoryType>git</RepositoryType>
|
<RepositoryType>git</RepositoryType>
|
||||||
<PackageTags>stb; stb_image; stbi; image; load; save; read; write</PackageTags>
|
<PackageTags>stb; stb_image; stbi; image; load; save; read; write</PackageTags>
|
||||||
<PackageReleaseNotes># 2.0.0
|
<PackageReleaseNotes># 2.1.0 (ABI BRAKING)
|
||||||
|
* Fixed calling convention of unmanaged function pointers. (Thanks NogginBops!)
|
||||||
|
* Modified StbiStreamWrapper in order to fixed backing delegates of function pointers from being prematurely collected
|
||||||
|
by release mode JIT and the GC. StbiStreamWrapper.Callbacks is now a readonly field. (ABI BREAKING)
|
||||||
|
|
||||||
|
# 2.0.1
|
||||||
|
* Enabled optimizations across the board for native and managed assemblies.
|
||||||
|
|
||||||
|
# 2.0.0
|
||||||
* Exposed stbi_image_write.h
|
* Exposed stbi_image_write.h
|
||||||
* Moved native function calls to ReFuel.Stb.Native</PackageReleaseNotes>
|
* Moved native function calls to ReFuel.Stb.Native</PackageReleaseNotes>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
@ -47,7 +56,7 @@
|
|||||||
<Content Include="runtimes/linux-arm64/native/*.so">
|
<Content Include="runtimes/linux-arm64/native/*.so">
|
||||||
<PackagePath>runtimes/linux-arm64/native/</PackagePath>
|
<PackagePath>runtimes/linux-arm64/native/</PackagePath>
|
||||||
<Pack>true</Pack>
|
<Pack>true</Pack>
|
||||||
<CopyToOutputDirectory>PreserveNewest/</CopyToOutputDirectory>
|
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||||
</Content>
|
</Content>
|
||||||
<Content Include="runtimes/linux-x64/native/*.so">
|
<Content Include="runtimes/linux-x64/native/*.so">
|
||||||
<PackagePath>runtimes/linux-x64/native/</PackagePath>
|
<PackagePath>runtimes/linux-x64/native/</PackagePath>
|
||||||
|
46
StbImage.cs
46
StbImage.cs
@ -33,6 +33,7 @@ namespace ReFuel.Stb
|
|||||||
/// Internal image format.
|
/// Internal image format.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public StbiImageFormat Format { get; }
|
public StbiImageFormat Format { get; }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// True if the image is a floating point image.
|
/// True if the image is a floating point image.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@ -66,7 +67,7 @@ namespace ReFuel.Stb
|
|||||||
StbiImageFormat.GreyAlpha => 2,
|
StbiImageFormat.GreyAlpha => 2,
|
||||||
StbiImageFormat.Rgb => 3,
|
StbiImageFormat.Rgb => 3,
|
||||||
StbiImageFormat.Rgba => 4,
|
StbiImageFormat.Rgba => 4,
|
||||||
_ => throw new Exception("unkown image format")
|
_ => throw new Exception("unknown image format")
|
||||||
} * (IsFloat ? sizeof(float) : sizeof(byte));
|
} * (IsFloat ? sizeof(float) : sizeof(byte));
|
||||||
|
|
||||||
return new ReadOnlySpan<T>((T*)ImagePointer, Width * Height * sz / sizeof(T));
|
return new ReadOnlySpan<T>((T*)ImagePointer, Width * Height * sz / sizeof(T));
|
||||||
@ -112,6 +113,7 @@ namespace ReFuel.Stb
|
|||||||
/// Write image to a PNG file.
|
/// Write image to a PNG file.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="dest">The destination stream.</param>
|
/// <param name="dest">The destination stream.</param>
|
||||||
|
/// <param name="quality">The JPEG quality factor.</param>
|
||||||
/// <remarks>
|
/// <remarks>
|
||||||
/// Incurs a conversion cost if the image format is not a byte format. Ignores alpha channel. Affected by non-thread safe global options.
|
/// Incurs a conversion cost if the image format is not a byte format. Ignores alpha channel. Affected by non-thread safe global options.
|
||||||
/// </remarks>
|
/// </remarks>
|
||||||
@ -149,7 +151,7 @@ namespace ReFuel.Stb
|
|||||||
/// According to the stb_image documentation, only iPhone PNG images
|
/// According to the stb_image documentation, only iPhone PNG images
|
||||||
/// can come with premultiplied alpha.
|
/// can come with premultiplied alpha.
|
||||||
/// </remarks>
|
/// </remarks>
|
||||||
public static bool UnpremultiplyOnLoad { set => Stbi.set_unpremultiply_on_load(1); }
|
public static bool UnpremultiplyOnLoad { set => Stbi.set_unpremultiply_on_load(value ? 1 : 0); }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Force a filter on PNG filter when saving.
|
/// Force a filter on PNG filter when saving.
|
||||||
@ -201,22 +203,24 @@ namespace ReFuel.Stb
|
|||||||
/// <param name="image">The resulting image.</param>
|
/// <param name="image">The resulting image.</param>
|
||||||
/// <param name="stream">Source stream.</param>
|
/// <param name="stream">Source stream.</param>
|
||||||
/// <param name="format">The desired image format.</param>
|
/// <param name="format">The desired image format.</param>
|
||||||
|
/// <param name="asFloat">The buffer uses floating point pixels if true.</param>
|
||||||
/// <returns>True on success.</returns>
|
/// <returns>True on success.</returns>
|
||||||
public static bool TryLoad([NotNullWhen(true)] out StbImage? image, Stream stream, StbiImageFormat format = StbiImageFormat.Default, bool asFloat = false)
|
public static bool TryLoad([NotNullWhen(true)] out StbImage? image, Stream stream, StbiImageFormat format = StbiImageFormat.Default, bool asFloat = false)
|
||||||
{
|
{
|
||||||
int x, y, iFormat;
|
int x, y, iFormat;
|
||||||
StbiStreamWrapper wrapper = new StbiStreamWrapper(stream, true);
|
StbiStreamWrapper wrapper = new StbiStreamWrapper(stream, true);
|
||||||
wrapper.CreateCallbacks(out stbi_io_callbacks cb);
|
|
||||||
|
|
||||||
stream.Position = 0;
|
stream.Position = 0;
|
||||||
IntPtr imagePtr;
|
IntPtr imagePtr;
|
||||||
if (asFloat)
|
fixed (stbi_io_callbacks* cb = &wrapper.Callbacks)
|
||||||
{
|
{
|
||||||
imagePtr = (IntPtr)Stbi.loadf_from_callbacks(&cb, null, &x, &y, &iFormat, (int)format);
|
if (asFloat)
|
||||||
}
|
{
|
||||||
else
|
imagePtr = (IntPtr)Stbi.loadf_from_callbacks(cb, null, &x, &y, &iFormat, (int)format);
|
||||||
{
|
}
|
||||||
imagePtr = (IntPtr)Stbi.load_from_callbacks(&cb, null, &x, &y, &iFormat, (int)format);
|
else
|
||||||
|
{
|
||||||
|
imagePtr = (IntPtr)Stbi.load_from_callbacks(cb, null, &x, &y, &iFormat, (int)format);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (imagePtr != IntPtr.Zero)
|
if (imagePtr != IntPtr.Zero)
|
||||||
@ -237,6 +241,7 @@ namespace ReFuel.Stb
|
|||||||
/// <param name="image">The resulting image.</param>
|
/// <param name="image">The resulting image.</param>
|
||||||
/// <param name="span">Source memory span.</param>
|
/// <param name="span">Source memory span.</param>
|
||||||
/// <param name="format">The desired image format.</param>
|
/// <param name="format">The desired image format.</param>
|
||||||
|
/// <param name="asFloat">The buffer uses floating point pixels if true.</param>
|
||||||
/// <returns>True on success.</returns>
|
/// <returns>True on success.</returns>
|
||||||
public static bool TryLoad([NotNullWhen(true)] out StbImage? image, ReadOnlySpan<byte> span, StbiImageFormat format = StbiImageFormat.Default, bool asFloat = false)
|
public static bool TryLoad([NotNullWhen(true)] out StbImage? image, ReadOnlySpan<byte> span, StbiImageFormat format = StbiImageFormat.Default, bool asFloat = false)
|
||||||
{
|
{
|
||||||
@ -271,6 +276,7 @@ namespace ReFuel.Stb
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="stream">The stream to load from.</param>
|
/// <param name="stream">The stream to load from.</param>
|
||||||
/// <param name="format">The desired image format.</param>
|
/// <param name="format">The desired image format.</param>
|
||||||
|
/// <param name="asFloat">The buffer uses floating point pixels if true.</param>
|
||||||
/// <returns>The image object.</returns>
|
/// <returns>The image object.</returns>
|
||||||
public static StbImage Load(Stream stream, StbiImageFormat format = StbiImageFormat.Default, bool asFloat = false)
|
public static StbImage Load(Stream stream, StbiImageFormat format = StbiImageFormat.Default, bool asFloat = false)
|
||||||
{
|
{
|
||||||
@ -288,6 +294,7 @@ namespace ReFuel.Stb
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="span">The span of memory to load from.</param>
|
/// <param name="span">The span of memory to load from.</param>
|
||||||
/// <param name="format">The desired image format.</param>
|
/// <param name="format">The desired image format.</param>
|
||||||
|
/// <param name="asFloat">The buffer uses floating point pixels if true.</param>
|
||||||
/// <returns>The image object.</returns>
|
/// <returns>The image object.</returns>
|
||||||
public static StbImage Load(ReadOnlySpan<byte> span, StbiImageFormat format = StbiImageFormat.Default, bool asFloat = false)
|
public static StbImage Load(ReadOnlySpan<byte> span, StbiImageFormat format = StbiImageFormat.Default, bool asFloat = false)
|
||||||
{
|
{
|
||||||
@ -312,10 +319,12 @@ namespace ReFuel.Stb
|
|||||||
{
|
{
|
||||||
int x, y, iFormat;
|
int x, y, iFormat;
|
||||||
StbiStreamWrapper wrapper = new StbiStreamWrapper(stream, true);
|
StbiStreamWrapper wrapper = new StbiStreamWrapper(stream, true);
|
||||||
wrapper.CreateCallbacks(out stbi_io_callbacks cb);
|
int result;
|
||||||
|
|
||||||
stream.Position = 0;
|
stream.Position = 0;
|
||||||
int result = Stbi.info_from_callbacks(&cb, null, &x, &y, &iFormat);
|
fixed (stbi_io_callbacks* cb = &wrapper.Callbacks)
|
||||||
|
{
|
||||||
|
result = Stbi.info_from_callbacks(cb, null, &x, &y, &iFormat);
|
||||||
|
}
|
||||||
|
|
||||||
width = x;
|
width = x;
|
||||||
height = y;
|
height = y;
|
||||||
@ -389,7 +398,7 @@ namespace ReFuel.Stb
|
|||||||
/// <param name="data">Span of pixel data.</param>
|
/// <param name="data">Span of pixel data.</param>
|
||||||
/// <param name="width">Width of the pixel data in pixels.</param>
|
/// <param name="width">Width of the pixel data in pixels.</param>
|
||||||
/// <param name="height">Height of the pixel data in pixels.</param>
|
/// <param name="height">Height of the pixel data in pixels.</param>
|
||||||
/// <param name="format">Color format of the pixel data. Must not be <see cref="StbiImageFormat.StbiImageFormat"/>.</param>
|
/// <param name="format">Color format of the pixel data. Must not be <see cref="StbiImageFormat"/>.</param>
|
||||||
/// <param name="destination">The destination stream.</param>
|
/// <param name="destination">The destination stream.</param>
|
||||||
/// <param name="isFloat">True if the pixel format in data is a floating point format.</param>
|
/// <param name="isFloat">True if the pixel format in data is a floating point format.</param>
|
||||||
/// <remarks>
|
/// <remarks>
|
||||||
@ -425,7 +434,7 @@ namespace ReFuel.Stb
|
|||||||
/// <param name="data">Span of pixel data.</param>
|
/// <param name="data">Span of pixel data.</param>
|
||||||
/// <param name="width">Width of the pixel data in pixels.</param>
|
/// <param name="width">Width of the pixel data in pixels.</param>
|
||||||
/// <param name="height">Height of the pixel data in pixels.</param>
|
/// <param name="height">Height of the pixel data in pixels.</param>
|
||||||
/// <param name="format">Color format of the pixel data. Must not be <see cref="StbiImageFormat.StbiImageFormat"/>.</param>
|
/// <param name="format">Color format of the pixel data. Must not be <see cref="StbiImageFormat"/>.</param>
|
||||||
/// <param name="destination">The destination stream.</param>
|
/// <param name="destination">The destination stream.</param>
|
||||||
/// <param name="isFloat">True if the pixel format in data is a floating point format.</param>
|
/// <param name="isFloat">True if the pixel format in data is a floating point format.</param>
|
||||||
/// <remarks>
|
/// <remarks>
|
||||||
@ -461,7 +470,7 @@ namespace ReFuel.Stb
|
|||||||
/// <param name="data">Span of pixel data.</param>
|
/// <param name="data">Span of pixel data.</param>
|
||||||
/// <param name="width">Width of the pixel data in pixels.</param>
|
/// <param name="width">Width of the pixel data in pixels.</param>
|
||||||
/// <param name="height">Height of the pixel data in pixels.</param>
|
/// <param name="height">Height of the pixel data in pixels.</param>
|
||||||
/// <param name="format">Color format of the pixel data. Must not be <see cref="StbiImageFormat.StbiImageFormat"/>.</param>
|
/// <param name="format">Color format of the pixel data. Must not be <see cref="StbiImageFormat"/>.</param>
|
||||||
/// <param name="destination">The destination stream.</param>
|
/// <param name="destination">The destination stream.</param>
|
||||||
/// <param name="isFloat">True if the pixel format in data is a floating point format.</param>
|
/// <param name="isFloat">True if the pixel format in data is a floating point format.</param>
|
||||||
/// <remarks>
|
/// <remarks>
|
||||||
@ -497,7 +506,7 @@ namespace ReFuel.Stb
|
|||||||
/// <param name="data">Span of pixel data.</param>
|
/// <param name="data">Span of pixel data.</param>
|
||||||
/// <param name="width">Width of the pixel data in pixels.</param>
|
/// <param name="width">Width of the pixel data in pixels.</param>
|
||||||
/// <param name="height">Height of the pixel data in pixels.</param>
|
/// <param name="height">Height of the pixel data in pixels.</param>
|
||||||
/// <param name="format">Color format of the pixel data. Must not be <see cref="StbiImageFormat.StbiImageFormat"/>.</param>
|
/// <param name="format">Color format of the pixel data. Must not be <see cref="StbiImageFormat"/>.</param>
|
||||||
/// <param name="destination">The destination stream.</param>
|
/// <param name="destination">The destination stream.</param>
|
||||||
/// <param name="isFloat">True if the pixel format in data is a floating point format.</param>
|
/// <param name="isFloat">True if the pixel format in data is a floating point format.</param>
|
||||||
/// <remarks>
|
/// <remarks>
|
||||||
@ -533,8 +542,9 @@ namespace ReFuel.Stb
|
|||||||
/// <param name="data">Span of pixel data.</param>
|
/// <param name="data">Span of pixel data.</param>
|
||||||
/// <param name="width">Width of the pixel data in pixels.</param>
|
/// <param name="width">Width of the pixel data in pixels.</param>
|
||||||
/// <param name="height">Height of the pixel data in pixels.</param>
|
/// <param name="height">Height of the pixel data in pixels.</param>
|
||||||
/// <param name="format">Color format of the pixel data. Must not be <see cref="StbiImageFormat.StbiImageFormat"/>.</param>
|
/// <param name="format">Color format of the pixel data. Must not be <see cref="StbiImageFormat"/>.</param>
|
||||||
/// <param name="destination">The destination stream.</param>
|
/// <param name="destination">The destination stream.</param>
|
||||||
|
/// <param name="quality">The JPEG quality factor.</param>
|
||||||
/// <param name="isFloat">True if the pixel format in data is a floating point format.</param>
|
/// <param name="isFloat">True if the pixel format in data is a floating point format.</param>
|
||||||
/// <remarks>
|
/// <remarks>
|
||||||
/// This will incur a conversion cost if the pixel format is not a byte format. Ignores the alpha channel. Affected by global non-thread safe options.
|
/// This will incur a conversion cost if the pixel format is not a byte format. Ignores the alpha channel. Affected by global non-thread safe options.
|
||||||
|
@ -12,26 +12,32 @@ namespace ReFuel.Stb
|
|||||||
/// <param name="buffer">C array to read into.</param>
|
/// <param name="buffer">C array to read into.</param>
|
||||||
/// <param name="count">Size of the C array in bytes.</param>
|
/// <param name="count">Size of the C array in bytes.</param>
|
||||||
/// <returns>The number of bytes read from the stream.</returns>
|
/// <returns>The number of bytes read from the stream.</returns>
|
||||||
|
[UnmanagedFunctionPointer(CallingConvention.Cdecl)]
|
||||||
public unsafe delegate int StbiReadProc(void *userdata, byte* buffer, int count);
|
public unsafe delegate int StbiReadProc(void *userdata, byte* buffer, int count);
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Pointer to STBI stream skip function.
|
/// Pointer to STBI stream skip function.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="userdata">User provided userdata pointer.</param>
|
/// <param name="userdata">User provided userdata pointer.</param>
|
||||||
/// <param name="count">Number of bytes to skip.</param>
|
/// <param name="count">Number of bytes to skip.</param>
|
||||||
|
[UnmanagedFunctionPointer(CallingConvention.Cdecl)]
|
||||||
public unsafe delegate void StbiSkipProc(void *userdata, int count);
|
public unsafe delegate void StbiSkipProc(void *userdata, int count);
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Pointer to STBI stream end of file function.
|
/// Pointer to STBI stream end of file function.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="userdata">User provided userdata pointer.</param>
|
/// <param name="userdata">User provided userdata pointer.</param>
|
||||||
/// <returns>Non-zero value if the end of the stream has been reached.</returns>
|
/// <returns>Non-zero value if the end of the stream has been reached.</returns>
|
||||||
|
[UnmanagedFunctionPointer(CallingConvention.Cdecl)]
|
||||||
public unsafe delegate int StbiEofProc(void *userdata);
|
public unsafe delegate int StbiEofProc(void *userdata);
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// An easy to use stream wrapper for use with STBI image load functions.
|
/// An easy-to-use stream wrapper for use with STBI image load functions.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public unsafe class StbiStreamWrapper : IDisposable
|
public unsafe class StbiStreamWrapper : IDisposable
|
||||||
{
|
{
|
||||||
private readonly stbi_io_callbacks _callbacks;
|
public readonly stbi_io_callbacks Callbacks;
|
||||||
|
|
||||||
private readonly Stream _stream;
|
private readonly Stream _stream;
|
||||||
private readonly bool _keepOpen;
|
private readonly bool _keepOpen;
|
||||||
private bool _isDisposed;
|
private bool _isDisposed;
|
||||||
@ -40,8 +46,6 @@ namespace ReFuel.Stb
|
|||||||
private StbiSkipProc _skipCb;
|
private StbiSkipProc _skipCb;
|
||||||
private StbiEofProc _eofCb;
|
private StbiEofProc _eofCb;
|
||||||
|
|
||||||
public ref readonly stbi_io_callbacks Callbacks => ref _callbacks;
|
|
||||||
|
|
||||||
public StbiStreamWrapper(Stream stream, bool keepOpen = false)
|
public StbiStreamWrapper(Stream stream, bool keepOpen = false)
|
||||||
{
|
{
|
||||||
if (stream == null) throw new ArgumentNullException(nameof(stream));
|
if (stream == null) throw new ArgumentNullException(nameof(stream));
|
||||||
@ -53,18 +57,10 @@ namespace ReFuel.Stb
|
|||||||
_skipCb = SkipCb;
|
_skipCb = SkipCb;
|
||||||
_eofCb = EofCb;
|
_eofCb = EofCb;
|
||||||
|
|
||||||
_callbacks = default;
|
Callbacks = default;
|
||||||
_callbacks.read = Marshal.GetFunctionPointerForDelegate<StbiReadProc>(_readCb);
|
Callbacks.read = Marshal.GetFunctionPointerForDelegate<StbiReadProc>(_readCb);
|
||||||
_callbacks.skip = Marshal.GetFunctionPointerForDelegate<StbiSkipProc>(_skipCb);
|
Callbacks.skip = Marshal.GetFunctionPointerForDelegate<StbiSkipProc>(_skipCb);
|
||||||
_callbacks.eof = Marshal.GetFunctionPointerForDelegate<StbiEofProc>(_eofCb);
|
Callbacks.eof = Marshal.GetFunctionPointerForDelegate<StbiEofProc>(_eofCb);
|
||||||
}
|
|
||||||
|
|
||||||
public void CreateCallbacks(out stbi_io_callbacks cb)
|
|
||||||
{
|
|
||||||
cb = default;
|
|
||||||
cb.read = Marshal.GetFunctionPointerForDelegate<StbiReadProc>(_readCb);
|
|
||||||
cb.skip = Marshal.GetFunctionPointerForDelegate<StbiSkipProc>(_skipCb);
|
|
||||||
cb.eof = Marshal.GetFunctionPointerForDelegate<StbiEofProc>(_eofCb);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private int ReadCb(void *userdata, byte* buffer, int count)
|
private int ReadCb(void *userdata, byte* buffer, int count)
|
||||||
|
@ -9,6 +9,7 @@ namespace ReFuel.Stb.Native
|
|||||||
/// <param name="context">User provided context pointer.</param>
|
/// <param name="context">User provided context pointer.</param>
|
||||||
/// <param name="data">C Array of data to write.</param>
|
/// <param name="data">C Array of data to write.</param>
|
||||||
/// <param name="size">Size of the C array in bytes.</param>
|
/// <param name="size">Size of the C array in bytes.</param>
|
||||||
|
[UnmanagedFunctionPointer(CallingConvention.Cdecl)]
|
||||||
public unsafe delegate void StbiWriteProc(void* context, void* data, int size);
|
public unsafe delegate void StbiWriteProc(void* context, void* data, int size);
|
||||||
|
|
||||||
public unsafe partial class Stbi
|
public unsafe partial class Stbi
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
cd $(dirname "$0")
|
cd $(dirname "$0")
|
||||||
./docker-cross-compiler/sh/build_native.sh .
|
./docker-cross-compiler/sh/build_native.sh .
|
||||||
dotnet build
|
dotnet build -c Release
|
||||||
|
@ -1 +1 @@
|
|||||||
Subproject commit 5901e3e317571bce4a8772e2e994aaaadeae828e
|
Subproject commit d0f5760c7a7995cec50bf31fef78f5408445f27c
|
2
stb
2
stb
@ -1 +1 @@
|
|||||||
Subproject commit 013ac3beddff3dbffafd5177e7972067cd2b5083
|
Subproject commit f7f20f39fe4f206c6f19e26ebfef7b261ee59ee4
|
Loading…
x
Reference in New Issue
Block a user