[DEV] start to work on GALE

This commit is contained in:
Edouard DUPIN 2020-05-07 01:09:43 +02:00
parent dd6fb69230
commit e9fe2b9649
46 changed files with 3136 additions and 1289 deletions

805
.classpath Normal file
View File

@ -0,0 +1,805 @@
<?xml version="1.0" encoding="UTF-8"?>
<classpath>
<classpathentry excluding="org/atriaSoft/ege/physics/|org/atriaSoft/ege/ia/|org/atriaSoft/ege/physics/shape/|org/atriaSoft/ege/particule/|org/atriaSoft/ege/camera/|org/atriaSoft/ege/|org/atriaSoft/ege/resource/tools/|org/atriaSoft/ege/render/|org/atriaSoft/ege/widget/|org/atriaSoft/ege/position/|org/atriaSoft/ege/elements/|org/atriaSoft/ege/resource/" kind="src" path="src"/>
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/pngdecoder.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-assimp-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-assimp-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-assimp-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-assimp.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-bgfx-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-bgfx-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-bgfx-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-bgfx.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-bullet-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-bullet-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-bullet-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-bullet.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-cuda-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-cuda-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-cuda.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-driftfx-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-driftfx-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-driftfx-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-driftfx.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-egl-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-egl-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-egl.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-glfw-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-glfw-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-glfw-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-glfw.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-jawt-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-jawt-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-jawt.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-jemalloc-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-jemalloc-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-jemalloc-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-jemalloc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-libdivide-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-libdivide-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-libdivide-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-libdivide.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-llvm-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-llvm-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-llvm-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-llvm.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-lmdb-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-lmdb-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-lmdb-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-lmdb.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-lz4-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-lz4-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-lz4-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-lz4.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-meow-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-meow-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-meow-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-meow.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-meshoptimizer-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-meshoptimizer-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-meshoptimizer-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-meshoptimizer.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-nanovg-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-nanovg-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-nanovg-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-nanovg.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-nfd-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-nfd-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-nfd-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-nfd.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-nuklear-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-nuklear-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-nuklear-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-nuklear.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-odbc-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-odbc-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-odbc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-openal-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-openal-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-openal-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-openal.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-opencl-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-opencl-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-opencl.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-opengl-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-opengl-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-opengl-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-opengl.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-opengles-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-opengles-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-opengles-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-opengles.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-openvr-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-openvr-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-openvr-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-openvr.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-opus-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-opus-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-opus-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-opus.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-par-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-par-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-par-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-par.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-remotery-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-remotery-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-remotery-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-remotery.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-rpmalloc-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-rpmalloc-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-rpmalloc-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-rpmalloc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-shaderc-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-shaderc-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-shaderc-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-shaderc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-spvc-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-spvc-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-spvc-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-spvc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-sse-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-sse-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-sse-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-sse.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-stb-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-stb-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-stb-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-stb.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-tinyexr-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-tinyexr-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-tinyexr-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-tinyexr.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-tinyfd-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-tinyfd-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-tinyfd-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-tinyfd.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-tootle-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-tootle-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-tootle-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-tootle.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-vma-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-vma-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-vma-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-vma.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-vulkan-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-vulkan-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-vulkan.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-xxhash-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-xxhash-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-xxhash-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-xxhash.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-yoga-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-yoga-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-yoga-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-yoga.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-zstd-javadoc.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-zstd-natives-linux.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-zstd-sources.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl-zstd.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="lib" path="lib/lwjgl/lwjgl.jar">
<attributes>
<attribute name="module" value="true"/>
</attributes>
</classpathentry>
<classpathentry kind="output" path="bin"/>
</classpath>

17
.project Normal file
View File

@ -0,0 +1,17 @@
<?xml version="1.0" encoding="UTF-8"?>
<projectDescription>
<name>jege</name>
<comment></comment>
<projects>
</projects>
<buildSpec>
<buildCommand>
<name>org.eclipse.jdt.core.javabuilder</name>
<arguments>
</arguments>
</buildCommand>
</buildSpec>
<natures>
<nature>org.eclipse.jdt.core.javanature</nature>
</natures>
</projectDescription>

24
LICENSE Normal file
View File

@ -0,0 +1,24 @@
This is free and unencumbered software released into the public domain.
Anyone is free to copy, modify, publish, use, compile, sell, or
distribute this software, either in source code form or as a compiled
binary, for any purpose, commercial or non-commercial, and by any
means.
In jurisdictions that recognize copyright laws, the author or authors
of this software dedicate any and all copyright interest in the
software to the public domain. We make this dedication for the benefit
of the public at large and to the detriment of our heirs and
successors. We intend this dedication to be an overt act of
relinquishment in perpetuity of all present and future rights to this
software under copyright law.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
OTHER DEALINGS IN THE SOFTWARE.
For more information, please refer to <http://unlicense.org>

View File

