Added support for Android Studio
This commit is contained in:
parent
e4a7822385
commit
99a6b3728d
@ -1,432 +0,0 @@
|
||||
#Engine and libs path for Android projects
|
||||
|
||||
|
||||
ENGINE_PATH = $(SalmonEnginePathCygwin)
|
||||
|
||||
BOOST_PATH = $(LibsPathCygwin)/boost_1_52_0
|
||||
|
||||
OGG_PATH = $(LibsPathCygwin)/libogg-1.3.0
|
||||
|
||||
VORBIS_PATH = $(LibsPathCygwin)/libvorbis-1.3.2
|
||||
|
||||
SQUIRREL_PATH = $(LibsPathCygwin)/sqplus
|
||||
|
||||
LIBPNG_PATH = $(LibsPathCygwin)/libpng_1.4.1_android
|
||||
|
||||
LIBJPEG_PATH = $(LibsPathCygwin)/jpeg-9
|
||||
|
||||
ZIP_PATH = $(LibsPathCygwin)/julienr-libzip-android/jni
|
||||
|
||||
#ENGINE_PATH = $(SalmonEnginePath)
|
||||
|
||||
#BOOST_PATH = $(LibsPath)/boost_1_52_0
|
||||
|
||||
#OGG_PATH = $(LibsPath)/libogg-1.3.0
|
||||
|
||||
#VORBIS_PATH = $(LibsPath)/libvorbis-1.3.2
|
||||
|
||||
#SQUIRREL_PATH = $(LibsPath)/sqplus
|
||||
|
||||
#LIBPNG_PATH = $(LibsPath)/libpng_1.4.1_android
|
||||
|
||||
#ZIP_PATH = $(LibsPath)/julienr-libzip-android/jni
|
||||
|
||||
|
||||
#================== ZIP =================
|
||||
|
||||
LOCAL_PATH := $(ZIP_PATH)
|
||||
|
||||
include $(CLEAR_VARS)
|
||||
|
||||
LOCAL_MODULE := zip
|
||||
|
||||
LOCAL_SRC_FILES :=\
|
||||
zip_add.c \
|
||||
zip_add_dir.c \
|
||||
zip_close.c \
|
||||
zip_delete.c \
|
||||
zip_dirent.c \
|
||||
zip_entry_free.c \
|
||||
zip_entry_new.c \
|
||||
zip_err_str.c \
|
||||
zip_error.c \
|
||||
zip_error_clear.c \
|
||||
zip_error_get.c \
|
||||
zip_error_get_sys_type.c \
|
||||
zip_error_strerror.c \
|
||||
zip_error_to_str.c \
|
||||
zip_fclose.c \
|
||||
zip_file_error_clear.c \
|
||||
zip_file_error_get.c \
|
||||
zip_file_get_offset.c \
|
||||
zip_file_strerror.c \
|
||||
zip_filerange_crc.c \
|
||||
zip_fopen.c \
|
||||
zip_fopen_index.c \
|
||||
zip_fread.c \
|
||||
zip_free.c \
|
||||
zip_get_archive_comment.c \
|
||||
zip_get_archive_flag.c \
|
||||
zip_get_file_comment.c \
|
||||
zip_get_num_files.c \
|
||||
zip_get_name.c \
|
||||
zip_memdup.c \
|
||||
zip_name_locate.c \
|
||||
zip_new.c \
|
||||
zip_open.c \
|
||||
zip_rename.c \
|
||||
zip_replace.c \
|
||||
zip_set_archive_comment.c \
|
||||
zip_set_archive_flag.c \
|
||||
zip_set_file_comment.c \
|
||||
zip_source_buffer.c \
|
||||
zip_source_file.c \
|
||||
zip_source_filep.c \
|
||||
zip_source_free.c \
|
||||
zip_source_function.c \
|
||||
zip_source_zip.c \
|
||||
zip_set_name.c \
|
||||
zip_stat.c \
|
||||
zip_stat_index.c \
|
||||
zip_stat_init.c \
|
||||
zip_strerror.c \
|
||||
zip_unchange.c \
|
||||
zip_unchange_all.c \
|
||||
zip_unchange_archive.c \
|
||||
zip_unchange_data.c
|
||||
|
||||
LOCAL_LDLIBS := -lz
|
||||
|
||||
#debug
|
||||
#LOCAL_CFLAGS := -g -ggdb -O0
|
||||
#LOCAL_LDLIBS += -g -ggdb
|
||||
|
||||
|
||||
include $(BUILD_STATIC_LIBRARY)
|
||||
|
||||
#================== PNG =================
|
||||
|
||||
LOCAL_PATH := $(LIBPNG_PATH)
|
||||
include $(CLEAR_VARS)
|
||||
|
||||
LOCAL_MODULE := png_lib
|
||||
LOCAL_SRC_FILES :=\
|
||||
png.c \
|
||||
pngerror.c \
|
||||
pngget.c \
|
||||
pngmem.c \
|
||||
pngpread.c \
|
||||
pngread.c \
|
||||
pngrio.c \
|
||||
pngrtran.c \
|
||||
pngrutil.c \
|
||||
pngset.c \
|
||||
pngtrans.c \
|
||||
pngwio.c \
|
||||
pngwrite.c \
|
||||
pngwtran.c \
|
||||
pngwutil.c
|
||||
|
||||
LOCAL_LDLIBS := -lz
|
||||
|
||||
#debug
|
||||
#LOCAL_CFLAGS := -g -ggdb -O0
|
||||
#LOCAL_LDLIBS += -g -ggdb
|
||||
|
||||
include $(BUILD_STATIC_LIBRARY)
|
||||
|
||||
|
||||
#=============== JPEG =============
|
||||
|
||||
LOCAL_PATH := $(LIBJPEG_PATH)
|
||||
include $(CLEAR_VARS)
|
||||
|
||||
LOCAL_C_INCLUDES := $(LIBJPEG_PATH)
|
||||
LOCAL_C_INCLUDES += $(LIBJPEG_PATH)/vc10
|
||||
|
||||
|
||||
LOCAL_MODULE := jpeg
|
||||
LOCAL_SRC_FILES :=\
|
||||
jaricom.c\
|
||||
jcapimin.c\
|
||||
jcapistd.c\
|
||||
jcarith.c\
|
||||
jccoefct.c\
|
||||
jccolor.c\
|
||||
jcdctmgr.c\
|
||||
jchuff.c\
|
||||
jcinit.c\
|
||||
jcmainct.c\
|
||||
jcmarker.c\
|
||||
jcmaster.c\
|
||||
jcomapi.c\
|
||||
jcparam.c\
|
||||
jcprepct.c\
|
||||
jcsample.c\
|
||||
jctrans.c\
|
||||
jdapimin.c\
|
||||
jdapistd.c\
|
||||
jdarith.c\
|
||||
jdatadst.c\
|
||||
jdatasrc.c\
|
||||
jdcoefct.c\
|
||||
jdcolor.c\
|
||||
jddctmgr.c\
|
||||
jdhuff.c\
|
||||
jdinput.c\
|
||||
jdmainct.c\
|
||||
jdmarker.c\
|
||||
jdmaster.c\
|
||||
jdmerge.c\
|
||||
jdpostct.c\
|
||||
jdsample.c\
|
||||
jdtrans.c\
|
||||
jerror.c\
|
||||
jfdctflt.c\
|
||||
jfdctfst.c\
|
||||
jfdctint.c\
|
||||
jidctflt.c\
|
||||
jidctfst.c\
|
||||
jidctint.c\
|
||||
jmemmgr.c\
|
||||
jmemnobs.c\
|
||||
jquant1.c\
|
||||
jquant2.c\
|
||||
jutils.c
|
||||
|
||||
LOCAL_LDLIBS :=
|
||||
|
||||
#debug
|
||||
#LOCAL_CFLAGS := -g -ggdb -O0
|
||||
#LOCAL_LDLIBS += -g -ggdb
|
||||
|
||||
include $(BUILD_STATIC_LIBRARY)
|
||||
|
||||
|
||||
#================== SQUIRREL =================
|
||||
|
||||
|
||||
include $(CLEAR_VARS)
|
||||
|
||||
LOCAL_MODULE := squirrel
|
||||
LOCAL_PATH := $(SQUIRREL_PATH)
|
||||
LOCAL_C_INCLUDES := $(SQUIRREL_PATH)/include $(SQUIRREL_PATH)/sqplus/sqplus $(SQUIRREL_PATH)/squirrel $(SQUIRREL_PATH)/sqstdlib
|
||||
LOCAL_SRC_FILES := squirrel/sqapi.cpp \
|
||||
squirrel/sqbaselib.cpp \
|
||||
squirrel/sqclass.cpp \
|
||||
squirrel/sqcompiler.cpp \
|
||||
squirrel/sqdebug.cpp \
|
||||
squirrel/sqfuncstate.cpp \
|
||||
squirrel/sqlexer.cpp \
|
||||
squirrel/sqmem.cpp \
|
||||
squirrel/sqobject.cpp \
|
||||
squirrel/sqstate.cpp \
|
||||
squirrel/sqtable.cpp \
|
||||
squirrel/sqvm.cpp \
|
||||
sqplus/SqPlus.cpp \
|
||||
sqplus/SqPlusOCharBuf.cpp \
|
||||
sqplus/SqPlusUtf8.cpp \
|
||||
sqplus/SquirrelBindingsUtils.cpp \
|
||||
sqplus/SquirrelObject.cpp \
|
||||
sqplus/SquirrelVM.cpp \
|
||||
sqstdlib/sqstdblob.cpp \
|
||||
sqstdlib/sqstdio.cpp \
|
||||
sqstdlib/sqstdmath.cpp \
|
||||
sqstdlib/sqstdrex.cpp \
|
||||
sqstdlib/sqstdstream.cpp \
|
||||
sqstdlib/sqstdstring.cpp \
|
||||
sqstdlib/sqstdsystem.cpp \
|
||||
sqstdlib/sqstdaux.cpp \
|
||||
|
||||
|
||||
#debug
|
||||
#LOCAL_CFLAGS := -g -ggdb -O0
|
||||
#LOCAL_LDLIBS := -g -ggdb
|
||||
|
||||
include $(BUILD_STATIC_LIBRARY)
|
||||
|
||||
|
||||
#================== OGG / VORBIS / VORBISFILE ===================
|
||||
|
||||
include $(CLEAR_VARS)
|
||||
|
||||
LOCAL_MODULE := vorbis
|
||||
|
||||
LOCAL_PATH := $(VORBIS_PATH)/lib
|
||||
LOCAL_C_INCLUDES := $(VORBIS_PATH)/include
|
||||
LOCAL_C_INCLUDES += $(VORBIS_PATH)/include/vorbis
|
||||
LOCAL_C_INCLUDES += $(VORBIS_PATH)/lib/src
|
||||
LOCAL_C_INCLUDES += $(VORBIS_PATH)/lib/books
|
||||
LOCAL_C_INCLUDES += $(VORBIS_PATH)/lib/modes
|
||||
LOCAL_C_INCLUDES += $(OGG_PATH)/include
|
||||
LOCAL_C_INCLUDES += $(OGG_PATH)/include/ogg
|
||||
LOCAL_SRC_FILES := ../../libogg-1.3.0/src/framing.c ../../libogg-1.3.0/src/bitwise.c
|
||||
LOCAL_SRC_FILES += mdct.c smallft.c block.c envelope.c window.c lsp.c \
|
||||
lpc.c analysis.c synthesis.c psy.c info.c \
|
||||
floor1.c floor0.c\
|
||||
res0.c mapping0.c registry.c codebook.c sharedbook.c\
|
||||
lookup.c bitrate.c
|
||||
LOCAL_SRC_FILES += vorbisfile.c
|
||||
|
||||
#debug
|
||||
#LOCAL_CFLAGS := -g -ggdb -O0
|
||||
#LOCAL_LDLIBS := -g -ggdb
|
||||
|
||||
include $(BUILD_STATIC_LIBRARY)
|
||||
|
||||
|
||||
#================== BOOST ====================
|
||||
|
||||
LOCAL_PATH := $(BOOST_PATH)
|
||||
|
||||
include $(CLEAR_VARS)
|
||||
|
||||
LOCAL_MODULE := boost
|
||||
LOCAL_C_INCLUDES := $(BOOST_PATH)
|
||||
|
||||
LOCAL_CFLAGS := -std=gnu++11 --std=c++11
|
||||
|
||||
|
||||
#thread
|
||||
LOCAL_SRC_FILES := /libs/thread/src/pthread/thread.cpp
|
||||
LOCAL_SRC_FILES += /libs/thread/src/pthread/once.cpp
|
||||
|
||||
#signals
|
||||
LOCAL_SRC_FILES += /libs/signals/src/connection.cpp
|
||||
LOCAL_SRC_FILES += /libs/signals/src/named_slot_map.cpp
|
||||
LOCAL_SRC_FILES += /libs/signals/src/signal_base.cpp
|
||||
LOCAL_SRC_FILES += /libs/signals/src/slot.cpp
|
||||
LOCAL_SRC_FILES += /libs/signals/src/trackable.cpp
|
||||
|
||||
#system
|
||||
LOCAL_SRC_FILES += /libs/system/src/error_code.cpp
|
||||
|
||||
#regex
|
||||
LOCAL_SRC_FILES += /libs/regex/src/c_regex_traits.cpp
|
||||
LOCAL_SRC_FILES += /libs/regex/src/cpp_regex_traits.cpp
|
||||
LOCAL_SRC_FILES += /libs/regex/src/cregex.cpp
|
||||
LOCAL_SRC_FILES += /libs/regex/src/fileiter.cpp
|
||||
LOCAL_SRC_FILES += /libs/regex/src/icu.cpp
|
||||
LOCAL_SRC_FILES += /libs/regex/src/instances.cpp
|
||||
LOCAL_SRC_FILES += /libs/regex/src/posix_api.cpp
|
||||
LOCAL_SRC_FILES += /libs/regex/src/regex.cpp
|
||||
LOCAL_SRC_FILES += /libs/regex/src/regex_debug.cpp
|
||||
LOCAL_SRC_FILES += /libs/regex/src/regex_raw_buffer.cpp
|
||||
LOCAL_SRC_FILES += /libs/regex/src/regex_traits_defaults.cpp
|
||||
LOCAL_SRC_FILES += /libs/regex/src/static_mutex.cpp
|
||||
LOCAL_SRC_FILES += /libs/regex/src/usinstances.cpp
|
||||
LOCAL_SRC_FILES += /libs/regex/src/w32_regex_traits.cpp
|
||||
LOCAL_SRC_FILES += /libs/regex/src/wc_regex_traits.cpp
|
||||
LOCAL_SRC_FILES += /libs/regex/src/wide_posix_api.cpp
|
||||
LOCAL_SRC_FILES += /libs/regex/src/winstances.cpp
|
||||
|
||||
#date_time
|
||||
LOCAL_SRC_FILES += /libs/date_time/src/gregorian/greg_month.cpp
|
||||
LOCAL_SRC_FILES += /libs/date_time/src/gregorian/greg_weekday.cpp
|
||||
LOCAL_SRC_FILES += /libs/date_time/src/gregorian/date_generators.cpp
|
||||
|
||||
#asio
|
||||
#nothing
|
||||
|
||||
LOCAL_LDLIBS := -llog -Wl
|
||||
|
||||
#debug
|
||||
#LOCAL_CFLAGS += -g -ggdb -O0
|
||||
#LOCAL_LDLIBS += -g -ggdb
|
||||
|
||||
|
||||
include $(BUILD_STATIC_LIBRARY)
|
||||
|
||||
|
||||
#============= SALMON ENGINE ================
|
||||
|
||||
LOCAL_PATH := $(ENGINE_PATH)
|
||||
|
||||
include $(CLEAR_VARS)
|
||||
|
||||
LOCAL_MODULE := SalmonEngine
|
||||
|
||||
|
||||
LOCAL_CFLAGS := -DTARGET_ANDROID -std=gnu++11 --std=c++11
|
||||
|
||||
LOCAL_STATIC_LIBRARIES := boost
|
||||
LOCAL_STATIC_LIBRARIES += ogg
|
||||
LOCAL_STATIC_LIBRARIES += vorbis
|
||||
LOCAL_STATIC_LIBRARIES += squirrel
|
||||
LOCAL_STATIC_LIBRARIES += png_lib
|
||||
LOCAL_STATIC_LIBRARIES += jpeg
|
||||
LOCAL_STATIC_LIBRARIES += zip
|
||||
LOCAL_SHARED_LIBRARIES := gnustl_shared
|
||||
LOCAL_C_INCLUDES := $(BOOST_PATH)
|
||||
LOCAL_C_INCLUDES += $(VORBIS_PATH)/include
|
||||
LOCAL_C_INCLUDES += $(VORBIS_PATH)/include/vorbis
|
||||
LOCAL_C_INCLUDES += $(VORBIS_PATH)/lib
|
||||
LOCAL_C_INCLUDES += $(VORBIS_PATH)/lib/books
|
||||
LOCAL_C_INCLUDES += $(VORBIS_PATH)/lib/modes
|
||||
LOCAL_C_INCLUDES += $(OGG_PATH)/include
|
||||
LOCAL_C_INCLUDES += $(OGG_PATH)/include/ogg
|
||||
LOCAL_C_INCLUDES += $(SQUIRREL_PATH)/include
|
||||
LOCAL_C_INCLUDES += $(SQUIRREL_PATH)/sqplus
|
||||
LOCAL_C_INCLUDES += $(SQUIRREL_PATH)/sqstdlib
|
||||
LOCAL_C_INCLUDES += $(SQUIRREL_PATH)/squirrel
|
||||
LOCAL_C_INCLUDES += $(LIBPNG_PATH)
|
||||
LOCAL_C_INCLUDES += $(LIBJPEG_PATH)
|
||||
LOCAL_C_INCLUDES += $(LIBJPEG_PATH)/vc10
|
||||
LOCAL_C_INCLUDES += $(ZIP_PATH)
|
||||
LOCAL_SRC_FILES := src/Utils/DataTypes/DataTypes.cpp
|
||||
LOCAL_SRC_FILES += src/Utils/DataTypes/NewDataTypes.cpp
|
||||
LOCAL_SRC_FILES += src/Utils/FileUtils/FileUtils.cpp
|
||||
LOCAL_SRC_FILES += src/Utils/JniApi/JniApi.cpp
|
||||
LOCAL_SRC_FILES += src/Utils/JniApi/JniApplication.cpp
|
||||
LOCAL_SRC_FILES += src/Utils/Console/Console.cpp
|
||||
LOCAL_SRC_FILES += src/Utils/SerializeInterface/SerializeInterface.cpp
|
||||
LOCAL_SRC_FILES += src/Utils/Network/Network.cpp
|
||||
LOCAL_SRC_FILES += src/Utils/PngHelper.cpp
|
||||
LOCAL_SRC_FILES += src/Utils/JpegHelper.cpp
|
||||
LOCAL_SRC_FILES += src/Utils/TgaLoader.cpp
|
||||
LOCAL_SRC_FILES += src/Utils/SimpleTimer.cpp
|
||||
LOCAL_SRC_FILES += src/Utils/ThreadUtils.cpp
|
||||
LOCAL_SRC_FILES += src/TextureManager/SalmonTexture.cpp
|
||||
LOCAL_SRC_FILES += src/ShaderManager/ShaderManager.cpp
|
||||
LOCAL_SRC_FILES += src/FrameManager/FrameManager.cpp
|
||||
LOCAL_SRC_FILES += src/LightManager/LightManager.cpp
|
||||
LOCAL_SRC_FILES += src/SoundManager/SoundManagerAndroid.cpp
|
||||
LOCAL_SRC_FILES += src/SoundManager/SoundManagerDataTypes.cpp
|
||||
LOCAL_SRC_FILES += src/FontManager/FontManager.cpp
|
||||
LOCAL_SRC_FILES += src/ScriptManager/ScriptManager.cpp
|
||||
LOCAL_SRC_FILES += src/SmartValueManager/SmartValueManager.cpp
|
||||
|
||||
LOCAL_SRC_FILES += src/GUIManager/GUIManager.cpp
|
||||
LOCAL_SRC_FILES += src/GUIManager/ButtonWidget.cpp
|
||||
LOCAL_SRC_FILES += src/GUIManager/WidgetXmlParsers.cpp
|
||||
|
||||
LOCAL_SRC_FILES += src/HalibutAnimation/HalibutAnimation.cpp
|
||||
|
||||
LOCAL_SRC_FILES += src/ModelManager/ModelManager.cpp
|
||||
LOCAL_SRC_FILES += src/ModelManager/NewModelManager.cpp
|
||||
LOCAL_SRC_FILES += src/SimpleLand/SimpleLand.cpp
|
||||
LOCAL_SRC_FILES += src/PhysicsManager/PhysicsManager.cpp
|
||||
|
||||
LOCAL_SRC_FILES += src/Render/RenderMisc.cpp
|
||||
LOCAL_SRC_FILES += src/Render/RenderParams.cpp
|
||||
|
||||
LOCAL_SRC_FILES += src/Render/SalmonRender/BackgroundCubemap.cpp
|
||||
LOCAL_SRC_FILES += src/Render/SalmonRender/SalmonRenderInterface.cpp
|
||||
LOCAL_SRC_FILES += src/Render/SalmonRender/SalmonRenderGLES20.cpp
|
||||
LOCAL_SRC_FILES += src/Render/SalmonRender/SalmonRenderAndroid.cpp
|
||||
LOCAL_SRC_FILES += src/Render/SalmonRender/Cameras.cpp
|
||||
|
||||
LOCAL_SRC_FILES += src/Animation/SalmonAnimation.cpp
|
||||
LOCAL_SRC_FILES += src/SalmonEngineAndroid.cpp
|
||||
LOCAL_SRC_FILES += src/SalmonEngineInterface.cpp
|
||||
LOCAL_LDLIBS := -lGLESv2
|
||||
|
||||
LOCAL_LDLIBS += -llog -Wl -lz
|
||||
|
||||
#debug
|
||||
#LOCAL_CFLAGS += -g -ggdb -O0
|
||||
#LOCAL_LDLIBS += -g -ggdb
|
||||
|
||||
#no -s cause no need stripping!!!!
|
||||
|
||||
include $(BUILD_SHARED_LIBRARY)
|
9
SalmonEngineAndroid/.gitignore
vendored
Executable file
9
SalmonEngineAndroid/.gitignore
vendored
Executable file
@ -0,0 +1,9 @@
|
||||
*.iml
|
||||
.gradle
|
||||
/local.properties
|
||||
/.idea/workspace.xml
|
||||
/.idea/libraries
|
||||
.DS_Store
|
||||
/build
|
||||
/captures
|
||||
.externalNativeBuild
|
22
SalmonEngineAndroid/.idea/compiler.xml
Executable file
22
SalmonEngineAndroid/.idea/compiler.xml
Executable file
@ -0,0 +1,22 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="CompilerConfiguration">
|
||||
<resourceExtensions />
|
||||
<wildcardResourcePatterns>
|
||||
<entry name="!?*.java" />
|
||||
<entry name="!?*.form" />
|
||||
<entry name="!?*.class" />
|
||||
<entry name="!?*.groovy" />
|
||||
<entry name="!?*.scala" />
|
||||
<entry name="!?*.flex" />
|
||||
<entry name="!?*.kt" />
|
||||
<entry name="!?*.clj" />
|
||||
<entry name="!?*.aj" />
|
||||
</wildcardResourcePatterns>
|
||||
<annotationProcessing>
|
||||
<profile default="true" name="Default" enabled="false">
|
||||
<processorPath useClasspath="true" />
|
||||
</profile>
|
||||
</annotationProcessing>
|
||||
</component>
|
||||
</project>
|
3
SalmonEngineAndroid/.idea/copyright/profiles_settings.xml
Executable file
3
SalmonEngineAndroid/.idea/copyright/profiles_settings.xml
Executable file
@ -0,0 +1,3 @@
|
||||
<component name="CopyrightManager">
|
||||
<settings default="" />
|
||||
</component>
|
6
SalmonEngineAndroid/.idea/encodings.xml
Executable file
6
SalmonEngineAndroid/.idea/encodings.xml
Executable file
@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="Encoding">
|
||||
<file url="PROJECT" charset="UTF-8" />
|
||||
</component>
|
||||
</project>
|
19
SalmonEngineAndroid/.idea/gradle.xml
Executable file
19
SalmonEngineAndroid/.idea/gradle.xml
Executable file
@ -0,0 +1,19 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="GradleSettings">
|
||||
<option name="linkedExternalProjectsSettings">
|
||||
<GradleProjectSettings>
|
||||
<option name="distributionType" value="LOCAL" />
|
||||
<option name="externalProjectPath" value="$PROJECT_DIR$" />
|
||||
<option name="gradleHome" value="C:\Android\Android Studio\gradle\gradle-2.14.1" />
|
||||
<option name="modules">
|
||||
<set>
|
||||
<option value="$PROJECT_DIR$" />
|
||||
<option value="$PROJECT_DIR$/app" />
|
||||
</set>
|
||||
</option>
|
||||
<option name="resolveModulePerSourceSet" value="false" />
|
||||
</GradleProjectSettings>
|
||||
</option>
|
||||
</component>
|
||||
</project>
|
49
SalmonEngineAndroid/.idea/misc.xml
Executable file
49
SalmonEngineAndroid/.idea/misc.xml
Executable file
@ -0,0 +1,49 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="EntryPointsManager">
|
||||
<entry_points version="2.0" />
|
||||
</component>
|
||||
<component name="NullableNotNullManager">
|
||||
<option name="myDefaultNullable" value="android.support.annotation.Nullable" />
|
||||
<option name="myDefaultNotNull" value="android.support.annotation.NonNull" />
|
||||
<option name="myNullables">
|
||||
<value>
|
||||
<list size="4">
|
||||
<item index="0" class="java.lang.String" itemvalue="org.jetbrains.annotations.Nullable" />
|
||||
<item index="1" class="java.lang.String" itemvalue="javax.annotation.Nullable" />
|
||||
<item index="2" class="java.lang.String" itemvalue="edu.umd.cs.findbugs.annotations.Nullable" />
|
||||
<item index="3" class="java.lang.String" itemvalue="android.support.annotation.Nullable" />
|
||||
</list>
|
||||
</value>
|
||||
</option>
|
||||
<option name="myNotNulls">
|
||||
<value>
|
||||
<list size="4">
|
||||
<item index="0" class="java.lang.String" itemvalue="org.jetbrains.annotations.NotNull" />
|
||||
<item index="1" class="java.lang.String" itemvalue="javax.annotation.Nonnull" />
|
||||
<item index="2" class="java.lang.String" itemvalue="edu.umd.cs.findbugs.annotations.NonNull" />
|
||||
<item index="3" class="java.lang.String" itemvalue="android.support.annotation.NonNull" />
|
||||
</list>
|
||||
</value>
|
||||
</option>
|
||||
</component>
|
||||
<component name="ProjectLevelVcsManager" settingsEditedManually="false">
|
||||
<OptionsSetting value="true" id="Add" />
|
||||
<OptionsSetting value="true" id="Remove" />
|
||||
<OptionsSetting value="true" id="Checkout" />
|
||||
<OptionsSetting value="true" id="Update" />
|
||||
<OptionsSetting value="true" id="Status" />
|
||||
<OptionsSetting value="true" id="Edit" />
|
||||
<ConfirmationsSetting value="0" id="Add" />
|
||||
<ConfirmationsSetting value="0" id="Remove" />
|
||||
</component>
|
||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_1_8" default="true" assert-keyword="true" jdk-15="true" project-jdk-name="1.8" project-jdk-type="JavaSDK">
|
||||
<output url="file://$PROJECT_DIR$/build/classes" />
|
||||
</component>
|
||||
<component name="ProjectType">
|
||||
<option name="id" value="Android" />
|
||||
</component>
|
||||
<component name="SvnBranchConfigurationManager">
|
||||
<option name="mySupportsUserInfoFilter" value="true" />
|
||||
</component>
|
||||
</project>
|
9
SalmonEngineAndroid/.idea/modules.xml
Executable file
9
SalmonEngineAndroid/.idea/modules.xml
Executable file
@ -0,0 +1,9 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ProjectModuleManager">
|
||||
<modules>
|
||||
<module fileurl="file://$PROJECT_DIR$/SalmonEngineAndroid.iml" filepath="$PROJECT_DIR$/SalmonEngineAndroid.iml" />
|
||||
<module fileurl="file://$PROJECT_DIR$/app/app.iml" filepath="$PROJECT_DIR$/app/app.iml" />
|
||||
</modules>
|
||||
</component>
|
||||
</project>
|
12
SalmonEngineAndroid/.idea/runConfigurations.xml
Executable file
12
SalmonEngineAndroid/.idea/runConfigurations.xml
Executable file
@ -0,0 +1,12 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="RunConfigurationProducerService">
|
||||
<option name="ignoredProducers">
|
||||
<set>
|
||||
<option value="org.jetbrains.plugins.gradle.execution.test.runner.AllInPackageGradleConfigurationProducer" />
|
||||
<option value="org.jetbrains.plugins.gradle.execution.test.runner.TestClassGradleConfigurationProducer" />
|
||||
<option value="org.jetbrains.plugins.gradle.execution.test.runner.TestMethodGradleConfigurationProducer" />
|
||||
</set>
|
||||
</option>
|
||||
</component>
|
||||
</project>
|
10
SalmonEngineAndroid/.idea/vcs.xml
Executable file
10
SalmonEngineAndroid/.idea/vcs.xml
Executable file
@ -0,0 +1,10 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="VcsDirectoryMappings">
|
||||
<mapping directory="$PROJECT_DIR$/../../libs/jpeg-9" vcs="svn" />
|
||||
<mapping directory="$PROJECT_DIR$/../../libs/julienr-libzip-android/jni" vcs="svn" />
|
||||
<mapping directory="$PROJECT_DIR$/../../libs/libogg-1.3.0/src" vcs="svn" />
|
||||
<mapping directory="$PROJECT_DIR$/../../libs/libpng_1.4.1_android" vcs="svn" />
|
||||
<mapping directory="$PROJECT_DIR$/../../libs/libvorbis-1.3.2/lib" vcs="svn" />
|
||||
</component>
|
||||
</project>
|
1
SalmonEngineAndroid/app/.gitignore
vendored
Executable file
1
SalmonEngineAndroid/app/.gitignore
vendored
Executable file
@ -0,0 +1 @@
|
||||
/build
|
372
SalmonEngineAndroid/app/CMakeLists.txt
Executable file
372
SalmonEngineAndroid/app/CMakeLists.txt
Executable file
@ -0,0 +1,372 @@
|
||||
|
||||
# Sets the minimum version of CMake required to build the native
|
||||
# library. You should either keep the default value or only pass a
|
||||
# value of 3.4.0 or lower.
|
||||
|
||||
cmake_minimum_required(VERSION 3.4.1)
|
||||
|
||||
# Creates and names a library, sets it as either STATIC
|
||||
# or SHARED, and provides the relative paths to its source code.
|
||||
# You can define multiple libraries, and CMake builds it for you.
|
||||
# Gradle automatically packages shared libraries with your APK.
|
||||
|
||||
|
||||
|
||||
#ENGINE_PATH = $(SalmonEnginePathCygwin)
|
||||
|
||||
#BOOST_PATH = $(LibsPathCygwin)/boost_1_52_0
|
||||
|
||||
#OGG_PATH = $(LibsPathCygwin)/libogg-1.3.0
|
||||
|
||||
#VORBIS_PATH = $(LibsPathCygwin)/libvorbis-1.3.2
|
||||
|
||||
#SQUIRREL_PATH = $(LibsPathCygwin)/sqplus
|
||||
|
||||
#LIBPNG_PATH = $(LibsPathCygwin)/libpng_1.4.1_android
|
||||
|
||||
#LIBJPEG_PATH = $(LibsPathCygwin)/jpeg-9
|
||||
|
||||
#ZIP_PATH = $(LibsPathCygwin)/julienr-libzip-android/jni
|
||||
|
||||
set(BOOST_PATH ${CMAKE_CURRENT_SOURCE_DIR}/../../../boost_1_63_0)
|
||||
|
||||
set(BOOST_GIL_PATH ${CMAKE_CURRENT_SOURCE_DIR}/../../../libs/boost-gil-extension)
|
||||
|
||||
set(ZIP_PATH ${CMAKE_CURRENT_SOURCE_DIR}/../../../libs/julienr-libzip-android/jni)
|
||||
|
||||
set(LIBPNG_PATH ${CMAKE_CURRENT_SOURCE_DIR}/../../../libs/libpng_1.4.1_android)
|
||||
|
||||
set(LIBJPEG_PATH "${CMAKE_CURRENT_SOURCE_DIR}/../../../libs/jpeg-9")
|
||||
|
||||
set(SQUIRREL_PATH ${CMAKE_CURRENT_SOURCE_DIR}/../../../libs/sqplus)
|
||||
|
||||
set(OGG_PATH ${CMAKE_CURRENT_SOURCE_DIR}/../../../libs/libogg-1.3.0)
|
||||
|
||||
set(VORBIS_PATH ${CMAKE_CURRENT_SOURCE_DIR}/../../../libs/libvorbis-1.3.2)
|
||||
|
||||
|
||||
#include_directories(ZIP_PATH)
|
||||
|
||||
add_library(zip
|
||||
${ZIP_PATH}/zip_add.c
|
||||
${ZIP_PATH}/zip_add_dir.c
|
||||
${ZIP_PATH}/zip_close.c
|
||||
${ZIP_PATH}/zip_delete.c
|
||||
${ZIP_PATH}/zip_dirent.c
|
||||
${ZIP_PATH}/zip_entry_free.c
|
||||
${ZIP_PATH}/zip_entry_new.c
|
||||
${ZIP_PATH}/zip_err_str.c
|
||||
${ZIP_PATH}/zip_error.c
|
||||
${ZIP_PATH}/zip_error_clear.c
|
||||
${ZIP_PATH}/zip_error_get.c
|
||||
${ZIP_PATH}/zip_error_get_sys_type.c
|
||||
${ZIP_PATH}/zip_error_strerror.c
|
||||
${ZIP_PATH}/zip_error_to_str.c
|
||||
${ZIP_PATH}/zip_fclose.c
|
||||
${ZIP_PATH}/zip_file_error_clear.c
|
||||
${ZIP_PATH}/zip_file_error_get.c
|
||||
${ZIP_PATH}/zip_file_get_offset.c
|
||||
${ZIP_PATH}/zip_file_strerror.c
|
||||
${ZIP_PATH}/zip_filerange_crc.c
|
||||
${ZIP_PATH}/zip_fopen.c
|
||||
${ZIP_PATH}/zip_fopen_index.c
|
||||
${ZIP_PATH}/zip_fread.c
|
||||
${ZIP_PATH}/zip_free.c
|
||||
${ZIP_PATH}/zip_get_archive_comment.c
|
||||
${ZIP_PATH}/zip_get_archive_flag.c
|
||||
${ZIP_PATH}/zip_get_file_comment.c
|
||||
${ZIP_PATH}/zip_get_num_files.c
|
||||
${ZIP_PATH}/zip_get_name.c
|
||||
${ZIP_PATH}/zip_memdup.c
|
||||
${ZIP_PATH}/zip_name_locate.c
|
||||
${ZIP_PATH}/zip_new.c
|
||||
${ZIP_PATH}/zip_open.c
|
||||
${ZIP_PATH}/zip_rename.c
|
||||
${ZIP_PATH}/zip_replace.c
|
||||
${ZIP_PATH}/zip_set_archive_comment.c
|
||||
${ZIP_PATH}/zip_set_archive_flag.c
|
||||
${ZIP_PATH}/zip_set_file_comment.c
|
||||
${ZIP_PATH}/zip_source_buffer.c
|
||||
${ZIP_PATH}/zip_source_file.c
|
||||
${ZIP_PATH}/zip_source_filep.c
|
||||
${ZIP_PATH}/zip_source_free.c
|
||||
${ZIP_PATH}/zip_source_function.c
|
||||
${ZIP_PATH}/zip_source_zip.c
|
||||
${ZIP_PATH}/zip_set_name.c
|
||||
${ZIP_PATH}/zip_stat.c
|
||||
${ZIP_PATH}/zip_stat_index.c
|
||||
${ZIP_PATH}/zip_stat_init.c
|
||||
${ZIP_PATH}/zip_strerror.c
|
||||
${ZIP_PATH}/zip_unchange.c
|
||||
${ZIP_PATH}/zip_unchange_all.c
|
||||
${ZIP_PATH}/zip_unchange_archive.c
|
||||
${ZIP_PATH}/zip_unchange_data.c
|
||||
)
|
||||
|
||||
#include_directories(LIBPNG_PATH)
|
||||
|
||||
add_library(png
|
||||
${LIBPNG_PATH}/png.c
|
||||
${LIBPNG_PATH}/pngerror.c
|
||||
${LIBPNG_PATH}/pngget.c
|
||||
${LIBPNG_PATH}/pngmem.c
|
||||
${LIBPNG_PATH}/pngpread.c
|
||||
${LIBPNG_PATH}/pngread.c
|
||||
${LIBPNG_PATH}/pngrio.c
|
||||
${LIBPNG_PATH}/pngrtran.c
|
||||
${LIBPNG_PATH}/pngrutil.c
|
||||
${LIBPNG_PATH}/pngset.c
|
||||
${LIBPNG_PATH}/pngtrans.c
|
||||
${LIBPNG_PATH}/pngwio.c
|
||||
${LIBPNG_PATH}/pngwrite.c
|
||||
${LIBPNG_PATH}/pngwtran.c
|
||||
${LIBPNG_PATH}/pngwutil.c
|
||||
)
|
||||
|
||||
include_directories(${LIBJPEG_PATH}/vc10)
|
||||
|
||||
add_library(jpeg
|
||||
${LIBJPEG_PATH}/jaricom.c
|
||||
${LIBJPEG_PATH}/jcapimin.c
|
||||
${LIBJPEG_PATH}/jcapistd.c
|
||||
${LIBJPEG_PATH}/jcarith.c
|
||||
${LIBJPEG_PATH}/jccoefct.c
|
||||
${LIBJPEG_PATH}/jccolor.c
|
||||
${LIBJPEG_PATH}/jcdctmgr.c
|
||||
${LIBJPEG_PATH}/jchuff.c
|
||||
${LIBJPEG_PATH}/jcinit.c
|
||||
${LIBJPEG_PATH}/jcmainct.c
|
||||
${LIBJPEG_PATH}/jcmarker.c
|
||||
${LIBJPEG_PATH}/jcmaster.c
|
||||
${LIBJPEG_PATH}/jcomapi.c
|
||||
${LIBJPEG_PATH}/jcparam.c
|
||||
${LIBJPEG_PATH}/jcprepct.c
|
||||
${LIBJPEG_PATH}/jcsample.c
|
||||
${LIBJPEG_PATH}/jctrans.c
|
||||
${LIBJPEG_PATH}/jdapimin.c
|
||||
${LIBJPEG_PATH}/jdapistd.c
|
||||
${LIBJPEG_PATH}/jdarith.c
|
||||
${LIBJPEG_PATH}/jdatadst.c
|
||||
${LIBJPEG_PATH}/jdatasrc.c
|
||||
${LIBJPEG_PATH}/jdcoefct.c
|
||||
${LIBJPEG_PATH}/jdcolor.c
|
||||
${LIBJPEG_PATH}/jddctmgr.c
|
||||
${LIBJPEG_PATH}/jdhuff.c
|
||||
${LIBJPEG_PATH}/jdinput.c
|
||||
${LIBJPEG_PATH}/jdmainct.c
|
||||
${LIBJPEG_PATH}/jdmarker.c
|
||||
${LIBJPEG_PATH}/jdmaster.c
|
||||
${LIBJPEG_PATH}/jdmerge.c
|
||||
${LIBJPEG_PATH}/jdpostct.c
|
||||
${LIBJPEG_PATH}/jdsample.c
|
||||
${LIBJPEG_PATH}/jdtrans.c
|
||||
${LIBJPEG_PATH}/jerror.c
|
||||
${LIBJPEG_PATH}/jfdctflt.c
|
||||
${LIBJPEG_PATH}/jfdctfst.c
|
||||
${LIBJPEG_PATH}/jfdctint.c
|
||||
${LIBJPEG_PATH}/jidctflt.c
|
||||
${LIBJPEG_PATH}/jidctfst.c
|
||||
${LIBJPEG_PATH}/jidctint.c
|
||||
${LIBJPEG_PATH}/jmemmgr.c
|
||||
${LIBJPEG_PATH}/jmemnobs.c
|
||||
${LIBJPEG_PATH}/jquant1.c
|
||||
${LIBJPEG_PATH}/jquant2.c
|
||||
${LIBJPEG_PATH}/jutils.c
|
||||
)
|
||||
|
||||
|
||||
|
||||
#LOCAL_PATH := $(VORBIS_PATH)/lib
|
||||
#LOCAL_C_INCLUDES := $(VORBIS_PATH)/include
|
||||
#LOCAL_C_INCLUDES += $(VORBIS_PATH)/include/vorbis
|
||||
#LOCAL_C_INCLUDES += $(VORBIS_PATH)/lib/src
|
||||
#LOCAL_C_INCLUDES += $(VORBIS_PATH)/lib/books
|
||||
#LOCAL_C_INCLUDES += $(VORBIS_PATH)/lib/modes
|
||||
#LOCAL_C_INCLUDES += $(OGG_PATH)/include
|
||||
#LOCAL_C_INCLUDES += $(OGG_PATH)/include/ogg
|
||||
|
||||
include_directories(${OGG_PATH}/include)
|
||||
include_directories(${VORBIS_PATH}/include)
|
||||
|
||||
add_library(ogg
|
||||
${OGG_PATH}/src/framing.c
|
||||
${OGG_PATH}/src/bitwise.c
|
||||
)
|
||||
|
||||
add_library(vorbis
|
||||
${VORBIS_PATH}/lib/mdct.c
|
||||
${VORBIS_PATH}/lib/smallft.c
|
||||
${VORBIS_PATH}/lib/block.c
|
||||
${VORBIS_PATH}/lib/envelope.c
|
||||
${VORBIS_PATH}/lib/window.c
|
||||
${VORBIS_PATH}/lib/lsp.c
|
||||
${VORBIS_PATH}/lib/lpc.c
|
||||
${VORBIS_PATH}/lib/analysis.c
|
||||
${VORBIS_PATH}/lib/synthesis.c
|
||||
${VORBIS_PATH}/lib/psy.c
|
||||
${VORBIS_PATH}/lib/info.c
|
||||
${VORBIS_PATH}/lib/floor1.c
|
||||
${VORBIS_PATH}/lib/floor0.c
|
||||
${VORBIS_PATH}/lib/res0.c
|
||||
${VORBIS_PATH}/lib/mapping0.c
|
||||
${VORBIS_PATH}/lib/registry.c
|
||||
${VORBIS_PATH}/lib/codebook.c
|
||||
${VORBIS_PATH}/lib/sharedbook.c
|
||||
${VORBIS_PATH}/lib/lookup.c
|
||||
${VORBIS_PATH}/lib/bitrate.c
|
||||
${VORBIS_PATH}/lib/vorbisfile.c
|
||||
)
|
||||
|
||||
|
||||
include_directories(${BOOST_PATH})
|
||||
|
||||
add_library(boost
|
||||
${BOOST_PATH}/libs/thread/src/pthread/thread.cpp
|
||||
|
||||
|
||||
#thread
|
||||
${BOOST_PATH}/libs/thread/src/pthread/thread.cpp
|
||||
${BOOST_PATH}/libs/thread/src/pthread/once.cpp
|
||||
|
||||
#signals
|
||||
${BOOST_PATH}/libs/signals/src/connection.cpp
|
||||
${BOOST_PATH}/libs/signals/src/named_slot_map.cpp
|
||||
${BOOST_PATH}/libs/signals/src/signal_base.cpp
|
||||
${BOOST_PATH}/libs/signals/src/slot.cpp
|
||||
${BOOST_PATH}/libs/signals/src/trackable.cpp
|
||||
|
||||
#system
|
||||
${BOOST_PATH}/libs/system/src/error_code.cpp
|
||||
|
||||
#regex
|
||||
${BOOST_PATH}/libs/regex/src/c_regex_traits.cpp
|
||||
${BOOST_PATH}/libs/regex/src/cpp_regex_traits.cpp
|
||||
${BOOST_PATH}/libs/regex/src/cregex.cpp
|
||||
${BOOST_PATH}/libs/regex/src/fileiter.cpp
|
||||
${BOOST_PATH}/libs/regex/src/icu.cpp
|
||||
${BOOST_PATH}/libs/regex/src/instances.cpp
|
||||
${BOOST_PATH}/libs/regex/src/posix_api.cpp
|
||||
${BOOST_PATH}/libs/regex/src/regex.cpp
|
||||
${BOOST_PATH}/libs/regex/src/regex_debug.cpp
|
||||
${BOOST_PATH}/libs/regex/src/regex_raw_buffer.cpp
|
||||
${BOOST_PATH}/libs/regex/src/regex_traits_defaults.cpp
|
||||
${BOOST_PATH}/libs/regex/src/static_mutex.cpp
|
||||
${BOOST_PATH}/libs/regex/src/usinstances.cpp
|
||||
${BOOST_PATH}/libs/regex/src/w32_regex_traits.cpp
|
||||
${BOOST_PATH}/libs/regex/src/wc_regex_traits.cpp
|
||||
${BOOST_PATH}/libs/regex/src/wide_posix_api.cpp
|
||||
${BOOST_PATH}/libs/regex/src/winstances.cpp
|
||||
|
||||
#date_time
|
||||
${BOOST_PATH}/libs/date_time/src/gregorian/greg_month.cpp
|
||||
${BOOST_PATH}/libs/date_time/src/gregorian/greg_weekday.cpp
|
||||
${BOOST_PATH}/libs/date_time/src/gregorian/date_generators.cpp
|
||||
)
|
||||
|
||||
|
||||
|
||||
find_library( # Sets the name of the path variable.
|
||||
z-lib
|
||||
|
||||
# Specifies the name of the NDK library that
|
||||
# you want CMake to locate.
|
||||
z )
|
||||
|
||||
find_library( # Sets the name of the path variable.
|
||||
GLESv2-lib
|
||||
|
||||
# Specifies the name of the NDK library that
|
||||
# you want CMake to locate.
|
||||
GLESv2 )
|
||||
find_library( # Sets the name of the path variable.
|
||||
log-lib
|
||||
|
||||
# Specifies the name of the NDK library that
|
||||
# you want CMake to locate.
|
||||
log )
|
||||
|
||||
|
||||
|
||||
|
||||
include_directories(${CMAKE_CURRENT_SOURCE_DIR}/../../)
|
||||
|
||||
|
||||
include_directories(${BOOST_PATH})
|
||||
include_directories(${LIBPNG_PATH})
|
||||
include_directories(${LIBJPEG_PATH})
|
||||
include_directories(${ZIP_PATH})
|
||||
|
||||
include_directories(${BOOST_GIL_PATH})
|
||||
|
||||
|
||||
|
||||
add_definitions(-DTARGET_ANDROID)
|
||||
|
||||
|
||||
add_library( # Sets the name of the library.
|
||||
engine
|
||||
|
||||
# Sets the library as a shared library.
|
||||
SHARED
|
||||
|
||||
# Provides a relative path to your source file(s).
|
||||
# Associated headers in the same location as their source
|
||||
# file are automatically included.
|
||||
|
||||
#testcpp.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Utils/DataTypes/DataTypes.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Utils/DataTypes/NewDataTypes.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Utils/FileUtils/FileUtils.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Utils/JniApi/JniApi.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Utils/JniApi/JniApplication.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Utils/Console/Console.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Utils/SerializeInterface/SerializeInterface.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Utils/Network/Network.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Utils/PngHelper.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Utils/JpegHelper.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Utils/TgaLoader.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Utils/SimpleTimer.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Utils/ThreadUtils.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/TextureManager/SalmonTexture.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/ShaderManager/ShaderManager.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/FrameManager/FrameManager.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/LightManager/LightManager.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/SoundManager/SoundManagerAndroid.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/SoundManager/SoundManagerDataTypes.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/FontManager/FontManager.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/ScriptManager/ScriptManager.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/SmartValueManager/SmartValueManager.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/GUIManager/GUIManager.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/GUIManager/ButtonWidget.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/GUIManager/WidgetXmlParsers.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/HalibutAnimation/HalibutAnimation.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/ModelManager/ModelManager.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/ModelManager/NewModelManager.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/SimpleLand/SimpleLand.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/PhysicsManager/PhysicsManager.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Render/RenderMisc.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Render/RenderParams.cpp
|
||||
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Render/SalmonRender/BackgroundCubemap.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Render/SalmonRender/SalmonRenderInterface.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Render/SalmonRender/SalmonRenderGLES20.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Render/SalmonRender/SalmonRenderAndroid.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Render/SalmonRender/Cameras.cpp
|
||||
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/Animation/SalmonAnimation.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/SalmonEngineAndroid.cpp
|
||||
${CMAKE_CURRENT_SOURCE_DIR}/../../src/SalmonEngineInterface.cpp
|
||||
)
|
||||
|
||||
|
||||
target_link_libraries(engine
|
||||
${z-lib}
|
||||
${log-lib}
|
||||
${GLESv2-lib}
|
||||
png
|
||||
zip
|
||||
boost
|
||||
jpeg
|
||||
ogg
|
||||
vorbis
|
||||
)
|
38
SalmonEngineAndroid/app/build.gradle
Executable file
38
SalmonEngineAndroid/app/build.gradle
Executable file
@ -0,0 +1,38 @@
|
||||
apply plugin: 'com.android.library'
|
||||
|
||||
android {
|
||||
compileSdkVersion 24
|
||||
buildToolsVersion "24.0.1"
|
||||
defaultConfig {
|
||||
minSdkVersion 15
|
||||
targetSdkVersion 24
|
||||
versionCode 1
|
||||
versionName "1.0"
|
||||
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
|
||||
externalNativeBuild {
|
||||
cmake {
|
||||
cppFlags "-std=c++11 -frtti -fexceptions -Wno-c++11-narrowing"
|
||||
}
|
||||
}
|
||||
}
|
||||
buildTypes {
|
||||
release {
|
||||
minifyEnabled false
|
||||
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
|
||||
}
|
||||
}
|
||||
externalNativeBuild {
|
||||
cmake {
|
||||
path "CMakeLists.txt"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
dependencies {
|
||||
compile fileTree(dir: 'libs', include: ['*.jar'])
|
||||
androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {
|
||||
exclude group: 'com.android.support', module: 'support-annotations'
|
||||
})
|
||||
compile 'com.android.support:appcompat-v7:24.2.1'
|
||||
testCompile 'junit:junit:4.12'
|
||||
}
|
17
SalmonEngineAndroid/app/proguard-rules.pro
vendored
Executable file
17
SalmonEngineAndroid/app/proguard-rules.pro
vendored
Executable file
@ -0,0 +1,17 @@
|
||||
# Add project specific ProGuard rules here.
|
||||
# By default, the flags in this file are appended to flags specified
|
||||
# in C:\Android\sdk/tools/proguard/proguard-android.txt
|
||||
# You can edit the include path and order by changing the proguardFiles
|
||||
# directive in build.gradle.
|
||||
#
|
||||
# For more details, see
|
||||
# http://developer.android.com/guide/developing/tools/proguard.html
|
||||
|
||||
# Add any project specific keep options here:
|
||||
|
||||
# If your project uses WebView with JS, uncomment the following
|
||||
# and specify the fully qualified class name to the JavaScript interface
|
||||
# class:
|
||||
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
|
||||
# public *;
|
||||
#}
|
@ -0,0 +1,26 @@
|
||||
package fishrungames.salmonengineandroid;
|
||||
|
||||
import android.content.Context;
|
||||
import android.support.test.InstrumentationRegistry;
|
||||
import android.support.test.runner.AndroidJUnit4;
|
||||
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
|
||||
import static org.junit.Assert.*;
|
||||
|
||||
/**
|
||||
* Instrumentation test, which will execute on an Android device.
|
||||
*
|
||||
* @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
|
||||
*/
|
||||
@RunWith(AndroidJUnit4.class)
|
||||
public class ExampleInstrumentedTest {
|
||||
@Test
|
||||
public void useAppContext() throws Exception {
|
||||
// Context of the app under test.
|
||||
Context appContext = InstrumentationRegistry.getTargetContext();
|
||||
|
||||
assertEquals("fishrungames.salmonengineandroid", appContext.getPackageName());
|
||||
}
|
||||
}
|
17
SalmonEngineAndroid/app/src/main/AndroidManifest.xml
Executable file
17
SalmonEngineAndroid/app/src/main/AndroidManifest.xml
Executable file
@ -0,0 +1,17 @@
|
||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
package="fishrungames.salmonengineandroid">
|
||||
|
||||
<application android:allowBackup="true"
|
||||
android:label="@string/app_name"
|
||||
android:icon="@mipmap/ic_launcher"
|
||||
android:supportsRtl="true"
|
||||
android:theme="@style/AppTheme"
|
||||
android:screenOrientation="landscape"
|
||||
android:launchMode="singleTask"
|
||||
android:configChanges="orientation|keyboardHidden"
|
||||
android:noHistory="true">
|
||||
|
||||
</application>
|
||||
<uses-feature android:glEsVersion="0x00020000"/>
|
||||
|
||||
</manifest>
|
3
SalmonEngineAndroid/app/src/main/cpp/native-lib.cpp
Executable file
3
SalmonEngineAndroid/app/src/main/cpp/native-lib.cpp
Executable file
@ -0,0 +1,3 @@
|
||||
#include <jni.h>
|
||||
#include <string>
|
||||
|
@ -0,0 +1,448 @@
|
||||
package fishrungames.salmonengineandroid;
|
||||
|
||||
|
||||
import java.io.IOException;
|
||||
import java.io.InputStream;
|
||||
import android.content.Context;
|
||||
import android.content.ContextWrapper;
|
||||
import android.content.res.AssetFileDescriptor;
|
||||
import android.media.AudioManager;
|
||||
import android.media.MediaPlayer;
|
||||
import android.media.SoundPool;
|
||||
import android.opengl.GLSurfaceView;
|
||||
import android.view.GestureDetector;
|
||||
import android.view.KeyEvent;
|
||||
import android.view.MotionEvent;
|
||||
import android.view.GestureDetector.SimpleOnGestureListener;
|
||||
//import android.net.Uri;
|
||||
|
||||
import java.util.Collections;
|
||||
import java.util.Enumeration;
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
public class EngineWrapper {
|
||||
|
||||
static class CustomGestureListener extends SimpleOnGestureListener
|
||||
{
|
||||
|
||||
@Override
|
||||
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
|
||||
float velocityY)
|
||||
{
|
||||
EngineWrapper.OnFling(velocityX, velocityY, e2.getEventTime());
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
static class JniDestroyRunnable implements Runnable
|
||||
{
|
||||
public void run()
|
||||
{
|
||||
EngineWrapper.Destroy();
|
||||
}
|
||||
}
|
||||
|
||||
static ContextWrapper Instance = null;
|
||||
|
||||
static Map<String, Integer> FileMap = new HashMap<String, Integer>();
|
||||
|
||||
static Map<String, Integer> SoundMap = new HashMap<String, Integer>();
|
||||
|
||||
static Context context;
|
||||
|
||||
static SoundPool soundPool;
|
||||
|
||||
static MediaPlayer mp;
|
||||
|
||||
static GLSurfaceView mView;
|
||||
|
||||
static GestureDetector customGestureDetector = new GestureDetector(new CustomGestureListener());
|
||||
|
||||
|
||||
public static void SetActivityInstance(ContextWrapper inst)
|
||||
{
|
||||
Instance = inst;
|
||||
context = Instance.getBaseContext();
|
||||
|
||||
soundPool = new SoundPool(4, AudioManager.STREAM_MUSIC, 0);
|
||||
|
||||
mp = new MediaPlayer();
|
||||
|
||||
}
|
||||
|
||||
public static void SetView(GLSurfaceView view)
|
||||
{
|
||||
|
||||
mView = view;
|
||||
|
||||
}
|
||||
|
||||
public static String GetApplicationDir()
|
||||
{
|
||||
return Instance.getFilesDir().getPath();
|
||||
}
|
||||
|
||||
public static void AddToFileMap(String s, Integer i)
|
||||
{
|
||||
FileMap.put(s, i);
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
public synchronized static int OpenFile(String fileName)
|
||||
{
|
||||
String newFileName;
|
||||
|
||||
int i = fileName.lastIndexOf(".");
|
||||
|
||||
if (i == -1)
|
||||
{
|
||||
|
||||
newFileName = fileName;
|
||||
}
|
||||
else
|
||||
{
|
||||
newFileName = fileName.substring(0, i);
|
||||
}
|
||||
|
||||
|
||||
if (!FileMap.containsKey(newFileName))
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
Integer id = FileMap.get(newFileName);
|
||||
|
||||
try
|
||||
{
|
||||
|
||||
InputStream is = Instance.getResources().openRawResource(id);
|
||||
|
||||
byte[] buffer = new byte[256];
|
||||
int bytesRead;
|
||||
|
||||
CreateFile(is.available());
|
||||
|
||||
while ((bytesRead = is.read(buffer, 0, 256)) != -1)
|
||||
{
|
||||
WriteToFile(buffer, bytesRead);
|
||||
}
|
||||
|
||||
|
||||
} catch (Throwable t) {
|
||||
ConsoleOut("Exception in FileWrapper::OpenFile!\n");
|
||||
return 0;
|
||||
|
||||
}
|
||||
|
||||
return 1;
|
||||
|
||||
}
|
||||
|
||||
public static native void SetupEnviroment();
|
||||
|
||||
public static native void SetupApkFilePath(String s);
|
||||
|
||||
public static native void ConsoleOut(String s);
|
||||
|
||||
public static native void CreateFile(int fileSize);
|
||||
|
||||
public static native void WriteToFile(byte [] buffer, int bufferSize);
|
||||
|
||||
|
||||
public static void LoadSound(String soundFileName)
|
||||
{
|
||||
|
||||
if (SoundMap.containsKey(soundFileName))
|
||||
{
|
||||
return;
|
||||
}
|
||||
/*
|
||||
String newFileName;
|
||||
|
||||
int i = soundFileName.lastIndexOf(".");
|
||||
|
||||
if (i == -1)
|
||||
{
|
||||
|
||||
newFileName = soundFileName;
|
||||
}
|
||||
else
|
||||
{
|
||||
newFileName = soundFileName.substring(0, i);
|
||||
}*/
|
||||
|
||||
//int soundId = soundPool.load(context, FileMap.get(newFileName), 1);
|
||||
|
||||
AssetFileDescriptor afd = null;
|
||||
|
||||
try
|
||||
{
|
||||
afd = Instance.getAssets().openFd(soundFileName);
|
||||
} catch (IOException e)
|
||||
{
|
||||
e.printStackTrace();
|
||||
}
|
||||
|
||||
int soundId = soundPool.load(afd, 1);
|
||||
|
||||
SoundMap.put(soundFileName, soundId);
|
||||
|
||||
}
|
||||
|
||||
public static void ReleaseAllSoundsAndMusic()
|
||||
{
|
||||
|
||||
mp.stop();
|
||||
mp.reset();
|
||||
|
||||
//soundPool.autoPause();
|
||||
|
||||
Enumeration<Integer> i = Collections.enumeration(SoundMap.values());
|
||||
|
||||
while(i.hasMoreElements())
|
||||
{
|
||||
soundPool.stop(i.nextElement());
|
||||
}
|
||||
|
||||
SoundMap.clear();
|
||||
|
||||
}
|
||||
|
||||
public static void PauseAllSoundsAndMusic()
|
||||
{
|
||||
//NIU right now
|
||||
|
||||
soundPool.autoPause();
|
||||
|
||||
mp.pause();
|
||||
}
|
||||
|
||||
public static void ResumeAllSoundsAndMusic()
|
||||
{
|
||||
|
||||
//NIU right now
|
||||
|
||||
soundPool.autoResume();
|
||||
|
||||
mp.start();
|
||||
}
|
||||
|
||||
|
||||
public static void StopMusic()
|
||||
{
|
||||
mp.stop();
|
||||
mp.reset();
|
||||
}
|
||||
|
||||
public static void PlayMusic(String musicFileName)
|
||||
{
|
||||
InnerPlayMusic(musicFileName, false);
|
||||
}
|
||||
|
||||
|
||||
public static void PlayMusicLooped(String musicFileName)
|
||||
{
|
||||
InnerPlayMusic(musicFileName, true);
|
||||
}
|
||||
|
||||
private static void InnerPlayMusic(String musicFileName, boolean looped)
|
||||
{
|
||||
/*
|
||||
String newFileName;
|
||||
|
||||
int i = musicFileName.lastIndexOf(".");
|
||||
|
||||
if (i == -1)
|
||||
{
|
||||
|
||||
newFileName = musicFileName;
|
||||
}
|
||||
else
|
||||
{
|
||||
newFileName = musicFileName.substring(0, i);
|
||||
}
|
||||
*/
|
||||
try
|
||||
{
|
||||
//Uri path = Uri.parse("android.resource://"+Instance.getPackageName()+"/assets/"+newFileName);
|
||||
|
||||
AssetFileDescriptor afd = null;
|
||||
|
||||
try
|
||||
{
|
||||
afd = Instance.getAssets().openFd(musicFileName);
|
||||
} catch (IOException e)
|
||||
{
|
||||
e.printStackTrace();
|
||||
}
|
||||
|
||||
//mp.setDataSource(context, path);
|
||||
|
||||
mp.setDataSource(afd.getFileDescriptor(),afd.getStartOffset(),afd.getLength());
|
||||
|
||||
mp.prepare();
|
||||
mp.setLooping(looped);
|
||||
mp.start();
|
||||
} catch (IllegalArgumentException e)
|
||||
{
|
||||
// TODO Auto-generated catch block
|
||||
e.printStackTrace();
|
||||
} catch (IllegalStateException e)
|
||||
{
|
||||
// TODO Auto-generated catch block
|
||||
e.printStackTrace();
|
||||
} catch (IOException e)
|
||||
{
|
||||
// TODO Auto-generated catch block
|
||||
e.printStackTrace();
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
public static void PlaySound(String soundFileName)
|
||||
{
|
||||
if (!SoundMap.containsKey(soundFileName))
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
int soundId = SoundMap.get(soundFileName);
|
||||
|
||||
soundPool.play(soundId, 1,1,1,0,1);
|
||||
}
|
||||
|
||||
|
||||
public static void LoadSalmonEngineLibrary()
|
||||
{
|
||||
System.loadLibrary("engine");
|
||||
}
|
||||
|
||||
static
|
||||
{
|
||||
//System.loadLibrary("gnustl_shared");
|
||||
}
|
||||
|
||||
//Application methods
|
||||
|
||||
public static native void Update(long dt);
|
||||
|
||||
public static native void Destroy();
|
||||
public static native int IsInited();
|
||||
public static native void OnTapDown(float x, float y, long time);
|
||||
public static native void OnTapUp(float x, float y, long time);
|
||||
public static native void OnTapUpAfterMove(float x, float y, long time);
|
||||
public static native void OnTapMove(float x, float y, long time);
|
||||
|
||||
public static native void OnFling(float velocityX, float velocityY, long time);
|
||||
public static native void OnScroll(float distanceX, float distanceY, long time);
|
||||
|
||||
public static native void OnKeyPress(int keyCode);
|
||||
|
||||
|
||||
public static void CallDestroy()
|
||||
{
|
||||
mView.queueEvent(new JniDestroyRunnable());
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
public static void ProcessKeyDown(int keyCode, KeyEvent event)
|
||||
{
|
||||
int ascii_keycode = keyCode;
|
||||
|
||||
if (keyCode == KeyEvent.KEYCODE_DEL)
|
||||
{
|
||||
ascii_keycode = 8; //Hack - getUnicodeChar does not recognize backspace
|
||||
}
|
||||
else
|
||||
{
|
||||
ascii_keycode = event.getUnicodeChar();
|
||||
}
|
||||
|
||||
OnKeyPress(ascii_keycode);
|
||||
|
||||
}
|
||||
|
||||
static boolean IsScrolling = false;
|
||||
static float PrevMovePosX = 0;
|
||||
static float PrevMovePosY = 0;
|
||||
static boolean EnableFlingGesture = false;
|
||||
|
||||
public static void ProcessTouchEvent(MotionEvent event)
|
||||
{
|
||||
|
||||
if (EnableFlingGesture)
|
||||
{
|
||||
if (customGestureDetector.onTouchEvent(event))
|
||||
{
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
if (event.getAction() == MotionEvent.ACTION_MOVE)
|
||||
{
|
||||
float x = event.getX();
|
||||
float y = (float) mView.getHeight() - event.getY();
|
||||
|
||||
float oldX = PrevMovePosX;
|
||||
float oldY = (float) mView.getHeight() - PrevMovePosY;
|
||||
|
||||
|
||||
float shiftX = x - oldX;
|
||||
float shiftY = y - oldY;
|
||||
|
||||
if (Math.abs(shiftX) > 0.001f || Math.abs(shiftY) > 0.001f)
|
||||
{
|
||||
OnScroll(-shiftX, -shiftY, event.getEventTime());
|
||||
}
|
||||
|
||||
PrevMovePosX = event.getX();
|
||||
PrevMovePosY = event.getY();
|
||||
|
||||
IsScrolling = true;
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
if (event.getAction() == MotionEvent.ACTION_UP)
|
||||
{
|
||||
|
||||
|
||||
float x = event.getX();
|
||||
float y = (float) mView.getHeight() - event.getY();
|
||||
|
||||
if (IsScrolling)
|
||||
{
|
||||
IsScrolling = false;
|
||||
OnTapUpAfterMove(x, y, event.getEventTime());
|
||||
}
|
||||
else
|
||||
{
|
||||
OnTapUp(x, y, event.getEventTime());
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
if (event.getAction() == MotionEvent.ACTION_DOWN)
|
||||
{
|
||||
float x = event.getX();
|
||||
float y = (float) mView.getHeight() - event.getY();
|
||||
|
||||
PrevMovePosX = event.getX();
|
||||
PrevMovePosY = event.getY();
|
||||
|
||||
OnTapDown(x, y, event.getEventTime());
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
}
|
@ -0,0 +1,289 @@
|
||||
package fishrungames.salmonengineandroid;
|
||||
|
||||
|
||||
import android.content.Context;
|
||||
import android.graphics.PixelFormat;
|
||||
import android.opengl.GLSurfaceView;
|
||||
import android.util.Log;
|
||||
|
||||
import javax.microedition.khronos.egl.EGL10;
|
||||
import javax.microedition.khronos.egl.EGLConfig;
|
||||
import javax.microedition.khronos.egl.EGLContext;
|
||||
import javax.microedition.khronos.egl.EGLDisplay;
|
||||
|
||||
/*
|
||||
This is a OpenGL View template. Do not change this code - derive your own class instead!!
|
||||
*/
|
||||
|
||||
public class GLViewAncestor extends GLSurfaceView
|
||||
{
|
||||
private static String TAG = "GL2JNIView";
|
||||
private static final boolean DEBUG = false;
|
||||
|
||||
public GLViewAncestor(Context context)
|
||||
{
|
||||
super(context);
|
||||
}
|
||||
|
||||
public void init(boolean translucent, int depth, int stencil)
|
||||
{
|
||||
|
||||
/*
|
||||
* By default, GLSurfaceView() creates a RGB_565 opaque surface. If we
|
||||
* want a translucent one, we should change the surface's format here,
|
||||
* using PixelFormat.TRANSLUCENT for GL Surfaces is interpreted as any
|
||||
* 32-bit surface with alpha by SurfaceFlinger.
|
||||
*/
|
||||
if (translucent)
|
||||
{
|
||||
this.getHolder().setFormat(PixelFormat.TRANSLUCENT);
|
||||
}
|
||||
|
||||
/*
|
||||
* Setup the context factory for 2.0 rendering. See ContextFactory class
|
||||
* definition below
|
||||
*/
|
||||
setEGLContextFactory(new ContextFactory());
|
||||
|
||||
/*
|
||||
* We need to choose an EGLConfig that matches the format of our surface
|
||||
* exactly. This is going to be done in our custom config chooser. See
|
||||
* ConfigChooser class definition below.
|
||||
*/
|
||||
setEGLConfigChooser(translucent ? new ConfigChooser(8, 8, 8, 8, depth,
|
||||
stencil) : new ConfigChooser(5, 6, 5, 0, depth, stencil));
|
||||
|
||||
}
|
||||
|
||||
private static class ContextFactory implements
|
||||
GLSurfaceView.EGLContextFactory
|
||||
{
|
||||
private static int EGL_CONTEXT_CLIENT_VERSION = 0x3098;
|
||||
|
||||
@Override
|
||||
public EGLContext createContext(EGL10 egl, EGLDisplay display,
|
||||
EGLConfig eglConfig)
|
||||
{
|
||||
Log.w(TAG, "creating OpenGL ES 2.0 context");
|
||||
checkEglError("Before eglCreateContext", egl);
|
||||
int[] attrib_list =
|
||||
{ EGL_CONTEXT_CLIENT_VERSION, 2, EGL10.EGL_NONE };
|
||||
EGLContext context = egl.eglCreateContext(display, eglConfig,
|
||||
EGL10.EGL_NO_CONTEXT, attrib_list);
|
||||
checkEglError("After eglCreateContext", egl);
|
||||
return context;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void destroyContext(EGL10 egl, EGLDisplay display,
|
||||
EGLContext context)
|
||||
{
|
||||
egl.eglDestroyContext(display, context);
|
||||
}
|
||||
}
|
||||
|
||||
private static void checkEglError(String prompt, EGL10 egl)
|
||||
{
|
||||
int error;
|
||||
while ((error = egl.eglGetError()) != EGL10.EGL_SUCCESS)
|
||||
{
|
||||
Log.e(TAG, String.format("%s: EGL error: 0x%x", prompt, error));
|
||||
}
|
||||
}
|
||||
|
||||
private static class ConfigChooser implements
|
||||
GLSurfaceView.EGLConfigChooser
|
||||
{
|
||||
|
||||
public ConfigChooser(int r, int g, int b, int a, int depth, int stencil)
|
||||
{
|
||||
mRedSize = r;
|
||||
mGreenSize = g;
|
||||
mBlueSize = b;
|
||||
mAlphaSize = a;
|
||||
mDepthSize = depth;
|
||||
mStencilSize = stencil;
|
||||
}
|
||||
|
||||
/*
|
||||
* This EGL config specification is used to specify 2.0 rendering. We
|
||||
* use a minimum size of 4 bits for red/green/blue, but will perform
|
||||
* actual matching in chooseConfig() below.
|
||||
*/
|
||||
private static int EGL_OPENGL_ES2_BIT = 4;
|
||||
private static int[] s_configAttribs2 =
|
||||
{ EGL10.EGL_RED_SIZE, 4, EGL10.EGL_GREEN_SIZE, 4,
|
||||
EGL10.EGL_BLUE_SIZE, 4, EGL10.EGL_RENDERABLE_TYPE,
|
||||
EGL_OPENGL_ES2_BIT, EGL10.EGL_NONE };
|
||||
|
||||
@Override
|
||||
public EGLConfig chooseConfig(EGL10 egl, EGLDisplay display)
|
||||
{
|
||||
|
||||
/*
|
||||
* Get the number of minimally matching EGL configurations
|
||||
*/
|
||||
int[] num_config = new int[1];
|
||||
egl.eglChooseConfig(display, s_configAttribs2, null, 0, num_config);
|
||||
|
||||
int numConfigs = num_config[0];
|
||||
|
||||
if (numConfigs <= 0)
|
||||
{
|
||||
throw new IllegalArgumentException(
|
||||
"No configs match configSpec");
|
||||
}
|
||||
|
||||
/*
|
||||
* Allocate then read the array of minimally matching EGL configs
|
||||
*/
|
||||
EGLConfig[] configs = new EGLConfig[numConfigs];
|
||||
egl.eglChooseConfig(display, s_configAttribs2, configs, numConfigs,
|
||||
num_config);
|
||||
|
||||
if (DEBUG)
|
||||
{
|
||||
printConfigs(egl, display, configs);
|
||||
}
|
||||
/*
|
||||
* Now return the "best" one
|
||||
*/
|
||||
return chooseConfig(egl, display, configs);
|
||||
}
|
||||
|
||||
public EGLConfig chooseConfig(EGL10 egl, EGLDisplay display,
|
||||
EGLConfig[] configs)
|
||||
{
|
||||
for (EGLConfig config : configs)
|
||||
{
|
||||
int d = findConfigAttrib(egl, display, config,
|
||||
EGL10.EGL_DEPTH_SIZE, 0);
|
||||
int s = findConfigAttrib(egl, display, config,
|
||||
EGL10.EGL_STENCIL_SIZE, 0);
|
||||
|
||||
// We need at least mDepthSize and mStencilSize bits
|
||||
if (d < mDepthSize || s < mStencilSize)
|
||||
continue;
|
||||
|
||||
// We want an *exact* match for red/green/blue/alpha
|
||||
int r = findConfigAttrib(egl, display, config,
|
||||
EGL10.EGL_RED_SIZE, 0);
|
||||
int g = findConfigAttrib(egl, display, config,
|
||||
EGL10.EGL_GREEN_SIZE, 0);
|
||||
int b = findConfigAttrib(egl, display, config,
|
||||
EGL10.EGL_BLUE_SIZE, 0);
|
||||
int a = findConfigAttrib(egl, display, config,
|
||||
EGL10.EGL_ALPHA_SIZE, 0);
|
||||
|
||||
if (r == mRedSize && g == mGreenSize && b == mBlueSize
|
||||
&& a == mAlphaSize)
|
||||
return config;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
private int findConfigAttrib(EGL10 egl, EGLDisplay display,
|
||||
EGLConfig config, int attribute, int defaultValue)
|
||||
{
|
||||
|
||||
if (egl.eglGetConfigAttrib(display, config, attribute, mValue))
|
||||
{
|
||||
return mValue[0];
|
||||
}
|
||||
return defaultValue;
|
||||
}
|
||||
|
||||
private void printConfigs(EGL10 egl, EGLDisplay display,
|
||||
EGLConfig[] configs)
|
||||
{
|
||||
int numConfigs = configs.length;
|
||||
Log.w(TAG, String.format("%d configurations", numConfigs));
|
||||
for (int i = 0; i < numConfigs; i++)
|
||||
{
|
||||
Log.w(TAG, String.format("Configuration %d:\n", i));
|
||||
printConfig(egl, display, configs[i]);
|
||||
}
|
||||
}
|
||||
|
||||
private void printConfig(EGL10 egl, EGLDisplay display, EGLConfig config)
|
||||
{
|
||||
int[] attributes =
|
||||
{
|
||||
EGL10.EGL_BUFFER_SIZE,
|
||||
EGL10.EGL_ALPHA_SIZE,
|
||||
EGL10.EGL_BLUE_SIZE,
|
||||
EGL10.EGL_GREEN_SIZE,
|
||||
EGL10.EGL_RED_SIZE,
|
||||
EGL10.EGL_DEPTH_SIZE,
|
||||
EGL10.EGL_STENCIL_SIZE,
|
||||
EGL10.EGL_CONFIG_CAVEAT,
|
||||
EGL10.EGL_CONFIG_ID,
|
||||
EGL10.EGL_LEVEL,
|
||||
EGL10.EGL_MAX_PBUFFER_HEIGHT,
|
||||
EGL10.EGL_MAX_PBUFFER_PIXELS,
|
||||
EGL10.EGL_MAX_PBUFFER_WIDTH,
|
||||
EGL10.EGL_NATIVE_RENDERABLE,
|
||||
EGL10.EGL_NATIVE_VISUAL_ID,
|
||||
EGL10.EGL_NATIVE_VISUAL_TYPE,
|
||||
0x3030, // EGL10.EGL_PRESERVED_RESOURCES,
|
||||
EGL10.EGL_SAMPLES,
|
||||
EGL10.EGL_SAMPLE_BUFFERS,
|
||||
EGL10.EGL_SURFACE_TYPE,
|
||||
EGL10.EGL_TRANSPARENT_TYPE,
|
||||
EGL10.EGL_TRANSPARENT_RED_VALUE,
|
||||
EGL10.EGL_TRANSPARENT_GREEN_VALUE,
|
||||
EGL10.EGL_TRANSPARENT_BLUE_VALUE,
|
||||
0x3039, // EGL10.EGL_BIND_TO_TEXTURE_RGB,
|
||||
0x303A, // EGL10.EGL_BIND_TO_TEXTURE_RGBA,
|
||||
0x303B, // EGL10.EGL_MIN_SWAP_INTERVAL,
|
||||
0x303C, // EGL10.EGL_MAX_SWAP_INTERVAL,
|
||||
EGL10.EGL_LUMINANCE_SIZE, EGL10.EGL_ALPHA_MASK_SIZE,
|
||||
EGL10.EGL_COLOR_BUFFER_TYPE, EGL10.EGL_RENDERABLE_TYPE,
|
||||
0x3042 // EGL10.EGL_CONFORMANT
|
||||
};
|
||||
String[] names =
|
||||
{ "EGL_BUFFER_SIZE", "EGL_ALPHA_SIZE", "EGL_BLUE_SIZE",
|
||||
"EGL_GREEN_SIZE", "EGL_RED_SIZE", "EGL_DEPTH_SIZE",
|
||||
"EGL_STENCIL_SIZE", "EGL_CONFIG_CAVEAT",
|
||||
"EGL_CONFIG_ID", "EGL_LEVEL", "EGL_MAX_PBUFFER_HEIGHT",
|
||||
"EGL_MAX_PBUFFER_PIXELS", "EGL_MAX_PBUFFER_WIDTH",
|
||||
"EGL_NATIVE_RENDERABLE", "EGL_NATIVE_VISUAL_ID",
|
||||
"EGL_NATIVE_VISUAL_TYPE", "EGL_PRESERVED_RESOURCES",
|
||||
"EGL_SAMPLES", "EGL_SAMPLE_BUFFERS",
|
||||
"EGL_SURFACE_TYPE", "EGL_TRANSPARENT_TYPE",
|
||||
"EGL_TRANSPARENT_RED_VALUE",
|
||||
"EGL_TRANSPARENT_GREEN_VALUE",
|
||||
"EGL_TRANSPARENT_BLUE_VALUE",
|
||||
"EGL_BIND_TO_TEXTURE_RGB", "EGL_BIND_TO_TEXTURE_RGBA",
|
||||
"EGL_MIN_SWAP_INTERVAL", "EGL_MAX_SWAP_INTERVAL",
|
||||
"EGL_LUMINANCE_SIZE", "EGL_ALPHA_MASK_SIZE",
|
||||
"EGL_COLOR_BUFFER_TYPE", "EGL_RENDERABLE_TYPE",
|
||||
"EGL_CONFORMANT" };
|
||||
int[] value = new int[1];
|
||||
for (int i = 0; i < attributes.length; i++)
|
||||
{
|
||||
int attribute = attributes[i];
|
||||
String name = names[i];
|
||||
if (egl.eglGetConfigAttrib(display, config, attribute, value))
|
||||
{
|
||||
Log.w(TAG, String.format(" %s: %d\n", name, value[0]));
|
||||
} else
|
||||
{
|
||||
// Log.w(TAG, String.format(" %s: failed\n", name));
|
||||
while (egl.eglGetError() != EGL10.EGL_SUCCESS)
|
||||
;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Subclasses can adjust these values:
|
||||
protected int mRedSize;
|
||||
protected int mGreenSize;
|
||||
protected int mBlueSize;
|
||||
protected int mAlphaSize;
|
||||
protected int mDepthSize;
|
||||
protected int mStencilSize;
|
||||
private int[] mValue = new int[1];
|
||||
}
|
||||
|
||||
}
|
BIN
SalmonEngineAndroid/app/src/main/res/mipmap-hdpi/ic_launcher.png
Executable file
BIN
SalmonEngineAndroid/app/src/main/res/mipmap-hdpi/ic_launcher.png
Executable file
Binary file not shown.
After Width: | Height: | Size: 3.3 KiB |
BIN
SalmonEngineAndroid/app/src/main/res/mipmap-mdpi/ic_launcher.png
Executable file
BIN
SalmonEngineAndroid/app/src/main/res/mipmap-mdpi/ic_launcher.png
Executable file
Binary file not shown.
After Width: | Height: | Size: 2.2 KiB |
BIN
SalmonEngineAndroid/app/src/main/res/mipmap-xhdpi/ic_launcher.png
Executable file
BIN
SalmonEngineAndroid/app/src/main/res/mipmap-xhdpi/ic_launcher.png
Executable file
Binary file not shown.
After Width: | Height: | Size: 4.7 KiB |
BIN
SalmonEngineAndroid/app/src/main/res/mipmap-xxhdpi/ic_launcher.png
Executable file
BIN
SalmonEngineAndroid/app/src/main/res/mipmap-xxhdpi/ic_launcher.png
Executable file
Binary file not shown.
After Width: | Height: | Size: 7.5 KiB |
BIN
SalmonEngineAndroid/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png
Executable file
BIN
SalmonEngineAndroid/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png
Executable file
Binary file not shown.
After Width: | Height: | Size: 10 KiB |
6
SalmonEngineAndroid/app/src/main/res/values/colors.xml
Executable file
6
SalmonEngineAndroid/app/src/main/res/values/colors.xml
Executable file
@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<resources>
|
||||
<color name="colorPrimary">#3F51B5</color>
|
||||
<color name="colorPrimaryDark">#303F9F</color>
|
||||
<color name="colorAccent">#FF4081</color>
|
||||
</resources>
|
3
SalmonEngineAndroid/app/src/main/res/values/strings.xml
Executable file
3
SalmonEngineAndroid/app/src/main/res/values/strings.xml
Executable file
@ -0,0 +1,3 @@
|
||||
<resources>
|
||||
<string name="app_name">SalmonEngineAndroid</string>
|
||||
</resources>
|
11
SalmonEngineAndroid/app/src/main/res/values/styles.xml
Executable file
11
SalmonEngineAndroid/app/src/main/res/values/styles.xml
Executable file
@ -0,0 +1,11 @@
|
||||
<resources>
|
||||
|
||||
<!-- Base application theme. -->
|
||||
<style name="AppTheme" parent="Theme.AppCompat.Light">
|
||||
<item name="windowNoTitle">true</item>
|
||||
<item name="windowActionBar">false</item>
|
||||
<item name="android:windowFullscreen">true</item>
|
||||
<item name="android:windowContentOverlay">@null</item>
|
||||
</style>
|
||||
|
||||
</resources>
|
@ -0,0 +1,17 @@
|
||||
package fishrungames.salmonengineandroid;
|
||||
|
||||
import org.junit.Test;
|
||||
|
||||
import static org.junit.Assert.*;
|
||||
|
||||
/**
|
||||
* Example local unit test, which will execute on the development machine (host).
|
||||
*
|
||||
* @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
|
||||
*/
|
||||
public class ExampleUnitTest {
|
||||
@Test
|
||||
public void addition_isCorrect() throws Exception {
|
||||
assertEquals(4, 2 + 2);
|
||||
}
|
||||
}
|
23
SalmonEngineAndroid/build.gradle
Executable file
23
SalmonEngineAndroid/build.gradle
Executable file
@ -0,0 +1,23 @@
|
||||
// Top-level build file where you can add configuration options common to all sub-projects/modules.
|
||||
|
||||
buildscript {
|
||||
repositories {
|
||||
jcenter()
|
||||
}
|
||||
dependencies {
|
||||
classpath 'com.android.tools.build:gradle:2.2.2'
|
||||
|
||||
// NOTE: Do not place your application dependencies here; they belong
|
||||
// in the individual module build.gradle files
|
||||
}
|
||||
}
|
||||
|
||||
allprojects {
|
||||
repositories {
|
||||
jcenter()
|
||||
}
|
||||
}
|
||||
|
||||
task clean(type: Delete) {
|
||||
delete rootProject.buildDir
|
||||
}
|
17
SalmonEngineAndroid/gradle.properties
Executable file
17
SalmonEngineAndroid/gradle.properties
Executable file
@ -0,0 +1,17 @@
|
||||
# Project-wide Gradle settings.
|
||||
|
||||
# IDE (e.g. Android Studio) users:
|
||||
# Gradle settings configured through the IDE *will override*
|
||||
# any settings specified in this file.
|
||||
|
||||
# For more details on how to configure your build environment visit
|
||||
# http://www.gradle.org/docs/current/userguide/build_environment.html
|
||||
|
||||
# Specifies the JVM arguments used for the daemon process.
|
||||
# The setting is particularly useful for tweaking memory settings.
|
||||
org.gradle.jvmargs=-Xmx1536m
|
||||
|
||||
# When configured, Gradle will run in incubating parallel mode.
|
||||
# This option should only be used with decoupled projects. More details, visit
|
||||
# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
|
||||
# org.gradle.parallel=true
|
BIN
SalmonEngineAndroid/gradle/wrapper/gradle-wrapper.jar
vendored
Executable file
BIN
SalmonEngineAndroid/gradle/wrapper/gradle-wrapper.jar
vendored
Executable file
Binary file not shown.
6
SalmonEngineAndroid/gradle/wrapper/gradle-wrapper.properties
vendored
Executable file
6
SalmonEngineAndroid/gradle/wrapper/gradle-wrapper.properties
vendored
Executable file
@ -0,0 +1,6 @@
|
||||
#Mon Dec 28 10:00:20 PST 2015
|
||||
distributionBase=GRADLE_USER_HOME
|
||||
distributionPath=wrapper/dists
|
||||
zipStoreBase=GRADLE_USER_HOME
|
||||
zipStorePath=wrapper/dists
|
||||
distributionUrl=https\://services.gradle.org/distributions/gradle-2.14.1-all.zip
|
160
SalmonEngineAndroid/gradlew
vendored
Executable file
160
SalmonEngineAndroid/gradlew
vendored
Executable file
@ -0,0 +1,160 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
##############################################################################
|
||||
##
|
||||
## Gradle start up script for UN*X
|
||||
##
|
||||
##############################################################################
|
||||
|
||||
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
||||
DEFAULT_JVM_OPTS=""
|
||||
|
||||
APP_NAME="Gradle"
|
||||
APP_BASE_NAME=`basename "$0"`
|
||||
|
||||
# Use the maximum available, or set MAX_FD != -1 to use that value.
|
||||
MAX_FD="maximum"
|
||||
|
||||
warn ( ) {
|
||||
echo "$*"
|
||||
}
|
||||
|
||||
die ( ) {
|
||||
echo
|
||||
echo "$*"
|
||||
echo
|
||||
exit 1
|
||||
}
|
||||
|
||||
# OS specific support (must be 'true' or 'false').
|
||||
cygwin=false
|
||||
msys=false
|
||||
darwin=false
|
||||
case "`uname`" in
|
||||
CYGWIN* )
|
||||
cygwin=true
|
||||
;;
|
||||
Darwin* )
|
||||
darwin=true
|
||||
;;
|
||||
MINGW* )
|
||||
msys=true
|
||||
;;
|
||||
esac
|
||||
|
||||
# Attempt to set APP_HOME
|
||||
# Resolve links: $0 may be a link
|
||||
PRG="$0"
|
||||
# Need this for relative symlinks.
|
||||
while [ -h "$PRG" ] ; do
|
||||
ls=`ls -ld "$PRG"`
|
||||
link=`expr "$ls" : '.*-> \(.*\)$'`
|
||||
if expr "$link" : '/.*' > /dev/null; then
|
||||
PRG="$link"
|
||||
else
|
||||
PRG=`dirname "$PRG"`"/$link"
|
||||
fi
|
||||
done
|
||||
SAVED="`pwd`"
|
||||
cd "`dirname \"$PRG\"`/" >/dev/null
|
||||
APP_HOME="`pwd -P`"
|
||||
cd "$SAVED" >/dev/null
|
||||
|
||||
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
|
||||
|
||||
# Determine the Java command to use to start the JVM.
|
||||
if [ -n "$JAVA_HOME" ] ; then
|
||||
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
|
||||
# IBM's JDK on AIX uses strange locations for the executables
|
||||
JAVACMD="$JAVA_HOME/jre/sh/java"
|
||||
else
|
||||
JAVACMD="$JAVA_HOME/bin/java"
|
||||
fi
|
||||
if [ ! -x "$JAVACMD" ] ; then
|
||||
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
|
||||
|
||||
Please set the JAVA_HOME variable in your environment to match the
|
||||
location of your Java installation."
|
||||
fi
|
||||
else
|
||||
JAVACMD="java"
|
||||
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
||||
|
||||
Please set the JAVA_HOME variable in your environment to match the
|
||||
location of your Java installation."
|
||||
fi
|
||||
|
||||
# Increase the maximum file descriptors if we can.
|
||||
if [ "$cygwin" = "false" -a "$darwin" = "false" ] ; then
|
||||
MAX_FD_LIMIT=`ulimit -H -n`
|
||||
if [ $? -eq 0 ] ; then
|
||||
if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
|
||||
MAX_FD="$MAX_FD_LIMIT"
|
||||
fi
|
||||
ulimit -n $MAX_FD
|
||||
if [ $? -ne 0 ] ; then
|
||||
warn "Could not set maximum file descriptor limit: $MAX_FD"
|
||||
fi
|
||||
else
|
||||
warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
|
||||
fi
|
||||
fi
|
||||
|
||||
# For Darwin, add options to specify how the application appears in the dock
|
||||
if $darwin; then
|
||||
GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
|
||||
fi
|
||||
|
||||
# For Cygwin, switch paths to Windows format before running java
|
||||
if $cygwin ; then
|
||||
APP_HOME=`cygpath --path --mixed "$APP_HOME"`
|
||||
CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
|
||||
JAVACMD=`cygpath --unix "$JAVACMD"`
|
||||
|
||||
# We build the pattern for arguments to be converted via cygpath
|
||||
ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
|
||||
SEP=""
|
||||
for dir in $ROOTDIRSRAW ; do
|
||||
ROOTDIRS="$ROOTDIRS$SEP$dir"
|
||||
SEP="|"
|
||||
done
|
||||
OURCYGPATTERN="(^($ROOTDIRS))"
|
||||
# Add a user-defined pattern to the cygpath arguments
|
||||
if [ "$GRADLE_CYGPATTERN" != "" ] ; then
|
||||
OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
|
||||
fi
|
||||
# Now convert the arguments - kludge to limit ourselves to /bin/sh
|
||||
i=0
|
||||
for arg in "$@" ; do
|
||||
CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
|
||||
CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
|
||||
|
||||
if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
|
||||
eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
|
||||
else
|
||||
eval `echo args$i`="\"$arg\""
|
||||
fi
|
||||
i=$((i+1))
|
||||
done
|
||||
case $i in
|
||||
(0) set -- ;;
|
||||
(1) set -- "$args0" ;;
|
||||
(2) set -- "$args0" "$args1" ;;
|
||||
(3) set -- "$args0" "$args1" "$args2" ;;
|
||||
(4) set -- "$args0" "$args1" "$args2" "$args3" ;;
|
||||
(5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
|
||||
(6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
|
||||
(7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
|
||||
(8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
|
||||
(9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
|
||||
esac
|
||||
fi
|
||||
|
||||
# Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules
|
||||
function splitJvmOpts() {
|
||||
JVM_OPTS=("$@")
|
||||
}
|
||||
eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS
|
||||
JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME"
|
||||
|
||||
exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@"
|
90
SalmonEngineAndroid/gradlew.bat
vendored
Executable file
90
SalmonEngineAndroid/gradlew.bat
vendored
Executable file
@ -0,0 +1,90 @@
|
||||
@if "%DEBUG%" == "" @echo off
|
||||
@rem ##########################################################################
|
||||
@rem
|
||||
@rem Gradle startup script for Windows
|
||||
@rem
|
||||
@rem ##########################################################################
|
||||
|
||||
@rem Set local scope for the variables with windows NT shell
|
||||
if "%OS%"=="Windows_NT" setlocal
|
||||
|
||||
@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
||||
set DEFAULT_JVM_OPTS=
|
||||
|
||||
set DIRNAME=%~dp0
|
||||
if "%DIRNAME%" == "" set DIRNAME=.
|
||||
set APP_BASE_NAME=%~n0
|
||||
set APP_HOME=%DIRNAME%
|
||||
|
||||
@rem Find java.exe
|
||||
if defined JAVA_HOME goto findJavaFromJavaHome
|
||||
|
||||
set JAVA_EXE=java.exe
|
||||
%JAVA_EXE% -version >NUL 2>&1
|
||||
if "%ERRORLEVEL%" == "0" goto init
|
||||
|
||||
echo.
|
||||
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
||||
echo.
|
||||
echo Please set the JAVA_HOME variable in your environment to match the
|
||||
echo location of your Java installation.
|
||||
|
||||
goto fail
|
||||
|
||||
:findJavaFromJavaHome
|
||||
set JAVA_HOME=%JAVA_HOME:"=%
|
||||
set JAVA_EXE=%JAVA_HOME%/bin/java.exe
|
||||
|
||||
if exist "%JAVA_EXE%" goto init
|
||||
|
||||
echo.
|
||||
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
|
||||
echo.
|
||||
echo Please set the JAVA_HOME variable in your environment to match the
|
||||
echo location of your Java installation.
|
||||
|
||||
goto fail
|
||||
|
||||
:init
|
||||
@rem Get command-line arguments, handling Windowz variants
|
||||
|
||||
if not "%OS%" == "Windows_NT" goto win9xME_args
|
||||
if "%@eval[2+2]" == "4" goto 4NT_args
|
||||
|
||||
:win9xME_args
|
||||
@rem Slurp the command line arguments.
|
||||
set CMD_LINE_ARGS=
|
||||
set _SKIP=2
|
||||
|
||||
:win9xME_args_slurp
|
||||
if "x%~1" == "x" goto execute
|
||||
|
||||
set CMD_LINE_ARGS=%*
|
||||
goto execute
|
||||
|
||||
:4NT_args
|
||||
@rem Get arguments from the 4NT Shell from JP Software
|
||||
set CMD_LINE_ARGS=%$
|
||||
|
||||
:execute
|
||||
@rem Setup the command line
|
||||
|
||||
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
|
||||
|
||||
@rem Execute Gradle
|
||||
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
|
||||
|
||||
:end
|
||||
@rem End local scope for the variables with windows NT shell
|
||||
if "%ERRORLEVEL%"=="0" goto mainEnd
|
||||
|
||||
:fail
|
||||
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
|
||||
rem the _cmd.exe /c_ return code!
|
||||
if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
|
||||
exit /b 1
|
||||
|
||||
:mainEnd
|
||||
if "%OS%"=="Windows_NT" endlocal
|
||||
|
||||
:omega
|
1
SalmonEngineAndroid/settings.gradle
Executable file
1
SalmonEngineAndroid/settings.gradle
Executable file
@ -0,0 +1 @@
|
||||
include ':app'
|
26
include/ScriptManager/ScriptManager.h
Normal file → Executable file
26
include/ScriptManager/ScriptManager.h
Normal file → Executable file
@ -1,10 +1,12 @@
|
||||
#ifndef SCRIPT_MANAGER_H_INCLUDED
|
||||
#define SCRIPT_MANAGER_H_INCLUDED
|
||||
|
||||
#include "sqplus.h"
|
||||
//#include "sqplus.h"
|
||||
#include <iostream>
|
||||
#include <string>
|
||||
|
||||
typedef char SQChar;
|
||||
|
||||
namespace SE
|
||||
{
|
||||
|
||||
@ -30,6 +32,7 @@ struct TScriptInfo
|
||||
};
|
||||
|
||||
|
||||
|
||||
class TFunctionBinderInterface
|
||||
{
|
||||
public:
|
||||
@ -47,9 +50,9 @@ public:
|
||||
class TScriptManager : public TSerializeInterface
|
||||
{
|
||||
protected:
|
||||
HSQUIRRELVM virtualMachine;
|
||||
std::map<std::string, TScriptInfo> FuncInfoMap;
|
||||
|
||||
//HSQUIRRELVM virtualMachine;
|
||||
//std::map<std::string, TScriptInfo> FuncInfoMap;
|
||||
/*
|
||||
template<typename T1,typename T2>
|
||||
void RegisterFunc(T1& object, T2 method, const std::string& funcName)
|
||||
{
|
||||
@ -60,7 +63,7 @@ protected:
|
||||
void RegisterFunc(T globalFunc, const std::string& funcName)
|
||||
{
|
||||
SqPlus::RegisterGlobal(virtualMachine, globalFunc, _SC(funcName.c_str()));
|
||||
}
|
||||
}*/
|
||||
|
||||
public:
|
||||
TScriptManager();
|
||||
@ -75,20 +78,21 @@ public:
|
||||
template<typename T1, typename T2>
|
||||
void AddFunction(const std::string& shortName, TScriptInfo scriptInfo, T1& object, T2 method)
|
||||
{
|
||||
/*
|
||||
AddFuncDescription(shortName, scriptInfo);
|
||||
RegisterFunc(object, method, shortName);
|
||||
RegisterFunc(object, method, scriptInfo.LongName);
|
||||
FuncInfoMap[shortName].Registered = true;
|
||||
FuncInfoMap[shortName].Registered = true;*/
|
||||
}
|
||||
|
||||
|
||||
template<typename T>
|
||||
void AddFunction(const std::string& shortName, TScriptInfo scriptInfo, T globalFunc)
|
||||
{
|
||||
AddFuncDescription(shortName, scriptInfo);
|
||||
/*AddFuncDescription(shortName, scriptInfo);
|
||||
RegisterFunc(globalFunc, shortName);
|
||||
RegisterFunc(globalFunc, scriptInfo.LongName);
|
||||
FuncInfoMap[shortName].Registered = true;
|
||||
FuncInfoMap[shortName].Registered = true;*/
|
||||
}
|
||||
|
||||
void BindFunctionsFromObject(TFunctionBinderInterface* binderObject);
|
||||
@ -103,9 +107,9 @@ public:
|
||||
|
||||
|
||||
|
||||
void SQ_Print(const SQChar *inString);
|
||||
void SQ_PrintWidgetList();
|
||||
void SQ_MoveWidget(const SQChar *widgetName, float x, float y);
|
||||
//void SQ_Print(const SQChar *inString);
|
||||
//void SQ_PrintWidgetList();
|
||||
//void SQ_MoveWidget(const SQChar *widgetName, float x, float y);
|
||||
//void SQ_PrintTextureList();
|
||||
//void SQ_PrintAnimationList();
|
||||
|
||||
|
4
include/SoundManager/SoundManagerDataTypes.h
Normal file → Executable file
4
include/SoundManager/SoundManagerDataTypes.h
Normal file → Executable file
@ -5,8 +5,8 @@
|
||||
|
||||
|
||||
#ifdef TARGET_ANDROID
|
||||
#include <asm/page.h>
|
||||
#include <limits.h>
|
||||
//#include <asm/page.h>
|
||||
//#include <limits.h>
|
||||
#endif
|
||||
|
||||
#include "boost/thread.hpp"
|
||||
|
4
include/Utils/Console/Console.h
Normal file → Executable file
4
include/Utils/Console/Console.h
Normal file → Executable file
@ -20,8 +20,8 @@ Use global variable Console like that:
|
||||
#include <fstream>
|
||||
#endif
|
||||
#ifdef TARGET_ANDROID
|
||||
#include <asm/page.h>
|
||||
#include <limits.h>
|
||||
//#include <asm/page.h>
|
||||
//#include <limits.h>
|
||||
|
||||
#include "boost/thread.hpp"
|
||||
#endif
|
||||
|
22
include/Utils/JniApi/JniApi.h
Normal file → Executable file
22
include/Utils/JniApi/JniApi.h
Normal file → Executable file
@ -12,6 +12,18 @@
|
||||
#include <zlib.h>
|
||||
#include <zconf.h>
|
||||
|
||||
extern "C" {
|
||||
JNIEXPORT void JNICALL Java_fishrungames_salmonengineandroid_EngineWrapper_SetupEnviroment(JNIEnv* env, jobject thiz);
|
||||
JNIEXPORT void JNICALL Java_fishrungames_salmonengineandroid_EngineWrapper_SetupApkFilePath(JNIEnv* env, jobject thiz, jstring s);
|
||||
JNIEXPORT void JNICALL Java_fishrungames_salmonengineandroid_EngineWrapper_ConsoleOut(JNIEnv* env, jobject thiz, jstring s);
|
||||
|
||||
//All 2 deprecated
|
||||
JNIEXPORT void JNICALL Java_fishrungames_salmonengineandroid_EngineWrapper_CreateFile(JNIEnv* env, jobject thiz, int fileSize);
|
||||
JNIEXPORT void JNICALL Java_fishrungames_salmonengineandroid_EngineWrapper_WriteToFile(JNIEnv* env, jobject thiz, jbyteArray buffer, int bufferSize);
|
||||
|
||||
|
||||
};
|
||||
|
||||
namespace SE
|
||||
{
|
||||
|
||||
@ -35,17 +47,7 @@ extern cardinal* FileArr;
|
||||
extern int FileSize;
|
||||
extern std::string ApkFilePath;
|
||||
|
||||
extern "C" {
|
||||
JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_SetupEnviroment(JNIEnv* env, jobject thiz);
|
||||
JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_SetupApkFilePath(JNIEnv* env, jobject thiz, jstring s);
|
||||
JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_ConsoleOut(JNIEnv* env, jobject thiz, jstring s);
|
||||
|
||||
//All 2 deprecated
|
||||
JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_CreateFile(JNIEnv* env, jobject thiz, int fileSize);
|
||||
JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_WriteToFile(JNIEnv* env, jobject thiz, jbyteArray buffer, int bufferSize);
|
||||
|
||||
|
||||
};
|
||||
|
||||
//Deprecated
|
||||
void JniCallOpenFile(const std::string& fileName);
|
||||
|
@ -10,9 +10,9 @@ std::vector<TFunctionBinderInterface*> TFunctionBinderInterface::BinderList;
|
||||
|
||||
TScriptManager::TScriptManager()
|
||||
{
|
||||
SquirrelVM::Init();
|
||||
//SquirrelVM::Init();
|
||||
|
||||
virtualMachine = SquirrelVM::GetVMPtr();
|
||||
//virtualMachine = SquirrelVM::GetVMPtr();
|
||||
|
||||
//SqPlus::RegisterGlobal(virtualMachine, SQ_Print, _SC("Print"));
|
||||
//SqPlus::RegisterGlobal(virtualMachine, SQ_Print, _SC("p"));
|
||||
@ -58,11 +58,12 @@ TScriptManager::TScriptManager()
|
||||
TScriptManager::~TScriptManager()
|
||||
{
|
||||
*Console<<"Script manager shutdown";
|
||||
SquirrelVM::Shutdown();
|
||||
//SquirrelVM::Shutdown();
|
||||
}
|
||||
|
||||
void TScriptManager::RunScript(const std::string& scriptCode)
|
||||
{
|
||||
/*
|
||||
try
|
||||
{
|
||||
SquirrelObject m = SquirrelVM::CompileBuffer(_T(scriptCode.c_str()));
|
||||
@ -73,13 +74,14 @@ void TScriptManager::RunScript(const std::string& scriptCode)
|
||||
{
|
||||
*Console<<"Script failed to run";
|
||||
}
|
||||
|
||||
*/
|
||||
}
|
||||
|
||||
|
||||
void TScriptManager::BindBasicFunctions()
|
||||
{
|
||||
//Hack =D
|
||||
/*
|
||||
static bool alreadyBind = false;
|
||||
|
||||
if (!alreadyBind)
|
||||
@ -103,7 +105,7 @@ void TScriptManager::BindBasicFunctions()
|
||||
alreadyBind = true;
|
||||
}
|
||||
|
||||
|
||||
*/
|
||||
|
||||
|
||||
}
|
||||
@ -111,13 +113,14 @@ void TScriptManager::BindBasicFunctions()
|
||||
|
||||
void TScriptManager::AddFuncDescription(const std::string& shortName, TScriptInfo scriptInfo)
|
||||
{
|
||||
/*
|
||||
if (FuncInfoMap.count(shortName) > 0)
|
||||
{
|
||||
//If this description is already exists
|
||||
scriptInfo.Registered = FuncInfoMap[shortName].Registered;
|
||||
}
|
||||
|
||||
FuncInfoMap[shortName] = scriptInfo;
|
||||
FuncInfoMap[shortName] = scriptInfo;*/
|
||||
|
||||
|
||||
}
|
||||
@ -125,12 +128,13 @@ void TScriptManager::AddFuncDescription(const std::string& shortName, TScriptInf
|
||||
|
||||
void TScriptManager::BindFunctionsFromObject(TFunctionBinderInterface* binderObject)
|
||||
{
|
||||
binderObject->BindFunctions();
|
||||
//binderObject->BindFunctions();
|
||||
}
|
||||
|
||||
|
||||
void TScriptManager::PrintRegisteredFunctionList()
|
||||
{
|
||||
/*
|
||||
std::map<std::string, TScriptInfo>::iterator i;
|
||||
|
||||
Console->PrintImmediate("========== Console function list ===========");
|
||||
@ -141,20 +145,21 @@ void TScriptManager::PrintRegisteredFunctionList()
|
||||
{
|
||||
Console->PrintImmediate(i->first + " | " + i->second.ShortDescription);
|
||||
}
|
||||
}
|
||||
}*/
|
||||
}
|
||||
|
||||
void TScriptManager::PrintFunctionInfo(const std::string& funcName)
|
||||
{
|
||||
/*
|
||||
if (FuncInfoMap.count(funcName) > 0 && FuncInfoMap[funcName].Registered)
|
||||
{
|
||||
Console->PrintImmediate( funcName + " | " + FuncInfoMap[funcName].LongName + " | " + FuncInfoMap[funcName].Description);
|
||||
}
|
||||
}*/
|
||||
}
|
||||
|
||||
void TScriptManager::Serialize(boost::property_tree::ptree& propertyTree)
|
||||
{
|
||||
|
||||
/*
|
||||
BOOST_FOREACH(boost::property_tree::ptree::value_type &v, propertyTree.get_child("FunctionInfoList"))
|
||||
{
|
||||
std::string shortName = v.second.get<std::string>("ShortName");
|
||||
@ -163,20 +168,19 @@ void TScriptManager::Serialize(boost::property_tree::ptree& propertyTree)
|
||||
std::string description = v.second.get<std::string>("Description");
|
||||
|
||||
AddFuncDescription(shortName, TScriptInfo(longName, shortDescription, description));
|
||||
}
|
||||
}*/
|
||||
}
|
||||
|
||||
|
||||
//=============================================
|
||||
//============= Typical commands ==============
|
||||
//=============================================
|
||||
|
||||
/*
|
||||
void SQ_Print(const SQChar *inString)
|
||||
{
|
||||
Console->PrintImmediate(std::string(inString));
|
||||
}
|
||||
|
||||
/*
|
||||
void SQ_PrintWidgetList()
|
||||
{
|
||||
ResourceManager->GUIManager.PrintWidgetList();
|
||||
|
0
src/TextureManager/SalmonTexture.cpp
Normal file → Executable file
0
src/TextureManager/SalmonTexture.cpp
Normal file → Executable file
12
src/Utils/Console/Console.cpp
Normal file → Executable file
12
src/Utils/Console/Console.cpp
Normal file → Executable file
@ -1,6 +1,13 @@
|
||||
#include "include/Engine.h"
|
||||
#include "boost/date_time.hpp"
|
||||
|
||||
#ifdef TARGET_ANDROID
|
||||
#include <android/log.h>
|
||||
|
||||
#define APPNAME "SalmonEngine"
|
||||
|
||||
#endif
|
||||
|
||||
namespace SE
|
||||
{
|
||||
|
||||
@ -227,6 +234,11 @@ TJavaConsole& TJavaConsole::operator<<(const std::string& s)
|
||||
CutHistory();
|
||||
|
||||
|
||||
__android_log_print(ANDROID_LOG_VERBOSE, APPNAME, "%s", string_with_time_mark.c_str());
|
||||
|
||||
|
||||
|
||||
|
||||
return *this;
|
||||
}
|
||||
|
||||
|
35
src/Utils/JniApi/JniApi.cpp
Normal file → Executable file
35
src/Utils/JniApi/JniApi.cpp
Normal file → Executable file
@ -7,7 +7,7 @@ namespace SE
|
||||
|
||||
JavaVM* JavaVirtualMachine = 0;
|
||||
|
||||
const std::string CONST_JAVA_FILESYSTEM_CLASS_NAME = "fishrungames/engine/EngineWrapper";
|
||||
const std::string CONST_JAVA_FILESYSTEM_CLASS_NAME = "fishrungames/salmonengineandroid/EngineWrapper";
|
||||
|
||||
//Private data
|
||||
|
||||
@ -26,36 +26,37 @@ void CheckCommonExceptionWithMessage(const std::string& message);
|
||||
//Deprecated
|
||||
void JniCallOpenFile(const std::string& fileName);
|
||||
|
||||
}
|
||||
|
||||
//==================================================
|
||||
//=============== IMPLEMENTATION ===================
|
||||
//==================================================
|
||||
|
||||
|
||||
JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_SetupEnviroment(JNIEnv* env, jobject thiz)
|
||||
extern "C" void JNICALL Java_fishrungames_salmonengineandroid_EngineWrapper_SetupEnviroment(JNIEnv* env, jobject thiz)
|
||||
{
|
||||
int JVMResult;
|
||||
JVMResult = env->GetJavaVM(&JavaVirtualMachine);
|
||||
JVMResult = env->GetJavaVM(&SE::JavaVirtualMachine);
|
||||
|
||||
//TODO: Check if jmvresult != 0
|
||||
}
|
||||
|
||||
JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_SetupApkFilePath(JNIEnv* env, jobject thiz, jstring s)
|
||||
extern "C" void JNICALL Java_fishrungames_salmonengineandroid_EngineWrapper_SetupApkFilePath(JNIEnv* env, jobject thiz, jstring s)
|
||||
{
|
||||
|
||||
const char *nativeString = env->GetStringUTFChars(s, 0);
|
||||
|
||||
ApkFilePath = std::string(nativeString);
|
||||
SE::ApkFilePath = std::string(nativeString);
|
||||
|
||||
env->ReleaseStringUTFChars(s, nativeString);
|
||||
|
||||
}
|
||||
|
||||
JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_ConsoleOut(JNIEnv* env, jobject thiz, jstring s)
|
||||
extern "C" void JNICALL Java_fishrungames_salmonengineandroid_EngineWrapper_ConsoleOut(JNIEnv* env, jobject thiz, jstring s)
|
||||
{
|
||||
const char *nativeString = env->GetStringUTFChars(s, 0);
|
||||
|
||||
*Console<<std::string("OUT OF JAVA: ")+nativeString;
|
||||
*SE::Console<<std::string("OUT OF JAVA: ")+nativeString;
|
||||
|
||||
env->ReleaseStringUTFChars(s, nativeString);
|
||||
|
||||
@ -63,21 +64,21 @@ JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_ConsoleOut(JNIEnv*
|
||||
|
||||
|
||||
//Deprecated
|
||||
JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_CreateFile(JNIEnv* env, jobject thiz, int fileSize)
|
||||
extern "C" void JNICALL Java_fishrungames_salmonengineandroid_EngineWrapper_CreateFile(JNIEnv* env, jobject thiz, int fileSize)
|
||||
{
|
||||
FileSize = fileSize;
|
||||
FileArr = new cardinal [fileSize % 4 == 0 ? fileSize/4 : fileSize/4 + 1];
|
||||
filePointer = 0;
|
||||
SE::FileSize = fileSize;
|
||||
SE::FileArr = new SE::cardinal [fileSize % 4 == 0 ? fileSize/4 : fileSize/4 + 1];
|
||||
SE::filePointer = 0;
|
||||
}
|
||||
|
||||
|
||||
//Deprecated
|
||||
JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_WriteToFile(JNIEnv* env, jobject thiz, jbyteArray buffer, int bufferSize)
|
||||
extern "C" void JNICALL Java_fishrungames_salmonengineandroid_EngineWrapper_WriteToFile(JNIEnv* env, jobject thiz, jbyteArray buffer, int bufferSize)
|
||||
{
|
||||
JNIEnv* jenv;
|
||||
JavaVirtualMachine->GetEnv((void**)&jenv, JNI_VERSION_1_4);
|
||||
jenv->GetByteArrayRegion(buffer, 0, bufferSize, (jbyte*)((char*)FileArr + filePointer));
|
||||
filePointer += bufferSize;
|
||||
SE::JavaVirtualMachine->GetEnv((void**)&jenv, JNI_VERSION_1_4);
|
||||
jenv->GetByteArrayRegion(buffer, 0, bufferSize, (jbyte*)((char*)SE::FileArr + SE::filePointer));
|
||||
SE::filePointer += bufferSize;
|
||||
|
||||
}
|
||||
|
||||
@ -85,6 +86,10 @@ JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_WriteToFile(JNIEnv
|
||||
//============== Private methods ====================
|
||||
//===================================================
|
||||
|
||||
namespace SE
|
||||
{
|
||||
|
||||
|
||||
jclass JniTryFindClass(const std::string& className)
|
||||
{
|
||||
|
||||
|
115
src/Utils/JniApi/JniApplication.cpp
Normal file → Executable file
115
src/Utils/JniApi/JniApplication.cpp
Normal file → Executable file
@ -1,25 +1,25 @@
|
||||
|
||||
#include "include/Engine.h"
|
||||
|
||||
namespace SE
|
||||
{
|
||||
namespace SE {
|
||||
|
||||
TApplication *App = NULL;
|
||||
|
||||
boost::mutex InitLock;
|
||||
|
||||
bool Inited = false;
|
||||
} // namespace SE
|
||||
|
||||
|
||||
JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_Update(JNIEnv * env, jobject obj, long dt)
|
||||
extern "C"
|
||||
JNIEXPORT void JNICALL Java_fishrungames_salmonengineandroid_EngineWrapper_Update(JNIEnv * env, jobject obj, long dt)
|
||||
{
|
||||
InitLock.lock();
|
||||
SE::InitLock.lock();
|
||||
try
|
||||
{
|
||||
if (Inited)
|
||||
if (SE::Inited)
|
||||
{
|
||||
App->OuterDraw();
|
||||
App->OuterUpdate(dt);
|
||||
SE::App->OuterDraw();
|
||||
SE::App->OuterUpdate(dt);
|
||||
}
|
||||
|
||||
|
||||
@ -28,13 +28,14 @@ JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_Update(JNIEnv * en
|
||||
{
|
||||
throw;
|
||||
}
|
||||
InitLock.unlock();
|
||||
SE::InitLock.unlock();
|
||||
|
||||
}
|
||||
|
||||
JNIEXPORT int JNICALL Java_fishrungames_engine_EngineWrapper_IsInited(JNIEnv * env, jobject obj)
|
||||
extern "C"
|
||||
JNIEXPORT int JNICALL Java_fishrungames_salmonengineandroid_EngineWrapper_IsInited(JNIEnv * env, jobject obj)
|
||||
{
|
||||
if (Inited)
|
||||
if (SE::Inited)
|
||||
{
|
||||
return 1;
|
||||
}
|
||||
@ -45,23 +46,23 @@ JNIEXPORT int JNICALL Java_fishrungames_engine_EngineWrapper_IsInited(JNIEnv * e
|
||||
|
||||
}
|
||||
|
||||
|
||||
JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_Destroy(JNIEnv * env, jobject obj)
|
||||
extern "C"
|
||||
JNIEXPORT void JNICALL Java_fishrungames_salmonengineandroid_EngineWrapper_Destroy(JNIEnv * env, jobject obj)
|
||||
{
|
||||
InitLock.lock();
|
||||
SE::InitLock.lock();
|
||||
try
|
||||
{
|
||||
if (Inited)
|
||||
if (SE::Inited)
|
||||
{
|
||||
App->OuterDeinit();
|
||||
SE::App->OuterDeinit();
|
||||
|
||||
delete App;
|
||||
delete SE::App;
|
||||
|
||||
App = NULL;
|
||||
SE::App = NULL;
|
||||
|
||||
DestroyEngine();
|
||||
SE::DestroyEngine();
|
||||
|
||||
Inited = false;
|
||||
SE::Inited = false;
|
||||
}
|
||||
|
||||
}
|
||||
@ -69,7 +70,7 @@ JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_Destroy(JNIEnv * e
|
||||
{
|
||||
throw;
|
||||
}
|
||||
InitLock.unlock();
|
||||
SE::InitLock.unlock();
|
||||
}
|
||||
|
||||
void DestroyThreaded()
|
||||
@ -77,112 +78,118 @@ void DestroyThreaded()
|
||||
|
||||
}
|
||||
|
||||
JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_OnTapDown(JNIEnv * env, jobject obj, float x, float y, long time)
|
||||
extern "C"
|
||||
JNIEXPORT void JNICALL Java_fishrungames_salmonengineandroid_EngineWrapper_OnTapDown(JNIEnv * env, jobject obj, float x, float y, long time)
|
||||
{
|
||||
InitLock.lock();
|
||||
SE::InitLock.lock();
|
||||
try
|
||||
{
|
||||
if (Inited)
|
||||
if (SE::Inited)
|
||||
{
|
||||
App->OuterOnTapDown(vec2(x,y));
|
||||
SE::App->OuterOnTapDown(SE::vec2(x,y), time);
|
||||
}
|
||||
}
|
||||
catch (...)
|
||||
{
|
||||
throw;
|
||||
}
|
||||
InitLock.unlock();
|
||||
SE::InitLock.unlock();
|
||||
}
|
||||
|
||||
|
||||
JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_OnTapUp(JNIEnv * env, jobject obj, float x, float y, long time)
|
||||
extern "C"
|
||||
JNIEXPORT void JNICALL Java_fishrungames_salmonengineandroid_EngineWrapper_OnTapUp(JNIEnv * env, jobject obj, float x, float y, long time)
|
||||
{
|
||||
InitLock.lock();
|
||||
SE::InitLock.lock();
|
||||
try
|
||||
{
|
||||
if (Inited)
|
||||
if (SE::Inited)
|
||||
{
|
||||
App->OuterOnTapUp(vec2(x,y));
|
||||
SE::App->OuterOnTapUp(SE::vec2(x,y), time);
|
||||
}
|
||||
}
|
||||
catch (...)
|
||||
{
|
||||
throw;
|
||||
}
|
||||
InitLock.unlock();
|
||||
SE::InitLock.unlock();
|
||||
}
|
||||
|
||||
JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_OnTapUpAfterMove(JNIEnv * env, jobject obj, jfloat x, jfloat y, long time)
|
||||
extern "C"
|
||||
JNIEXPORT void JNICALL Java_fishrungames_salmonengineandroid_EngineWrapper_OnTapUpAfterMove(JNIEnv * env, jobject obj, jfloat x, jfloat y, long time)
|
||||
{
|
||||
InitLock.lock();
|
||||
SE::InitLock.lock();
|
||||
try
|
||||
{
|
||||
if (Inited)
|
||||
if (SE::Inited)
|
||||
{
|
||||
App->OuterOnTapUpAfterMove(vec2(x,y));
|
||||
SE::App->OuterOnTapUpAfterMove(SE::vec2(x,y), time);
|
||||
}
|
||||
}
|
||||
catch (...)
|
||||
{
|
||||
throw;
|
||||
}
|
||||
InitLock.unlock();
|
||||
SE::InitLock.unlock();
|
||||
}
|
||||
|
||||
JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_OnTapMove(JNIEnv * env, jobject obj, float x, float y, long time)
|
||||
extern "C"
|
||||
JNIEXPORT void JNICALL Java_fishrungames_salmonengineandroid_EngineWrapper_OnTapMove(JNIEnv * env, jobject obj, float x, float y, long time)
|
||||
{
|
||||
InitLock.lock();
|
||||
SE::InitLock.lock();
|
||||
try
|
||||
{
|
||||
if (Inited)
|
||||
if (SE::Inited)
|
||||
{
|
||||
App->OuterOnMove(vec2(x,y));
|
||||
SE::App->OuterOnMove(SE::vec2(x,y), time);
|
||||
}
|
||||
}
|
||||
catch (...)
|
||||
{
|
||||
throw;
|
||||
}
|
||||
InitLock.unlock();
|
||||
SE::InitLock.unlock();
|
||||
}
|
||||
|
||||
JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_OnFling(JNIEnv * env, jobject obj, jfloat velocityX, jfloat velocityY, long time)
|
||||
extern "C"
|
||||
JNIEXPORT void JNICALL Java_fishrungames_salmonengineandroid_EngineWrapper_OnFling(JNIEnv * env, jobject obj, jfloat velocityX, jfloat velocityY, long time)
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_OnScroll(JNIEnv * env, jobject obj, jfloat distanceX, jfloat distanceY, long time)
|
||||
extern "C"
|
||||
JNIEXPORT void JNICALL Java_fishrungames_salmonengineandroid_EngineWrapper_OnScroll(JNIEnv * env, jobject obj, jfloat distanceX, jfloat distanceY, long time)
|
||||
{
|
||||
InitLock.lock();
|
||||
SE::InitLock.lock();
|
||||
try
|
||||
{
|
||||
if (Inited)
|
||||
if (SE::Inited)
|
||||
{
|
||||
App->OuterOnMove(vec2(distanceX,distanceY));
|
||||
SE::App->OuterOnMove(SE::vec2(distanceX,distanceY), time);
|
||||
}
|
||||
}
|
||||
catch (...)
|
||||
{
|
||||
throw;
|
||||
}
|
||||
InitLock.unlock();
|
||||
SE::InitLock.unlock();
|
||||
}
|
||||
|
||||
JNIEXPORT void JNICALL Java_fishrungames_engine_EngineWrapper_OnKeyPress(JNIEnv * env, jobject obj, jint keyCode)
|
||||
extern "C"
|
||||
JNIEXPORT void JNICALL Java_fishrungames_salmonengineandroid_EngineWrapper_OnKeyPress(JNIEnv * env, jobject obj, jint keyCode)
|
||||
{
|
||||
InitLock.lock();
|
||||
SE::InitLock.lock();
|
||||
try
|
||||
{
|
||||
if (Inited)
|
||||
if (SE::Inited)
|
||||
{
|
||||
App->OnKeyPress(keyCode);
|
||||
SE::App->OnKeyPress(keyCode);
|
||||
}
|
||||
}
|
||||
catch (...)
|
||||
{
|
||||
throw;
|
||||
}
|
||||
InitLock.unlock();
|
||||
SE::InitLock.unlock();
|
||||
}
|
||||
|
||||
} // namespace SE
|
||||
|
||||
|
0
src/Utils/JpegHelper.cpp
Normal file → Executable file
0
src/Utils/JpegHelper.cpp
Normal file → Executable file
Loading…
Reference in New Issue
Block a user