Skip to content

Latest commit

 

History

History
99 lines (68 loc) · 4.46 KB

README.md

File metadata and controls

99 lines (68 loc) · 4.46 KB

LibJpeg-Turbo Unity

libjpeg-turbo for Unity. libjpeg-turbo is a faster image codec.

While Unity's ImageConversion.EncodeArrayToJPG is fast enough for single use, for every-frame use or on older PCs/Mobile platforms the difference is huge.

Currently supports Android armeabi-v7a / arm64-v8a and Windows x86 / x64. At least that was my use case. If you want more platforms, you can build your own libjpeg-turbo and still use the same importer/wrapper here.

Otherwise, simply download Plugins.zip file from releases tab and put it under your Assets folder.

Example/Demonstration

Capture settings:

  • Streaming Camera RenderTexture resolution: 1440x810
  • Target FPS for Streaming Camera: 30
  • Encode Quality: 75

Numbers in the first row are gathered with StopWatch, and in milliseconds.

Numbers in the second row are gathered with Time.realtimeSinceStartupAsDouble for more precision.

All values are aggregated and averaged on a fixed sized queue (250 frame).

Captured on Pico Neo 4 Enterprise (arm64-v8a)

ScreenRecording_2025.01.16-13.38.16.mp4

Captured on AMD Ryzen 7900X3D & nVidia 4080 Super (Win x64)

UnityProject.-.SampleScene.-.Windows.Mac.Linux.-.Unity.2022.3.56f1._DX11_.2025-01-16.13-17-51.mp4

Comparison

With version 3.1.0 the gap between became much larger.

Previously on Windows x64 libjpeg-turbo was x1.25 faster. Now it's x6.4 faster.

Previously on Android, the difference was around x5, so it was a pretty clear choice. Now it's around x4.7. It's still the clear choice.

Unity project

Unity project is under UnityProject folder, and is a simple representation/demonstration of the usage. It also shows the folder structure and usage (i.e. create/import/dispose) of the library. It's using AsyncGPUReadback to capture the gameview and display it on the preview screens on top of the screen.

You can simply get the Plugins.zip from releases and put it on your project if you don't want to deal with it, but still, you may need the example.

Library project

Library project is under CsProject folder and is used to create a dll file to use the libjpeg-turbo libraries. Basically it includes an importer and encoder functionalities.

You can simply get the .cs files from this project and put it under your Unity project to use it. You don't have to use the .dll file, but it's less clutter, and compatible with the IL2CPP build.

Building the actual libjpeg-turbo libraries from source

If you need to build the libraries yourself for any reason, or if an updated version of the libjpeg-turbo was released and you want to update, you need Android NDK, Visual Studio, CMake and make to be able to build the libraries yourself.

Go and get the source for libjpeg-turbo first.

Android

Set the necessary variables to use the paths.

NDK_PATH=<your Android NDK root path>
TOOLCHAIN=$NDK_PATH/toolchains/llvm/prebuilt/windows-x86_64/
ANDROID_VERSION=29

Depending on your use case, you may change the Android version

armeabi-v7a

cmake -G "Unix Makefiles" -DANDROID_ABI=armeabi-v7a -DAND

https://github.com/user-attachments/assets/2a1851b2-575f-4719-a873-32a3b4a8b9a3

ROID_ARM_MODE=arm -DANDROID_PLATFORM=android-${ANDROID_VERSION} -DANDROID_TOOLCHAIN=${TOOLCHAIN} -DCMAKE_ASM_FLAGS="--target=arm-linux-androideabi${ANDROID_VERSION}" -DCMAKE_TOOLCHAIN_FILE=${NDK_PATH}/build/cmake/android.toolchain.cmake -DCMAKE_MAKE_PROGRAM:FILEPATH=<your_make_binary_path> <your_libjpeg-turbo_source_folder>

Then simply

make

arm64-v8a

cmake -G "Unix Makefiles" -DANDROID_ABI=arm64-v8a -DANDROID_ARM_MODE=arm -DANDROID_PLATFORM=android-${ANDROID_VERSION} -DANDROID_TOOLCHAIN=${TOOLCHAIN} -DCMAKE_ASM_FLAGS="--target=aarch64-linux-android${ANDROID_VERSION}" -DCMAKE_TOOLCHAIN_FILE=${NDK_PATH}/build/cmake/android.toolchain.cmake -DCMAKE_MAKE_PROGRAM:FILEPATH=<your_make_binary_path> <your_libjpeg-turbo_source_folder>

Then simply

make

Windows

x86

cmake -G "Visual Studio 17 2022" -A Win32 ../../../libjpeg-turbo-3.0.2/

x64

cmake -G "Visual Studio 17 2022" -A x64 ../../../libjpeg-turbo-3.0.2/

Then use the generated Visual Studio project files to build your own .dll file of the libjpeg-turbo. You can also use a different version of Visual Studio if you want, just go check the CMake documentation for it.