@ -29,13 +29,9 @@ public class GuiRenderer {
GL30.glBindVertexArray(quad.getVaoID());
GL20.glEnableVertexAttribArray(0);
GL11.glEnable(GL11.GL_BLEND);
GL11.glBlendFunc(GL11.GL_SRC_ALPHA, GL11.GL_ONE_MINUS_SRC_ALPHA);
GL11.glDisable(GL11.GL_DEPTH_TEST);
//OpenGL.enable(OpenGL.Flag.flag_blend);
//GL11.glBlendFunc(GL11.GL_SRC_ALPHA, GL11.GL_ONE_MINUS_SRC_ALPHA);
//OpenGL.enable(OpenGL.Flag.flag_cullFace);
//OpenGL.enable(OpenGL.Flag.flag_back);
OpenGL.enable(OpenGL.Flag.flag_blend);
OpenGL.enable(OpenGL.Flag.flag_cullFace);
OpenGL.enable(OpenGL.Flag.flag_back);
for (GuiTexture gui: guis) {
GL13.glActiveTexture(GL13.GL_TEXTURE0);
GL11.glBindTexture(GL11.GL_TEXTURE_2D, gui.getTexture());
@ -45,11 +41,9 @@ public class GuiRenderer {
GL11.glDrawArrays(GL11.GL_TRIANGLE_STRIP, 0, quad.getVertexCount());
}
//OpenGL.disable(OpenGL.Flag.flag_blend);
//OpenGL.disable(OpenGL.Flag.flag_cullFace);
//OpenGL.disable(OpenGL.Flag.flag_back);
GL11.glDisable(GL11.GL_BLEND);
GL11.glEnable(GL11.GL_DEPTH_TEST);
OpenGL.disable(OpenGL.Flag.flag_blend);
OpenGL.disable(OpenGL.Flag.flag_cullFace);
OpenGL.disable(OpenGL.Flag.flag_back);
GL20.glDisableVertexAttribArray(0);
GL30.glBindVertexArray(0);

View File

@ -7,8 +7,8 @@ import shaders.ShaderProgram;
public class GuiShader extends ShaderProgram {
private static final String VERTEX_FILE = "src/guis/guiVertexShader.txt";
private static final String FRAGMENT_FILE = "src/guis/guiFragmentShader.txt";
private static final String VERTEX_FILE = "src/guis/gui.vert";
private static final String FRAGMENT_FILE = "src/guis/gui.frag";
private int location_transformationMatrix;

View File

@ -0,0 +1,61 @@
package org.atriaSoft.etk;
public abstract class ThreadAbstract {
// thread section:
private boolean threadStopRequested = false;
private Thread threadInstance = null;
private final String threadName;
public ThreadAbstract(String name) {
this.threadName = name;
}
public void threadStart() {
System.out.println("INFO: Start the thread : " + this.threadName);
if (threadInstance != null) {
threadStop();
}
threadStopRequested = false;
threadInstance = new Thread() {
public void run() {
threadRun();
}
};
threadInstance.setName(threadName);
threadInstance.start();
}
private void threadRun() {
System.out.println("INFO: Thread Start: " + threadName);
birth();
while (threadStopRequested == false) {
try {
runPeriodic();
} catch (Exception eee) {
eee.printStackTrace();
}
}
death();
System.out.println("INFO: Thread Stop: " + threadName);
}
protected abstract void birth();
protected abstract void runPeriodic();
protected abstract void death();
public void threadStop() {
if (threadStopRequested == true) {
return;
}
threadStopRequested = true;
if (threadInstance == null) {
return;
}
threadInstance.interrupt();
try {
threadInstance.join();
} catch (InterruptedException eee) {
// nothing to do
}
threadInstance = null;
}
}

View File

@ -24,7 +24,7 @@ public class Uri {
}
public String getPath() {
String[] ret = value.split(":",1);
String[] ret = value.split(":",2);
return genericMap.get(ret[0]) + "/" + ret[1];
}
public String get() {

View File

@ -1,5 +1,7 @@
package org.atriaSoft.etk.math;
import java.util.Arrays;
public class Matrix3f {
public float[] mat = new float[3*3]; //!< matrix data
/**

View File

@ -139,7 +139,7 @@ public class Matrix4f {
* @brief Operator*= Multiplication an other matrix with this one
* @param[in] obj Reference on the external object
*/
public void multiply(Matrix4f obj) {
public Matrix4f multiply(Matrix4f obj) {
// output Matrix
float[] matrixOut = new float[16];
for(int xxx=0; xxx<4 ; xxx++) {
@ -155,6 +155,10 @@ public class Matrix4f {
for(int iii=0; iii<4*4 ; iii++) {
this.mat[iii] = matrixOut[iii];
}
return this;
}
public Matrix4f multiply_new(Matrix4f obj) {
return this.clone().multiply(obj);
}
/**
* @brief Operator* apply matrix on a vector
@ -169,7 +173,7 @@ public class Matrix4f {
/**
* @brief Transpose the current matix (usefull for OpenGL display)
*/
public void transpose() {
public Matrix4f transpose() {
float tmpVal = this.mat[1];
this.mat[1] = this.mat[4];
this.mat[4] = tmpVal;
@ -193,13 +197,20 @@ public class Matrix4f {
tmpVal = this.mat[11];
this.mat[11] = this.mat[14];
this.mat[14] = tmpVal;
return this;
}
public Matrix4f transpose_new() {
return this.clone().transpose();
}
/**
* @brief Scale the current Matrix.
* @param[in] vect Scale vector to apply.
*/
public void scale(Vector3f vect) {
scale(vect.x, vect.y, vect.z);
public Matrix4f scale(Vector3f vect) {
return scale(vect.x, vect.y, vect.z);
}
public Matrix4f scale_new(Vector3f vect) {
return this.clone().scale(vect.x, vect.y, vect.z);
}
/**
* @brief Scale the current Matrix.
@ -207,34 +218,49 @@ public class Matrix4f {
* @param[in] sy Scale Y value to apply.
* @param[in] sz Scale Z value to apply.
*/
public void scale(float sx, float sy, float sz) {
public Matrix4f scale(float sx, float sy, float sz) {
this.mat[0] *= sx; this.mat[1] *= sy; this.mat[2] *= sz;
this.mat[4] *= sx; this.mat[5] *= sy; this.mat[6] *= sz;
this.mat[8] *= sx; this.mat[9] *= sy; this.mat[10] *= sz;
return this;
}
public Matrix4f scale_new(float sx, float sy, float sz) {
return this.clone().scale(sx, sy, sz);
}
/**
* @brief Scale the current Matrix in all direction with 1 value.
* @param[in] scale Scale XYZ value to apply.
*/
public void scale(float scale) {
scale(scale, scale, scale);
public Matrix4f scale(float scale) {
return scale(scale, scale, scale);
}
public Matrix4f scale_new(float scale) {
return this.clone().scale(scale, scale, scale);
}
/**
* @brief Makes a rotation matrix about an arbitrary axis.
* @param[in] vect vector to apply the angle.
* @param[in] angleRad angle to apply.
*/
public void rotate(Vector3f vect, float angleRad) {
public Matrix4f rotate(Vector3f vect, float angleRad) {
Matrix4f tmpMat = createMatrixRotate(vect, angleRad);
this.multiply(tmpMat);
return this.multiply(tmpMat);
}
public Matrix4f rotate_new(Vector3f vect, float angleRad) {
Matrix4f tmpMat = createMatrixRotate(vect, angleRad);
return this.multiply_new(tmpMat);
}
/**
* @brief Makes a translation of the matrix
* @param[in] vect Translation to apply.
*/
public void translate(Vector3f vect) {
public Matrix4f translate(Vector3f vect) {
Matrix4f tmpMat = createMatrixTranslate(vect);
this.multiply(tmpMat);
return this.multiply(tmpMat);
}
public Matrix4f translate_new(Vector3f vect) {
Matrix4f tmpMat = createMatrixTranslate(vect);
return this.multiply_new(tmpMat);
}
/**
* @brief Computes a cofactor. Used for matrix inversion.
@ -267,7 +293,7 @@ public class Matrix4f {
* @note The determinant must be != 0, otherwithe the matrix can't be inverted.
* @return The inverted matrix.
*/
public Matrix4f invert() {
public Matrix4f invert_new() {
float det = determinant();
if(Math.abs(det) < (1.0e-7f)) {
// The matrix is not invertible! Singular case!

View File

@ -1,5 +1,7 @@
package org.atriaSoft.etk.math;
import java.util.Arrays;
public class Quaternion {
public float x;
public float y;
@ -645,4 +647,8 @@ public class Quaternion {
public Quaternion clone() {
return new Quaternion(this);
}
@Override
public String toString() {
return "Quaternion(" + this.x + "," + this.y + "," + this.z + "," + this.w + ")";
}
}

View File

@ -104,4 +104,8 @@ public class Transform3D {
public Transform3D clone() {
return new Transform3D(this);
}
@Override
public String toString() {
return "Transform3D(" + this.position + " & " + this.orientation + ")";
}
}

View File

@ -10,6 +10,9 @@ public class Vector2f {
this.x = 0;
this.y = 0;
}
public static Vector2f zero() {
return new Vector2f(0,0);
}
/**
* @brief Constructor from scalars
* @param[in] xxx X value
@ -355,4 +358,8 @@ public class Vector2f {
public Vector2f clone() {
return new Vector2f(this);
}
@Override
public String toString() {
return "Vector2f(" + this.x + "," + this.y + ")";
}
}

View File

@ -355,4 +355,8 @@ public class Vector2i {
public Vector2i clone() {
return new Vector2i(this);
}
@Override
public String toString() {
return "Vector2i(" + this.x + "," + this.y + ")";
}
}

View File

@ -500,4 +500,8 @@ public class Vector3f {
public static Vector3f zero() {
return new Vector3f(0,0,0);
}
@Override
public String toString() {
return "Vector3f(" + this.x + "," + this.y + "," + this.z + ")";
}
}

View File

@ -469,4 +469,8 @@ public class Vector3i {
public static Vector3i zero() {
return new Vector3i(0,0,0);
}
@Override
public String toString() {
return "Vector3i(" + this.x + "," + this.y + "," + this.z + ")";
}
}

View File

@ -1,189 +1,283 @@
package org.atriaSoft.gale;
import org.atriaSoft.etk.Uri;
import org.atriaSoft.etk.math.Vector2f;
import org.atriaSoft.gale.context.ClipboardList;
import org.atriaSoft.gale.context.Context;
import org.atriaSoft.gale.context.Cursor;
import org.atriaSoft.gale.key.Keyboard;
import org.atriaSoft.gale.key.Special;
import org.atriaSoft.gale.key.Status;
import org.atriaSoft.gale.key.Type;
public class Application {
private boolean m_canDraw;
private boolean m_needRedraw;
private String m_title;
private Uri m_iconName;
private Cursor m_cursor;
public boolean canDraw = false;
private boolean needRedraw = true;
private String title = "gale";
private Uri iconName = new Uri("");
private Cursor cursor = Cursor.arrow;
private Orientation orientation = Orientation.screenAuto;
Vector2f windowsSize = new Vector2f(800,600);
public Application() {
Log.verbose("Constructor Gale Application")
Log.verbose("Constructor Gale Application");
}
/**
* @brief The application is created.
* @param[in] _context Current gale context.
* @param[in] context Current gale context.
*/
public void onCreate(gale::Context& _context);
public void onCreate(Context context) {
Log.verbose("Create Gale Application");
}
/**
* @brief The application is started.
* @param[in] _context Current gale context.
* @param[in] context Current gale context.
*/
public void onStart(gale::Context& _context);
public void onStart(Context context){
Log.verbose("Start Gale Application");
}
/**
* @brief The application is resumed (now visible).
* @param[in] _context Current gale context.
* @param[in] context Current gale context.
*/
public void onResume(gale::Context& _context);
public void onResume(Context context){
Log.verbose("Start Gale Application");
}
/**
* @brief call application to precalculate drawing.
* @param[in] _context Current gale context.
* @param[in] context Current gale context.
*/
public void onRegenerateDisplay(gale::Context& _context);
public void onRegenerateDisplay(Context context) {
Log.verbose("Regenerate Gale Application");
markDrawingIsNeeded();
}
/**
* @brief Real draw of the application
* @param[in] _context Current gale context.
* @param[in] context Current gale context.
*/
public void onDraw(gale::Context& _context);
public void onDraw(Context context) {
Log.verbose("draw Gale Application");
}
/**
* @brief The application is Hide / not visible.
* @param[in] _context Current gale context.
* @param[in] context Current gale context.
*/
public void onPause(gale::Context& _context);
public void onPause(Context context) {
Log.verbose("Pause Gale Application");
}
/**
* @brief The application is stopped.
* @param[in] _context Current gale context.
* @param[in] context Current gale context.
*/
public void onStop(gale::Context& _context);
public void onStop(Context context) {
Log.verbose("Stop Gale Application");
}
/**
* @brief The application is removed (call destructor just adter it.).
* @param[in] _context Current gale context.
* @param[in] context Current gale context.
*/
public void onDestroy(gale::Context& _context);
public void onDestroy(Context context) {
Log.verbose("Destroy Gale Application");
}
/**
* @brief The user request application removing.
* @param[in] _context Current gale context.
* @param[in] context Current gale context.
*/
public void onKillDemand(gale::Context& _context);
public void onKillDemand(Context context) {
Log.info("Gale request auto destroy ==> no applification specification");
System.exit(0);
}
/**
* @brief Exit the application (not availlable on IOs, ==> the user will not understand the comportement. He will think the application has crashed (Apple philosophie))
* @param[in] _value value to return on the program
* @param[in] value value to return on the program
*/
public void exit(int32_t _value);
public void exit(int value) {
Log.verbose("Exit Requested " + value);
Gale.getContext().stop();
}
public void markDrawingIsNeeded();
public boolean isDrawingNeeded();
public void markDrawingIsNeeded() {
this.needRedraw = true;
}
public boolean isDrawingNeeded() {
boolean tmp = this.needRedraw;
this.needRedraw = false;
return tmp;
}
/**
* @brief Get touch/mouse/... event.
* @param[in] _type Type of pointer event
* @param[in] _pointerID Pointer id of the touch event.
* @param[in] _pos Position of the event (can be <0 if out of window).
* @param[in] _state Key state (up/down/move)
* @param[in] type Type of pointer event
* @param[in] pointerID Pointer id of the touch event.
* @param[in] pos Position of the event (can be <0 if out of window).
* @param[in] state Key state (up/down/move)
*/
public void onPointer(enum gale::key::type _type,
int32_t _pointerID,
const vec2& _pos,
gale::key::status _state);
public void onPointer(Type type,
int pointerID,
Vector2f pos,
Status state) {
}
/**
* @brief Get keyborad value input.
* @param[in] _special Current special key status (ctrl/alt/shift ...).
* @param[in] _type Type of the event.
* @param[in] _value Unicode value of the char pushed (viable only if _type==gale::key::keyboard::character).
* @param[in] _state State of the key (up/down/upRepeate/downRepeate)
* @param[in] special Current special key status (ctrl/alt/shift ...).
* @param[in] type Type of the event.
* @param[in] value Unicode value of the char pushed (viable only if type==gale::key::keyboard::character).
* @param[in] state State of the key (up/down/upRepeate/downRepeate)
*/
public void onKeyboard(const gale::key::Special& _special,
enum gale::key::keyboard _type,
char32_t _value,
gale::key::status _state);
public void onKeyboard(Special special,
Keyboard type,
Character value,
Status state) {
}
/**
* @brief Show the virtal keyboard (if possible : only on iOs/Android)
*/
public void keyboardShow();
public void keyboardShow() {
Context context = Gale.getContext();
if (context == null) {
return;
}
context.keyboardShow();
}
/**
* @brief Hide the virtal keyboard (if possible : only on iOs/Android)
*/
public void keyboardHide();
public void keyboardHide() {
Context context = Gale.getContext();
if (context == null) {
return;
}
context.keyboardHide();
}
/**
* @brief Event generated when user change the size of the window.
* @param[in] _size New size of the window.
* @param[in] size New size of the window.
*/
public void onResize(const ivec2& _size);
public void onResize(Vector2f size) {
}
/**
* @brief Set the size of the window (if possible: Android and Ios does not support it)
* @param[in] _size New size of the window.
* @param[in] size New size of the window.
* @return
*/
public void setSize(const vec2& _size);
public void setSize(Vector2f size) {
windowsSize = size;
Context context = Gale.getContext();
if (context == null) {
return;
}
context.setSize(size);
}
/**
* @brief Get the size of the window.
* @return Current size of the window.
*/
public vec2 getSize() const;
public Vector2f getSize() {
return windowsSize;
}
/**
* @brief Event generated when user change the position of the window.
* @param[in] _size New position of the window.
* @param[in] size New position of the window.
*/
public void onMovePosition(const vec2& _size);
public void onMovePosition(Vector2f size) {
}
/**
* @brief Set the position of the window (if possible: Android and Ios does not support it)
* @param[in] _size New position of the window.
* @param[in] size New position of the window.
*/
public void setPosition(const vec2& _size);
public void setPosition(Vector2f size) {
}
/**
* @brief Get the position of the window.
* @return Current position of the window.
*/
public vec2 getPosition() const;
public Vector2f getPosition() {
return new Vector2f(0,0);
}
/**
* @brief Set the title of the application
* @param[in] _title New title to set at the application (if possible: Android and Ios does not support it)
* @param[in] title New title to set at the application (if possible: Android and Ios does not support it)
*/
public void setTitle(const etk::String& _title);
public void setTitle(String title) {
this.title = title;
Context context = Gale.getContext();
if (context == null) {
return;
}
context.setTitle(this.title);
}
/**
* @brief Get the current title of the application
* @return Current title
*/
public etk::String getTitle();
public String getTitle() {
return this.title;
}
/**
* @brief set the Icon of the application.
* @param[in] _iconFile File name icon (.bmp/.png).
* @param[in] iconFile File name icon (.bmp/.png).
*/
public void setIcon(const etk::Uri& _iconFile);
public void setIcon(Uri iconFile) {
this.iconName = iconFile;
Gale.getContext().setIcon(this.iconName);
}
/**
* @brief Get the current filename of the application.
* @return Filename of the icon.
*/
public const etk::Uri& getIcon();
public Uri getIcon() {
return this.iconName;
}
/**
* @brief Set the cursor type.
* @param[in] _newCursor Selected cursor.
* @param[in] newCursor Selected cursor.
*/
public void setCursor(enum gale::context::cursor _newCursor);
public void setCursor(Cursor newCursor) {
Gale.getContext().setCursor(this.cursor);
}
/**
* @brief Get the cursor type.
* @return the current cursor.
*/
public enum gale::context::cursor getCursor();
/**
* @brief Open an URL on an internal brother.
* @param[in] _url URL to open.
*/
public void openURL(const etk::String& _url);
private Orientation m_orientation;
public Cursor getCursor() {
return this.cursor;
}
/**
* @brief set the screen orientation (if possible : only on iOs/Android)
* @param[in] _orientation New orientation.
* @param[in] orientation New orientation.
*/
public void setOrientation(Orientation _orientation);
public void setOrientation(Orientation orientation) {
this.orientation = orientation;
Gale.getContext().forceOrientation(this.orientation);
}
/**
* @brief get the screen orientation (if possible : only on iOs/Android)
* @return Current orientation.
*/
public Orientation getOrientation();
public Orientation getOrientation() {
return this.orientation;
}
/**
* @brief A clipboard data is back (apear after a request of a new clipboard).
* @param[in] _clipboardId Id of the clipboard.
* @param[in] clipboardId Id of the clipboard.
*/
public void onClipboardEvent(ClipboardList _clipboardId);
public void onClipboardEvent(ClipboardList clipboardId) {
}
/**
* @brief Call every time a draw is called (not entirely periodic, but faster at we can ...
* @param[in] _time Current time of the call;
* @param[in] time Current time of the call;
*/
public void onPeriod(const echrono::Clock& _time) {};
public void onPeriod(long time) {};
}

View File

@ -1,5 +1,8 @@
package org.atriaSoft.gale;
import org.atriaSoft.gale.context.Context;
import org.atriaSoft.gale.context.LWJGL.ContextLWJGL;
public class Gale {
/**
* @brief This is the only one things the User might done in his main();
@ -13,25 +16,30 @@ public class Gale {
* @param[in] _argv Standard argv
* @return normal error int for the application error management
*/
int run(Application application, String arg[]) {
public static int run(Application application, String arg[]) {
//etk::init(_argc, _argv);
Context context = null;
String request = "";
context = ContextLWJGL.create(_application, arg);
context = ContextLWJGL.create(application, arg);
if (context == null) {
Log.error("Can not allocate the interface of the GUI ...");
return -1;
}
return context->run();
return context.run();
}
/**
* @brief get GALE version
* @return The string that describe gale version
*/
String getVersion() {
public static String getVersion() {
return "J-0.5";
}
public static Context getContext() {
// TODO Auto-generated method stub
return Context.getContext();
}
}

View File

@ -3,6 +3,7 @@ package org.atriaSoft.gale.backend3d;
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.nio.FloatBuffer;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
@ -11,12 +12,14 @@ import java.util.Map;
import org.lwjgl.BufferUtils;
import org.lwjgl.opengl.GL11;
import org.lwjgl.opengl.GL13;
import org.lwjgl.opengl.GL15;
import org.lwjgl.opengl.GL20;
import org.lwjgl.opengl.GL30;
import org.atriaSoft.etk.math.Matrix4f;
import org.atriaSoft.etk.math.Vector2f;
import org.atriaSoft.etk.math.Vector2i;
import org.atriaSoft.etk.math.Vector3f;
import org.atriaSoft.etk.math.Vector3i;
import org.atriaSoft.etk.Color;
import org.atriaSoft.gale.Log;
@ -43,7 +46,7 @@ public class OpenGL {
}
private static List<Matrix4f> matrixList = new ArrayList<Matrix4f>();
private static Matrix4f matrixCamera;
private static Matrix4f matrixCamera = new Matrix4f();
private static int programId = 0;
// We map all the flag, but not all is supported by all platform...
@ -80,7 +83,7 @@ public class OpenGL {
flag_fog,
flag_back
};
enum RenderMode {
public enum RenderMode {
point,
line,
lineStrip, //!< Not supported in GALE (TODO : Later)
@ -113,6 +116,12 @@ public class OpenGL {
private static boolean flagsStatesChange = false;
private static Map<Flag, StateFlag> flagsStates = new HashMap<Flag, StateFlag>();
public enum Usage {
streamDraw,
staticDraw,
dynamicDraw
}
public static Map<Usage, Integer> convertUsage;
static {
flagsStates.put(Flag.flag_blend, new StateFlag());
flagsStates.put(Flag.flag_clipDistanceI, new StateFlag());
@ -175,6 +184,10 @@ public class OpenGL {
// basicFlag.put(Flag.flag_alphaTest, GLALPHATEST);
// basicFlag.put(Flag.flag_fog, GLFOG);
basicFlag.put(Flag.flag_back, GL11.GL_BACK);
convertUsage = new HashMap<Usage, Integer>();
convertUsage.put(Usage.streamDraw, GL20.GL_STREAM_DRAW);
convertUsage.put(Usage.staticDraw, GL20.GL_STATIC_DRAW);
convertUsage.put(Usage.dynamicDraw, GL20.GL_DYNAMIC_DRAW);
}
private static void clearFlagState() {
for (Map.Entry<Flag, StateFlag> elem: flagsStates.entrySet()) {
@ -316,10 +329,10 @@ public class OpenGL {
public static void flush(){
programId = -1;
GL11.glFlush();
checkGlError("glFlush");
Log.info("========================" );
Log.info("== FLUSH OPEN GL ==" );
Log.info("========================");
//checkGlError("glFlush");
//Log.info("========================" );
//Log.info("== FLUSH OPEN GL ==" );
//Log.info("========================");
}
/**
@ -329,12 +342,12 @@ public class OpenGL {
}
public static void setViewPort( Vector2i start, Vector2i stop){
Log.info("setViewport " + start + " " + stop);
//Log.info("setViewport " + start + " " + stop);
GL11.glViewport(start.x, start.y, stop.x, stop.y);
checkGlError("glViewport");
}
public static void setViewPort( Vector2f start, Vector2f stop){
Log.info("setViewport " + start + " " + stop);
//Log.info("setViewport " + start + " " + stop);
GL11.glViewport((int)start.x, (int)start.y, (int)stop.x, (int)stop.y);
checkGlError("glViewport");
}
@ -535,61 +548,62 @@ public class OpenGL {
}
// public static boolean genBuffers(List<int> buffers) {
// if (buffers.size() == 0) {
// Log.warning("try to generate vector buffer with size 0");
// return true;
// }
// Log.info("Create N=" + buffers.size() + " Buffer");
// glGenBuffers(buffers.size(), &buffers[0]);
// checkGlError("glGenBuffers");
// boolean hasError = false;
// for (sizet iii=0; iii<buffers.size(); iii++) {
// if (buffers[iii] == 0) {
// Log.error("[" + iii + "] error to create a buffer id=" + buffers[iii]);
// hasError = true;
// }
// }
// return hasError;
// }
// public static boolean deleteBuffers(List<int> buffers) {
// if (buffers.size() == 0) {
// Log.warning("try to delete vector buffer with size 0");
// return true;
// }
// // TODO: Check if we are in the correct thread
// glDeleteBuffers(buffers.size(), buffers[0]);
// checkGlError("glDeleteBuffers");
// for (auto it : buffers) {
// it = 0;
// }
// return true;
// }
// public static boolean bindBuffer(int bufferId){
// glBindBuffer(GLARRAYBUFFER, bufferId);
// checkGlError("glBindBuffer");
// return true;
// }
// public static enum Usage {
// streamDraw,
// staticDraw,
// dynamicDraw
// }
// public static int convertUsage[] = {
// GL20.GL_STREAM_DRAW,
// GL20.GL_STATIC_DRAW,
// GL20.GL_DYNAMIC_DRAW
// };
// public static boolean bufferData(sizet size, void* data, Usage usage) {
// glBufferData(GLARRAYBUFFER, size, data, convertUsage[int(usage)]);
// checkGlError("glBufferData");
// return true;
// }
// public static boolean unbindBuffer() {
// glBindBuffer(GLARRAYBUFFER, 0);
// checkGlError("glBindBuffer(0)");
// return true;
// }
public static boolean genBuffers(int[] buffers) {
if (buffers.length == 0) {
Log.warning("try to generate vector buffer with size 0");
return true;
}
Log.info("Create N=" + buffers.length + " Buffer");
GL20.glGenBuffers(buffers);
checkGlError("glGenBuffers");
boolean hasError = false;
for (int iii=0; iii<buffers.length; iii++) {
if (buffers[iii] == 0) {
Log.error("[" + iii + "] error to create a buffer id=" + buffers[iii]);
hasError = true;
}
}
return hasError;
}
public static boolean deleteBuffers(int[] buffers) {
if (buffers.length == 0) {
Log.warning("try to delete vector buffer with size 0");
return true;
}
// TODO: Check if we are in the correct thread
GL20.glDeleteBuffers(buffers);
checkGlError("glDeleteBuffers");
for (int iii=0; iii<buffers.length; iii++) {
buffers[iii] = -1;
}
return true;
}
public static boolean bindBuffer(int bufferId){
GL20.glBindBuffer(GL20.GL_ARRAY_BUFFER, bufferId);
checkGlError("glBindBuffer");
return true;
}
private static FloatBuffer storeDataInFloatBuffer(float[] data) {
FloatBuffer buffer = BufferUtils.createFloatBuffer(data.length);
buffer.put(data);
buffer.flip();
return buffer;
}
public static boolean bufferData(float[] data, Usage usage) {
FloatBuffer buffer = storeDataInFloatBuffer(data);
GL15.glBufferData(GL15.GL_ARRAY_BUFFER, buffer, convertUsage.get(usage));
checkGlError("glBufferData");
return true;
}
public static boolean unbindBuffer() {
GL20.glBindBuffer(GL20.GL_ARRAY_BUFFER, 0);
checkGlError("glBindBuffer(0)");
return true;
}
public static void vertexAttribPointerFloat(int id, int size) {
GL20.glVertexAttribPointer(id, size, GL11.GL_FLOAT, false, 0, 0);
checkGlError("glVertexAttribPointer");
}
/* Shader wrapping : */
public static enum ShaderType {
vertex,
@ -793,10 +807,28 @@ public class OpenGL {
public static void programLoadUniformFloat(int location, float value) {
GL20.glUniform1f(location, value);
}
public static void programLoadUniformFloat(int location, float value, float value2) {
GL20.glUniform2f(location, value, value2);
}
public static void programLoadUniformFloat(int location, float value, float value2, float value3) {
GL20.glUniform3f(location, value, value2, value3);
}
public static void programLoadUniformFloat(int location, float value, float value2, float value3, float value4) {
GL20.glUniform4f(location, value, value2, value3, value4);
}
public static void programLoadUniformInt(int location, int value) {
GL20.glUniform1i(location, value);
}
public static void programLoadUniformInt(int location, int value, int value2) {
GL20.glUniform2i(location, value, value2);
}
public static void programLoadUniformInt(int location, int value, int value2, int value3) {
GL20.glUniform3i(location, value, value2, value3);
}
public static void programLoadUniformInt(int location, int value, int value2, int value3, int value4) {
GL20.glUniform4i(location, value, value2, value3, value4);
}
public static void programLoadUniformColor(int location, Color value) {
GL20.glUniform3f(location, value.r, value.g, value.b);
@ -805,10 +837,16 @@ public class OpenGL {
public static void programLoadUniformVector(int location, Vector3f value) {
GL20.glUniform3f(location, value.x, value.y, value.z);
}
public static void programLoadUniformVector(int location, Vector3i value) {
GL20.glUniform3i(location, value.x, value.y, value.z);
}
public static void programLoadUniformVector(int location, Vector2f value) {
GL20.glUniform2f(location, value.x, value.y);
}
public static void programLoadUniformVector(int location, Vector2i value) {
GL20.glUniform2i(location, value.x, value.y);
}
public static void programLoadUniformBoolean(int location, boolean value) {
//System.out.println("set value " + value + " " + (value==true?1.0f:0.0f));
@ -818,5 +856,8 @@ public class OpenGL {
public static void programLoadUniformMatrix(int location, Matrix4f value) {
GL20.glUniformMatrix4fv(location, true, value.getTable());
}
public static void programLoadUniformMatrix(int location, Matrix4f value, boolean transpose) {
GL20.glUniformMatrix4fv(location, transpose, value.getTable());
}
}

View File

@ -1,11 +1,63 @@
package org.atriaSoft.gale.context;
import org.atriaSoft.gale.Application;
import org.atriaSoft.gale.resource.ResourceManager;
import java.util.Vector;
public class Context {
protected Thread periodicThread;
private Application application; //!< Application handle
import org.atriaSoft.etk.ThreadAbstract;
import org.atriaSoft.etk.Uri;
import org.atriaSoft.etk.math.Vector2f;
import org.atriaSoft.gale.Application;
import org.atriaSoft.gale.Fps;
import org.atriaSoft.gale.Gale;
import org.atriaSoft.gale.Log;
import org.atriaSoft.gale.Orientation;
import org.atriaSoft.gale.backend3d.OpenGL;
import org.atriaSoft.gale.resource.ResourceManager;
import org.atriaSoft.gale.key.Keyboard;
import org.atriaSoft.gale.key.Special;
import org.atriaSoft.gale.key.Status;
import org.atriaSoft.gale.key.Type;
interface ActionToDoInAsyncLoop {
public void run(Context context);
}
class PeriodicThread extends ThreadAbstract {
private Context context;
public PeriodicThread(Context context) {
super("Galethread 2");
this.context = context;
}
@Override
protected void birth() {
// TODO Auto-generated method stub
}
@Override
protected void runPeriodic() {
try {
Thread.sleep(10);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
return;
}
// mutexInterface().lock();
context.processEvents();
// call all the application for periodic request (the application manage multiple instance )...
Application appl = context.getApplication();
if (appl != null) {
appl.onPeriod(System.currentTimeMillis());
}
// mutexInterface().unLock();
}
@Override
protected void death() {
// TODO Auto-generated method stub
}
};
public abstract class Context {
protected ThreadAbstract periodicThread;
protected Application application; //!< Application handle
public Application getApplication() {
return this.application;
}
@ -26,89 +78,61 @@ public class Context {
return globalContext;
}
public static void setContext(Context context) {
return globalContext = context;
globalContext = context;
}
public Context(Application _application, String[] args) {
protected void lockContext() {
}
protected void unLockContext() {
}
public Context(Application application, String[] args) {
// set a basic
//ethread::setName("galeThread");
this.application = application;
setContext(this);
Thread.currentThread().setName("galeThread");
if (this.application == null) {
Log.critical("Can not start context with no Application ==> rtfm ...");
}
commandLine.parse(args);
GALE_INFO(" == > Gale system init (BEGIN)");
Log.info(" == > Gale system init (BEGIN)");
// create thread to manage real periodic event
//this.periodicThread = ememory::makeShared<PeriodicThread>(this);
this.periodicThread = new PeriodicThread(this);
// By default we set 2 themes (1 color and 1 shape ...) :
//etk::theme::setNameDefault("GUI", "shape/square/");
//etk::theme::setNameDefault("COLOR", "color/black/");
//theme::setNameDefault("GUI", "shape/square/");
//theme::setNameDefault("COLOR", "color/black/");
// parse the debug level:
for(int iii=0; iii<this.commandLine.size(); ++iii) {
if (this.commandLine.get(iii) == "--gale-fps") {
this.displayFps=true;
} else if ( this.commandLine.get(iii) == "-h"
|| this.commandLine.get(iii) == "--help"
|| etk::start_with(this.commandLine.get(iii), "--gale") == true) {
Log.print("gale - help : ");
Log.print(" " << etk::getApplicationName() << " [options]");
Log.print(" --gale-simulation-file=XXX.gsim");
Log.print(" Enable the simulation mode of the gale IO, parameter: file (default:simulation gale.gsim)");
Log.print(" --gale-simulation-record");
Log.print(" Record the IO in the simulation file");
#ifdef GALE_SIMULATION_OPENGL_AVAILLABLE
Log.print(" --gale-disable-opengl");
Log.print(" Disable openGL access (availlable in SIMULATION mode)");
#endif
Log.print(" --gale-fps");
Log.print(" Display the current fps of the display");
#if defined(__TARGET_OS__Linux)
Log.print(" --gale-backend=XXX");
Log.print(" 'X11' For X11 backend (default)");
Log.print(" 'wayland' For wayland backend");
#ifdef GALE_BUILD_SIMULATION
Log.print(" 'simulation' For simulation backend");
#endif
Log.print(" can be set with environement variable 'export GALE_BACKEND=xxx'");
#endif
#if defined(__TARGET_OS__Windows)
Log.print(" --gale-backend=XXX");
Log.print(" 'windows' For windows backend (default)");
#ifdef GALE_BUILD_SIMULATION
Log.print(" 'simulation' For simulation backend");
#endif
Log.print(" can be set with environement variable 'export GALE_BACKEND=xxx'");
#endif
#if defined(__TARGET_OS__MacOs)
Log.print(" --gale-backend=XXX");
Log.print(" 'macos' For MacOs backend (default)");
#ifdef GALE_BUILD_SIMULATION
Log.print(" 'simulation' For simulation backend");
#endif
Log.print(" can be set with environement variable 'export GALE_BACKEND=xxx'");
#endif
Log.print(" -h/--help");
Log.print(" Display this help");
Log.print(" example:");
Log.print(" " << etk::getApplicationName() << " --gale-fps");
if (etk::start_with(this.commandLine.get(iii), "--gale") == true) {
Log.error("gale unknow element in parameter: '" << this.commandLine.get(iii) << "'");
// remove parameter ...
} else {
// this is a global help system does not remove it
continue;
}
} else {
continue;
}
this.commandLine.remove(iii);
--iii;
}
//etk::cout.setOutputFile(true);
// for(int iii=0; iii<this.commandLine.size(); ++iii) {
// if (this.commandLine.get(iii) == "--gale-fps") {
// this.displayFps=true;
// } else if ( this.commandLine.get(iii) == "-h"
// || this.commandLine.get(iii) == "--help"
// || start_with(this.commandLine.get(iii), "--gale") == true) {
// Log.print("gale - help : ");
// Log.print(" --gale-fps");
// Log.print(" Display the current fps of the display");
// Log.print(" -h/--help");
// Log.print(" Display this help");
// if (start_with(this.commandLine.get(iii), "--gale") == true) {
// Log.error("gale unknow element in parameter: '" << this.commandLine.get(iii) << "'");
// // remove parameter ...
// } else {
// // this is a global help system does not remove it
// continue;
// }
// } else {
// continue;
// }
// this.commandLine.remove(iii);
// --iii;
// }
//cout.setOutputFile(true);
GALE_INFO("GALE v:" << gale::getVersion());
forceOrientation(gale::orientation::screenAuto);
this.msgSystem.post([](gale::Context _context){
Log.info("GALE v:" + Gale.getVersion());
forceOrientation(Orientation.screenAuto);
postAction((_context)->{
Application appl = _context.getApplication();
if (appl == null) {
return;
@ -121,63 +145,80 @@ public class Context {
// force a recalculation
requestUpdateSize();
// release the curent interface :
unLockContext();
GALE_INFO(" == > Gale system init (END)");
Log.info(" == > Gale system init (END)");
}
/**
* @brief StartProcessing (2nd thread).
* @note to call when all the Context is started
*/
public void start2ndThreadProcessing() {
// set the curent interface:
// set the current interface:
lockContext();
this.periodicThread.start();
ethread::sleepMilliSeconds((1));
// release the curent interface:
this.periodicThread.threadStart();
try {
Thread.sleep(1);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
// release the current interface:
unLockContext();
}
// simulation area:
protected boolean this.simulationActive;
protected etk::Uri this.simulationUri;
protected etk::io::Interface> this.simulationFile;
private echrono::Steady this.previousDisplayTime; // this is to limit framerate ... in case...
private etk::Fifo<etk::Function<void(gale::Context _context)> > this.msgSystem;
private boolean this.displayFps;
private gale::context::Fps this.FpsSystemEvent;
private gale::context::Fps this.FpsSystemContext;
private gale::context::Fps this.FpsSystem;
private gale::context::Fps this.FpsFlush;
private long previousDisplayTime; // this is to limit framerate ... in case...
private Vector<ActionToDoInAsyncLoop> msgSystem = new Vector<ActionToDoInAsyncLoop>();
private boolean displayFps = false;
private Fps FpsSystemEvent = new Fps("SystemEvent", displayFps);
private Fps FpsSystemContext = new Fps("SystemContext", displayFps);
private Fps FpsSystem = new Fps("System", displayFps);
private Fps FpsFlush = new Fps("Flush", displayFps);
private synchronized void postAction(ActionToDoInAsyncLoop data) {
msgSystem.addElement(data);
notify();
//Later, when the necessary event happens, the thread that is running it calls notify() from a block synchronized on the same object.
}
// Called by Consumer
public synchronized ActionToDoInAsyncLoop getAction() {
notify();
while (msgSystem.size() == 0) {
try {
wait();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
return null;
}//By executing wait() from a synchronized block, a thread gives up its hold on the lock and goes to sleep.
}
ActionToDoInAsyncLoop message = (ActionToDoInAsyncLoop) msgSystem.firstElement();
msgSystem.removeElement(message);
return message;
}
/**
* @brief Processing all the event arrived ... (commoly called in draw function)
*/
public void processEvents() {
int nbEvent = 0;
//Log.debug(" ******** Event " << this.msgSystem.count());
while (this.msgSystem.count() > 0) {
while (this.msgSystem.size() > 0) {
nbEvent++;
//Log.verbose(" [" << nbEvent << "] event ...");
etk::Function<void(gale::Context _context)> func;
{
ethread::RecursiveLock lock(this.mutex);
this.msgSystem.wait(func);
}
ActionToDoInAsyncLoop func = getAction();
if (func == null) {
continue;
}
func(*this);
func.run(this);
}
}
public void postAction(etk::Function<void(gale::Context _context)> _action) {
ethread::RecursiveLock lock(this.mutex);
this.msgSystem.post(_action);
}
// gale::Context::~Context() {
// GALE_INFO(" == > Gale system Un-Init (BEGIN)");
// this.periodicThread.stop();
// Log.info(" == > Gale system Un-Init (BEGIN)");
// this.periodicThread.threadStart();
// getResourcesManager().applicationExiting();
// // TODO : Clean the message list ...
// // set the curent interface:
// // set the current interface:
// lockContext();
// // clean all widget and sub widget with their resources:
// //this.objectManager.cleanInternalRemoved();
@ -193,116 +234,94 @@ public class Context {
// //this.objectManager.cleanInternalRemoved();
// this.resourceManager.cleanInternalRemoved();
//
// GALE_INFO("List of all widget of this context must be equal at 0 ==> otherwise some remove is missing");
// Log.info("List of all widget of this context must be equal at 0 ==> otherwise some remove is missing");
// //this.objectManager.displayListObject();
// // Resource is an lower element as objects ...
// this.resourceManager.unInit();
// // now All must be removed !!!
// //this.objectManager.unInit();
// // release the curent interface :
// // release the current interface :
// unLockContext();
// GALE_INFO(" == > Gale system Un-Init (END)");
// Log.info(" == > Gale system Un-Init (END)");
// if (this.simulationActive == true) {
// // in simulation case:
// this.simulationFile.close();
// }
// }
public void OS_SetInput( gale::key::type _type,
gale::key::status _status,
int _pointerID,
vec2 _pos){
if (this.simulationActive == true) {
this.simulationFile.puts(etk::toString(echrono::Steady::now()));
this.simulationFile.puts(":INPUT:");
this.simulationFile.puts(etk::toString(_type));
this.simulationFile.puts(":");
this.simulationFile.puts(etk::toString(_status));
this.simulationFile.puts(":");
this.simulationFile.puts(etk::toString(_pointerID));
this.simulationFile.puts(":");
this.simulationFile.puts(etk::toString(_pos));
this.simulationFile.puts("\n");
}
ethread::RecursiveLock lock(this.mutex);
this.msgSystem.post([_type, _status, _pointerID, _pos](gale::Context _context){
Application> appl = _context.getApplication();
public void OS_SetInput( Type type,
Status status,
int pointerID,
Vector2f pos){
postAction((context)->{
Application appl = context.getApplication();
if (appl == null) {
return;
}
appl.onPointer(_type,
_pointerID,
_pos,
_status);
appl.onPointer(type,
pointerID,
pos,
status);
});
}
public void OS_setKeyboard( gale::key::Special _special,
gale::key::keyboard _type,
gale::key::status _state,
boolean _isARepeateKey = false,
char32_t _char = u32char::Null){
if (_isARepeateKey == true) {
if (_state == gale::key::status::down) {
_state = gale::key::status::downRepeate;
public void OS_setKeyboard( Special special,
Keyboard type,
Status state,
boolean isARepeateKey,
Character charValue) {
Status tmpState = state;
if (isARepeateKey == true) {
if (tmpState == Status.down) {
tmpState = Status.downRepeate;
} else {
_state = gale::key::status::upRepeate;
tmpState = Status.upRepeate;
}
}
if (this.simulationActive == true) {
this.simulationFile.puts(etk::toString(echrono::Steady::now()));
this.simulationFile.puts(":KEYBOARD:");
this.simulationFile.puts(etk::toString(_special));
this.simulationFile.puts(":");
this.simulationFile.puts(etk::toString(_type));
this.simulationFile.puts(":");
this.simulationFile.puts(etk::toString(_state));
this.simulationFile.puts(":");
this.simulationFile.puts(etk::toString(uint64_t(_char)));
this.simulationFile.puts("\n");
}
ethread::RecursiveLock lock(this.mutex);
this.msgSystem.post([_special, _type, _state, _char](gale::Context _context){
Application> appl = _context.getApplication();
OS_setKeyboard2(special, type, state, charValue);
}
public void OS_setKeyboard2( Special special,
Keyboard type,
Status state,
Character charValue){
postAction((context)->{
Application appl = context.getApplication();
if (appl == null) {
return;
}
appl.onKeyboard(_special,
_type,
_char,
_state);
appl.onKeyboard(special,
type,
charValue,
state);
});
}
/**
* @brief The current context is suspended
*/
public void OS_Suspend(){
// set the curent interface :
// set the current interface :
lockContext();
GALE_INFO("OS_Suspend...");
this.previousDisplayTime = echrono::Steady();
#if 0
if (this.windowsCurrent != null) {
this.windowsCurrent.onStateSuspend();
}
#endif
// release the curent interface :
Log.info("OS_Suspend...");
this.previousDisplayTime = 0;
// if (this.windowsCurrent != null) {
// this.windowsCurrent.onStateSuspend();
// }
// release the current interface :
unLockContext();
}
/**
* @brief The current context is resumed
*/
public void OS_Resume(){
// set the curent interface :
// set the current interface :
lockContext();
GALE_INFO("OS_Resume...");
this.previousDisplayTime = echrono::Steady::now();
Log.info("OS_Resume...");
this.previousDisplayTime = System.currentTimeMillis();
// TODO : this.objectManager.timeCallResume(this.previousDisplayTime);
#if 0
if (this.windowsCurrent != null) {
this.windowsCurrent.onStateResume();
}
#endif
// release the curent interface :
// if (this.windowsCurrent != null) {
// this.windowsCurrent.onStateResume();
// }
// release the current interface :
unLockContext();
}
@ -310,75 +329,58 @@ public class Context {
* @brief The current context is set in foreground (framerate is maximum speed)
*/
public void OS_Foreground(){
// set the curent interface :
// set the current interface :
lockContext();
GALE_INFO("OS_Foreground...");
#if 0
if (this.windowsCurrent != null) {
this.windowsCurrent.onStateForeground();
}
#endif
// release the curent interface :
Log.info("OS_Foreground...");
// if (this.windowsCurrent != null) {
// this.windowsCurrent.onStateForeground();
// }
// release the current interface :
unLockContext();
}
/**
* @brief The current context is set in background (framerate is slowing down (max fps)/5 # 4fps)
*/
public void OS_Background(){
// set the curent interface :
// set the current interface :
lockContext();
GALE_INFO("OS_Background...");
#if 0
if (this.windowsCurrent != null) {
this.windowsCurrent.onStateBackground();
}
#endif
// release the curent interface :
Log.info("OS_Background...");
// if (this.windowsCurrent != null) {
// this.windowsCurrent.onStateBackground();
// }
// release the current interface :
unLockContext();
}
public void requestUpdateSize() {
if (this.simulationActive == true) {
this.simulationFile.puts(etk::toString(echrono::Steady::now()));
this.simulationFile.puts(":RECALCULATE_SIZE\n");
}
ethread::RecursiveLock lock(this.mutex);
this.msgSystem.post([](gale::Context _context){
postAction((context)->{
//Log.debug("Receive MSG : THREAD_RESIZE");
_context.forceRedrawAll();
context.forceRedrawAll();
});
}
// return true if a flush is needed
public boolean OS_Draw(boolean _displayEveryTime){
if (this.simulationActive == true) {
this.simulationFile.puts(etk::toString(echrono::Steady::now()));
this.simulationFile.puts(":DRAW:");
this.simulationFile.puts(etk::toString(_displayEveryTime));
this.simulationFile.puts("\n");
}
{
static int countMemeCheck = 0;
if (countMemeCheck++ >= 10*16) {
countMemeCheck = 0;
ETK_MEM_SHOW_LOG(true);
}
private static int countMemeCheck = 0;
public boolean OS_Draw(boolean displayEveryTime) {
if (countMemeCheck++ >= 10*16) {
countMemeCheck = 0;
}
//Log.verbose("Call draw");
echrono::Steady currentTime = echrono::Steady::now();
long currentTime = System.currentTimeMillis();
//echrono::Time currentTime2 = echrono::Time::now();
//Log.warning("Time = " << currentTime << " " << currentTime2);
// TODO : Review this ...
// this is to prevent the multiple display at the a high frequency ...
#if ( !defined(__TARGET_OS__Windows) \
& !defined(__TARGET_OS__Android))
if(currentTime - this.previousDisplayTime < echrono::milliseconds(8)) {
ethread::sleepMilliSeconds((1));
return false;
if(currentTime - this.previousDisplayTime < 8) {
try {
Thread.sleep(1);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
#endif
return false;
}
this.previousDisplayTime = currentTime;
gale::openGL::threadHasContext();
OpenGL.threadHasContext();
// process the events
if (this.displayFps == true) {
this.FpsSystemEvent.tic();
@ -401,26 +403,26 @@ public class Context {
if (this.application != null) {
// Redraw all needed elements
//Log.debug("Regenerate Display");
this.application.onRegenerateDisplay(*this);
this.application.onRegenerateDisplay(this);
needRedraw = this.application.isDrawingNeeded();
}
if (this.displayFps == true) {
this.FpsSystemEvent.incrementCounter();
this.FpsSystemEvent.toc();
}
// release the curent interface :
// release the current interface :
unLockContext();
}
boolean hasDisplayDone = false;
//! drawing section:
{
// Lock openGl context:
gale::openGL::lock();
OpenGL.lock();
if (this.displayFps == true) {
this.FpsSystemContext.tic();
}
if( needRedraw == true
|| _displayEveryTime == true) {
|| displayEveryTime == true) {
//Log.debug(" ==> real Draw");
lockContext();
this.resourceManager.updateContext();
@ -435,12 +437,12 @@ public class Context {
}
if (this.application != null) {
if( needRedraw == true
|| _displayEveryTime == true) {
|| displayEveryTime == true) {
this.FpsSystem.incrementCounter();
// set the curent interface :
// set the current interface :
lockContext();
if (this.application.canDraw == true) {
this.application.onDraw(*this);
this.application.onDraw(this);
}
unLockContext();
hasDisplayDone = true;
@ -451,17 +453,17 @@ public class Context {
this.FpsFlush.tic();
}
if (hasDisplayDone == true) {
//GALE_INFO("lklklklklk " << _displayEveryTime);
//Log.info("lklklklklk " << _displayEveryTime);
if (this.displayFps == true) {
this.FpsFlush.incrementCounter();
}
gale::openGL::flush();
OpenGL.flush();
}
if (this.displayFps == true) {
this.FpsFlush.toc();
}
// release open GL Context
gale::openGL::unLock();
OpenGL.unLock();
}
if (this.displayFps == true) {
this.FpsSystemEvent.draw();
@ -470,20 +472,20 @@ public class Context {
this.FpsFlush.draw();
}
{
// set the curent interface:
// set the current interface:
lockContext();
// release open GL Context
gale::openGL::lock();
OpenGL.lock();
// while The Gui is drawing in OpenGl, we do some not realTime things
this.resourceManager.updateContext();
// release open GL Context
gale::openGL::unLock();
OpenGL.unLock();
// TODO : this.objectManager.cleanInternalRemoved();
this.resourceManager.cleanInternalRemoved();
// release the curent interface:
// release the current interface:
unLockContext();
}
gale::openGL::threadHasNoMoreContext();
OpenGL.threadHasNoMoreContext();
return hasDisplayDone;
}
/**
@ -502,114 +504,101 @@ public class Context {
* @brief The OS Inform that the Window has been killed
*/
public void OS_Stop(){
// set the curent interface :
// set the current interface :
lockContext();
GALE_INFO("OS_Stop...");
Log.info("OS_Stop...");
if (this.application == null) {
stop();
return;
}
this.application.onKillDemand(*this);
// release the curent interface :
this.application.onKillDemand(this);
// release the current interface :
unLockContext();
}
/**
* @brief The application request that the Window will be killed
*/
public void stop() {
Log.warning("stop: NOT implemented for this platform...");
}
protected ivec2 this.windowsSize; //!< current size of the system
protected Vector2f windowsSize; //!< current size of the system
/**
* @brief get the current windows size
* @return the current size ...
*/
public ivec2 getSize() {
public Vector2f getSize() {
return this.windowsSize;
};
/**
* @brief The OS inform that the current windows has change his size.
* @param[in] _size new size of the windows.
*/
public void OS_Resize( vec2 _size){
public void OS_Resize( Vector2f _size){
if (this.windowsSize == _size) {
return;
}
// TODO : Better in the thread ... ==> but generate some init error ...
gale::Dimension::setPixelWindowsSize(_size);
if (this.simulationActive == true) {
this.simulationFile.puts(etk::toString(echrono::Steady::now()));
this.simulationFile.puts(":RESIZE:");
this.simulationFile.puts(etk::toString(_size));
this.simulationFile.puts("\n");
}
ethread::RecursiveLock lock(this.mutex);
this.msgSystem.post([_size](gale::Context _context){
Log.debug("Receive MSG : THREAD_RESIZE : " << _context.windowsSize << " ==> " << _size);
_context.windowsSize = _size;
gale::Dimension::setPixelWindowsSize(_context.windowsSize);
//gale::Dimension::setPixelWindowsSize(_size);
postAction((context) -> {
Log.debug("Receive MSG : THREAD_RESIZE : " + context.windowsSize + " ==> " + _size);
context.windowsSize = _size;
//gale::Dimension::setPixelWindowsSize(_context.windowsSize);
// call application inside ..
_context.forceRedrawAll();
context.forceRedrawAll();
});
}
/**
* @brief The application request a change of his curent size.
* @brief The application request a change of his current size.
* @param[in] _size new Requested size of the windows.
*/
public void setSize( vec2 _size){
GALE_INFO("setSize: NOT implemented ...");
public void setSize( Vector2f _size){
Log.info("setSize: NOT implemented ...");
};
/**
* @brief The application request a change of his current size force the fullscreen mode.
* @param[in] _status status of the fullscreen mode.
*/
public void setFullScreen(boolean _status){
GALE_INFO("setFullScreen: NOT implemented ...");
Log.info("setFullScreen: NOT implemented ...");
};
protected ivec2 this.windowsPos; //!< current size of the system
protected Vector2f windowsPos; //!< current size of the system
/**
* @brief The OS inform that the current windows has change his position.
* @param[in] _pos New position of the Windows.
*/
public void OS_Move( vec2 _pos){
if (this.windowsPos == _pos) {
public void OS_Move( Vector2f _pos){
if (this.windowsPos.isEqual(_pos)) {
return;
}
ethread::RecursiveLock lock(this.mutex);
this.msgSystem.post([_pos](gale::Context _context){
Log.debug("Receive MSG : THREAD_MOVE : " << _context.windowsPos << " ==> " << _pos);
_context.windowsPos = _pos;
Application> appl = _context.getApplication();
postAction((context) -> {
Log.debug("Receive MSG : THREAD_MOVE : " + context.windowsPos + " ==> " + _pos);
context.windowsPos = _pos;
Application appl = context.getApplication();
if (appl == null) {
return;
}
appl.onMovePosition(_context.windowsPos);
appl.onMovePosition(context.windowsPos);
});
}
/**
* @brief The Application request that the current windows will change his position.
* @param[in] _pos New position of the Windows requested.
*/
public void setPos( vec2 _pos){
GALE_INFO("setPos: NOT implemented ...");
public void setPos( Vector2f _pos){
Log.info("setPos: NOT implemented ...");
}
/**
* @brief The Application request the current position of the windows.
* @return Turrent position of the Windows.
*/
public vec2 getPos(){
public Vector2f getPos(){
return this.windowsPos;
}
/**
* @brief The OS inform that the Windows is now Hidden.
*/
public void OS_Hide() {
if (this.simulationActive == true) {
this.simulationFile.puts(etk::toString(echrono::Steady::now()));
this.simulationFile.puts(":VIEW:false\n");
}
ethread::RecursiveLock lock(this.mutex);
this.msgSystem.post([](gale::Context _context){
postAction((context) -> {
/*
Application> appl = _context.getApplication();
if (appl == null) {
@ -620,24 +609,20 @@ public class Context {
_char,
_state);
*/
GALE_TODO("HIDE ... ");
Log.todo("HIDE ... ");
});
}
/**
* @brief The Application request that the Windows will be Hidden.
*/
public void hide(){
GALE_INFO("hide: NOT implemented ...");
Log.info("hide: NOT implemented ...");
};
/**
* @brief The OS inform that the Windows is now visible.
*/
public void OS_Show(){
if (this.simulationActive == true) {
this.simulationFile.puts(etk::toString(echrono::Steady::now()));
this.simulationFile.puts(":VIEW:true\n");
}
this.msgSystem.post([](gale::Context _context){
postAction((context) -> {
/*
Application> appl = _context.getApplication();
if (appl == null) {
@ -648,14 +633,14 @@ public class Context {
_char,
_state);
*/
GALE_TODO("SHOW ... ");
Log.todo("SHOW ... ");
});
}
/**
* @brief The Application request that the Windows will be visible.
*/
public void show(){
GALE_INFO("show: NOT implemented ...");
Log.info("show: NOT implemented ...");
}
/**
* @brief Redraw all the windows
@ -670,20 +655,20 @@ public class Context {
* @brief display the virtal keyboard (for touch system only)
*/
public void keyboardShow(){
GALE_INFO("keyboardShow: NOT implemented ...");
Log.info("keyboardShow: NOT implemented ...");
}
/**
* @brief Hide the virtal keyboard (for touch system only)
*/
public void keyboardHide(){
GALE_INFO("keyboardHide: NOT implemented ...");
Log.info("keyboardHide: NOT implemented ...");
}
/**
* @brief Inform the Gui that we want to have a copy of the clipboard
* @param[in] _clipboardID ID of the clipboard (STD/SELECTION) only apear here
*/
public void clipBoardGet( gale::context::clipBoard::clipboardListe _clipboardID){
public void clipBoardGet( ClipboardList _clipboardID){
// just transmit an event , we have the data in the system
OS_ClipBoardArrive(_clipboardID);
}
@ -691,17 +676,16 @@ public class Context {
* @brief Inform the Gui that we are the new owner of the clipboard
* @param[in] _clipboardID ID of the clipboard (STD/SELECTION) only apear here
*/
public void clipBoardSet( gale::context::clipBoard::clipboardListe _clipboardID){
public void clipBoardSet( ClipboardList _clipboardID){
// nothing to do, data is already copyed in the GALE clipborad center
}
/**
* @brief Call by the OS when a clipboard arrive to US (previously requested by a widget)
* @param[in] Id of the clipboard
*/
public void OS_ClipBoardArrive( gale::context::clipBoard::clipboardListe _clipboardID) {
ethread::RecursiveLock lock(this.mutex);
this.msgSystem.post([_clipboardID](gale::Context _context){
Application appl = _context.getApplication();
public void OS_ClipBoardArrive( ClipboardList _clipboardID) {
postAction((context) -> {
Application appl = context.getApplication();
if (appl != null) {
appl.onClipboardEvent(_clipboardID);
}
@ -712,7 +696,7 @@ public class Context {
* @param[in] title New desired title
*/
public void setTitle( String _title){
GALE_INFO("setTitle: NOT implemented ...");
Log.info("setTitle: NOT implemented ...");
}
/**
* @brief Open an URL on an eternal brother.
@ -723,7 +707,7 @@ public class Context {
* @brief force the screen orientation (availlable on portable elements ...
* @param[in] _orientation Selected orientation.
*/
public void forceOrientation( gale::orientation _orientation) { };
public void forceOrientation(Orientation _orientation) { };
/**
* @brief get all Keyboard event from the X system (like many time use of META)
* @param[in] _status "true" if all the event will be get, false if we want only ours.
@ -734,7 +718,7 @@ public class Context {
* @param[in] _status "true" if all the event will be get, false if we want only ours.
* @param[in] _forcedPosition the position where the mouse might be reset at every events ...
*/
public void grabPointerEvents(boolean _status, vec2 _forcedPosition) { };
public void grabPointerEvents(boolean _status, Vector2f _forcedPosition) { };
/**
* @brief set the cursor display type.
* @param[in] _newCursor selected new cursor.
@ -742,9 +726,9 @@ public class Context {
public void setCursor( Cursor _newCursor) { };
/**
* @brief set the Icon of the program
* @param[in] _inputFile new filename icon of the curent program.
* @param[in] _inputFile new filename icon of the current program.
*/
public void setIcon(etk::Uri _inputFile) { };
public void setIcon(Uri _inputFile) { };
/**
* @brief Enable or Disable the decoration on the Windows (availlable only on Desktop)
* @param[in] _status "true" to enable decoration / false otherwise

View File

@ -0,0 +1,388 @@
package org.atriaSoft.gale.context.LWJGL;
import static org.lwjgl.glfw.Callbacks.glfwFreeCallbacks;
import static org.lwjgl.glfw.GLFW.GLFW_FALSE;
import static org.lwjgl.glfw.GLFW.GLFW_KEY_A;
import static org.lwjgl.glfw.GLFW.GLFW_KEY_D;
import static org.lwjgl.glfw.GLFW.GLFW_KEY_ESCAPE;
import static org.lwjgl.glfw.GLFW.GLFW_KEY_Q;
import static org.lwjgl.glfw.GLFW.GLFW_KEY_S;
import static org.lwjgl.glfw.GLFW.GLFW_KEY_SPACE;
import static org.lwjgl.glfw.GLFW.GLFW_KEY_W;
import static org.lwjgl.glfw.GLFW.GLFW_KEY_Z;
import static org.lwjgl.glfw.GLFW.GLFW_MOUSE_BUTTON_LEFT;
import static org.lwjgl.glfw.GLFW.GLFW_MOUSE_BUTTON_RIGHT;
import static org.lwjgl.glfw.GLFW.GLFW_PRESS;
import static org.lwjgl.glfw.GLFW.GLFW_RELEASE;
import static org.lwjgl.glfw.GLFW.GLFW_RESIZABLE;
import static org.lwjgl.glfw.GLFW.GLFW_TRUE;
import static org.lwjgl.glfw.GLFW.GLFW_VISIBLE;
import static org.lwjgl.glfw.GLFW.glfwCreateWindow;
import static org.lwjgl.glfw.GLFW.glfwDefaultWindowHints;
import static org.lwjgl.glfw.GLFW.glfwDestroyWindow;
import static org.lwjgl.glfw.GLFW.glfwGetPrimaryMonitor;
import static org.lwjgl.glfw.GLFW.glfwGetVideoMode;
import static org.lwjgl.glfw.GLFW.glfwGetWindowSize;
import static org.lwjgl.glfw.GLFW.glfwInit;
import static org.lwjgl.glfw.GLFW.glfwMakeContextCurrent;
import static org.lwjgl.glfw.GLFW.glfwPollEvents;
import static org.lwjgl.glfw.GLFW.glfwSetCursorPosCallback;
import static org.lwjgl.glfw.GLFW.glfwSetErrorCallback;
import static org.lwjgl.glfw.GLFW.glfwSetKeyCallback;
import static org.lwjgl.glfw.GLFW.glfwSetMouseButtonCallback;
import static org.lwjgl.glfw.GLFW.glfwSetScrollCallback;
import static org.lwjgl.glfw.GLFW.glfwSetWindowPos;
import static org.lwjgl.glfw.GLFW.glfwSetWindowShouldClose;
import static org.lwjgl.glfw.GLFW.glfwShowWindow;
import static org.lwjgl.glfw.GLFW.glfwSwapBuffers;
import static org.lwjgl.glfw.GLFW.glfwSwapInterval;
import static org.lwjgl.glfw.GLFW.glfwTerminate;
import static org.lwjgl.glfw.GLFW.glfwWindowHint;
import static org.lwjgl.glfw.GLFW.glfwWindowShouldClose;
import static org.lwjgl.opengl.GL11.GL_COLOR_BUFFER_BIT;
import static org.lwjgl.opengl.GL11.GL_DEPTH_BUFFER_BIT;
import static org.lwjgl.opengl.GL11.glClear;
import static org.lwjgl.opengl.GL11.glClearColor;
import static org.lwjgl.opengl.GL11.glViewport;
import static org.lwjgl.system.MemoryStack.stackPush;
import static org.lwjgl.system.MemoryUtil.NULL;
import java.nio.IntBuffer;
import org.atriaSoft.etk.math.Vector2f;
import org.atriaSoft.gale.Application;
import org.atriaSoft.gale.Fps;
import org.atriaSoft.gale.context.Context;
import org.atriaSoft.gale.key.Special;
import org.lwjgl.Version;
import org.lwjgl.glfw.GLFWErrorCallback;
import org.lwjgl.glfw.GLFWVidMode;
import org.lwjgl.opengl.GL;
import org.lwjgl.system.MemoryStack;
import renderEngine.DisplayManagerDraw;
public class ContextLWJGL extends Context {
private static final int WIDTH = 800;
private static final int HEIGHT = 600;
private static final String TITLE = "Gale basic UI";
private static long lastFrameTime;
private static float delta;
private Fps fps = new Fps("Main Loop", true);
private DisplayManagerDraw drawer = null;
private static double whellOffsetY;
private static double whellOffsetX;
private static boolean rightButtonStateDown = false;
private static boolean leftButtonStateDown = false;
private static double lastMousePositionX = 0;
private static double lastMousePositionY = 0;
private static double currentMousePositionX = 0;
private static double currentMousePositionY = 0;
// The window handle
private long window = 0;
private Special guiKeyBoardMode = new Special();
public ContextLWJGL(Application application, String[] args) {
super(application, args);
System.out.println("Hello LWJGL " + Version.getVersion() + "!");
initWindows();
// This line is critical for LWJGL's interoperation with GLFW's
// OpenGL context, or any context that is managed externally.
// LWJGL detects the context that is current in the current thread,
// creates the GLCapabilities instance and makes the OpenGL
// bindings available for use.
GL.createCapabilities();
// Set the clear color
glClearColor(0.0f, 1.0f, 0.0f, 0.0f);
glViewport(0, 0, (int)application.getSize().x, (int)application.getSize().y);
start2ndThreadProcessing();
}
public void setDrawer(DisplayManagerDraw drawer) {
this.drawer = drawer;
}
// public static Vector2f getSize() {
// return new Vector2f(WIDTH, HEIGHT);
// }
public void unInit() {
// Free the window callbacks and destroy the window
glfwFreeCallbacks(window);
glfwDestroyWindow(window);
// Terminate GLFW and free the error callback
glfwTerminate();
glfwSetErrorCallback(null).free();
}
private static boolean valueS = false;
private static boolean valueZ = false;
private static boolean valueQ = false;
private static boolean valueD = false;
private static boolean valueA = false;
private static boolean valueW = false;
private static boolean valueSPACE = false;
public static boolean isKeyDown(char value) {
if (value == 's') {
return valueS;
}
if (value == 'z') {
return valueZ;
}
if (value == 'q') {
return valueQ;
}
if (value == 'd') {
return valueD;
}
if (value == 'w') {
return valueW;
}
if (value == 'a') {
return valueA;
}
if (value == ' ') {
return valueSPACE;
}
return false;
}
private void initWindows() {
// Setup an error callback. The default implementation
// will print the error message in System.err.
GLFWErrorCallback.createPrint(System.err).set();
// Initialize GLFW. Most GLFW functions will not work before doing this.
if ( !glfwInit() ) {
throw new IllegalStateException("Unable to initialize GLFW");
}
// Configure GLFW
glfwDefaultWindowHints(); // optional, the current window hints are already the default
glfwWindowHint(GLFW_VISIBLE, GLFW_FALSE); // the window will stay hidden after creation
glfwWindowHint(GLFW_RESIZABLE, GLFW_TRUE); // the window will be resizable
// Create the window
window = glfwCreateWindow((int)application.getSize().x, (int)application.getSize().y, application.getTitle(), NULL, NULL);
if ( window == 0 ) {
throw new RuntimeException("Failed to create the GLFW window");
}
// Setup a key callback. It will be called every time a key is pressed, repeated or released.
// https://www.glfw.org/docs/latest/input_guide.html
glfwSetKeyCallback(window, (window, key, scancode, action, mods) -> {
if ( key == GLFW_KEY_ESCAPE && action == GLFW_RELEASE ) {
glfwSetWindowShouldClose(window, true); // We will detect this in the rendering loop
}
if ( key == GLFW_KEY_Z ) {
if (action == GLFW_PRESS ) {
System.out.println("Key Z is pressed");
valueZ = true;
} else if (action == GLFW_RELEASE ) {
System.out.println("Key Z is release");
valueZ = false;
}
}
if ( key == GLFW_KEY_S ) {
if (action == GLFW_PRESS ) {
System.out.println("Key S is pressed");
valueS = true;
} else if (action == GLFW_RELEASE ) {
System.out.println("Key S is release");
valueS = false;
}
}
if ( key == GLFW_KEY_Q ) {
if (action == GLFW_PRESS ) {
System.out.println("Key Q is pressed");
valueQ = true;
} else if (action == GLFW_RELEASE ) {
System.out.println("Key Q is release");
valueQ = false;
}
}
if ( key == GLFW_KEY_D ) {
if (action == GLFW_PRESS ) {
System.out.println("Key D is pressed");
valueD = true;
} else if (action == GLFW_RELEASE ) {
System.out.println("Key D is release");
valueD = false;
}
}
if ( key == GLFW_KEY_A ) {
if (action == GLFW_PRESS ) {
System.out.println("Key A is pressed");
valueA = true;
} else if (action == GLFW_RELEASE ) {
System.out.println("Key A is release");
valueA = false;
}
}
if ( key == GLFW_KEY_W ) {
if (action == GLFW_PRESS ) {
System.out.println("Key W is pressed");
valueW = true;
} else if (action == GLFW_RELEASE ) {
System.out.println("Key W is release");
valueW = false;
}
}
if ( key == GLFW_KEY_SPACE ) {
if (action == GLFW_PRESS ) {
System.out.println("Key SPACE is pressed");
valueSPACE = true;
} else if (action == GLFW_RELEASE ) {
System.out.println("Key SPACE is release");
valueSPACE = false;
}
}
});
glfwSetCursorPosCallback(window, (window, xpos, ypos) -> {
currentMousePositionX = xpos;
currentMousePositionY = ypos;
});
glfwSetMouseButtonCallback(window, (window, button, action, mods) -> {
if (button == GLFW_MOUSE_BUTTON_RIGHT) {
if (action == GLFW_PRESS) {
rightButtonStateDown = true;
} else if (action == GLFW_RELEASE) {
rightButtonStateDown = false;
}
} else if (button == GLFW_MOUSE_BUTTON_LEFT) {
if (action == GLFW_PRESS) {
leftButtonStateDown = true;
} else if (action == GLFW_RELEASE) {
leftButtonStateDown = false;
}
}
});
glfwSetScrollCallback(window, (window, xoffset, yoffset) -> {
whellOffsetY += yoffset;
whellOffsetX += xoffset;
});
// Get the thread stack and push a new frame
try ( MemoryStack stack = stackPush() ) {
IntBuffer pWidth = stack.mallocInt(1); // int*
IntBuffer pHeight = stack.mallocInt(1); // int*
// Get the window size passed to glfwCreateWindow
glfwGetWindowSize(window, pWidth, pHeight);
// Get the resolution of the primary monitor
GLFWVidMode vidmode = glfwGetVideoMode(glfwGetPrimaryMonitor());
// Center the window
glfwSetWindowPos(
window,
(vidmode.width() - pWidth.get(0)) / 2,
(vidmode.height() - pHeight.get(0)) / 2
);
} // the stack frame is popped automatically
// Make the OpenGL context current
glfwMakeContextCurrent(window);
// Enable v-sync
glfwSwapInterval(1);
// Make the window visible
glfwShowWindow(window);
lastFrameTime = getCurrentTime();
}
public static float getFrameTimeSecconds() {
return delta;
}
private static long getCurrentTime() {
return System.currentTimeMillis();
}
public static boolean isButtonRightDown() {
return rightButtonStateDown;
}
public static boolean isButtonLeftDown() {
return leftButtonStateDown;
}
public static float getDX() {
return (float) (currentMousePositionX-lastMousePositionX);
}
public static float getDY() {
return (float) (currentMousePositionY-lastMousePositionY);
}
public static float getDWheel() {
// TODO Auto-generated method stub
return (float) whellOffsetY;
}
@Override
public int run() {
// Run the rendering loop until the user has attempted to close
// the window or has pressed the ESCAPE key.
while ( !glfwWindowShouldClose(window) ) {
/*
fps.tic();
long currentFrameTime = getCurrentTime();
delta = (currentFrameTime-lastFrameTime)/1000f;
lastFrameTime = currentFrameTime;
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); // clear the framebuffer
if (this.drawer != null) {
fps.incrementCounter();
this.drawer.draw();
}
lastMousePositionX = currentMousePositionX;
lastMousePositionY = currentMousePositionY;
whellOffsetY = 0;
whellOffsetY = 0;
glfwSwapBuffers(window); // swap the color buffers
// Poll for window events. The key callback above will only be
// invoked during this call.
glfwPollEvents();
fps.toc();
fps.draw();
*/
OS_Draw(true);
glfwSwapBuffers(window); // swap the color buffers
glfwPollEvents();
/*
if (specialEventThatNeedARedraw == true) {
X11_INFO("specialEventThatNeedARedraw = " << specialEventThatNeedARedraw);
}
hasDisplay = OS_Draw(specialEventThatNeedARedraw);
if (hasDisplay == true) {
// need to request it every time needed to have a redrawing (this can take some time if the application filter the drfaw periodicity)
specialEventThatNeedARedraw = false;
}
*/
}
System.exit(0);
return 0;
}
public static Context create(Application application, String[] arg) {
// TODO Auto-generated method stub
return new ContextLWJGL(application, arg);
}
}

View File

@ -4,15 +4,14 @@ import java.util.ArrayList;
import java.util.List;
import org.atriaSoft.etk.Uri;
import org.atriaSoft.gale.Gale;
import org.atriaSoft.gale.Log;
import org.atriaSoft.gale.context.Context;
public class Resource {
public abstract class Resource {
protected static int MAXRESOURCELEVEL = 5;
private static int idGenerated = 0;
protected long uid = 0; //!< unique ID definition
protected int count = 0;
protected int count = 1;
protected int resourceLevel = MAXRESOURCELEVEL-1; //!< Level of the resource ==> for update priority [0..5] 0 must be update first.
protected String name; //!< name of the resource ...
protected boolean resourceHasBeenInit = false; //!< Know if the init function has bben called
@ -20,34 +19,32 @@ public class Resource {
/**
* @brief generic protected contructor (use factory to create this class)
*/
Resource() {
protected Resource() {
this.uid = idGenerated++;
this.addResourceType("gale::Resource");
}
/**
* @brief Initialisation of the class and previous classes.
* @param[in] name Name of the resource.
* @param[in] uri Uri of the resource.
*/
protected void init() {
this.resourceHasBeenInit = true;
}
//! @previous
protected void init( String name) {
protected Resource(String name) {
this.resourceHasBeenInit = true;
this.name = name;
}
//! @previous
protected void init( Uri uri) {
protected Resource( Uri uri) {
this.resourceHasBeenInit = true;
this.name = uri.get();
this.name = uri.getValue();
}
public void keep() {
this.count++;
}
public void retease() {
this.count--;
public int getCount() {
return this.count;
}
public void release() {
this.count--;
if (this.count == 0) {
}
}
public abstract void cleanUp();
public long getId() {
return this.uid;
}

View File

@ -3,15 +3,20 @@ package org.atriaSoft.gale.resource;
import java.util.ArrayList;
import java.util.List;
import org.atriaSoft.gale.Log;
public class ResourceManager {
private List<Resource> resourceList = new ArrayList<Resource>();
private List<Resource> resourceListToUpdate = new ArrayList<Resource>();
private boolean contextHasBeenRemoved = true;
private boolean exiting = false;
private final int MAXRESOURCELEVEL = 9;
/**
* @brief initialize the internal variable
*/
public Manager();
public ResourceManager() {
}
/**
* @brief Uninitiamize the resource manager, free all resources previously requested
* @note when not free == > generate warning, because the segfault can appear after...
@ -21,20 +26,13 @@ public class ResourceManager {
* @brief remove all resources (un-init) out of the destructor (due to the system implementation)
*/
public void unInit() {
ethread::RecursiveLock lock(this.mutex);
display();
this.resourceListToUpdate.clear();
// remove all resources ...
auto it(this.resourceList.begin());
while(it != this.resourceList.end()) {
gale::Resource> tmpRessource = (*it).lock();
if (tmpRessource != null) {
Log.warning("Find a resource that is not removed : [" + tmpRessource.getId() + "]"
+ "=\"" + tmpRessource.getName() + "\" "
+ tmpRessource.useCount() + " elements");
}
this.resourceList.erase(it);
it = this.resourceList.begin();
for(Resource it : this.resourceList) {
Log.warning("Find a resource that is not removed : [" + it.getId() + "]"
+ "='" + it.getName() + "' "
+ it.getCount() + " elements");
}
this.resourceList.clear();
}
@ -44,15 +42,11 @@ public class ResourceManager {
public void display(){
Log.info("Resources loaded : ");
// remove all resources ...
ethread::RecursiveLock lock(this.mutex);
for (auto it : this.resourceList) {
gale::Resource> tmpRessource = it.lock();
if (tmpRessource != null) {
Log.info(" [" + tmpRessource.getId() + "]"
+ tmpRessource.getType()
+ "=\"" + tmpRessource.getName() + "\" "
+ tmpRessource.useCount() + " elements");
}
for(Resource it : this.resourceList) {
Log.info(" [" + it.getId() + "]"
+ it.getType()
+ "='" + it.getName() + "' "
+ it.getCount() + " elements");
}
Log.info("Resources ---");
}
@ -63,17 +57,13 @@ public class ResourceManager {
public void reLoadResources() {
Log.info("------------- Resources re-loaded -------------");
// remove all resources ...
ethread::RecursiveLock lock(this.mutex);
if (this.resourceList.size() != 0) {
for (long jjj=0; jjj<MAXRESOURCELEVEL; jjj++) {
Log.info(" Reload level : " + jjj + "/" + (MAXRESOURCELEVEL-1));
for (auto it : this.resourceList) {
gale::Resource> tmpRessource = it.lock();
if(tmpRessource != null) {
if (jjj == tmpRessource.getResourceLevel()) {
tmpRessource.reload();
Log.info(" [" + tmpRessource.getId() + "]="+ tmpRessource.getType());
}
for (long jjj=0; jjj<MAXRESOURCELEVEL; jjj++) {
Log.info(" Reload level : " + jjj + "/" + (MAXRESOURCELEVEL-1));
for(Resource it : this.resourceList) {
if(jjj == it.getResourceLevel()) {
if (it.getCount() > 0) {
it.reload();
Log.info(" [" + it.getId() + "]="+ it.getType());
}
}
}
@ -87,18 +77,16 @@ public class ResourceManager {
* @brief Call by the system to send all the needed data on the graphic card chen they change ...
* @param[in] object The resources that might be updated
*/
public void update( gale::Resource> object) {
// chek if not added before
ethread::RecursiveLock lock(this.mutex);
for (auto it : this.resourceListToUpdate) {
if ( it != null
it == object) {
public void update(Resource object) {
// check if not added before
for (Resource it : this.resourceListToUpdate) {
if (it == object) {
// just prevent some double add ...
return;
}
}
// add it ...
this.resourceListToUpdate.pushBack(object);
this.resourceListToUpdate.add(object);
}
/**
* @brief Call by the system chen the openGL Context has been unexpectially removed == > This reload all the texture, VBO and other ....
@ -112,48 +100,37 @@ public class ResourceManager {
if (this.contextHasBeenRemoved == true) {
// need to update all ...
this.contextHasBeenRemoved = false;
etk::Vector<ememory::WeakPtr<gale::Resource>> resourceList;
{
ethread::RecursiveLock lock(this.mutex);
// Clean the update list
this.resourceListToUpdate.clear();
resourceList = this.resourceList;
}
if (resourceList.size() != 0) {
for (long jjj=0; jjj<MAXRESOURCELEVEL; jjj++) {
Log.verbose(" updateContext level (D) : " + jjj + "/" + (MAXRESOURCELEVEL-1));
for (auto it : resourceList) {
gale::Resource> tmpRessource = it.lock();
if( tmpRessource != null
jjj == tmpRessource.getResourceLevel()) {
//Log.debug("Update context named : " + lresourceList[iii].getName());
if (tmpRessource.updateContext() == false) {
// Lock error ==> postponned
ethread::RecursiveLock lock(this.mutex);
this.resourceListToUpdate.pushBack(tmpRessource);
this.resourceListToUpdate.clear();
synchronized(this.resourceList) {
if (this.resourceList.size() != 0) {
for (long jjj=0; jjj<MAXRESOURCELEVEL; jjj++) {
Log.verbose(" updateContext level (D) : " + jjj + "/" + (MAXRESOURCELEVEL-1));
for (Resource it : this.resourceList) {
if(jjj == it.getResourceLevel()) {
//Log.debug("Update context named : " + lresourceList[iii].getName());
if (it.updateContext() == false) {
// Lock error ==> postponned
this.resourceListToUpdate.add(it);
}
}
}
}
}
}
} else {
etk::Vector<gale::Resource>> resourceListToUpdate;
{
ethread::RecursiveLock lock(this.mutex);
List<Resource> resourceListToUpdate = null;
synchronized(this.resourceListToUpdate) {
resourceListToUpdate = this.resourceListToUpdate;
// Clean the update list
this.resourceListToUpdate.clear();
this.resourceListToUpdate = new ArrayList<Resource>();
}
if (resourceListToUpdate.size() != 0) {
for (long jjj=0; jjj<MAXRESOURCELEVEL; jjj++) {
Log.verbose(" updateContext level (U) : " + jjj + "/" + (MAXRESOURCELEVEL-1));
for (auto it : resourceListToUpdate) {
if ( it != null
jjj == it.getResourceLevel()) {
for (Resource it : resourceListToUpdate) {
if (jjj == it.getResourceLevel()) {
if (it.updateContext() == false) {
ethread::RecursiveLock lock(this.mutex);
// Lock error ==> postponned
this.resourceListToUpdate.pushBack(it);
this.resourceListToUpdate.add(it);
}
}
}
@ -165,11 +142,9 @@ public class ResourceManager {
* @brief This is to inform the resources manager that we have no more openGl context ...
*/
public void contextHasBeenDestroyed() {
ethread::RecursiveLock lock(this.mutex);
for (auto it : this.resourceList) {
gale::Resource> tmpRessource = it.lock();
if (tmpRessource != null) {
tmpRessource.removeContextToLate();
for (Resource it : this.resourceList) {
if (it.getCount() > 0) {
it.removeContextToLate();
}
}
// no context preent ...
@ -182,15 +157,13 @@ public class ResourceManager {
contextHasBeenDestroyed();
this.exiting = true;
}
public:
// internal API to extent eResources in extern Soft
public Resource localKeep(String filename) {
Log.verbose("KEEP (DEFAULT) : file : '" + filename + "' in " + this.resourceList.size() + " resources");
for (auto it : this.resourceList) {
gale::Resource> tmpRessource = it.lock();
if (tmpRessource != null) {
if (tmpRessource.getName() == filename) {
return tmpRessource;
for (Resource it : this.resourceList) {
if (it != null) {
if (it.getName() == filename) {
return it;
}
}
}
@ -203,12 +176,13 @@ public:
public void cleanInternalRemoved() {
//Log.info("remove object in Manager");
updateContext();
for (auto it(this.resourceList.begin()); it!=this.resourceList.end(); ++it) {
if ((*it).expired() == true) {
this.resourceList.erase(it);
it = this.resourceList.begin();
}
}
// TODO: ...
// for (auto it(this.resourceList.begin()); it!=this.resourceList.end(); ++it) {
// if ((*it).expired() == true) {
// this.resourceList.erase(it);
// it = this.resourceList.begin();
// }
// }
}
}

File diff suppressed because it is too large Load Diff

View File

@ -1,147 +1,141 @@
package org.atriaSoft.gale.resource;
public class ResourceShader {
import org.atriaSoft.etk.Uri;
import org.atriaSoft.gale.Log;
import org.atriaSoft.gale.backend3d.OpenGL;
import org.atriaSoft.gale.backend3d.OpenGL.ShaderType;
private :
boolean this.exist; //!< The shader file existed and has been loaded
String this.fileData; //!< A copy of the data loaded from the file (usefull only when opengl context is removed)
long this.shader; //!< opengl id of this element
gale::openGL::shader::type this.type; //!< Type of the current shader(vertex/fragment)
protected:
/**
* @brief Contructor of an opengl Shader
* @param[in] filename Standard file name format. see @ref etk::FSNode
*/
Shader():
gale::Resource(),
this.exist(false),
this.fileData(""),
this.shader(-1),
this.type(gale::openGL::shader::type::vertex) {
addResourceType("gale::Shader");
this.resourceLevel = 0;
}
public:
void init( etk::Uri uri){
ethread::RecursiveLock lock(this.mutex);
gale::Resource::init(uri.get());
Log.debug("OGL : load SHADER '" + uri + "'");
// load data from file "all the time ..."
public class ResourceShader extends Resource {
if (uri.getPath().getExtention() == "frag") {
this.type = gale::openGL::shader::type::fragment;
} else if (uri.getPath().getExtention() == "vert") {
this.type = gale::openGL::shader::type::vertex;
} else {
Log.error("File does not have extention \".vert\" for Vertex Shader or \".frag\" for Fragment Shader. but : \"" + uri + "\"");
return;
}
reload();
private boolean exist = false; //!< The shader file existed and has been loaded
private String fileData = ""; //!< A copy of the data loaded from the file (usefull only when opengl context is removed)
private int shader = -1; //!< opengl id of this element
private final ShaderType type; //!< Type of the current shader(vertex/fragment)
private final Uri uri;
/**
* @brief Contructor of an opengl Shader
* @param[in] filename Standard file name format. see @ref etk::FSNode
*/
protected ResourceShader(Uri uri) {
super(uri);
this.uri = uri;
addResourceType("gale::Shader");
this.resourceLevel = 0;
Log.debug("OGL : load SHADER '" + uri + "'");
// load data from file "all the time ..."
if (uri.get().endsWith(".frag")) {
this.type = ShaderType.fragment;
} else if (uri.get().endsWith(".vert")) {
this.type = ShaderType.vertex;
} else {
Log.error("File does not have extention '.vert' for Vertex Shader or '.frag' for Fragment Shader. but : \"" + uri + "\"");
this.type = ShaderType.vertex;
return;
}
/**
* @brief Destructor, remove the current Shader
*/
virtual ~Shader(){
ethread::RecursiveLock lock(this.mutex);
this.fileData.clear();
gale::openGL::shader::remove(this.shader);
reload();
}
/**
* @brief Destructor, remove the current Shader
*/
public void cleanUp() {
OpenGL.shaderRemove(this.shader);
this.exist = false;
}
/**
* @brief get the opengl reference id of this shader.
* @return The opengl id.
*/
public int getGLID() {
return this.shader;
};
/**
* @brief get the opengl type of this shader.
* @return The type of this loaded shader.
*/
public ShaderType getShaderType() {
return this.type;
};
/**
* @brief This load/reload the data in the opengl context, needed when removed previously.
*/
public boolean updateContext(){
if (this.exist == true) {
// Do nothing == > too dangerous ...
} else {
this.shader = OpenGL.shaderLoad(this.uri.get(), type);
// create the Shader
if (this.shader < 0) {
return true;
}
this.exist = true;
}
return true;
}
/**
* @brief remove the data from the opengl context.
*/
public void removeContext(){
if (true == this.exist) {
OpenGL.shaderRemove(this.shader);
this.shader = -1;
this.exist = false;
}
public:
/**
* @brief get the opengl reference id of this shader.
* @return The opengl id.
*/
long getGLID() {
return this.shader;
};
/**
* @brief get the opengl type of this shader.
* @return The type of this loaded shader.
*/
gale::openGL::shader::type getShaderType() {
return this.type;
};
/**
* @brief This load/reload the data in the opengl context, needed when removed previously.
*/
boolean updateContext(){
ethread::RecursiveLock lock(this.mutex, true);
if (lock.tryLock() == false) {
//Lock error ==> try later ...
return false;
}
if (this.exist == true) {
// Do nothing == > too dangerous ...
} else {
// create the Shader
if (this.fileData.size() == 0) {
this.shader = -1;
return true;
}
Log.debug("Create Shader : '" + this.name + "'");
this.shader = gale::openGL::shader::create(this.type);
if (this.shader < 0) {
Log.critical(" can not load shader");
return true;
} else {
Log.debug("Compile shader with GLID=" + this.shader);
boolean ret = gale::openGL::shader::compile(this.shader, this.fileData);
if (ret == false) {
char * tmpShaderType = "FRAGMENT SHADER";
if (this.type == gale::openGL::shader::type::vertex){
tmpShaderType = "VERTEX SHADER";
}
Log.critical("Could not compile '" + tmpShaderType + "' name='" + this.name + "'");
return true;
}
}
this.exist = true;
}
return true;
}
/**
* @brief remove the data from the opengl context.
*/
void removeContext(){
ethread::RecursiveLock lock(this.mutex);
if (true == this.exist) {
gale::openGL::shader::remove(this.shader);
this.exist = false;
}
}
/**
* @brief Special android spec! It inform us that all context is removed and after notify us...
*/
void removeContextToLate(){
ethread::RecursiveLock lock(this.mutex);
}
/**
* @brief Special android spec! It inform us that all context is removed and after notify us...
*/
public void removeContextToLate(){
this.exist = false;
this.shader = -1;
}
/**
* @brief Relode the shader from the file. used when a request of resouces reload is done.
* @note this is really usefull when we tested the new themes or shader developpements.
*/
public void reload() {
Log.verbose("load shader:\n-----------------------------------------------------------------\n" + this.fileData + "\n-----------------------------------------------------------------");
// now change the OGL context ...
if (OpenGL.hasContext() == true) {
Log.debug("OGL : load SHADER '" + this.name + "' ==> call update context (direct)");
removeContext();
updateContext();
} else {
Log.debug("OGL : load SHADER '" + this.name + "' ==> tagged has update context needed");
// TODO : Check this, this is a leek ==> in the GPU ... really bad ...
this.exist = false;
this.shader = 0;
getManager().update(this);
}
/**
* @brief Relode the shader from the file. used when a request of resouces reload is done.
* @note this is really usefull when we tested the new themes or shader developpements.
*/
void reload() {
ethread::RecursiveLock lock(this.mutex);
etk::Uri uri = this.name;
if (etk::uri::exist(uri) == false) {
Log.critical("File does not Exist : '" + uri + "' : path='" + uri.getPath() + "'");
return;
}
etk::uri::readAll(uri, this.fileData);
Log.verbose("load shader:\n-----------------------------------------------------------------\n" + this.fileData + "\n-----------------------------------------------------------------");
// now change the OGL context ...
if (gale::openGL::hasContext() == true) {
Log.debug("OGL : load SHADER '" + this.name + "' ==> call update context (direct)");
removeContext();
updateContext();
} else {
Log.debug("OGL : load SHADER '" + this.name + "' ==> tagged has update context needed");
// TODO : Check this, this is a leek ==> in the GPU ... really bad ...
this.exist = false;
this.shader = 0;
getManager().update(ememory::dynamicPointerCast<gale::Resource>(sharedFromThis()));
}
}
public static ResourceShader create(Uri uriShader) {
ResourceShader resource;
Resource resource2;
String name = uriShader.getValue();
if (name.isEmpty() == false && name != "---") {
resource2 = getManager().localKeep(name);
} else {
Log.error("Can not create a shader without a filaname");
return null;
}
if (resource2 != null) {
if (resource2 instanceof ResourceShader) {
resource2.keep();
return (ResourceShader)resource2;
}
Log.critical("Request resource file : '" + name + "' With the wrong type (dynamic cast error)");
return null;
}
resource = new ResourceShader(uriShader);
if (resource == null) {
Log.error("allocation error of a resource : " + name);
return null;
}
if (resource.resourceHasBeenCorectlyInit() == false) {
Log.critical("resource Is not correctly init : ResourceProgram" );
return null;
}
getManager().localAdd(resource);
return resource;
}
}

View File

@ -0,0 +1,212 @@
package org.atriaSoft.gale.resource;
import java.nio.FloatBuffer;
import java.nio.IntBuffer;
import java.util.ArrayList;
import java.util.List;
import java.util.Vector;
import org.atriaSoft.etk.Color;
import org.atriaSoft.etk.math.Vector2f;
import org.atriaSoft.etk.math.Vector3f;
import org.atriaSoft.gale.Log;
import org.atriaSoft.gale.backend3d.OpenGL;
import org.lwjgl.BufferUtils;
import org.lwjgl.opengl.GL11;
import org.lwjgl.opengl.GL15;
import org.lwjgl.opengl.GL20;
import org.lwjgl.opengl.GL30;
import models.RawModel;
public class ResourceVirtualArrayObject extends Resource {
private int vaoID = -1;
private boolean exist = false; //!< This data is availlable in the Graphic card
private List<Integer> vbo = new ArrayList<Integer>();
float[] positions = null;
float[] colors = null;
float[] textureCoordinates = null;
float[] normals = null;
int[] indices = null;
int vertexCount = -1;
private FloatBuffer storeDataInFloatBuffer(float[] data) {
FloatBuffer buffer = BufferUtils.createFloatBuffer(data.length);
buffer.put(data);
buffer.flip();
return buffer;
}
private IntBuffer storeDataInIntBuffer(int[] data) {
IntBuffer buffer = BufferUtils.createIntBuffer(data.length);
buffer.put(data);
buffer.flip();
return buffer;
}
private void storeDataInAttributeList(int attributeNumber, int coordinateSize, float[] data) {
int vboID = GL15.glGenBuffers();
vbo.add(vboID);
GL15.glBindBuffer(GL15.GL_ARRAY_BUFFER, vboID);
FloatBuffer buffer = storeDataInFloatBuffer(data);
GL15.glBufferData(GL15.GL_ARRAY_BUFFER, buffer, GL15.GL_STATIC_DRAW);
GL20.glVertexAttribPointer(attributeNumber, coordinateSize, GL11.GL_FLOAT, false, 0, 0);
GL15.glBindBuffer(GL15.GL_ARRAY_BUFFER, 0);
}
private void bindIndicesBuffer(int[] indices) {
int vboId = GL15.glGenBuffers();
vbo.add(vboId);
GL15.glBindBuffer(GL15.GL_ELEMENT_ARRAY_BUFFER, vboId);
IntBuffer buffer = storeDataInIntBuffer(indices);
GL15.glBufferData(GL15.GL_ELEMENT_ARRAY_BUFFER, buffer, GL15.GL_STATIC_DRAW);
}
private void createVAO() {
vaoID = GL30.glGenVertexArrays();
GL30.glBindVertexArray(vaoID);
}
private void unbindVAO() {
GL30.glBindVertexArray(0);
}
public void loadToVAO() {
createVAO();
if (indices != null) {
Log.info("Set indices");
bindIndicesBuffer(indices);
}
if (positions != null) {
Log.info("Set positions");
storeDataInAttributeList(0, 3, positions);
}
if (textureCoordinates != null) {
Log.info("Set textureCoordinates");
storeDataInAttributeList(1, 2, textureCoordinates);
}
if (normals != null) {
Log.info("Set normals");
storeDataInAttributeList(2, 3, normals);
}
if (colors != null) {
Log.info("Set colors");
storeDataInAttributeList(3, 4, colors);
}
unbindVAO();
}
/**
* @brief ructor of this VBO.
* @param[in] accesMode Acces mode : ???
*/
protected ResourceVirtualArrayObject(float[] positions, float[] colors, float[] textureCoordinates, float[] normals, int[] indices, int vertexCount) {
super();
addResourceType("gale::VirtualBufferObject");
this.resourceLevel = 3;
this.positions = positions;
this.colors = colors;
this.textureCoordinates = textureCoordinates;
this.normals = normals;
this.indices = indices;
this.vertexCount = vertexCount;
Log.debug("OGL: load VBO count");
}
/**
* @brief Destructor of this VBO.
*/
@Override
public void cleanUp() {
removeContext();
}
/**
* @brief clear buffers
*/
public void clear() {
//Log.verbose(" Clear: [" + getId() + "] '" + getName() + "' (size=" + this.buffer.get(0).length + ")");
// DO not clear the this.vbo indexed in the graphic cards ...
}
/**
* @brief get the real openGL ID.
* @return the Ogl id reference of this VBO.
*/
public int getGLID() {
return this.vaoID;
};
/**
* @brief Send the data to the graphic card.
*/
public void flush() {
// request to the manager to be call at the next update ...
getManager().update(this);
Log.verbose("Request flush of VBO: [" + getId() + "] '" + getName() + "'");
}
/**
* @brief This load/reload the data in the opengl context, needed when removed previously.
*/
public boolean updateContext() {
//Log.verbose(" Start: [" + getId() + "] '" + getName() + "' (size=" + this.buffer.get(0).length + ")");
if (this.exist == false) {
Log.debug(" ==> ALLOCATE new handle");
// Allocate and assign a Vertex Array Object to our handle
loadToVAO();
}
this.exist = true;
Log.verbose(" Stop: [" + getId() + "] '" + getName() + "'");
return true;
}
/**
* @brief remove the data from the opengl context.
*/
public void removeContext() {
if (this.exist == true) {
//OpenGL.deleteBuffers(this.vbo);
this.exist = false;
}
}
/**
* @brief Special android spec! It inform us that all context is removed and after notify us...
*/
public void removeContextToLate() {
this.exist = false;
// for (int iii=0; iii<this.vbo.length; iii++) {
// this.vbo[iii] = 0;
// }
}
/**
* @brief Relode the shader from the file. used when a request of resouces reload is done.
* @note this is really usefull when we tested the new themes or shader developpements.
*/
public void reload() {
removeContext();
updateContext();
}
public static ResourceVirtualArrayObject create(float[] positions, float[] colors, int[] indices) {
ResourceVirtualArrayObject resource = new ResourceVirtualArrayObject(positions, colors, null, null, indices, indices.length);
if (resource.resourceHasBeenCorectlyInit() == false) {
Log.critical("resource Is not correctly init: ResourceVirtualBufferObject");
}
getManager().localAdd(resource);
return resource;
}
public static ResourceVirtualArrayObject create(float[] positions, int dimentions) {
ResourceVirtualArrayObject resource = new ResourceVirtualArrayObject(positions, null, null, null, null, positions.length/dimentions);
if (resource.resourceHasBeenCorectlyInit() == false) {
Log.critical("resource Is not correctly init: ResourceVirtualBufferObject");
}
getManager().localAdd(resource);
return resource;
}
public static ResourceVirtualArrayObject create(float[] positions, float[] textureCoordinates, float[] normals, int[] indices) {
ResourceVirtualArrayObject resource = new ResourceVirtualArrayObject(positions, null, textureCoordinates, normals, indices, indices.length);
if (resource.resourceHasBeenCorectlyInit() == false) {
Log.critical("resource Is not correctly init: ResourceVirtualBufferObject");
}
getManager().localAdd(resource);
return resource;
}
}

View File

@ -0,0 +1,29 @@
package org.atriaSoft.gale.test.sample1;
public class Log {
private static String LIBNAME = "Sample1";
public static void print(String data) {
System.out.println(data);
}
public static void critical(String data) {
System.out.println("[C] " + LIBNAME + " | " + data);
}
public static void error(String data) {
System.out.println("[E] " + LIBNAME + " | " + data);
}
public static void warning(String data) {
System.out.println("[W] " + LIBNAME + " | " + data);
}
public static void info(String data) {
System.out.println("[I] " + LIBNAME + " | " + data);
}
public static void debug(String data) {
System.out.println("[D] " + LIBNAME + " | " + data);
}
public static void verbose(String data) {
System.out.println("[V] " + LIBNAME + " | " + data);
}
public static void todo(String data) {
System.out.println("[TODO] " + LIBNAME + " | " + data);
}
}

View File

@ -0,0 +1,162 @@
package org.atriaSoft.gale.test.sample1;
import org.atriaSoft.etk.Color;
import org.atriaSoft.etk.Uri;
import org.atriaSoft.etk.math.Matrix4f;
import org.atriaSoft.etk.math.Vector2f;
import org.atriaSoft.etk.math.Vector2i;
import org.atriaSoft.etk.math.Vector3f;
import org.atriaSoft.gale.Application;
import org.atriaSoft.gale.backend3d.OpenGL;
import org.atriaSoft.gale.backend3d.OpenGL.RenderMode;
import org.atriaSoft.gale.context.Context;
import org.atriaSoft.gale.resource.ResourceProgram;
import org.atriaSoft.gale.resource.ResourceVirtualArrayObject;
import org.atriaSoft.gale.context.Cursor;
import org.atriaSoft.gale.key.Keyboard;
import org.atriaSoft.gale.key.Special;
import org.atriaSoft.gale.key.Status;
import org.atriaSoft.gale.key.Type;
import org.lwjgl.opengl.GL11;
import org.lwjgl.opengl.GL20;
import org.lwjgl.opengl.GL30;
public class MainApplication extends Application {
private ResourceProgram GLprogram;
private int GLPosition;
private int GLMatrixTransformation;
private int GLMatrixProjection;
private int GLMatrixView;
private int GLColor;
private float angle;
private ResourceVirtualArrayObject verticesVBO;
private static final int INDICE_VBO_POSITIONS = 0;
private static final int INDICE_VBO_TEXTURE_COORDINATES = 1;
private static final int INDICE_VBO_NORMALS = 2;
private static final int INDICE_VBO_COLORS = 3;
@Override
public void onCreate(Context _context) {
this.canDraw = true;
setSize(new Vector2f(800, 600));
this.angle = 0.0f;
this.GLprogram = ResourceProgram.create(new Uri("DATA", "basic.vert"), new Uri("DATA", "basic.frag"));
if (this.GLprogram != null) {
//this.GLPosition = this.GLprogram.getAttribute("EW_coord3d");
//this.GLColor = this.GLprogram.getAttribute("EW_color");
this.GLMatrixTransformation = this.GLprogram.getUniform("EW_MatrixTransformation");
this.GLMatrixProjection = this.GLprogram.getUniform("EW_MatrixProjection");
this.GLMatrixView = this.GLprogram.getUniform("EW_MatrixView");
// this.GLprogram.bindAttribute(INDICE_VBO_POSITIONS, "position");
// //this.GLprogram.bindAttribute(INDICE_VBO_TEXTURE_COORDINATES, "textureCoords");
// //this.GLprogram.bindAttribute(INDICE_VBO_NORMALS, "normal");
// this.GLprogram.bindAttribute(INDICE_VBO_COLORS, "colors");
}
float[] vertices = {
-0.5f, -0.5f, -1.0f,
0.0f, 0.5f, -1.0f,
0.5f,-0.5f, -1.0f
};
float[] colors = {
1.0f, 0.0f, 0.0f, 1.0f,
0.0f, 1.0f, 0.0f, 1.0f,
0.0f, 0.0f, 1.0f, 1.0f,
};
int[] indices = {
0, 1, 2,
};
// this is the properties of the buffer requested : "r"/"w" + "-" + buffer type "f"=float "i"=integer
this.verticesVBO = ResourceVirtualArrayObject.create(vertices, colors, indices);
if (this.verticesVBO == null) {
Log.error("can not instanciate VBO ...");
return;
}
// TO facilitate some debugs we add a name of the VBO:
this.verticesVBO.setName("[VBO] of basic SAMPLE");
// update all the VBO elements ...
this.verticesVBO.flush();
Log.info("==> Init APPL (END)");
}
@Override
public void onDraw(Context _context) {
this.angle += 0.01;
Log.info("==> appl Draw ...");
Vector2f size = getSize();
// set the basic openGL view port: (position drawed in the windows)
OpenGL.setViewPort(new Vector2f(0,0), size);
// Clear all the stacked matrix ...
OpenGL.setBasicMatrix(Matrix4f.identity());
// clear background
Color bgColor = new Color(0.0f, 1.0f, 1.0f, 0.75f);
OpenGL.clearColor(bgColor);
// real clear request:
OpenGL.clear(OpenGL.ClearFlag.clearFlag_colorBuffer);
// create a local matrix environnement.
OpenGL.push();
Matrix4f tmpProjection = Matrix4f.createMatrixOrtho(-1, 1, -1, 1, -2, 2);
// set internal matrix system:
OpenGL.setMatrix(tmpProjection);
if (this.GLprogram == null) {
Log.info("No shader ...");
return;
}
//EWOL_DEBUG(" display " + this.coord.size() + " elements" );
this.GLprogram.use();
// set Matrix : translation/positionMatrix
Matrix4f projectionMatrix = tmpProjection; //OpenGL.getMatrix();
Matrix4f transforamtionMatrix = Matrix4f.createMatrixRotate(new Vector3f(0,0,1),this.angle);
Matrix4f viewMatrix = OpenGL.getCameraMatrix();
//Matrix4f tmpMatrix = projMatrix * camMatrix;
this.GLprogram.uniformMatrix(this.GLMatrixView, viewMatrix);
this.GLprogram.uniformMatrix(this.GLMatrixTransformation, transforamtionMatrix);
this.GLprogram.uniformMatrix(this.GLMatrixProjection, projectionMatrix);
// position:
//this.GLprogram.sendAttributePointer2(this.GLPosition, this.verticesVBO, INDICE_VBO_VERTICES);
//glEnableVertexAttribArray
// color:
//this.GLprogram.sendAttributePointer2(this.GLColor, this.verticesVBO, INDICE_VBO_COLOR);
GL30.glBindVertexArray(this.verticesVBO.getGLID());
GL20.glEnableVertexAttribArray(INDICE_VBO_POSITIONS);
GL20.glEnableVertexAttribArray(INDICE_VBO_COLORS);
// Request the draw od the elements:
//OpenGL.drawArrays(OpenGL.RenderMode.triangle, 0, 3 /*number of points*/);
Log.warning("Draw 3 points");
//GL11.glDrawElements(GL11.GL_TRIANGLES, 3 /*number of points*/, GL11.GL_UNSIGNED_INT, 0);
GL11.glDrawElements(GL11.GL_TRIANGLES, 3, GL11.GL_UNSIGNED_INT, 0);
GL20.glDisableVertexAttribArray(INDICE_VBO_COLORS);
GL20.glDisableVertexAttribArray(INDICE_VBO_POSITIONS);
GL30.glBindVertexArray(0);
this.GLprogram.unUse();
// Restore context of matrix
OpenGL.pop();
this.markDrawingIsNeeded();
}
@Override
public void onPointer(Type _type,
int _pointerID,
Vector2f _pos,
Status _state) {
/*
Log.info("input event: type=" + _type);
Log.info(" id=" + _pointerID);
Log.info(" pos=" + _pos);
Log.info(" state=" + _state);
*/
}
@Override
public void onKeyboard( Special _special,
Keyboard _type,
Character _value,
Status _state) {
Log.info("Keyboard event: special=" + _special);
Log.info(" type=" + _type);
Log.info(" value='" + _value + "'");
Log.info(" state=" + _state);
}
}

View File

@ -0,0 +1,13 @@
#version 400 core
#ifdef GL_ES
precision mediump float;
precision mediump int;
#endif
// output:
varying vec4 f_color;
void main(void) {
gl_FragColor = f_color;
}

View File

@ -0,0 +1,21 @@
#version 400 core
#ifdef GL_ES
precision mediump float;
precision mediump int;
#endif
// Input:
attribute vec3 position;
attribute vec4 colors;
uniform mat4 EW_MatrixTransformation;
uniform mat4 EW_MatrixProjection;
uniform mat4 EW_MatrixView;
// output:
varying vec4 f_color;
void main(void) {
gl_Position = EW_MatrixProjection * EW_MatrixView * EW_MatrixTransformation * vec4(position, 1.0);
f_color = colors;
}

View File

@ -0,0 +1,11 @@
package org.atriaSoft.gale.test.sample1;
import org.atriaSoft.etk.Uri;
import org.atriaSoft.gale.Gale;
public class sample_1 {
public static void main(String[] args) {
Uri.setGroup("DATA", "src/org/atriaSoft/gale/test/sample1/");
Gale.run(new MainApplication(), args);
}
}

View File

@ -32,10 +32,9 @@ public class EntityRenderer {
shader.stop();
}
public void render(Map<TexturedModel, List<Entity>> entities) {
//OpenGL.enable(OpenGL.Flag.flag_blend);
//GL11.glBlendFunc(GL11.GL_SRC_ALPHA, GL11.GL_ONE_MINUS_SRC_ALPHA);
//OpenGL.enable(OpenGL.Flag.flag_cullFace);
//OpenGL.enable(OpenGL.Flag.flag_back);
OpenGL.enable(OpenGL.Flag.flag_blend);
OpenGL.enable(OpenGL.Flag.flag_cullFace);
OpenGL.enable(OpenGL.Flag.flag_back);
for (TexturedModel model:entities.keySet()) {
prepareTexturedModel(model);
OpenGL.updateAllFlags();
@ -47,9 +46,9 @@ public class EntityRenderer {
}
unbindTexturedModel();
}
//OpenGL.disable(OpenGL.Flag.flag_blend);
//OpenGL.disable(OpenGL.Flag.flag_cullFace);
//OpenGL.disable(OpenGL.Flag.flag_back);
OpenGL.disable(OpenGL.Flag.flag_blend);
OpenGL.disable(OpenGL.Flag.flag_cullFace);
OpenGL.disable(OpenGL.Flag.flag_back);
}
private void prepareTexturedModel(TexturedModel model) {
@ -60,10 +59,9 @@ public class EntityRenderer {
GL20.glEnableVertexAttribArray(2);
ModelTexture texture = model.getTexture();
shader.loadNumberOfRows(texture.getNumberOfRows());
if (texture.isHasTransparency()) {
MasterRenderer.disableCulling();
//OpenGL.disable(OpenGL.Flag.flag_cullFace);
//OpenGL.disable(OpenGL.Flag.flag_back);
if (texture.isHasTransparency() == false) {
OpenGL.enable(OpenGL.Flag.flag_cullFace);
OpenGL.enable(OpenGL.Flag.flag_back);
}
shader.loadFakeLightingVariable(texture.isUseFakeLighting());
shader.loadShineVariable(texture.getShineDamper(), texture.getReflectivity());
@ -72,12 +70,11 @@ public class EntityRenderer {
}
private void unbindTexturedModel() {
MasterRenderer.enableCulling();
//OpenGL.enable(OpenGL.Flag.flag_cullFace);
//OpenGL.enable(OpenGL.Flag.flag_back);
GL20.glDisableVertexAttribArray(0);
GL20.glDisableVertexAttribArray(1);
OpenGL.disable(OpenGL.Flag.flag_cullFace);
OpenGL.disable(OpenGL.Flag.flag_back);
GL20.glDisableVertexAttribArray(2);
GL20.glDisableVertexAttribArray(1);
GL20.glDisableVertexAttribArray(0);
GL30.glBindVertexArray(0);
}

View File

@ -41,8 +41,7 @@ public class MasterRenderer {
public MasterRenderer(Loader loader) {
//enableCulling();
//OpenGL.enable(OpenGL.Flag.flag_blend);
GL11.glEnable(GL11.GL_BLEND);
OpenGL.enable(OpenGL.Flag.flag_blend);
GL11.glBlendFunc(GL11.GL_SRC_ALPHA, GL11.GL_ONE_MINUS_SRC_ALPHA);
createProjectionMatrix();
renderer = new EntityRenderer(shader, projectionMatrix);
@ -51,16 +50,12 @@ public class MasterRenderer {
}
public static void enableCulling() {
GL11.glEnable(GL11.GL_CULL_FACE);
GL11.glEnable(GL11.GL_BACK);
//OpenGL.enable(OpenGL.Flag.flag_cullFace);
//OpenGL.enable(OpenGL.Flag.flag_back);
OpenGL.enable(OpenGL.Flag.flag_cullFace);
OpenGL.enable(OpenGL.Flag.flag_back);
}
public static void disableCulling() {
GL11.glDisable(GL11.GL_CULL_FACE);
GL11.glDisable(GL11.GL_BACK);
//OpenGL.disable(OpenGL.Flag.flag_cullFace);
//OpenGL.disable(OpenGL.Flag.flag_back);
OpenGL.disable(OpenGL.Flag.flag_cullFace);
OpenGL.disable(OpenGL.Flag.flag_back);
}
public void render(List<Light> lights, Camera camera) {
@ -99,11 +94,9 @@ public class MasterRenderer {
}
public void prepare() {
//OpenGL.enable(OpenGL.Flag.flag_depthTest);
GL11.glEnable(GL11.GL_DEPTH_TEST);
//OpenGL.clear(OpenGL.ClearFlag.clearFlag_depthBuffer);
//OpenGL.clear(OpenGL.ClearFlag.clearFlag_colorBuffer);
GL11.glClear(GL11.GL_COLOR_BUFFER_BIT|GL11.GL_DEPTH_BUFFER_BIT);
OpenGL.enable(OpenGL.Flag.flag_depthTest);
OpenGL.clear(OpenGL.ClearFlag.clearFlag_depthBuffer);
OpenGL.clear(OpenGL.ClearFlag.clearFlag_colorBuffer);
OpenGL.clearColor(SKY_COLOUR);
}
@ -114,20 +107,8 @@ public class MasterRenderer {
}
private void createProjectionMatrix() {
//float aspectRatio = (float) Display.getWidth() / (float) Display.getHeight();
Vector2f windowsSize = DisplayManager.getSize();
float aspectRatio = windowsSize.x / windowsSize.y;
// float y_scale = (float) ((1f/Math.atan(Math.toRadians(FOV/2f))) * aspectRatio);
// float x_scale = y_scale / aspectRatio;
// float frustrum_length = FAR_PLANE - NEAR_PLANE;
//
// projectionMatrix = new Matrix4f();
// projectionMatrix.m00 = x_scale;
// projectionMatrix.m11 = y_scale;
// projectionMatrix.m22 = -((FAR_PLANE + NEAR_PLANE) / frustrum_length);
// projectionMatrix.m23 = -1;;
// projectionMatrix.m32 = -((2*FAR_PLANE * NEAR_PLANE) / frustrum_length);
// projectionMatrix.m33 = 0;
projectionMatrix = Matrix4f.createMatrixPerspective(FOV, aspectRatio, NEAR_PLANE, FAR_PLANE);
}

View File

@ -30,10 +30,9 @@ public class TerrainRenderer {
}
public void render(List<Terrain> terrains) {
//OpenGL.enable(OpenGL.Flag.flag_blend);
//GL11.glBlendFunc(GL11.GL_SRC_ALPHA, GL11.GL_ONE_MINUS_SRC_ALPHA);
//OpenGL.enable(OpenGL.Flag.flag_cullFace);
//OpenGL.enable(OpenGL.Flag.flag_back);
OpenGL.enable(OpenGL.Flag.flag_blend);
OpenGL.enable(OpenGL.Flag.flag_cullFace);
OpenGL.enable(OpenGL.Flag.flag_back);
for (Terrain terrain : terrains) {
prepareTerrain(terrain);
loadModelMatrix(terrain);
@ -42,9 +41,9 @@ public class TerrainRenderer {
GL11.GL_UNSIGNED_INT, 0);
unbindTexturedModel();
}
//OpenGL.disable(OpenGL.Flag.flag_blend);
//OpenGL.disable(OpenGL.Flag.flag_cullFace);
//OpenGL.disable(OpenGL.Flag.flag_back);
OpenGL.disable(OpenGL.Flag.flag_blend);
OpenGL.disable(OpenGL.Flag.flag_cullFace);
OpenGL.disable(OpenGL.Flag.flag_back);
}
private void prepareTerrain(Terrain terrain) {

View File

@ -22,7 +22,6 @@ public abstract class ShaderProgram {
public ShaderProgram (String vertexFile, String fragmentFile) {
/*
vertexShaderID = OpenGL.shaderLoad(vertexFile, OpenGL.ShaderType.vertex);
fragmentShaderID = OpenGL.shaderLoad(fragmentFile, OpenGL.ShaderType.fragment);
programID = OpenGL.programCreate();
@ -31,50 +30,26 @@ public abstract class ShaderProgram {
bindAttributes();
OpenGL.programCompile(programID);
getAllUniformLocations();
*/
vertexShaderID = loadShader(vertexFile, GL20.GL_VERTEX_SHADER);
fragmentShaderID = loadShader(fragmentFile, GL20.GL_FRAGMENT_SHADER);
programID = GL20.glCreateProgram();
GL20.glAttachShader(programID, vertexShaderID);
GL20.glAttachShader(programID, fragmentShaderID);
bindAttributes();
GL20.glLinkProgram(programID);
GL20.glValidateProgram(programID);
getAllUniformLocations();
}
protected abstract void getAllUniformLocations();
// protected abstract void setRenderFlags();
// protected abstract void unSetRenderFlags();
protected int getUniformLocation(String uniformName) {
//return OpenGL.programGetUniformLocation(programID, uniformName);
return GL20.glGetUniformLocation(programID, uniformName);
return OpenGL.programGetUniformLocation(programID, uniformName);
}
public void start() {
//setRenderFlags();
//OpenGL.useProgram(programID);
GL20.glUseProgram(programID);
OpenGL.useProgram(programID);
}
public void stop() {
//OpenGL.unUseProgram(programID);
//unSetRenderFlags();
GL20.glUseProgram(0);
OpenGL.unUseProgram(programID);
}
public void cleanUp() {
stop();
/*
OpenGL.programDetach(programID, fragmentShaderID);
OpenGL.programDetach(programID, vertexShaderID);
OpenGL.shaderRemove(vertexShaderID);
OpenGL.shaderRemove(fragmentShaderID);
OpenGL.programRemove(programID);
*/
GL20.glDetachShader(programID, vertexShaderID);
GL20.glDetachShader(programID, fragmentShaderID);
GL20.glDeleteShader(vertexShaderID);
GL20.glDeleteShader(fragmentShaderID);
GL20.glDeleteProgram(programID);
}
protected abstract void bindAttributes();
@ -82,32 +57,4 @@ public abstract class ShaderProgram {
protected void bindAttribute(int attribute, String variableName) {
OpenGL.programBindAttribute(programID, attribute, variableName);
}
private static int loadShader(String file, int type) {
System.out.println("Load shader: '" + file + "'");
StringBuilder shaderSource = new StringBuilder();
try {
BufferedReader reader = new BufferedReader(new FileReader(file));
String line;
while((line = reader.readLine()) != null) {
shaderSource.append(line).append("\n");
}
reader.close();
} catch(IOException e) {
System.err.println("Could not read the file!");
e.printStackTrace();
System.exit(-1);
}
int shaderID = GL20.glCreateShader(type);
GL20.glShaderSource(shaderID, shaderSource);
GL20.glCompileShader(shaderID);
if (GL20.glGetShaderi(shaderID, GL20.GL_COMPILE_STATUS) == GL11.GL_FALSE) {
System.out.println(GL20.glGetShaderInfoLog(shaderID, 500));
System.out.println("Could not compile the shader");
System.exit(-1);
}
return shaderID;
}
}

View File

@ -14,8 +14,8 @@ import toolbox.Maths;
public class StaticShader extends ShaderProgram {
private static final int MAX_LIGHTS = 4;
private static final String VERTEX_FILE = "src/shaders/vertexShader.txt";
private static final String FRAGMENT_FILE = "src/shaders/fragmentShader.txt";
private static final String VERTEX_FILE = "src/shaders/static.vert";
private static final String FRAGMENT_FILE = "src/shaders/static.frag";
private int location_transformationMatrix;
private int location_projectionMatrix;

View File

@ -13,8 +13,8 @@ import toolbox.Maths;
public class TerrainShader extends ShaderProgram {
private static final int MAX_LIGHTS = 4;
private static final String VERTEX_FILE = "src/shaders/terrainVertexShader.txt";
private static final String FRAGMENT_FILE = "src/shaders/terrainFragmentShader.txt";
private static final String VERTEX_FILE = "src/shaders/terrain.vert";
private static final String FRAGMENT_FILE = "src/shaders/terrain.frag";
private int location_transformationMatrix;
private int location_projectionMatrix;

View File

@ -2,7 +2,6 @@ package skybox;
import org.atriaSoft.etk.math.Matrix4f;
import org.atriaSoft.etk.math.Vector3f;
import org.atriaSoft.gale.backend3d.OpenGL;
import org.atriaSoft.etk.Color;
import org.lwjgl.opengl.GL11;
@ -82,10 +81,9 @@ public class SkyboxRenderer {
}
public void render(Camera camera, Color colour) {
//OpenGL.enable(OpenGL.Flag.flag_blend);
//GL11.glBlendFunc(GL11.GL_SRC_ALPHA, GL11.GL_ONE_MINUS_SRC_ALPHA);
//OpenGL.enable(OpenGL.Flag.flag_cullFace);
//OpenGL.enable(OpenGL.Flag.flag_back);
OpenGL.enable(OpenGL.Flag.flag_blend);
OpenGL.enable(OpenGL.Flag.flag_cullFace);
OpenGL.enable(OpenGL.Flag.flag_back);
shader.start();
shader.loadViewMatrix(camera);
@ -99,9 +97,9 @@ public class SkyboxRenderer {
GL30.glBindVertexArray(0);
shader.stop();
//OpenGL.disable(OpenGL.Flag.flag_blend);
//OpenGL.disable(OpenGL.Flag.flag_cullFace);
//OpenGL.disable(OpenGL.Flag.flag_back);
OpenGL.disable(OpenGL.Flag.flag_blend);
OpenGL.disable(OpenGL.Flag.flag_cullFace);
OpenGL.disable(OpenGL.Flag.flag_back);
}
private void bindTextures(){

View File

@ -13,8 +13,8 @@ import toolbox.Maths;
public class SkyboxShader extends ShaderProgram {
private static final String VERTEX_FILE = "src/skybox/skyboxVertexShader.txt";
private static final String FRAGMENT_FILE = "src/skybox/skyboxFragmentShader.txt";
private static final String VERTEX_FILE = "src/skybox/skybox.vert";
private static final String FRAGMENT_FILE = "src/skybox/skybox.frag";
private static final float ROTATE_SPEED = 0.02f;