mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
More Android changes. DONT_BUILD.
git-svn-id: https://svn.eduke32.com/eduke32@4989 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
22ac21598b
commit
31b557ef61
14 changed files with 6798 additions and 636 deletions
|
@ -14,36 +14,33 @@
|
||||||
#
|
#
|
||||||
LOCAL_PATH := $(call my-dir)
|
LOCAL_PATH := $(call my-dir)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
include $(CLEAR_VARS)
|
include $(CLEAR_VARS)
|
||||||
|
|
||||||
|
|
||||||
LOCAL_MODULE := duke
|
LOCAL_MODULE := duke
|
||||||
|
|
||||||
# -O2 -fvisibility=hidden
|
# -O2 -fvisibility=hidden
|
||||||
|
|
||||||
LOCAL_CFLAGS := -fvisibility=hidden -fPIC -Wimplicit -O2 -funswitch-loops -fomit-frame-pointer -DNDEBUG -DUSING_LTO -flto -fno-stack-protector -W -Werror-implicit-function-declaration -Wpointer-arith -Wextra -funsigned-char -fno-strict-aliasing -D_FORTIFY_SOURCE=0 -fjump-tables -Wno-unused-result -Wno-char-subscripts -pthread -DHAVE_INTTYPES -D_GNU_SOURCE=1 -D_REENTRANT -DRENDERTYPESDL=1 -Wno-strict-overflow -DUSE_OPENGL -Wno-attributes
|
LOCAL_CFLAGS := -x c++ -std=gnu++03 -fvisibility=hidden -fPIC -O2 -funswitch-loops -fomit-frame-pointer -DNDEBUG -DUSING_LTO -flto -fno-stack-protector -funsigned-char -fno-strict-aliasing -DNO_GCC_BUILTINS -D_FORTIFY_SOURCE=0 -fjump-tables -pthread -DHAVE_INTTYPES -D_GNU_SOURCE=1 -D_REENTRANT
|
||||||
|
LOCAL_CFLAGS += -W -Werror-implicit-function-declaration -Wpointer-arith -Wextra -Wno-unused-result -Wno-char-subscripts -Wno-strict-overflow -Wno-attributes -Wno-write-strings
|
||||||
|
LOCAL_CPPFLAGS := -std=gnu++03
|
||||||
|
|
||||||
#-DUSE_LIBPNG
|
#-DUSE_LIBPNG
|
||||||
|
|
||||||
LOCAL_CFLAGS += -DHAVE_SDL -DHAVE_VORBIS -DDROIDMENU
|
LOCAL_CFLAGS += -DHAVE_SDL -DHAVE_VORBIS -DHAVE_JWZGLES -DHAVE_ANDROID -DRENDERTYPESDL=1 -DUSE_OPENGL -DNETCODE_DISABLE
|
||||||
|
|
||||||
#LOCAL_CFLAGS += -mhard-float -D_NDK_MATH_NO_SOFTFP=1
|
#LOCAL_CFLAGS += -mhard-float -D_NDK_MATH_NO_SOFTFP=1
|
||||||
|
|
||||||
|
LOCAL_LDFLAGS := -fuse-ld=bfd
|
||||||
LOCAL_ARM_NEON = true
|
LOCAL_ARM_NEON = true
|
||||||
|
|
||||||
LOCAL_LDLIBS += -lGLESv1_CM -lEGL
|
|
||||||
|
|
||||||
LOCAL_LDLIBS += -llog
|
|
||||||
|
|
||||||
LOCAL_C_INCLUDES := $(LOCAL_PATH)/source $(LOCAL_PATH)/source/jmact $(LOCAL_PATH)/source/jaudiolib/include $(LOCAL_PATH)/source/enet/include $(LOCAL_PATH)/build/include
|
LOCAL_C_INCLUDES := $(LOCAL_PATH)/source $(LOCAL_PATH)/source/jmact $(LOCAL_PATH)/source/jaudiolib/include $(LOCAL_PATH)/source/enet/include $(LOCAL_PATH)/build/include
|
||||||
|
|
||||||
LOCAL_C_INCLUDES += $(TOP_DIR)/ $(TOP_DIR)/Libraries/liboggvorbis/include $(TOP_DIR)/Libraries/ $(TOP_DIR)/Libraries/SDL2/include $(TOP_DIR)/Libraries/SDL2_mixer/include $(TOP_DIR)/Libraries/libpng/include $(TOP_DIR)/Libraries/TinyXML/include $(TOP_DIR)/TouchControls
|
LOCAL_C_INCLUDES += $(TOP_DIR)/ $(TOP_DIR)/Libraries/liboggvorbis/include $(TOP_DIR)/Libraries/ $(TOP_DIR)/Libraries/SDL2/include $(TOP_DIR)/Libraries/SDL2_mixer/include $(TOP_DIR)/Libraries/libpng/include $(TOP_DIR)/Libraries/TinyXML/include $(TOP_DIR)/TouchControls
|
||||||
|
|
||||||
ANDROID_SRC = \
|
ANDROID_SRC = \
|
||||||
source/android/android-jni.cpp \
|
source/android/android-jni.cpp \
|
||||||
source/android/in_android.c
|
source/android/in_android.c \
|
||||||
|
build/src/glbuild_android.c \
|
||||||
|
build/src/jwzgles.c
|
||||||
|
|
||||||
BUILD_SRC = \
|
BUILD_SRC = \
|
||||||
build/src/a-c.c \
|
build/src/a-c.c \
|
||||||
|
@ -54,6 +51,7 @@ BUILD_SRC = \
|
||||||
build/src/defs.c \
|
build/src/defs.c \
|
||||||
build/src/engine.c \
|
build/src/engine.c \
|
||||||
build/src/polymost.c \
|
build/src/polymost.c \
|
||||||
|
build/src/mdsprite.c \
|
||||||
build/src/texcache.c \
|
build/src/texcache.c \
|
||||||
build/src/dxtfilter.c \
|
build/src/dxtfilter.c \
|
||||||
build/src/hightile.c \
|
build/src/hightile.c \
|
||||||
|
@ -62,6 +60,7 @@ BUILD_SRC = \
|
||||||
build/src/kplib.c \
|
build/src/kplib.c \
|
||||||
build/src/lz4.c \
|
build/src/lz4.c \
|
||||||
build/src/osd.c \
|
build/src/osd.c \
|
||||||
|
build/src/md4.c \
|
||||||
build/src/pragmas.c \
|
build/src/pragmas.c \
|
||||||
build/src/scriptfile.c \
|
build/src/scriptfile.c \
|
||||||
build/src/mutex.c \
|
build/src/mutex.c \
|
||||||
|
@ -69,14 +68,7 @@ BUILD_SRC = \
|
||||||
build/src/mmulti_null.c \
|
build/src/mmulti_null.c \
|
||||||
build/src/voxmodel.c \
|
build/src/voxmodel.c \
|
||||||
build/src/common.c \
|
build/src/common.c \
|
||||||
|
build/src/sdlayer.c
|
||||||
|
|
||||||
GL_SRC = \
|
|
||||||
build/src/mdsprite.c \
|
|
||||||
build/src/glbuild_android.c \
|
|
||||||
|
|
||||||
SDL_SRC = \
|
|
||||||
build/src/sdlayer.c \
|
|
||||||
|
|
||||||
JMACT_SRC=source/jmact/file_lib.c \
|
JMACT_SRC=source/jmact/file_lib.c \
|
||||||
source/jmact//control.c \
|
source/jmact//control.c \
|
||||||
|
@ -90,6 +82,7 @@ JMACT_SRC=source/jmact/file_lib.c \
|
||||||
GAME_SRC=source/game.c \
|
GAME_SRC=source/game.c \
|
||||||
source/actors.c \
|
source/actors.c \
|
||||||
source/anim.c \
|
source/anim.c \
|
||||||
|
source/animsounds.c \
|
||||||
source/common.c \
|
source/common.c \
|
||||||
source/config.c \
|
source/config.c \
|
||||||
source/demo.c \
|
source/demo.c \
|
||||||
|
@ -137,12 +130,12 @@ GAME_SRC=source/game.c \
|
||||||
source/enet/src/compress.c \
|
source/enet/src/compress.c \
|
||||||
source/enet/src/unix.c
|
source/enet/src/unix.c
|
||||||
|
|
||||||
LOCAL_SRC_FILES = $(ANDROID_SRC) $(ENET_SRC) $(JAUDIO_SRC) $(JMACT_SRC) $(GAME_SRC) $(BUILD_SRC) $(GL_SRC) $(SDL_SRC)
|
LOCAL_SRC_FILES = $(ANDROID_SRC) $(JAUDIO_SRC) $(JMACT_SRC) $(GAME_SRC) $(BUILD_SRC)
|
||||||
|
|
||||||
|
LOCAL_LDLIBS := -lGLESv1_CM -lEGL -ldl -llog -lOpenSLES -lz -L$(TOP_DIR)/openssl/libs/
|
||||||
LOCAL_LDLIBS := -lGLESv1_CM -lEGL -ldl -llog -lOpenSLES -lz -L$(TOP_DIR)/openssl/libs/ -lcrypto
|
LOCAL_STATIC_LIBRARIES := libpng crypto
|
||||||
LOCAL_STATIC_LIBRARIES := nanogl SDL2_net libjpeg libpng
|
LOCAL_SHARED_LIBRARIES := touchcontrols ogg vorbis SDL2 SDL2_mixer
|
||||||
LOCAL_SHARED_LIBRARIES := touchcontrols openal ogg vorbis SDL2 SDL2_mixer SDL2_image
|
# SDL2_image
|
||||||
|
|
||||||
ifeq ($(GP_LIC),1)
|
ifeq ($(GP_LIC),1)
|
||||||
LOCAL_STATIC_LIBRARIES += s-setup
|
LOCAL_STATIC_LIBRARIES += s-setup
|
||||||
|
|
|
@ -93,6 +93,7 @@
|
||||||
|
|
||||||
#if defined __ANDROID__ || defined EDUKE32_IOS
|
#if defined __ANDROID__ || defined EDUKE32_IOS
|
||||||
# define EDUKE32_TOUCH_DEVICES
|
# define EDUKE32_TOUCH_DEVICES
|
||||||
|
# define EDUKE32_GLES
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// This gives us access to 'intptr_t' and 'uintptr_t', which are
|
// This gives us access to 'intptr_t' and 'uintptr_t', which are
|
||||||
|
@ -192,8 +193,8 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(__arm__)
|
#if defined(__arm__)
|
||||||
# define Bsqrt __sqrt
|
# define Bsqrt __builtin_sqrt
|
||||||
# define Bsqrtf __sqrtf
|
# define Bsqrtf __builtin_sqrtf
|
||||||
#else
|
#else
|
||||||
# define Bsqrt sqrt
|
# define Bsqrt sqrt
|
||||||
# define Bsqrtf sqrtf
|
# define Bsqrtf sqrtf
|
||||||
|
|
517
polymer/eduke32/build/include/jwzgles.h
Normal file
517
polymer/eduke32/build/include/jwzgles.h
Normal file
|
@ -0,0 +1,517 @@
|
||||||
|
/* xscreensaver, Copyright (c) 2012 Jamie Zawinski <jwz@jwz.org>
|
||||||
|
*
|
||||||
|
* Permission to use, copy, modify, distribute, and sell this software and its
|
||||||
|
* documentation for any purpose is hereby granted without fee, provided that
|
||||||
|
* the above copyright notice appear in all copies and that both that
|
||||||
|
* copyright notice and this permission notice appear in supporting
|
||||||
|
* documentation. No representations are made about the suitability of this
|
||||||
|
* software for any purpose. It is provided "as is" without express or
|
||||||
|
* implied warranty.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* A compatibility shim to allow OpenGL 1.3 source code to work in an
|
||||||
|
OpenGLES environment, where almost every OpenGL 1.3 function has
|
||||||
|
been "deprecated". See jwzgles.c for details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __JWZGLES_H__
|
||||||
|
#define __JWZGLES_H__
|
||||||
|
|
||||||
|
#ifndef HAVE_JWZGLES
|
||||||
|
# error: do not include this without HAVE_JWZGLES
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#include "jwzglesI.h"
|
||||||
|
|
||||||
|
|
||||||
|
/* These are the OpenGL 1.3 functions that are not present in OpenGLES 1.
|
||||||
|
As you can see from the length of this list, OpenGL and OpenGLES have
|
||||||
|
almost nothing to do with each other. To claim that GLES is a dialect
|
||||||
|
of OpenGL is absurd -- English and Latin have more in common!
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define glAccum jwzgles_glAccum
|
||||||
|
#define glAntialiasing jwzgles_glAntialiasing
|
||||||
|
#define glAreTexturesResident jwzgles_glAreTexturesResident
|
||||||
|
#define glArrayElement jwzgles_glArrayElement
|
||||||
|
#define glBegin jwzgles_glBegin
|
||||||
|
#define glBitmap jwzgles_glBitmap
|
||||||
|
#define glBlendColor jwzgles_glBlendColor
|
||||||
|
#define glBlendEquation jwzgles_glBlendEquation
|
||||||
|
#define glCallList jwzgles_glCallList
|
||||||
|
#define glCallLists jwzgles_glCallLists
|
||||||
|
#define glClearAccum jwzgles_glClearAccum
|
||||||
|
#define glClearDepth jwzgles_glClearDepth
|
||||||
|
#define glClearIndex jwzgles_glClearIndex
|
||||||
|
#define glClipPlane jwzgles_glClipPlane
|
||||||
|
#define glColor3b jwzgles_glColor3b
|
||||||
|
#define glColor3bv jwzgles_glColor3bv
|
||||||
|
#define glColor3d jwzgles_glColor3f
|
||||||
|
#define glColor3dv jwzgles_glColor3dv
|
||||||
|
#define glColor3f jwzgles_glColor3f
|
||||||
|
#define glColor3fv jwzgles_glColor3fv
|
||||||
|
#define glColor3i jwzgles_glColor3i
|
||||||
|
#define glColor3iv jwzgles_glColor3iv
|
||||||
|
#define glColor3s jwzgles_glColor3s
|
||||||
|
#define glColor3sv jwzgles_glColor3sv
|
||||||
|
#define glColor3ub jwzgles_glColor3ub
|
||||||
|
#define glColor3ubv jwzgles_glColor3ubv
|
||||||
|
#define glColor3ui jwzgles_glColor3ui
|
||||||
|
#define glColor3uiv jwzgles_glColor3uiv
|
||||||
|
#define glColor3us jwzgles_glColor3us
|
||||||
|
#define glColor3usv jwzgles_glColor3usv
|
||||||
|
#define glColor4b jwzgles_glColor4b
|
||||||
|
#define glColor4bv jwzgles_glColor4bv
|
||||||
|
#define glColor4d jwzgles_glColor4d
|
||||||
|
#define glColor4dv jwzgles_glColor4dv
|
||||||
|
#define glColor4fv jwzgles_glColor4fv
|
||||||
|
#define glColor4i jwzgles_glColor4i
|
||||||
|
#define glColor4iv jwzgles_glColor4iv
|
||||||
|
#define glColor4s jwzgles_glColor4s
|
||||||
|
#define glColor4sv jwzgles_glColor4sv
|
||||||
|
#define glColor4ub jwzgles_glColor4ub
|
||||||
|
#define glColor4ubv jwzgles_glColor4ubv
|
||||||
|
#define glColor4ui jwzgles_glColor4ui
|
||||||
|
#define glColor4uiv jwzgles_glColor4uiv
|
||||||
|
#define glColor4us jwzgles_glColor4us
|
||||||
|
#define glColor4usv jwzgles_glColor4usv
|
||||||
|
#define glColorMaterial jwzgles_glColorMaterial
|
||||||
|
#define glColorSubTable jwzgles_glColorSubTable
|
||||||
|
#define glColorTable jwzgles_glColorTable
|
||||||
|
#define glColorTableParameter jwzgles_glColorTableParameter
|
||||||
|
#define glColorTableParameterfv jwzgles_glColorTableParameterfv
|
||||||
|
#define glColorub jwzgles_glColorub
|
||||||
|
#define glColorui jwzgles_glColorui
|
||||||
|
#define glColorus jwzgles_glColorus
|
||||||
|
#define glCompressedTexImage jwzgles_glCompressedTexImage
|
||||||
|
#define glCompressedTexImage1D jwzgles_glCompressedTexImage1D
|
||||||
|
#define glCompressedTexImage3D jwzgles_glCompressedTexImage3D
|
||||||
|
#define glCompressedTexSubImage1D jwzgles_glCompressedTexSubImage1D
|
||||||
|
#define glCompressedTexSubImage3D jwzgles_glCompressedTexSubImage3D
|
||||||
|
#define glConvolutionFilter1D jwzgles_glConvolutionFilter1D
|
||||||
|
#define glConvolutionFilter2D jwzgles_glConvolutionFilter2D
|
||||||
|
#define glConvolutionParameter jwzgles_glConvolutionParameter
|
||||||
|
#define glConvolutionParameterfv jwzgles_glConvolutionParameterfv
|
||||||
|
#define glConvolutionParameteriv jwzgles_glConvolutionParameteriv
|
||||||
|
#define glCopyColorSubTable jwzgles_glCopyColorSubTable
|
||||||
|
#define glCopyColorTable jwzgles_glCopyColorTable
|
||||||
|
#define glCopyConvolutionFilter1D jwzgles_glCopyConvolutionFilter1D
|
||||||
|
#define glCopyConvolutionFilter2D jwzgles_glCopyConvolutionFilter2D
|
||||||
|
#define glCopyPixels jwzgles_glCopyPixels
|
||||||
|
#define glCopyTexImage1D jwzgles_glCopyTexImage1D
|
||||||
|
#define glCopyTexImage3D jwzgles_glCopyTexImage3D
|
||||||
|
#define glCopyTexSubImage1D jwzgles_glCopyTexSubImage1D
|
||||||
|
#define glCopyTexSubImage3D jwzgles_glCopyTexSubImage3D
|
||||||
|
#define glDeleteLists jwzgles_glDeleteLists
|
||||||
|
#define glDrawBuffer jwzgles_glDrawBuffer
|
||||||
|
#define glDrawPixels jwzgles_glDrawPixels
|
||||||
|
#define glDrawRangeElements jwzgles_glDrawRangeElements
|
||||||
|
#define glEdgeFlag jwzgles_glEdgeFlag
|
||||||
|
#define glEdgeFlagPointer jwzgles_glEdgeFlagPointer
|
||||||
|
#define glEdgeFlagv jwzgles_glEdgeFlagv
|
||||||
|
#define glEnd jwzgles_glEnd
|
||||||
|
#define glEndList jwzgles_glEndList
|
||||||
|
#define glEvalCoord1d jwzgles_glEvalCoord1d
|
||||||
|
#define glEvalCoord1dv jwzgles_glEvalCoord1dv
|
||||||
|
#define glEvalCoord1f jwzgles_glEvalCoord1f
|
||||||
|
#define glEvalCoord1fv jwzgles_glEvalCoord1fv
|
||||||
|
#define glEvalCoord2d jwzgles_glEvalCoord2d
|
||||||
|
#define glEvalCoord2dv jwzgles_glEvalCoord2dv
|
||||||
|
#define glEvalCoord2f jwzgles_glEvalCoord2f
|
||||||
|
#define glEvalCoord2fv jwzgles_glEvalCoord2fv
|
||||||
|
#define glEvalMesh1 jwzgles_glEvalMesh1
|
||||||
|
#define glEvalMesh2 jwzgles_glEvalMesh2
|
||||||
|
#define glEvalPoint1 jwzgles_glEvalPoint1
|
||||||
|
#define glEvalPoint2 jwzgles_glEvalPoint2
|
||||||
|
#define glFeedbackBuffer jwzgles_glFeedbackBuffer
|
||||||
|
#define glFogi jwzgles_glFogi
|
||||||
|
#define glFogiv jwzgles_glFogiv
|
||||||
|
#define glFrustum jwzgles_glFrustum
|
||||||
|
#define glGenLists jwzgles_glGenLists
|
||||||
|
#define glGet jwzgles_glGet
|
||||||
|
#define glGetBooleanv jwzgles_glGetBooleanv
|
||||||
|
#define glGetClipPlane jwzgles_glGetClipPlane
|
||||||
|
#define glGetColorTable jwzgles_glGetColorTable
|
||||||
|
#define glGetColorTableParameter jwzgles_glGetColorTableParameter
|
||||||
|
#define glGetCompressedTexImage jwzgles_glGetCompressedTexImage
|
||||||
|
#define glGetConvolutionFilter jwzgles_glGetConvolutionFilter
|
||||||
|
#define glGetConvolutionParameter jwzgles_glGetConvolutionParameter
|
||||||
|
#define glGetConvolutionParameteriv jwzgles_glGetConvolutionParameteriv
|
||||||
|
#define glGetDoublev jwzgles_glGetDoublev
|
||||||
|
#define glGetFloatv jwzgles_glGetFloatv
|
||||||
|
#define glGetHistogram jwzgles_glGetHistogram
|
||||||
|
#define glGetHistogramParameter jwzgles_glGetHistogramParameter
|
||||||
|
#define glGetLightfv jwzgles_glGetLightfv
|
||||||
|
#define glGetLightiv jwzgles_glGetLightiv
|
||||||
|
#define glGetMapdv jwzgles_glGetMapdv
|
||||||
|
#define glGetMapfv jwzgles_glGetMapfv
|
||||||
|
#define glGetMapiv jwzgles_glGetMapiv
|
||||||
|
#define glGetMaterialfv jwzgles_glGetMaterialfv
|
||||||
|
#define glGetMaterialiv jwzgles_glGetMaterialiv
|
||||||
|
#define glGetPixelMapfv jwzgles_glGetPixelMapfv
|
||||||
|
#define glGetPixelMapuiv jwzgles_glGetPixelMapuiv
|
||||||
|
#define glGetPixelMapusv jwzgles_glGetPixelMapusv
|
||||||
|
#define glGetPointerv jwzgles_glGetPointerv
|
||||||
|
#define glGetPolygonStipple jwzgles_glGetPolygonStipple
|
||||||
|
#define glGetSeparableFilter jwzgles_glGetSeparableFilter
|
||||||
|
#define glGetTexEnvfv jwzgles_glGetTexEnvfv
|
||||||
|
#define glGetTexEnviv jwzgles_glGetTexEnviv
|
||||||
|
#define glGetTexGendv jwzgles_glGetTexGendv
|
||||||
|
#define glGetTexGenfv jwzgles_glGetTexGenfv
|
||||||
|
#define glGetTexGeniv jwzgles_glGetTexGeniv
|
||||||
|
#define glGetTexImage jwzgles_glGetTexImage
|
||||||
|
#define glGetTexImage1D jwzgles_glGetTexImage1D
|
||||||
|
#define glGetTexImage2D jwzgles_glGetTexImage2D
|
||||||
|
#define glGetTexImage3D jwzgles_glGetTexImage3D
|
||||||
|
#define glGetTexLevelParameterfv jwzgles_glGetTexLevelParameterfv
|
||||||
|
//#define glGetTexLevelParameteriv jwzgles_glGetTexLevelParameteriv
|
||||||
|
#define glGetTexParameterfv jwzgles_glGetTexParameterfv
|
||||||
|
//#define glGetTexParameteriv jwzgles_glGetTexParameteriv
|
||||||
|
#define glHistogram jwzgles_glHistogram
|
||||||
|
#define glIndex jwzgles_glIndex
|
||||||
|
#define glIndexMask jwzgles_glIndexMask
|
||||||
|
#define glIndexPointer jwzgles_glIndexPointer
|
||||||
|
#define glIndexd jwzgles_glIndexd
|
||||||
|
#define glIndexdv jwzgles_glIndexdv
|
||||||
|
#define glIndexf jwzgles_glIndexf
|
||||||
|
#define glIndexfv jwzgles_glIndexfv
|
||||||
|
/*#define glIndexi jwzgles_glIndexi*/
|
||||||
|
#define glIndexiv jwzgles_glIndexiv
|
||||||
|
#define glIndexs jwzgles_glIndexs
|
||||||
|
#define glIndexsv jwzgles_glIndexsv
|
||||||
|
#define glIndexub jwzgles_glIndexub
|
||||||
|
#define glIndexubv jwzgles_glIndexubv
|
||||||
|
#define glInitNames jwzgles_glInitNames
|
||||||
|
#define glInterleavedArrays jwzgles_glInterleavedArrays
|
||||||
|
#define glIsEnabled jwzgles_glIsEnabled
|
||||||
|
#define glIsList jwzgles_glIsList
|
||||||
|
#define glIsTexture jwzgles_glIsTexture
|
||||||
|
#define glLightModeli jwzgles_glLightModeli
|
||||||
|
#define glLightModeliv jwzgles_glLightModeliv
|
||||||
|
#define glLighti jwzgles_glLighti
|
||||||
|
#define glLightiv jwzgles_glLightiv
|
||||||
|
#define glLightf jwzgles_glLightf
|
||||||
|
#define glLightfv jwzgles_glLightfv
|
||||||
|
#define glLineStipple jwzgles_glLineStipple
|
||||||
|
#define glListBase jwzgles_glListBase
|
||||||
|
#define glLoadMatrix jwzgles_glLoadMatrix
|
||||||
|
#define glLoadName jwzgles_glLoadName
|
||||||
|
#define glLoadTransposeMatrix jwzgles_glLoadTransposeMatrix
|
||||||
|
#define glLoadTransposeMatrixf jwzgles_glLoadTransposeMatrixf
|
||||||
|
#define glMap1d jwzgles_glMap1d
|
||||||
|
#define glMap1f jwzgles_glMap1f
|
||||||
|
#define glMap2d jwzgles_glMap2d
|
||||||
|
#define glMap2f jwzgles_glMap2f
|
||||||
|
#define glMapGrid1d jwzgles_glMapGrid1d
|
||||||
|
#define glMapGrid1f jwzgles_glMapGrid1f
|
||||||
|
#define glMapGrid2d jwzgles_glMapGrid2d
|
||||||
|
#define glMapGrid2f jwzgles_glMapGrid2f
|
||||||
|
#define glMateriali jwzgles_glMateriali
|
||||||
|
#define glMaterialiv jwzgles_glMaterialiv
|
||||||
|
#define glMultTransposeMatrix jwzgles_glMultTransposeMatrix
|
||||||
|
#define glMultTransposeMatrixf jwzgles_glMultTransposeMatrixf
|
||||||
|
#define glNewList jwzgles_glNewList
|
||||||
|
#define glNormal3b jwzgles_glNormal3b
|
||||||
|
#define glNormal3bv jwzgles_glNormal3bv
|
||||||
|
#define glNormal3d jwzgles_glNormal3f
|
||||||
|
#define glNormal3dv jwzgles_glNormal3dv
|
||||||
|
#define glNormal3fv jwzgles_glNormal3fv
|
||||||
|
#define glNormal3i jwzgles_glNormal3i
|
||||||
|
#define glNormal3iv jwzgles_glNormal3iv
|
||||||
|
#define glNormal3s jwzgles_glNormal3s
|
||||||
|
#define glNormal3sv jwzgles_glNormal3sv
|
||||||
|
#define glOrtho jwzgles_glOrtho
|
||||||
|
#define glPassThrough jwzgles_glPassThrough
|
||||||
|
#define glPixelMapfv jwzgles_glPixelMapfv
|
||||||
|
#define glPixelMapuiv jwzgles_glPixelMapuiv
|
||||||
|
#define glPixelMapusv jwzgles_glPixelMapusv
|
||||||
|
#define glPixelStoref jwzgles_glPixelStoref
|
||||||
|
#define glPixelTransferf jwzgles_glPixelTransferf
|
||||||
|
#define glPixelTransferi jwzgles_glPixelTransferi
|
||||||
|
#define glPixelZoom jwzgles_glPixelZoom
|
||||||
|
#define glPolygonMode jwzgles_glPolygonMode
|
||||||
|
#define glPolygonStipple jwzgles_glPolygonStipple
|
||||||
|
#define glPopAttrib jwzgles_glPopAttrib
|
||||||
|
#define glPopClientAttrib jwzgles_glPopClientAttrib
|
||||||
|
#define glPopName jwzgles_glPopName
|
||||||
|
#define glPrioritizeTextures jwzgles_glPrioritizeTextures
|
||||||
|
#define glPushAttrib jwzgles_glPushAttrib
|
||||||
|
#define glPushClientAttrib jwzgles_glPushClientAttrib
|
||||||
|
#define glPushName jwzgles_glPushName
|
||||||
|
#define glRasterPos2d jwzgles_glRasterPos2d
|
||||||
|
#define glRasterPos2dv jwzgles_glRasterPos2dv
|
||||||
|
#define glRasterPos2f jwzgles_glRasterPos2f
|
||||||
|
#define glRasterPos2fv jwzgles_glRasterPos2fv
|
||||||
|
#define glRasterPos2i jwzgles_glRasterPos2i
|
||||||
|
#define glRasterPos2iv jwzgles_glRasterPos2iv
|
||||||
|
#define glRasterPos2s jwzgles_glRasterPos2s
|
||||||
|
#define glRasterPos2sv jwzgles_glRasterPos2sv
|
||||||
|
#define glRasterPos3d jwzgles_glRasterPos3d
|
||||||
|
#define glRasterPos3dv jwzgles_glRasterPos3dv
|
||||||
|
#define glRasterPos3f jwzgles_glRasterPos3f
|
||||||
|
#define glRasterPos3fv jwzgles_glRasterPos3fv
|
||||||
|
#define glRasterPos3i jwzgles_glRasterPos3i
|
||||||
|
#define glRasterPos3iv jwzgles_glRasterPos3iv
|
||||||
|
#define glRasterPos3s jwzgles_glRasterPos3s
|
||||||
|
#define glRasterPos3sv jwzgles_glRasterPos3sv
|
||||||
|
#define glRasterPos4d jwzgles_glRasterPos4d
|
||||||
|
#define glRasterPos4dv jwzgles_glRasterPos4dv
|
||||||
|
#define glRasterPos4f jwzgles_glRasterPos4f
|
||||||
|
#define glRasterPos4fv jwzgles_glRasterPos4fv
|
||||||
|
//#define glRasterPos4i jwzgles_glRasterPos4i
|
||||||
|
#define glRasterPos4iv jwzgles_glRasterPos4iv
|
||||||
|
#define glRasterPos4s jwzgles_glRasterPos4s
|
||||||
|
#define glRasterPos4sv jwzgles_glRasterPos4sv
|
||||||
|
#define glReadBuffer jwzgles_glReadBuffer
|
||||||
|
#define glRectd jwzgles_glRectf
|
||||||
|
#define glRectdv jwzgles_glRectdv
|
||||||
|
#define glRectf jwzgles_glRectf
|
||||||
|
#define glRectfv jwzgles_glRectfv
|
||||||
|
#define glRecti jwzgles_glRecti
|
||||||
|
#define glRectiv jwzgles_glRectiv
|
||||||
|
#define glRects jwzgles_glRects
|
||||||
|
#define glRectsv jwzgles_glRectsv
|
||||||
|
#define glRenderMode jwzgles_glRenderMode
|
||||||
|
#define glResetHistogram jwzgles_glResetHistogram
|
||||||
|
#define glResetMinmax jwzgles_glResetMinmax
|
||||||
|
#define glRotated jwzgles_glRotated
|
||||||
|
#define glScaled jwzgles_glScalef
|
||||||
|
#define glSelectBuffer jwzgles_glSelectBuffer
|
||||||
|
#define glSeparableFilter2D jwzgles_glSeparableFilter2D
|
||||||
|
#define glTexCoord1d jwzgles_glTexCoord1d
|
||||||
|
#define glTexCoord1dv jwzgles_glTexCoord1dv
|
||||||
|
#define glTexCoord1f jwzgles_glTexCoord1f
|
||||||
|
#define glTexCoord1fv jwzgles_glTexCoord1fv
|
||||||
|
#define glTexCoord1i jwzgles_glTexCoord1i
|
||||||
|
#define glTexCoord1iv jwzgles_glTexCoord1iv
|
||||||
|
#define glTexCoord1s jwzgles_glTexCoord1s
|
||||||
|
#define glTexCoord1sv jwzgles_glTexCoord1sv
|
||||||
|
#define glTexCoord2d jwzgles_glTexCoord2f
|
||||||
|
#define glTexCoord2dv jwzgles_glTexCoord2dv
|
||||||
|
#define glTexCoord2f jwzgles_glTexCoord2f
|
||||||
|
#define glTexCoord2fv jwzgles_glTexCoord2fv
|
||||||
|
#define glTexCoord2i jwzgles_glTexCoord2i
|
||||||
|
#define glTexCoord2iv jwzgles_glTexCoord2iv
|
||||||
|
#define glTexCoord2s jwzgles_glTexCoord2s
|
||||||
|
#define glTexCoord2sv jwzgles_glTexCoord2sv
|
||||||
|
#define glTexCoord3d jwzgles_glTexCoord3d
|
||||||
|
#define glTexCoord3dv jwzgles_glTexCoord3dv
|
||||||
|
#define glTexCoord3f jwzgles_glTexCoord3f
|
||||||
|
#define glTexCoord3fv jwzgles_glTexCoord3fv
|
||||||
|
#define glTexCoord3i jwzgles_glTexCoord3i
|
||||||
|
#define glTexCoord3iv jwzgles_glTexCoord3iv
|
||||||
|
#define glTexCoord3s jwzgles_glTexCoord3s
|
||||||
|
#define glTexCoord3sv jwzgles_glTexCoord3sv
|
||||||
|
#define glTexCoord4d jwzgles_glTexCoord4d
|
||||||
|
#define glTexCoord4dv jwzgles_glTexCoord4dv
|
||||||
|
#define glTexCoord4f jwzgles_glTexCoord4f
|
||||||
|
#define glTexCoord4fv jwzgles_glTexCoord4fv
|
||||||
|
#define glTexCoord4i jwzgles_glTexCoord4i
|
||||||
|
#define glTexCoord4iv jwzgles_glTexCoord4iv
|
||||||
|
#define glTexCoord4s jwzgles_glTexCoord4s
|
||||||
|
#define glTexCoord4sv jwzgles_glTexCoord4sv
|
||||||
|
#define glTexEnvi jwzgles_glTexEnvi
|
||||||
|
#define glTexEnviv jwzgles_glTexEnviv
|
||||||
|
#define glTexGend jwzgles_glTexGend
|
||||||
|
#define glTexGendv jwzgles_glTexGendv
|
||||||
|
#define glTexGenf jwzgles_glTexGenf
|
||||||
|
#define glTexGenfv jwzgles_glTexGenfv
|
||||||
|
#define glTexGeni jwzgles_glTexGeni
|
||||||
|
#define glTexGeniv jwzgles_glTexGeniv
|
||||||
|
#define glTexImage1D jwzgles_glTexImage1D
|
||||||
|
#define glTexImage3D jwzgles_glTexImage3D
|
||||||
|
#define glTexParameterfv jwzgles_glTexParameterfv
|
||||||
|
#define glTexParameteri jwzgles_glTexParameteri
|
||||||
|
#define glTexParameteriv jwzgles_glTexParameteriv
|
||||||
|
#define glTexSubImage1D jwzgles_glTexSubImage1D
|
||||||
|
#define glTexSubImage3D jwzgles_glTexSubImage3D
|
||||||
|
#define glTranslated jwzgles_glTranslatef
|
||||||
|
#define glVertex2d jwzgles_glVertex2d
|
||||||
|
#define glVertex2dv jwzgles_glVertex2dv
|
||||||
|
#define glVertex2f jwzgles_glVertex2f
|
||||||
|
#define glVertex2fv jwzgles_glVertex2fv
|
||||||
|
#define glVertex2i jwzgles_glVertex2i
|
||||||
|
#define glVertex2iv jwzgles_glVertex2iv
|
||||||
|
#define glVertex2s jwzgles_glVertex2s
|
||||||
|
#define glVertex2sv jwzgles_glVertex2sv
|
||||||
|
#define glVertex3d jwzgles_glVertex3f
|
||||||
|
#define glVertex3dv jwzgles_glVertex3dv
|
||||||
|
#define glVertex3f jwzgles_glVertex3f
|
||||||
|
#define glVertex3fv jwzgles_glVertex3fv
|
||||||
|
#define glVertex3i jwzgles_glVertex3i
|
||||||
|
#define glVertex3iv jwzgles_glVertex3iv
|
||||||
|
#define glVertex3s jwzgles_glVertex3s
|
||||||
|
#define glVertex3sv jwzgles_glVertex3sv
|
||||||
|
#define glVertex4d jwzgles_glVertex4d
|
||||||
|
#define glVertex4dv jwzgles_glVertex4dv
|
||||||
|
#define glVertex4f jwzgles_glVertex4f
|
||||||
|
#define glVertex4fv jwzgles_glVertex4fv
|
||||||
|
#define glVertex4i jwzgles_glVertex4i
|
||||||
|
#define glVertex4iv jwzgles_glVertex4iv
|
||||||
|
#define glVertex4s jwzgles_glVertex4s
|
||||||
|
#define glVertex4sv jwzgles_glVertex4sv
|
||||||
|
|
||||||
|
#define gluOrtho2D(L,R,B,T) glOrtho(L,R,B,T,-1,1)
|
||||||
|
#define gluPerspective jwzgles_gluPerspective
|
||||||
|
|
||||||
|
#define glXChooseVisual jwzgles_glXChooseVisual
|
||||||
|
#define glXCopyContext jwzgles_glXCopyContext
|
||||||
|
/*#define glXCreateContext jwzgles_glXCreateContext*/
|
||||||
|
#define glXCreateGLXPixmap jwzgles_glXCreateGLXPixmap
|
||||||
|
#define glXDestroyContext jwzgles_glXDestroyContext
|
||||||
|
#define glXDestroyGLXPixmap jwzgles_glXDestroyGLXPixmap
|
||||||
|
#define glXFreeContextEXT jwzgles_glXFreeContextEXT
|
||||||
|
#define glXGetClientString jwzgles_glXGetClientString
|
||||||
|
#define glXGetConfig jwzgles_glXGetConfig
|
||||||
|
#define glXGetContextIDEXT jwzgles_glXGetContextIDEXT
|
||||||
|
#define glXGetCurrentContext jwzgles_glXGetCurrentContext
|
||||||
|
#define glXGetCurrentDisplay jwzgles_glXGetCurrentDisplay
|
||||||
|
#define glXGetCurrentDrawable jwzgles_glXGetCurrentDrawable
|
||||||
|
#define glXImportContextEXT jwzgles_glXImportContextEXT
|
||||||
|
#define glXIntro jwzgles_glXIntro
|
||||||
|
#define glXIsDirect jwzgles_glXIsDirect
|
||||||
|
/*#define glXMakeCurrent jwzgles_glXMakeCurrent*/
|
||||||
|
#define glXQueryContextInfoEXT jwzgles_glXQueryContextInfoEXT
|
||||||
|
#define glXQueryExtension jwzgles_glXQueryExtension
|
||||||
|
#define glXQueryExtensionsString jwzgles_glXQueryExtensionsString
|
||||||
|
#define glXQueryServerString jwzgles_glXQueryServerString
|
||||||
|
#define glXQueryVersion jwzgles_glXQueryVersion
|
||||||
|
/*#define glXSwapBuffers jwzgles_glXSwapBuffers*/
|
||||||
|
#define glXUseXFont jwzgles_glXUseXFont
|
||||||
|
#define glXWaitGL jwzgles_glXWaitGL
|
||||||
|
#define glXWaitX jwzgles_glXWaitX
|
||||||
|
|
||||||
|
#define gluBeginCurve jwzgles_gluBeginCurve
|
||||||
|
#define gluBeginPolygon jwzgles_gluBeginPolygon
|
||||||
|
#define gluBeginSurface jwzgles_gluBeginSurface
|
||||||
|
#define gluBeginTrim jwzgles_gluBeginTrim
|
||||||
|
#define gluBuild1DMipmaps jwzgles_gluBuild1DMipmaps
|
||||||
|
#define gluBuild2DMipmaps jwzgles_gluBuild2DMipmaps
|
||||||
|
#define gluCylinder jwzgles_gluCylinder
|
||||||
|
#define gluDeleteNurbsRenderer jwzgles_gluDeleteNurbsRenderer
|
||||||
|
#define gluDeleteQuadric jwzgles_gluDeleteQuadric
|
||||||
|
#define gluDeleteTess jwzgles_gluDeleteTess
|
||||||
|
#define gluDisk jwzgles_gluDisk
|
||||||
|
#define gluEndCurve jwzgles_gluEndCurve
|
||||||
|
#define gluEndPolygon jwzgles_gluEndPolygon
|
||||||
|
#define gluEndSurface jwzgles_gluEndSurface
|
||||||
|
#define gluEndTrim jwzgles_gluEndTrim
|
||||||
|
#define gluErrorString jwzgles_gluErrorString
|
||||||
|
#define gluGetNurbsProperty jwzgles_gluGetNurbsProperty
|
||||||
|
#define gluGetString jwzgles_gluGetString
|
||||||
|
#define gluGetTessProperty jwzgles_gluGetTessProperty
|
||||||
|
#define gluLoadSamplingMatrices jwzgles_gluLoadSamplingMatrices
|
||||||
|
#define gluLookAt jwzgles_gluLookAt
|
||||||
|
#define gluNewNurbsRenderer jwzgles_gluNewNurbsRenderer
|
||||||
|
#define gluNewQuadric jwzgles_gluNewQuadric
|
||||||
|
#define gluNewTess jwzgles_gluNewTess
|
||||||
|
#define gluNextContour jwzgles_gluNextContour
|
||||||
|
#define gluNurbsCallback jwzgles_gluNurbsCallback
|
||||||
|
#define gluNurbsCurve jwzgles_gluNurbsCurve
|
||||||
|
#define gluNurbsProperty jwzgles_gluNurbsProperty
|
||||||
|
#define gluNurbsSurface jwzgles_gluNurbsSurface
|
||||||
|
#define gluPartialDisk jwzgles_gluPartialDisk
|
||||||
|
#define gluPickMatrix jwzgles_gluPickMatrix
|
||||||
|
#define gluProject jwzgles_gluProject
|
||||||
|
#define gluPwlCurve jwzgles_gluPwlCurve
|
||||||
|
#define gluQuadricCallback jwzgles_gluQuadricCallback
|
||||||
|
#define gluQuadricDrawStyle jwzgles_gluQuadricDrawStyle
|
||||||
|
#define gluQuadricNormals jwzgles_gluQuadricNormals
|
||||||
|
#define gluQuadricOrientation jwzgles_gluQuadricOrientation
|
||||||
|
#define gluQuadricTexture jwzgles_gluQuadricTexture
|
||||||
|
#define gluScaleImage jwzgles_gluScaleImage
|
||||||
|
#define gluSphere jwzgles_gluSphere
|
||||||
|
#define gluTessBeginContour jwzgles_gluTessBeginContour
|
||||||
|
#define gluTessBeginPolygon jwzgles_gluTessBeginPolygon
|
||||||
|
#define gluTessCallback jwzgles_gluTessCallback
|
||||||
|
#define gluTessEndPolygon jwzgles_gluTessEndPolygon
|
||||||
|
#define gluTessEndContour jwzgles_gluTessEndContour
|
||||||
|
#define gluTessNormal jwzgles_gluTessNormal
|
||||||
|
#define gluTessProperty jwzgles_gluTessProperty
|
||||||
|
#define gluTessVertex jwzgles_gluTessVertex
|
||||||
|
#define gluUnProject jwzgles_gluUnProject
|
||||||
|
|
||||||
|
|
||||||
|
/* These functions are present in both OpenGL 1.1 and in OpenGLES 1,
|
||||||
|
but are allowed within glNewList/glEndList, so we must wrap them
|
||||||
|
to allow them to be recorded.
|
||||||
|
*/
|
||||||
|
#define glActiveTexture jwzgles_glActiveTexture
|
||||||
|
#define glAlphaFunc jwzgles_glAlphaFunc
|
||||||
|
#define glBindTexture jwzgles_glBindTexture
|
||||||
|
#define glBlendFunc jwzgles_glBlendFunc
|
||||||
|
#define glClear jwzgles_glClear
|
||||||
|
#define glClearColor jwzgles_glClearColor
|
||||||
|
#define glClearStencil jwzgles_glClearStencil
|
||||||
|
#define glColor4f jwzgles_glColor4f
|
||||||
|
#define glColorMask jwzgles_glColorMask
|
||||||
|
#define glColorPointer jwzgles_glColorPointer
|
||||||
|
#define glCompressedTexImage2D jwzgles_glCompressedTexImage2D
|
||||||
|
#define glCompressedTexSubImage2D jwzgles_glCompressedTexSubImage2D
|
||||||
|
#define glCopyTexImage2D jwzgles_glCopyTexImage2D
|
||||||
|
#define glCopyTexSubImage2D jwzgles_glCopyTexSubImage2D
|
||||||
|
#define glCullFace jwzgles_glCullFace
|
||||||
|
#define glDeleteTextures jwzgles_glDeleteTextures
|
||||||
|
#define glDepthFunc jwzgles_glDepthFunc
|
||||||
|
#define glDepthMask jwzgles_glDepthMask
|
||||||
|
#define glDisable jwzgles_glDisable
|
||||||
|
#define glDrawArrays jwzgles_glDrawArrays
|
||||||
|
#define glDrawElements jwzgles_glDrawElements
|
||||||
|
#define glEnable jwzgles_glEnable
|
||||||
|
#define glFinish jwzgles_glFinish
|
||||||
|
#define glFlush jwzgles_glFlush
|
||||||
|
#define glFogf jwzgles_glFogf
|
||||||
|
#define glFogfv jwzgles_glFogfv
|
||||||
|
#define glFrontFace jwzgles_glFrontFace
|
||||||
|
#define glGenTextures jwzgles_glGenTextures
|
||||||
|
#define glGetIntegerv jwzgles_glGetIntegerv
|
||||||
|
#define glHint jwzgles_glHint
|
||||||
|
#define glLightModelf jwzgles_glLightModelf
|
||||||
|
#define glLightModelfv jwzgles_glLightModelfv
|
||||||
|
#define glLightf jwzgles_glLightf
|
||||||
|
#define glLightfv jwzgles_glLightfv
|
||||||
|
#define glLineWidth jwzgles_glLineWidth
|
||||||
|
#define glLoadIdentity jwzgles_glLoadIdentity
|
||||||
|
#define glLoadMatrixf jwzgles_glLoadMatrixf
|
||||||
|
#define glLogicOp jwzgles_glLogicOp
|
||||||
|
#define glMaterialf jwzgles_glMaterialf
|
||||||
|
#define glMateriali jwzgles_glMateriali
|
||||||
|
#define glMaterialfv jwzgles_glMaterialfv
|
||||||
|
#define glMaterialiv jwzgles_glMaterialiv
|
||||||
|
#define glMatrixMode jwzgles_glMatrixMode
|
||||||
|
#define glMultMatrixf jwzgles_glMultMatrixf
|
||||||
|
#define glNormal3f jwzgles_glNormal3f
|
||||||
|
#define glNormalPointer jwzgles_glNormalPointer
|
||||||
|
#define glPixelStorei jwzgles_glPixelStorei
|
||||||
|
#define glPointSize jwzgles_glPointSize
|
||||||
|
#define glPolygonOffset jwzgles_glPolygonOffset
|
||||||
|
#define glPopMatrix jwzgles_glPopMatrix
|
||||||
|
#define glPushMatrix jwzgles_glPushMatrix
|
||||||
|
#define glReadPixels jwzgles_glReadPixels
|
||||||
|
#define glRotatef jwzgles_glRotatef
|
||||||
|
#define glScalef jwzgles_glScalef
|
||||||
|
#define glSampleCoverage jwzgles_glSampleCoverage
|
||||||
|
#define glScissor jwzgles_glScissor
|
||||||
|
#define glShadeModel jwzgles_glShadeModel
|
||||||
|
#define glStencilFunc jwzgles_glStencilFunc
|
||||||
|
#define glStencilMask jwzgles_glStencilMask
|
||||||
|
#define glStencilOp jwzgles_glStencilOp
|
||||||
|
#define glTexCoordPointer jwzgles_glTexCoordPointer
|
||||||
|
#define glTexEnvf jwzgles_glTexEnvf
|
||||||
|
#define glTexEnvfv jwzgles_glTexEnvfv
|
||||||
|
#define glTexImage2D jwzgles_glTexImage2D
|
||||||
|
#define glTexParameterf jwzgles_glTexParameterf
|
||||||
|
#define glTexSubImage2D jwzgles_glTexSubImage2D
|
||||||
|
#define glTranslatef jwzgles_glTranslatef
|
||||||
|
#define glVertexPointer jwzgles_glVertexPointer
|
||||||
|
#define glViewport jwzgles_glViewport
|
||||||
|
#define glEnableClientState jwzgles_glEnableClientState
|
||||||
|
#define glDisableClientState jwzgles_glDisableClientState
|
||||||
|
#define glClipPlane jwzgles_glClipPlane
|
||||||
|
|
||||||
|
|
||||||
|
#define glGetError jwzgles_glGetError
|
||||||
|
#define glGetString jwzgles_glGetString
|
||||||
|
|
||||||
|
#endif /* __JWZGLES_H__ */
|
353
polymer/eduke32/build/include/jwzglesI.h
Normal file
353
polymer/eduke32/build/include/jwzglesI.h
Normal file
|
@ -0,0 +1,353 @@
|
||||||
|
/* xscreensaver, Copyright (c) 2012-2014 Jamie Zawinski <jwz@jwz.org>
|
||||||
|
*
|
||||||
|
* Permission to use, copy, modify, distribute, and sell this software and its
|
||||||
|
* documentation for any purpose is hereby granted without fee, provided that
|
||||||
|
* the above copyright notice appear in all copies and that both that
|
||||||
|
* copyright notice and this permission notice appear in supporting
|
||||||
|
* documentation. No representations are made about the suitability of this
|
||||||
|
* software for any purpose. It is provided "as is" without express or
|
||||||
|
* implied warranty.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* A compatibility shim to allow OpenGL 1.3 source code to work in an
|
||||||
|
OpenGLES environment, where almost every OpenGL 1.3 function has
|
||||||
|
been "deprecated". See jwzgles.c for details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __JWZGLES_I_H__
|
||||||
|
#define __JWZGLES_I_H__
|
||||||
|
|
||||||
|
#ifdef GL_VERSION_ES_CM_1_0 /* compiling against OpenGLES 1.x */
|
||||||
|
|
||||||
|
/* These OpenGL 1.3 constants are not present in OpenGLES 1.
|
||||||
|
Fortunately, it looks like they didn't re-use any of the numbers,
|
||||||
|
so we can just keep using the OpenGL 1.3 values. I'm actually
|
||||||
|
kind of shocked that the GLES folks passed up that opportunity
|
||||||
|
for further clusterfuckery.
|
||||||
|
*/
|
||||||
|
# define GLdouble double
|
||||||
|
|
||||||
|
# define GL_ACCUM_BUFFER_BIT 0x00000200
|
||||||
|
# define GL_ALL_ATTRIB_BITS 0x000FFFFF
|
||||||
|
# define GL_AUTO_NORMAL 0x0D80
|
||||||
|
# define GL_BLEND_SRC_ALPHA 0x80CB
|
||||||
|
# define GL_C3F_V3F 0x2A24
|
||||||
|
# define GL_C4F_N3F_V3F 0x2A26
|
||||||
|
# define GL_C4UB_V2F 0x2A22
|
||||||
|
# define GL_C4UB_V3F 0x2A23
|
||||||
|
# define GL_CLAMP 0x2900
|
||||||
|
# define GL_COLOR_BUFFER_BIT 0x00004000
|
||||||
|
# define GL_COLOR_MATERIAL_FACE 0x0B55
|
||||||
|
# define GL_COLOR_MATERIAL_PARAMETER 0x0B56
|
||||||
|
# define GL_COMPILE 0x1300
|
||||||
|
# define GL_CURRENT_BIT 0x00000001
|
||||||
|
# define GL_DEPTH_BUFFER_BIT 0x00000100
|
||||||
|
# define GL_DOUBLEBUFFER 0x0C32
|
||||||
|
# define GL_ENABLE_BIT 0x00002000
|
||||||
|
# define GL_EVAL_BIT 0x00010000
|
||||||
|
# define GL_EYE_LINEAR 0x2400
|
||||||
|
# define GL_EYE_PLANE 0x2502
|
||||||
|
# define GL_FEEDBACK 0x1C01
|
||||||
|
# define GL_FILL 0x1B02
|
||||||
|
# define GL_FOG_BIT 0x00000080
|
||||||
|
# define GL_HINT_BIT 0x00008000
|
||||||
|
# define GL_INTENSITY 0x8049
|
||||||
|
# define GL_LIGHTING_BIT 0x00000040
|
||||||
|
# define GL_LIGHT_MODEL_COLOR_CONTROL 0x81F8
|
||||||
|
# define GL_LIGHT_MODEL_LOCAL_VIEWER 0x0B51
|
||||||
|
# define GL_LINE 0x1B01
|
||||||
|
# define GL_LINE_BIT 0x00000004
|
||||||
|
# define GL_LIST_BIT 0x00020000
|
||||||
|
# define GL_N3F_V3F 0x2A25
|
||||||
|
# define GL_OBJECT_LINEAR 0x2401
|
||||||
|
# define GL_OBJECT_PLANE 0x2501
|
||||||
|
# define GL_PIXEL_MODE_BIT 0x00000020
|
||||||
|
# define GL_POINT_BIT 0x00000002
|
||||||
|
# define GL_POLYGON 0x0009
|
||||||
|
# define GL_POLYGON_BIT 0x00000008
|
||||||
|
# define GL_POLYGON_MODE 0x0B40
|
||||||
|
# define GL_POLYGON_SMOOTH 0x0B41
|
||||||
|
# define GL_POLYGON_STIPPLE 0x0B42
|
||||||
|
# define GL_POLYGON_STIPPLE_BIT 0x00000010
|
||||||
|
# define GL_Q 0x2003
|
||||||
|
# define GL_QUADS 0x0007
|
||||||
|
# define GL_QUAD_STRIP 0x0008
|
||||||
|
# define GL_R 0x2002
|
||||||
|
# define GL_RENDER 0x1C00
|
||||||
|
# define GL_RGBA_MODE 0x0C31
|
||||||
|
# define GL_S 0x2000
|
||||||
|
# define GL_SCISSOR_BIT 0x00080000
|
||||||
|
# define GL_SELECT 0x1C02
|
||||||
|
# define GL_SEPARATE_SPECULAR_COLOR 0x81FA
|
||||||
|
# define GL_SINGLE_COLOR 0x81F9
|
||||||
|
# define GL_SPHERE_MAP 0x2402
|
||||||
|
# define GL_STENCIL_BUFFER_BIT 0x00000400
|
||||||
|
# define GL_T 0x2001
|
||||||
|
# define GL_T2F_C3F_V3F 0x2A2A
|
||||||
|
# define GL_T2F_C4F_N3F_V3F 0x2A2C
|
||||||
|
# define GL_T2F_C4UB_V3F 0x2A29
|
||||||
|
# define GL_T2F_N3F_V3F 0x2A2B
|
||||||
|
# define GL_T2F_V3F 0x2A27
|
||||||
|
# define GL_T4F_C4F_N3F_V4F 0x2A2D
|
||||||
|
# define GL_T4F_V4F 0x2A28
|
||||||
|
# define GL_TEXTURE_1D 0x0DE0
|
||||||
|
# define GL_TEXTURE_ALPHA_SIZE 0x805F
|
||||||
|
# define GL_TEXTURE_BIT 0x00040000
|
||||||
|
# define GL_TEXTURE_BLUE_SIZE 0x805E
|
||||||
|
# define GL_TEXTURE_BORDER 0x1005
|
||||||
|
# define GL_TEXTURE_BORDER_COLOR 0x1004
|
||||||
|
# define GL_TEXTURE_COMPONENTS 0x1003
|
||||||
|
# define GL_TEXTURE_GEN_MODE 0x2500
|
||||||
|
# define GL_TEXTURE_GEN_Q 0x0C63
|
||||||
|
# define GL_TEXTURE_GEN_R 0x0C62
|
||||||
|
# define GL_TEXTURE_GEN_S 0x0C60
|
||||||
|
# define GL_TEXTURE_GEN_T 0x0C61
|
||||||
|
# define GL_TEXTURE_GREEN_SIZE 0x805D
|
||||||
|
# define GL_TEXTURE_HEIGHT 0x1001
|
||||||
|
# define GL_TEXTURE_INTENSITY_SIZE 0x8061
|
||||||
|
# define GL_TEXTURE_LUMINANCE_SIZE 0x8060
|
||||||
|
# define GL_TEXTURE_RED_SIZE 0x805C
|
||||||
|
# define GL_TEXTURE_WIDTH 0x1000
|
||||||
|
# define GL_TRANSFORM_BIT 0x00001000
|
||||||
|
# define GL_UNPACK_ROW_LENGTH 0x0CF2
|
||||||
|
# define GL_UNSIGNED_INT_8_8_8_8_REV 0x8367
|
||||||
|
# define GL_V2F 0x2A20
|
||||||
|
# define GL_V3F 0x2A21
|
||||||
|
# define GL_VIEWPORT_BIT 0x00000800
|
||||||
|
# define GL_INT 0x1404
|
||||||
|
# define GL_DOUBLE 0x140A
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
extern void jwzgles_reset (void);
|
||||||
|
|
||||||
|
|
||||||
|
/* Prototypes for the things re-implemented in jwzgles.c
|
||||||
|
*/
|
||||||
|
|
||||||
|
extern int jwzgles_glGenLists (int n);
|
||||||
|
extern void jwzgles_glNewList (int id, int mode);
|
||||||
|
extern void jwzgles_glEndList (void);
|
||||||
|
extern void jwzgles_glDeleteLists (int list, int range);
|
||||||
|
extern void jwzgles_glBegin (int mode);
|
||||||
|
extern void jwzgles_glNormal3fv (const GLfloat *);
|
||||||
|
extern void jwzgles_glNormal3f (GLfloat x, GLfloat y, GLfloat z);
|
||||||
|
extern void jwzgles_glTexCoord1f (GLfloat s);
|
||||||
|
extern void jwzgles_glTexCoord2fv (const GLfloat *);
|
||||||
|
extern void jwzgles_glTexCoord2f (GLfloat s, GLfloat t);
|
||||||
|
extern void jwzgles_glTexCoord2i (GLint s, GLint t);
|
||||||
|
extern void jwzgles_glTexCoord3fv (const GLfloat *);
|
||||||
|
extern void jwzgles_glTexCoord3f (GLfloat s, GLfloat t, GLfloat r);
|
||||||
|
extern void jwzgles_glTexCoord4fv (const GLfloat *);
|
||||||
|
extern void jwzgles_glTexCoord4f (GLfloat s, GLfloat t, GLfloat r, GLfloat q);
|
||||||
|
extern void jwzgles_glVertex2f (GLfloat x, GLfloat y);
|
||||||
|
extern void jwzgles_glVertex2fv (const GLfloat *);
|
||||||
|
extern void jwzgles_glVertex2i (GLint x, GLint y);
|
||||||
|
extern void jwzgles_glVertex3f (GLfloat x, GLfloat y, GLfloat z);
|
||||||
|
extern void jwzgles_glVertex3dv (const GLdouble *);
|
||||||
|
extern void jwzgles_glVertex3fv (const GLfloat *);
|
||||||
|
extern void jwzgles_glVertex3i (GLint x, GLint y, GLint z);
|
||||||
|
extern void jwzgles_glVertex4f (GLfloat x, GLfloat y, GLfloat z, GLfloat w);
|
||||||
|
extern void jwzgles_glVertex4fv (const GLfloat *);
|
||||||
|
extern void jwzgles_glVertex4i (GLint x, GLint y, GLint z, GLint w);
|
||||||
|
extern void jwzgles_glEnd (void);
|
||||||
|
extern void jwzgles_glCallList (int id);
|
||||||
|
extern void jwzgles_glClearIndex(GLfloat c);
|
||||||
|
extern void jwzgles_glBitmap (GLsizei, GLsizei, GLfloat, GLfloat, GLfloat,
|
||||||
|
GLfloat, const GLubyte *);
|
||||||
|
extern void jwzgles_glPushAttrib(int);
|
||||||
|
extern void jwzgles_glPopAttrib(void);
|
||||||
|
|
||||||
|
|
||||||
|
/* These functions are present in both OpenGL 1.3 and in OpenGLES 1,
|
||||||
|
but are allowed within glNewList/glEndList, so we must wrap them
|
||||||
|
to allow them to be recorded.
|
||||||
|
*/
|
||||||
|
extern void jwzgles_glActiveTexture (GLuint);
|
||||||
|
extern void jwzgles_glBindTexture (GLuint, GLuint);
|
||||||
|
extern void jwzgles_glBlendFunc (GLuint, GLuint);
|
||||||
|
extern void jwzgles_glClear (GLuint);
|
||||||
|
extern void jwzgles_glClearColor (GLclampf, GLclampf, GLclampf, GLclampf);
|
||||||
|
extern void jwzgles_glClearStencil (GLuint);
|
||||||
|
extern void jwzgles_glColorMask (GLuint, GLuint, GLuint, GLuint);
|
||||||
|
extern void jwzgles_glCullFace (GLuint);
|
||||||
|
extern void jwzgles_glDepthFunc (GLuint);
|
||||||
|
extern void jwzgles_glDepthMask (GLuint);
|
||||||
|
extern void jwzgles_glDisable (GLuint);
|
||||||
|
extern void jwzgles_glDrawArrays (GLuint, GLuint, GLuint);
|
||||||
|
extern GLboolean jwzgles_glIsEnabled (GLuint);
|
||||||
|
extern void jwzgles_glEnable (GLuint);
|
||||||
|
extern void jwzgles_glFrontFace (GLuint);
|
||||||
|
extern void jwzgles_glHint (GLuint, GLuint);
|
||||||
|
extern void jwzgles_glLineWidth (GLfloat);
|
||||||
|
extern void jwzgles_glLoadIdentity (void);
|
||||||
|
extern void jwzgles_glLogicOp (GLuint);
|
||||||
|
extern void jwzgles_glMatrixMode (GLuint);
|
||||||
|
extern void jwzgles_glMultMatrixf (const GLfloat *);
|
||||||
|
extern void jwzgles_glLoadMatrixf (const GLfloat *);
|
||||||
|
extern void jwzgles_glPointSize (GLfloat);
|
||||||
|
extern void jwzgles_glPolygonOffset (GLfloat, GLfloat);
|
||||||
|
extern void jwzgles_glPopMatrix (void);
|
||||||
|
extern void jwzgles_glPushMatrix (void);
|
||||||
|
extern void jwzgles_glScissor (GLuint, GLuint, GLuint, GLuint);
|
||||||
|
extern void jwzgles_glShadeModel (GLuint);
|
||||||
|
extern void jwzgles_glStencilFunc (GLuint, GLuint, GLuint);
|
||||||
|
extern void jwzgles_glStencilMask (GLuint);
|
||||||
|
extern void jwzgles_glStencilOp (GLuint, GLuint, GLuint);
|
||||||
|
extern void jwzgles_glViewport (GLuint, GLuint, GLuint, GLuint);
|
||||||
|
extern void jwzgles_glTranslatef (GLfloat, GLfloat, GLfloat);
|
||||||
|
extern void jwzgles_glRotatef (GLfloat, GLfloat, GLfloat, GLfloat);
|
||||||
|
extern void jwzgles_glRotated (GLdouble, GLdouble x, GLdouble y, GLdouble z);
|
||||||
|
extern void jwzgles_glScalef (GLfloat, GLfloat, GLfloat);
|
||||||
|
extern void jwzgles_glColor3f (GLfloat, GLfloat, GLfloat);
|
||||||
|
extern void jwzgles_glColor4f (GLfloat, GLfloat, GLfloat, GLfloat);
|
||||||
|
extern void jwzgles_glColor3fv (const GLfloat *);
|
||||||
|
extern void jwzgles_glColor4fv (const GLfloat *);
|
||||||
|
extern void jwzgles_glColor3s (GLshort, GLshort, GLshort);
|
||||||
|
extern void jwzgles_glColor4s (GLshort, GLshort, GLshort, GLshort);
|
||||||
|
extern void jwzgles_glColor3sv (const GLshort *);
|
||||||
|
extern void jwzgles_glColor4sv (const GLshort *);
|
||||||
|
extern void jwzgles_glColor3us (GLushort, GLushort, GLushort);
|
||||||
|
extern void jwzgles_glColor4us (GLushort, GLushort, GLushort, GLushort);
|
||||||
|
extern void jwzgles_glColor3usv (const GLushort *);
|
||||||
|
extern void jwzgles_glColor4usv (const GLushort *);
|
||||||
|
extern void jwzgles_glColor3d (GLdouble, GLdouble, GLdouble);
|
||||||
|
extern void jwzgles_glColor4d (GLdouble, GLdouble, GLdouble, GLdouble);
|
||||||
|
extern void jwzgles_glColor3dv (const GLdouble *);
|
||||||
|
extern void jwzgles_glColor4dv (const GLdouble *);
|
||||||
|
extern void jwzgles_glColor4i (GLint, GLint, GLint, GLint);
|
||||||
|
extern void jwzgles_glColor3i (GLint, GLint, GLint);
|
||||||
|
extern void jwzgles_glColor3iv (const GLint *);
|
||||||
|
extern void jwzgles_glColor4iv (const GLint *);
|
||||||
|
extern void jwzgles_glColor4ui (GLuint, GLuint, GLuint, GLuint);
|
||||||
|
extern void jwzgles_glColor3ui (GLuint, GLuint, GLuint);
|
||||||
|
extern void jwzgles_glColor3uiv (const GLuint *);
|
||||||
|
extern void jwzgles_glColor4uiv (const GLuint *);
|
||||||
|
extern void jwzgles_glColor4b (GLbyte, GLbyte, GLbyte, GLbyte);
|
||||||
|
extern void jwzgles_glColor3b (GLbyte, GLbyte, GLbyte);
|
||||||
|
extern void jwzgles_glColor4bv (const GLbyte *);
|
||||||
|
extern void jwzgles_glColor3bv (const GLbyte *);
|
||||||
|
extern void jwzgles_glColor4ub (GLubyte, GLubyte, GLubyte, GLubyte);
|
||||||
|
extern void jwzgles_glColor3ub (GLubyte, GLubyte, GLubyte);
|
||||||
|
extern void jwzgles_glColor4ubv (const GLubyte *);
|
||||||
|
extern void jwzgles_glColor3ubv (const GLubyte *);
|
||||||
|
extern void jwzgles_glMaterialf (GLuint, GLuint, GLfloat);
|
||||||
|
extern void jwzgles_glMateriali (GLuint, GLuint, GLuint);
|
||||||
|
extern void jwzgles_glMaterialfv (GLuint, GLuint, const GLfloat *);
|
||||||
|
extern void jwzgles_glMaterialiv (GLuint, GLuint, const GLint *);
|
||||||
|
extern void jwzgles_glFinish (void);
|
||||||
|
extern void jwzgles_glFlush (void);
|
||||||
|
extern void jwzgles_glPixelStorei (GLuint, GLuint);
|
||||||
|
extern void jwzgles_glEnableClientState (GLuint);
|
||||||
|
extern void jwzgles_glDisableClientState (GLuint);
|
||||||
|
|
||||||
|
extern void jwzgles_glInitNames (void);
|
||||||
|
extern void jwzgles_glPushName (GLuint);
|
||||||
|
extern GLuint jwzgles_glPopName (void);
|
||||||
|
extern GLuint jwzgles_glRenderMode (GLuint);
|
||||||
|
extern void jwzgles_glSelectBuffer (GLsizei, GLuint *);
|
||||||
|
extern void jwzgles_glLightf (GLenum, GLenum, GLfloat);
|
||||||
|
extern void jwzgles_glLighti (GLenum, GLenum, GLint);
|
||||||
|
extern void jwzgles_glLightfv (GLenum, GLenum, const GLfloat *);
|
||||||
|
extern void jwzgles_glLightiv (GLenum, GLenum, const GLint *);
|
||||||
|
extern void jwzgles_glLightModelf (GLenum, GLfloat);
|
||||||
|
extern void jwzgles_glLightModeli (GLenum, GLint);
|
||||||
|
extern void jwzgles_glLightModelfv (GLenum, const GLfloat *);
|
||||||
|
extern void jwzgles_glLightModeliv (GLenum, const GLint *);
|
||||||
|
extern void jwzgles_glGenTextures (GLuint, GLuint *);
|
||||||
|
extern void jwzgles_glFrustum (GLfloat, GLfloat, GLfloat, GLfloat,
|
||||||
|
GLfloat, GLfloat);
|
||||||
|
extern void jwzgles_glOrtho (GLfloat, GLfloat, GLfloat, GLfloat,
|
||||||
|
GLfloat, GLfloat);
|
||||||
|
extern void jwzgles_glTexImage1D (GLenum target, GLint level,
|
||||||
|
GLint internalFormat,
|
||||||
|
GLsizei width, GLint border,
|
||||||
|
GLenum format, GLenum type,
|
||||||
|
const GLvoid *pixels);
|
||||||
|
extern void jwzgles_glTexImage2D (GLenum target,
|
||||||
|
GLint level,
|
||||||
|
GLint internalFormat,
|
||||||
|
GLsizei width,
|
||||||
|
GLsizei height,
|
||||||
|
GLint border,
|
||||||
|
GLenum format,
|
||||||
|
GLenum type,
|
||||||
|
const GLvoid *data);
|
||||||
|
extern void jwzgles_glTexSubImage2D (GLenum target, GLint level,
|
||||||
|
GLint xoffset, GLint yoffset,
|
||||||
|
GLsizei width, GLsizei height,
|
||||||
|
GLenum format, GLenum type,
|
||||||
|
const GLvoid *pixels);
|
||||||
|
extern void jwzgles_glCopyTexImage2D (GLenum target, GLint level,
|
||||||
|
GLenum internalformat,
|
||||||
|
GLint x, GLint y,
|
||||||
|
GLsizei width, GLsizei height,
|
||||||
|
GLint border);
|
||||||
|
extern void jwzgles_glInterleavedArrays (GLenum, GLsizei, const GLvoid *);
|
||||||
|
extern void jwzgles_glTexEnvf (GLuint, GLuint, GLfloat);
|
||||||
|
extern void jwzgles_glTexEnvi (GLuint, GLuint, GLuint);
|
||||||
|
extern void jwzgles_glTexParameterf (GLuint, GLuint, GLfloat);
|
||||||
|
extern void jwzgles_glTexParameteri (GLuint, GLuint, GLuint);
|
||||||
|
extern void jwzgles_glTexGeni (GLenum, GLenum, GLint);
|
||||||
|
extern void jwzgles_glTexGenfv (GLenum, GLenum, const GLfloat *);
|
||||||
|
extern void jwzgles_glGetTexGenfv (GLenum, GLenum, GLfloat *);
|
||||||
|
extern void jwzgles_glRectf (GLfloat, GLfloat, GLfloat, GLfloat);
|
||||||
|
extern void jwzgles_glRecti (GLint, GLint, GLint, GLint);
|
||||||
|
extern void jwzgles_glLightModelfv (GLenum, const GLfloat *);
|
||||||
|
extern void jwzgles_glClearDepth (GLfloat);
|
||||||
|
extern GLboolean jwzgles_glIsList (GLuint);
|
||||||
|
extern void jwzgles_glColorMaterial (GLenum, GLenum);
|
||||||
|
extern void jwzgles_glPolygonMode (GLenum, GLenum);
|
||||||
|
extern void jwzgles_glFogf (GLenum, GLfloat);
|
||||||
|
extern void jwzgles_glFogi (GLenum, GLint);
|
||||||
|
extern void jwzgles_glFogfv (GLenum, const GLfloat *);
|
||||||
|
extern void jwzgles_glFogiv (GLenum, const GLint *);
|
||||||
|
extern void jwzgles_glAlphaFunc (GLenum, GLfloat);
|
||||||
|
extern void jwzgles_glClipPlane (GLenum, const GLdouble *);
|
||||||
|
extern void jwzgles_glDrawBuffer (GLenum);
|
||||||
|
extern void jwzgles_glDeleteTextures (GLuint, const GLuint *);
|
||||||
|
|
||||||
|
extern void jwzgles_gluPerspective (GLdouble fovy, GLdouble aspect,
|
||||||
|
GLdouble near, GLdouble far);
|
||||||
|
extern void jwzgles_gluLookAt (GLfloat eyex, GLfloat eyey, GLfloat eyez,
|
||||||
|
GLfloat centerx, GLfloat centery,
|
||||||
|
GLfloat centerz,
|
||||||
|
GLfloat upx, GLfloat upy, GLfloat upz);
|
||||||
|
extern GLint jwzgles_gluProject (GLdouble objx, GLdouble objy, GLdouble objz,
|
||||||
|
const GLdouble modelMatrix[16],
|
||||||
|
const GLdouble projMatrix[16],
|
||||||
|
const GLint viewport[4],
|
||||||
|
GLdouble *winx, GLdouble *winy,
|
||||||
|
GLdouble *winz);
|
||||||
|
extern int jwzgles_gluBuild2DMipmaps (GLenum target,
|
||||||
|
GLint internalFormat,
|
||||||
|
GLsizei width,
|
||||||
|
GLsizei height,
|
||||||
|
GLenum format,
|
||||||
|
GLenum type,
|
||||||
|
const GLvoid *data);
|
||||||
|
extern void jwzgles_glGetFloatv (GLenum pname, GLfloat *params);
|
||||||
|
extern void jwzgles_glGetPointerv (GLenum pname, GLvoid *params);
|
||||||
|
extern void jwzgles_glGetDoublev (GLenum pname, GLdouble *params);
|
||||||
|
extern void jwzgles_glGetIntegerv (GLenum pname, GLint *params);
|
||||||
|
extern void jwzgles_glGetBooleanv (GLenum pname, GLboolean *params);
|
||||||
|
extern void jwzgles_glVertexPointer (GLuint, GLuint, GLuint, const void *);
|
||||||
|
extern void jwzgles_glNormalPointer (GLenum, GLuint, const void *);
|
||||||
|
extern void jwzgles_glColorPointer (GLuint, GLuint, GLuint, const void *);
|
||||||
|
extern void jwzgles_glTexCoordPointer (GLuint, GLuint, GLuint, const void *);
|
||||||
|
extern void jwzgles_glBindBuffer (GLuint, GLuint);
|
||||||
|
extern void jwzgles_glBufferData (GLenum, GLsizeiptr, const void *, GLenum);
|
||||||
|
extern const char *jwzgles_gluErrorString (GLenum error);
|
||||||
|
|
||||||
|
extern GLenum jwzgles_glGetError();
|
||||||
|
extern const GLubyte * jwzgles_glGetString(GLenum name);
|
||||||
|
|
||||||
|
|
||||||
|
typedef float GLclampd;
|
||||||
|
|
||||||
|
extern void jwzgles_glReadPixels (GLint x, GLint y, GLsizei width, GLsizei height, GLenum format, GLenum type, GLvoid *pixels);
|
||||||
|
extern void jwzgles_glCopyTexSubImage2D (GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint x, GLint y, GLsizei width, GLsizei height);
|
||||||
|
extern void jwzgles_glDrawElements( GLenum mode, GLsizei count, GLenum type, const GLvoid *indices );
|
||||||
|
|
||||||
|
#endif /* __JWZGLES_I_H__ */
|
1047
polymer/eduke32/build/src/glbuild_android.c
Normal file
1047
polymer/eduke32/build/src/glbuild_android.c
Normal file
File diff suppressed because it is too large
Load diff
4152
polymer/eduke32/build/src/jwzgles.c
Normal file
4152
polymer/eduke32/build/src/jwzgles.c
Normal file
File diff suppressed because it is too large
Load diff
|
@ -36,6 +36,9 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
extern void CONTROL_Android_ClearButton(int32_t whichbutton);
|
extern void CONTROL_Android_ClearButton(int32_t whichbutton);
|
||||||
extern void CONTROL_Android_PollDevices(ControlInfo *info);
|
extern void CONTROL_Android_PollDevices(ControlInfo *info);
|
||||||
extern void CONTROL_Android_SetLastWeapon(int w);
|
extern void CONTROL_Android_SetLastWeapon(int w);
|
||||||
|
|
||||||
|
extern void CONTROL_Android_ScrollMap(int32_t *angle,int32_t *x, int32_t *y, uint16_t *zoom );
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -20,28 +20,46 @@
|
||||||
#include "s-setup/s-setup.h"
|
#include "s-setup/s-setup.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern "C"
|
extern "C" {
|
||||||
{
|
|
||||||
|
|
||||||
#define DEFAULT_FADE_FRAMES 10
|
#define DEFAULT_FADE_FRAMES 10
|
||||||
|
|
||||||
extern void SDL_Android_Init(JNIEnv *env, jclass cls);
|
extern void SDL_Android_Init(JNIEnv *env, jclass cls);
|
||||||
// This is a new function I put into SDL2, file SDL_androidgl.c
|
// This is a new function I put into SDL2, file SDL_androidgl.c
|
||||||
extern void SDL_SetSwapBufferCallBack(void (*pt2Func)(void));
|
extern void SDL_SetSwapBufferCallBack(void (*pt2Func)(void));
|
||||||
|
|
||||||
|
extern char const *G_GetStringFromSavegame(const char *filename, int type);
|
||||||
|
extern int32_t G_GetScreenshotFromSavegame(const char *filename, char *pal, char *data);
|
||||||
|
|
||||||
#include "in_android.h"
|
#include "in_android.h"
|
||||||
#include "../function.h"
|
#include "../function.h"
|
||||||
|
|
||||||
#include "../GL/gl.h"
|
#include "../GL/gl.h"
|
||||||
#include "../GL/nano_gl.h"
|
|
||||||
|
|
||||||
// Copied from build.h, which didnt include here
|
// Copied from build.h, which didnt include here
|
||||||
enum rendmode_t {
|
enum rendmode_t
|
||||||
|
{
|
||||||
REND_CLASSIC,
|
REND_CLASSIC,
|
||||||
REND_POLYMOST = 3,
|
REND_POLYMOST = 3,
|
||||||
REND_POLYMER
|
REND_POLYMER
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum dukeinv_t
|
||||||
|
{
|
||||||
|
GET_STEROIDS, // 0
|
||||||
|
GET_SHIELD,
|
||||||
|
GET_SCUBA,
|
||||||
|
GET_HOLODUKE,
|
||||||
|
GET_JETPACK,
|
||||||
|
GET_DUMMY1, // 5
|
||||||
|
GET_ACCESS,
|
||||||
|
GET_HEATS,
|
||||||
|
GET_DUMMY2,
|
||||||
|
GET_FIRSTAID,
|
||||||
|
GET_BOOTS, // 10
|
||||||
|
GET_MAX
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
#ifndef LOGI
|
#ifndef LOGI
|
||||||
#define LOGI(...) ((void)__android_log_print(ANDROID_LOG_INFO, "DUKE", __VA_ARGS__))
|
#define LOGI(...) ((void)__android_log_print(ANDROID_LOG_INFO, "DUKE", __VA_ARGS__))
|
||||||
#define LOGW(...) ((void)__android_log_print(ANDROID_LOG_WARN, "DUKE", __VA_ARGS__))
|
#define LOGW(...) ((void)__android_log_print(ANDROID_LOG_WARN, "DUKE", __VA_ARGS__))
|
||||||
|
@ -55,17 +73,7 @@ droidsysinfo_t droidinfo;
|
||||||
|
|
||||||
static int curRenderer;
|
static int curRenderer;
|
||||||
|
|
||||||
float gameControlsAlpha = 0.5;
|
|
||||||
|
|
||||||
static bool invertLook = false;
|
|
||||||
static bool precisionShoot = false;
|
|
||||||
static bool showSticks = true;
|
|
||||||
static bool hideTouchControls = true;
|
static bool hideTouchControls = true;
|
||||||
char toggleCrouch = true;
|
|
||||||
static bool selectLastWeap = true;
|
|
||||||
|
|
||||||
static bool shooting = false;
|
|
||||||
|
|
||||||
static int weaponWheelVisible = false;
|
static int weaponWheelVisible = false;
|
||||||
|
|
||||||
|
|
||||||
|
@ -87,6 +95,8 @@ touchcontrols::WheelSelect *weaponWheel;
|
||||||
extern JNIEnv *env_;
|
extern JNIEnv *env_;
|
||||||
JavaVM *jvm_;
|
JavaVM *jvm_;
|
||||||
|
|
||||||
|
touchcontrols::Button *inv_buttons[GET_MAX];
|
||||||
|
|
||||||
void openGLStart()
|
void openGLStart()
|
||||||
{
|
{
|
||||||
if (curRenderer == REND_GL)
|
if (curRenderer == REND_GL)
|
||||||
|
@ -120,8 +130,9 @@ void openGLStart()
|
||||||
|
|
||||||
glMatrixMode(GL_MODELVIEW);
|
glMatrixMode(GL_MODELVIEW);
|
||||||
|
|
||||||
nanoPushState();
|
// nanoPushState();
|
||||||
}
|
}
|
||||||
|
/*
|
||||||
else // software mode
|
else // software mode
|
||||||
{
|
{
|
||||||
glDisable(GL_ALPHA_TEST);
|
glDisable(GL_ALPHA_TEST);
|
||||||
|
@ -135,6 +146,7 @@ void openGLStart()
|
||||||
glDisable(GL_CULL_FACE);
|
glDisable(GL_CULL_FACE);
|
||||||
glMatrixMode(GL_MODELVIEW);
|
glMatrixMode(GL_MODELVIEW);
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
void openGLEnd()
|
void openGLEnd()
|
||||||
|
@ -142,14 +154,16 @@ void openGLEnd()
|
||||||
if (curRenderer == REND_GL)
|
if (curRenderer == REND_GL)
|
||||||
{
|
{
|
||||||
// glPopMatrix();
|
// glPopMatrix();
|
||||||
nanoPopState();
|
// nanoPopState();
|
||||||
glPopMatrix();
|
glPopMatrix();
|
||||||
}
|
}
|
||||||
|
/*
|
||||||
else // Software mode
|
else // Software mode
|
||||||
{
|
{
|
||||||
glTexEnvf(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_REPLACE);
|
glTexEnvf(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_REPLACE);
|
||||||
glMatrixMode(GL_MODELVIEW);
|
glMatrixMode(GL_MODELVIEW);
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
void gameSettingsButton(int state)
|
void gameSettingsButton(int state)
|
||||||
|
@ -162,6 +176,7 @@ void gameSettingsButton(int state)
|
||||||
|
|
||||||
// Because there is no Frame(), we need to check back to java each frame to see if the app hase paused
|
// Because there is no Frame(), we need to check back to java each frame to see if the app hase paused
|
||||||
|
|
||||||
|
/*
|
||||||
static jclass NativeLibClass = 0;
|
static jclass NativeLibClass = 0;
|
||||||
static jmethodID checkPauseMethod = 0;
|
static jmethodID checkPauseMethod = 0;
|
||||||
|
|
||||||
|
@ -169,13 +184,15 @@ void swapBuffers()
|
||||||
{
|
{
|
||||||
if (NativeLibClass == 0)
|
if (NativeLibClass == 0)
|
||||||
{
|
{
|
||||||
NativeLibClass = env_->FindClass("com/beloko/duke/engine/NativeLib");
|
NativeLibClass = env_->FindClass("com/voidpoint/duke3d/engine/NativeLib");
|
||||||
checkPauseMethod = env_->GetStaticMethodID(NativeLibClass, "swapBuffers", "()V");
|
checkPauseMethod = env_->GetStaticMethodID(NativeLibClass, "swapBuffers", "()V");
|
||||||
}
|
}
|
||||||
env_->CallStaticVoidMethod(NativeLibClass, checkPauseMethod);
|
env_->CallStaticVoidMethod(NativeLibClass, checkPauseMethod);
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
//This is a bit of a hack, if the weapon wheel was selected, then an inv chosen instead, we need to cancel the weapon selection
|
// This is a bit of a hack, if the weapon wheel was selected, then an inv chosen instead, we need to cancel the weapon
|
||||||
|
// selection
|
||||||
// NOT needed actually, weapon wheel disabled before is get finger up anyway
|
// NOT needed actually, weapon wheel disabled before is get finger up anyway
|
||||||
// static bool invWasSelected = false;
|
// static bool invWasSelected = false;
|
||||||
|
|
||||||
|
@ -207,8 +224,12 @@ void gameButton(int state, int code)
|
||||||
switch (code)
|
switch (code)
|
||||||
{
|
{
|
||||||
case gamefunc_Fire:
|
case gamefunc_Fire:
|
||||||
shooting = state;
|
if (state && PortableRead(READ_SOMETHINGONPLAYER))
|
||||||
PortableAction(state, code);
|
{
|
||||||
|
PortableAction(1, gamefunc_Quick_Kick);
|
||||||
|
PortableAction(0, gamefunc_Quick_Kick);
|
||||||
|
}
|
||||||
|
else PortableAction(state, code);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case KEY_SHOW_KBRD:
|
case KEY_SHOW_KBRD:
|
||||||
|
@ -246,16 +267,11 @@ void gameButton(int state, int code)
|
||||||
PortableKeyEvent(state, SDL_SCANCODE_F9, 0);
|
PortableKeyEvent(state, SDL_SCANCODE_F9, 0);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default: PortableAction(state, code); break;
|
||||||
PortableAction(state, code);
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void automapButton(int state,int code)
|
void automapButton(int state, int code) { PortableAction(state, code); }
|
||||||
{
|
|
||||||
PortableAction(state,code);
|
|
||||||
}
|
|
||||||
|
|
||||||
void inventoryButton(int state, int code)
|
void inventoryButton(int state, int code)
|
||||||
{
|
{
|
||||||
|
@ -267,9 +283,15 @@ void inventoryButton(int state,int code)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void menuButton(int state,int code)
|
void menuButton(int state, int code) { PortableKeyEvent(state, code, code); }
|
||||||
|
|
||||||
|
void menuMouse(int action, float x, float y, float dx, float dy)
|
||||||
{
|
{
|
||||||
PortableKeyEvent(state, code,code);
|
// PortableMouse(dx,dy);
|
||||||
|
PortableMouseMenu(x * droidinfo.screen_width, y * droidinfo.screen_height);
|
||||||
|
|
||||||
|
if (action == MULTITOUCHMOUSE_DOWN || action == MULTITOUCHMOUSE_UP)
|
||||||
|
PortableMouseMenuButton(action == MULTITOUCHMOUSE_DOWN, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void blankTapButton(int state, int code)
|
void blankTapButton(int state, int code)
|
||||||
|
@ -283,43 +305,20 @@ void blankTapButton(int state,int code)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else // everything else send a return key
|
else // everything else send a return key
|
||||||
{
|
|
||||||
PortableKeyEvent(state, SDL_SCANCODE_RETURN, 0);
|
PortableKeyEvent(state, SDL_SCANCODE_RETURN, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
void weaponWheelSelected(int enabled) { showWeaponsInventory(enabled ? true : false); }
|
||||||
|
|
||||||
void weaponWheelSelected(int enabled)
|
|
||||||
{
|
|
||||||
if (enabled)
|
|
||||||
{
|
|
||||||
showWeaponsInventory(true);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
showWeaponsInventory(false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void weaponWheelChosen(int segment)
|
void weaponWheelChosen(int segment)
|
||||||
{
|
{
|
||||||
|
|
||||||
// LOGI("weaponWheel %d",segment);
|
// LOGI("weaponWheel %d",segment);
|
||||||
if (segment == -1) //Nothing was selected
|
if (segment == -1 && droidinput.quickSelectWeapon)
|
||||||
{
|
segment = PortableRead(READ_LASTWEAPON);
|
||||||
if (selectLastWeap)
|
|
||||||
{
|
|
||||||
int32_t lw = PortableRead(READ_LASTWEAPON);
|
|
||||||
|
|
||||||
if (lw != -1)
|
if (segment != -1)
|
||||||
PortableAction(2, gamefunc_Weapon_1 + lw);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
PortableAction(2, gamefunc_Weapon_1 + segment);
|
PortableAction(2, gamefunc_Weapon_1 + segment);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void left_double_tap(int state)
|
void left_double_tap(int state)
|
||||||
{
|
{
|
||||||
|
@ -341,45 +340,36 @@ void mouseMove(int action, float x, float y, float dx, float dy)
|
||||||
if (weaponWheelVisible)
|
if (weaponWheelVisible)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
double scale = (shooting && precisionShoot) ? PRECISIONSHOOTFACTOR : 1.f;
|
float const scale = .1f;
|
||||||
|
|
||||||
PortableLook(dx * droidinput.yaw_sens * scale,
|
PortableLook(dx * droidinput.yaw_sens * scale, -dy * droidinput.pitch_sens * scale * (droidinput.invertLook ? -1.f : 1.f));
|
||||||
-dy * droidinput.pitch_sens * scale * (invertLook ? -1.f : 1.f));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void automap_multitouch_mouse_move(int action, float x, float y, float dx, float dy)
|
void automap_multitouch_mouse_move(int action, float x, float y, float dx, float dy)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (action == MULTITOUCHMOUSE_MOVE)
|
if (action == MULTITOUCHMOUSE_MOVE)
|
||||||
{
|
|
||||||
PortableAutomapControl(0, dx, dy);
|
PortableAutomapControl(0, dx, dy);
|
||||||
}
|
|
||||||
else if (action == MULTITOUCHMOUSE_ZOOM)
|
else if (action == MULTITOUCHMOUSE_ZOOM)
|
||||||
{
|
|
||||||
PortableAutomapControl(x, 0, 0);
|
PortableAutomapControl(x, 0, 0);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void left_stick(float joy_x, float joy_y, float mouse_x, float mouse_y)
|
void left_stick(float joy_x, float joy_y, float mouse_x, float mouse_y)
|
||||||
{
|
{
|
||||||
// LOGI("left_stick joy_x = %f, joy_y = %f",joy_x,joy_y);
|
// LOGI("left_stick joy_x = %f, joy_y = %f",joy_x,joy_y);
|
||||||
joy_x *=10;
|
PortableMove(joy_y * droidinput.forward_sens, -joy_x * droidinput.strafe_sens);
|
||||||
float strafe = joy_x*joy_x;
|
|
||||||
//float strafe = joy_x;
|
|
||||||
if (joy_x < 0)
|
|
||||||
strafe *= -1;
|
|
||||||
|
|
||||||
PortableMove(joy_y * 15 * droidinput.forward_sens, -strafe * droidinput.strafe_sens);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
void right_stick(float joy_x, float joy_y, float mouse_x, float mouse_y)
|
void right_stick(float joy_x, float joy_y, float mouse_x, float mouse_y)
|
||||||
{
|
{
|
||||||
mouseMove(0, joy_x, joy_y, mouse_x, mouse_y);
|
mouseMove(0, joy_x, joy_y, mouse_x, mouse_y);
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
void setHideSticks(bool v)
|
void setHideSticks(bool v)
|
||||||
{
|
{
|
||||||
if (touchJoyLeft) touchJoyLeft->setHideGraphics(v);
|
if (touchJoyLeft)
|
||||||
|
touchJoyLeft->setHideGraphics(v);
|
||||||
}
|
}
|
||||||
|
|
||||||
void touchSettingsButton(int state)
|
void touchSettingsButton(int state)
|
||||||
|
@ -423,70 +413,90 @@ void initControls(int width, int height, const char * graphics_path, const char
|
||||||
///////////////////////// BLANK TAP SCREEN //////////////////////
|
///////////////////////// BLANK TAP SCREEN //////////////////////
|
||||||
|
|
||||||
// One button on whole screen with no graphic, send a return key
|
// One button on whole screen with no graphic, send a return key
|
||||||
tcBlankTap->addControl(new touchcontrols::Button("whole_screen", touchcontrols::RectF(0,0,26,16), std::string("test"), SDL_SCANCODE_RETURN));
|
tcBlankTap->addControl(new touchcontrols::Button("whole_screen", touchcontrols::RectF(0, 0, 26, 16),
|
||||||
|
"" /*std::string("test")*/, SDL_SCANCODE_RETURN));
|
||||||
tcBlankTap->signal_button.connect(sigc::ptr_fun(&blankTapButton)); // Just reuse the menuButton function
|
tcBlankTap->signal_button.connect(sigc::ptr_fun(&blankTapButton)); // Just reuse the menuButton function
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///////////////////////// YES NO SCREEN /////////////////////
|
///////////////////////// YES NO SCREEN /////////////////////
|
||||||
|
|
||||||
tcYesNo->addControl(new touchcontrols::Button("enter", touchcontrols::RectF(8,10,11,13), "yes", SDL_SCANCODE_RETURN));
|
tcYesNo->addControl(
|
||||||
tcYesNo->addControl(new touchcontrols::Button("esc", touchcontrols::RectF(14,10,17,13), "no", SDL_SCANCODE_ESCAPE));
|
new touchcontrols::Button("enter", touchcontrols::RectF(16, 8, 19, 11), "yes", SDL_SCANCODE_RETURN));
|
||||||
|
tcYesNo->addControl(
|
||||||
|
new touchcontrols::Button("esc", touchcontrols::RectF(7, 8, 10, 11), "no", SDL_SCANCODE_ESCAPE));
|
||||||
tcYesNo->signal_button.connect(sigc::ptr_fun(&menuButton)); // Just reuse the menuButton function
|
tcYesNo->signal_button.connect(sigc::ptr_fun(&menuButton)); // Just reuse the menuButton function
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///////////////////////// MAIN MENU SCREEN /////////////////////
|
///////////////////////// MAIN MENU SCREEN /////////////////////
|
||||||
|
|
||||||
//Menu
|
/*
|
||||||
/* 3x3
|
tcMenuMain->addControl(new touchcontrols::Button("down_arrow", touchcontrols::RectF(22,14,24,16),
|
||||||
tcMenuMain->addControl(new touchcontrols::Button("down_arrow", touchcontrols::RectF(20,13,23,16), "arrow_down", SDL_SCANCODE_DOWN, true)); //Repeating buttons
|
"arrow_down", SDL_SCANCODE_DOWN, true)); //Repeating buttons
|
||||||
tcMenuMain->addControl(new touchcontrols::Button("up_arrow", touchcontrols::RectF(20,10,23,13), "arrow_up", SDL_SCANCODE_UP, true));
|
tcMenuMain->addControl(new touchcontrols::Button("up_arrow", touchcontrols::RectF(22,12,24,14), "arrow_up",
|
||||||
tcMenuMain->addControl(new touchcontrols::Button("left_arrow", touchcontrols::RectF(17,13,20,16), "arrow_left", SDL_SCANCODE_LEFT, true));
|
SDL_SCANCODE_UP, true));
|
||||||
tcMenuMain->addControl(new touchcontrols::Button("right_arrow", touchcontrols::RectF(23,13,26,16), "arrow_right", SDL_SCANCODE_RIGHT, true));
|
tcMenuMain->addControl(new touchcontrols::Button("left_arrow", touchcontrols::RectF(20,14,22,16),
|
||||||
tcMenuMain->addControl(new touchcontrols::Button("enter", touchcontrols::RectF(0,13,3,16), "enter", SDL_SCANCODE_RETURN));
|
"arrow_left", SDL_SCANCODE_LEFT, true));
|
||||||
tcMenuMain->addControl(new touchcontrols::Button("esc", touchcontrols::RectF(0,10,3,13), "esc", SDL_SCANCODE_ESCAPE));
|
tcMenuMain->addControl(new touchcontrols::Button("right_arrow", touchcontrols::RectF(24,14,26,16),
|
||||||
*/
|
"arrow_right", SDL_SCANCODE_RIGHT, true));
|
||||||
|
tcMenuMain->addControl(new touchcontrols::Button("enter", touchcontrols::RectF(0,14,2,16), "enter",
|
||||||
tcMenuMain->addControl(new touchcontrols::Button("down_arrow", touchcontrols::RectF(22,14,24,16), "arrow_down", SDL_SCANCODE_DOWN, true)); //Repeating buttons
|
SDL_SCANCODE_RETURN));
|
||||||
tcMenuMain->addControl(new touchcontrols::Button("up_arrow", touchcontrols::RectF(22,12,24,14), "arrow_up", SDL_SCANCODE_UP, true));
|
tcMenuMain->addControl(new touchcontrols::Button("esc", touchcontrols::RectF(0,12,2,14), "esc",
|
||||||
tcMenuMain->addControl(new touchcontrols::Button("left_arrow", touchcontrols::RectF(20,14,22,16), "arrow_left", SDL_SCANCODE_LEFT, true));
|
SDL_SCANCODE_ESCAPE));
|
||||||
tcMenuMain->addControl(new touchcontrols::Button("right_arrow", touchcontrols::RectF(24,14,26,16), "arrow_right", SDL_SCANCODE_RIGHT, true));
|
|
||||||
tcMenuMain->addControl(new touchcontrols::Button("enter", touchcontrols::RectF(0,14,2,16), "enter", SDL_SCANCODE_RETURN));
|
|
||||||
tcMenuMain->addControl(new touchcontrols::Button("esc", touchcontrols::RectF(0,12,2,14), "esc", SDL_SCANCODE_ESCAPE));
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
tcMenuMain->signal_button.connect( sigc::ptr_fun(&menuButton) );
|
tcMenuMain->signal_button.connect( sigc::ptr_fun(&menuButton) );
|
||||||
tcMenuMain->setAlpha(1);
|
tcMenuMain->setAlpha(1);
|
||||||
|
*/
|
||||||
|
|
||||||
|
touchcontrols::MultitouchMouse *mouseMenu =
|
||||||
|
new touchcontrols::MultitouchMouse("mouse", touchcontrols::RectF(0, 0, 26, 16), "");
|
||||||
|
mouseMenu->setHideGraphics(true);
|
||||||
|
tcMenuMain->addControl(mouseMenu);
|
||||||
|
mouseMenu->signal_action.connect(sigc::ptr_fun(&menuMouse));
|
||||||
|
|
||||||
|
touchcontrols::Button *console_button = new touchcontrols::Button(
|
||||||
|
"keyboard", "Development console", touchcontrols::RectF(8, 0, 10, 2), "keyboard", KEY_SHOW_KBRD, false, true);
|
||||||
|
|
||||||
|
tcMenuMain->addControl(console_button);
|
||||||
|
|
||||||
//////////////////////////// GAME SCREEN /////////////////////
|
//////////////////////////// GAME SCREEN /////////////////////
|
||||||
tcGameMain->setAlpha(gameControlsAlpha);
|
tcGameMain->setAlpha(droidinput.gameControlsAlpha);
|
||||||
controlsContainer.editButtonAlpha = gameControlsAlpha;
|
controlsContainer.editButtonAlpha = droidinput.gameControlsAlpha;
|
||||||
tcGameMain->addControl(new touchcontrols::Button("use", touchcontrols::RectF(23,3,26,6), "use", gamefunc_Open));
|
tcGameMain->addControl(
|
||||||
tcGameMain->addControl(new touchcontrols::Button("attack", touchcontrols::RectF(20,7,23,10), "fire2", gamefunc_Fire));
|
new touchcontrols::Button("use", touchcontrols::RectF(20, 4, 23, 7), "use", gamefunc_Open));
|
||||||
tcGameMain->addControl(new touchcontrols::Button("jump", touchcontrols::RectF(23,6,26,9), "jump", gamefunc_Jump));
|
tcGameMain->addControl(
|
||||||
tcGameMain->addControl(new touchcontrols::Button("crouch", touchcontrols::RectF(24,12,26,14), "crouch", gamefunc_Crouch));
|
new touchcontrols::Button("attack", touchcontrols::RectF(20, 7, 23, 10), "fire2", gamefunc_Fire));
|
||||||
tcGameMain->addControl(new touchcontrols::Button("kick","Mighty Foot", touchcontrols::RectF(20,4,23,7), "boot", gamefunc_Quick_Kick,false,true));
|
tcGameMain->addControl(
|
||||||
|
new touchcontrols::Button("jump", touchcontrols::RectF(23, 6, 26, 9), "jump", gamefunc_Jump));
|
||||||
|
tcGameMain->addControl(
|
||||||
|
new touchcontrols::Button("crouch", touchcontrols::RectF(24, 12, 26, 14), "crouch", gamefunc_Crouch));
|
||||||
|
tcGameMain->addControl(new touchcontrols::Button("kick", "Mighty Foot", touchcontrols::RectF(23, 3, 26, 6),
|
||||||
|
"boot", gamefunc_Quick_Kick, false, true));
|
||||||
|
|
||||||
tcGameMain->addControl(new touchcontrols::Button("quick_save","Quick Save", touchcontrols::RectF(22,0,24,2), "save", KEY_QUICK_SAVE,false,true));
|
touchcontrols::Button *map_button = new touchcontrols::Button(
|
||||||
tcGameMain->addControl(new touchcontrols::Button("quick_load","Quick Load", touchcontrols::RectF(20,0,22,2), "load", KEY_QUICK_LOAD,false,true));
|
"map", "Overhead map", touchcontrols::RectF(6, 0, 8, 2), "map", gamefunc_Map, false, true);
|
||||||
touchcontrols::Button *map_button = new touchcontrols::Button("map","Autotmap", touchcontrols::RectF(6,0,8,2), "map", gamefunc_Map, false,true);
|
|
||||||
tcGameMain->addControl(map_button);
|
tcGameMain->addControl(map_button);
|
||||||
tcGameMain->addControl(new touchcontrols::Button("keyboard","Show Console", touchcontrols::RectF(8,0,10,2), "keyboard", KEY_SHOW_KBRD, false,true));
|
tcGameMain->addControl(new touchcontrols::Button("show_inventory", "Inventory",
|
||||||
|
touchcontrols::RectF(24, 0, 26, 2), "inv", KEY_SHOW_INVEN));
|
||||||
|
tcGameMain->addControl(new touchcontrols::Button("next_weapon", "Next weapon", touchcontrols::RectF(0, 3, 3, 5),
|
||||||
|
"next_weap", gamefunc_Next_Weapon, false, true));
|
||||||
|
tcGameMain->addControl(new touchcontrols::Button("prev_weapon", "Previous weapon",
|
||||||
|
touchcontrols::RectF(0, 5, 3, 7), "prev_weap",
|
||||||
|
gamefunc_Previous_Weapon, false, true));
|
||||||
|
tcGameMain->addControl(new touchcontrols::Button("quick_save", "Save game", touchcontrols::RectF(22, 0, 24, 2),
|
||||||
|
"save", KEY_QUICK_SAVE, false, true));
|
||||||
|
tcGameMain->addControl(new touchcontrols::Button("quick_load", "Load game", touchcontrols::RectF(20, 0, 22, 2),
|
||||||
|
"load", KEY_QUICK_LOAD, false, true));
|
||||||
|
|
||||||
tcGameMain->addControl(new touchcontrols::Button("show_inventory","Show Inventory",touchcontrols::RectF(24,0,26,2), "inv", KEY_SHOW_INVEN));
|
tcGameMain->addControl(console_button);
|
||||||
|
|
||||||
tcGameMain->addControl(new touchcontrols::Button("next_weapon","Next Weapon", touchcontrols::RectF(0,3,3,5), "next_weap",gamefunc_Next_Weapon,false,true));
|
|
||||||
tcGameMain->addControl(new touchcontrols::Button("prev_weapon","Previous Weapon", touchcontrols::RectF(0,5,3,7), "prev_weap",gamefunc_Previous_Weapon,false,true));
|
|
||||||
/*
|
/*
|
||||||
//quick actions binds
|
//quick actions binds
|
||||||
tcGameMain->addControl(new touchcontrols::Button("quick_key_1",touchcontrols::RectF(4,3,6,5),"quick_key_1",KEY_QUICK_KEY1,false,true));
|
tcGameMain->addControl(new
|
||||||
tcGameMain->addControl(new touchcontrols::Button("quick_key_2",touchcontrols::RectF(6,3,8,5),"quick_key_2",KEY_QUICK_KEY2,false,true));
|
touchcontrols::Button("quick_key_1",touchcontrols::RectF(4,3,6,5),"quick_key_1",KEY_QUICK_KEY1,false,true));
|
||||||
tcGameMain->addControl(new touchcontrols::Button("quick_key_3",touchcontrols::RectF(8,3,10,5),"quick_key_3",KEY_QUICK_KEY3,false,true));
|
tcGameMain->addControl(new
|
||||||
tcGameMain->addControl(new touchcontrols::Button("quick_key_4",touchcontrols::RectF(10,3,12,5),"quick_key_4",KEY_QUICK_KEY4,false,true));
|
touchcontrols::Button("quick_key_2",touchcontrols::RectF(6,3,8,5),"quick_key_2",KEY_QUICK_KEY2,false,true));
|
||||||
|
tcGameMain->addControl(new
|
||||||
|
touchcontrols::Button("quick_key_3",touchcontrols::RectF(8,3,10,5),"quick_key_3",KEY_QUICK_KEY3,false,true));
|
||||||
|
tcGameMain->addControl(new
|
||||||
|
touchcontrols::Button("quick_key_4",touchcontrols::RectF(10,3,12,5),"quick_key_4",KEY_QUICK_KEY4,false,true));
|
||||||
*/
|
*/
|
||||||
// Left stick
|
// Left stick
|
||||||
touchJoyLeft = new touchcontrols::TouchJoy("stick", touchcontrols::RectF(0, 7, 8, 16), "strafe_arrow");
|
touchJoyLeft = new touchcontrols::TouchJoy("stick", touchcontrols::RectF(0, 7, 8, 16), "strafe_arrow");
|
||||||
|
@ -517,7 +527,8 @@ void initControls(int width, int height, const char * graphics_path, const char
|
||||||
|
|
||||||
|
|
||||||
// Automap
|
// Automap
|
||||||
touchcontrols::MultitouchMouse *multimouse = new touchcontrols::MultitouchMouse("gamemouse",touchcontrols::RectF(0,0,26,16),"");
|
touchcontrols::MultitouchMouse *multimouse =
|
||||||
|
new touchcontrols::MultitouchMouse("gamemouse", touchcontrols::RectF(0, 0, 26, 16), "");
|
||||||
multimouse->setHideGraphics(true);
|
multimouse->setHideGraphics(true);
|
||||||
tcAutomap->addControl(multimouse);
|
tcAutomap->addControl(multimouse);
|
||||||
multimouse->signal_action.connect(sigc::ptr_fun(&automap_multitouch_mouse_move));
|
multimouse->signal_action.connect(sigc::ptr_fun(&automap_multitouch_mouse_move));
|
||||||
|
@ -525,39 +536,35 @@ void initControls(int width, int height, const char * graphics_path, const char
|
||||||
tcAutomap->signal_button.connect(sigc::ptr_fun(&gameButton));
|
tcAutomap->signal_button.connect(sigc::ptr_fun(&gameButton));
|
||||||
tcAutomap->setAlpha(0.5);
|
tcAutomap->setAlpha(0.5);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Now inventory in the weapons control group!
|
// Now inventory in the weapons control group!
|
||||||
tcGameWeapons->addControl(new touchcontrols::Button("jetpack", touchcontrols::RectF(0,3,2,5),"jetpack",gamefunc_Jetpack,false,false,true));
|
|
||||||
tcGameWeapons->addControl(new touchcontrols::Button("medkit", touchcontrols::RectF(0,5,2,7),"medkit",gamefunc_MedKit,false,false,true));
|
inv_buttons[GET_JETPACK] = new touchcontrols::Button("jetpack", touchcontrols::RectF(0, 3, 2, 5), "jetpack",
|
||||||
tcGameWeapons->addControl(new touchcontrols::Button("nightv", touchcontrols::RectF(0,7,2,9),"nightvision",gamefunc_NightVision,false,false,true));
|
gamefunc_Jetpack, false, false, true);
|
||||||
tcGameWeapons->addControl(new touchcontrols::Button("holoduke",touchcontrols::RectF(0,9,2,11),"holoduke",gamefunc_Holo_Duke,false,false,true));
|
inv_buttons[GET_FIRSTAID] = new touchcontrols::Button("medkit", touchcontrols::RectF(0, 5, 2, 7), "medkit",
|
||||||
tcGameWeapons->addControl(new touchcontrols::Button("steroids",touchcontrols::RectF(0,11,2,13),"steroids",gamefunc_Steroids,false,false,true));
|
gamefunc_MedKit, false, false, true);
|
||||||
|
inv_buttons[GET_HEATS] = new touchcontrols::Button("nightv", touchcontrols::RectF(0, 7, 2, 9), "nightvision",
|
||||||
|
gamefunc_NightVision, false, false, true);
|
||||||
|
inv_buttons[GET_HOLODUKE] = new touchcontrols::Button("holoduke", touchcontrols::RectF(0, 9, 2, 11), "holoduke",
|
||||||
|
gamefunc_Holo_Duke, false, false, true);
|
||||||
|
inv_buttons[GET_STEROIDS] = new touchcontrols::Button("steroids", touchcontrols::RectF(0, 11, 2, 13),
|
||||||
|
"steroids", gamefunc_Steroids, false, false, true);
|
||||||
|
|
||||||
|
tcGameWeapons->addControl(inv_buttons[GET_JETPACK]);
|
||||||
|
tcGameWeapons->addControl(inv_buttons[GET_FIRSTAID]);
|
||||||
|
tcGameWeapons->addControl(inv_buttons[GET_HEATS]);
|
||||||
|
tcGameWeapons->addControl(inv_buttons[GET_HOLODUKE]);
|
||||||
|
tcGameWeapons->addControl(inv_buttons[GET_STEROIDS]);
|
||||||
// Inventory are the only buttons so safe to do this
|
// Inventory are the only buttons so safe to do this
|
||||||
tcGameWeapons->signal_button.connect(sigc::ptr_fun(&inventoryButton));
|
tcGameWeapons->signal_button.connect(sigc::ptr_fun(&inventoryButton));
|
||||||
|
|
||||||
|
|
||||||
// Weapons
|
// Weapons
|
||||||
weaponWheel = new touchcontrols::WheelSelect("weapon_wheel",touchcontrols::RectF(7,2,19,14),"weapon_wheel_orange_blank",10);
|
weaponWheel = new touchcontrols::WheelSelect("weapon_wheel", touchcontrols::RectF(7, 2, 19, 14),
|
||||||
|
"weapon_wheel_orange_blank", 10);
|
||||||
weaponWheel->signal_selected.connect(sigc::ptr_fun(&weaponWheelChosen));
|
weaponWheel->signal_selected.connect(sigc::ptr_fun(&weaponWheelChosen));
|
||||||
weaponWheel->signal_enabled.connect(sigc::ptr_fun(&weaponWheelSelected));
|
weaponWheel->signal_enabled.connect(sigc::ptr_fun(&weaponWheelSelected));
|
||||||
tcGameWeapons->addControl(weaponWheel);
|
tcGameWeapons->addControl(weaponWheel);
|
||||||
tcGameWeapons->setAlpha(0.9);
|
tcGameWeapons->setAlpha(0.9);
|
||||||
|
|
||||||
/*
|
|
||||||
tcInventory->addControl(new touchcontrols::Button("jetpack", touchcontrols::RectF(0,3,2,5),"jetpack",gamefunc_Jetpack));
|
|
||||||
tcInventory->addControl(new touchcontrols::Button("medkit", touchcontrols::RectF(0,5,2,7),"medkit",gamefunc_MedKit));
|
|
||||||
tcInventory->addControl(new touchcontrols::Button("nightv", touchcontrols::RectF(0,7,2,9),"nightvision",gamefunc_NightVision));
|
|
||||||
tcInventory->addControl(new touchcontrols::Button("holoduke",touchcontrols::RectF(0,9,2,11),"holoduke",gamefunc_Holo_Duke));
|
|
||||||
tcInventory->addControl(new touchcontrols::Button("steroids",touchcontrols::RectF(0,11,2,13),"steroids",gamefunc_Steroids));
|
|
||||||
tcInventory->setAlpha(1);
|
|
||||||
|
|
||||||
tcInventory->signal_button.connect( sigc::ptr_fun(&inventoryButton));
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
/////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
|
||||||
|
@ -570,10 +577,10 @@ void initControls(int width, int height, const char * graphics_path, const char
|
||||||
controlsContainer.addControlGroup(tcBlankTap);
|
controlsContainer.addControlGroup(tcBlankTap);
|
||||||
controlsCreated = 1;
|
controlsCreated = 1;
|
||||||
|
|
||||||
tcGameMain->setAlpha(gameControlsAlpha);
|
tcGameMain->setAlpha(droidinput.gameControlsAlpha);
|
||||||
controlsContainer.editButtonAlpha = gameControlsAlpha;
|
controlsContainer.editButtonAlpha = droidinput.gameControlsAlpha;
|
||||||
tcGameWeapons->setAlpha(gameControlsAlpha);
|
tcGameWeapons->setAlpha(droidinput.gameControlsAlpha);
|
||||||
tcMenuMain->setAlpha(gameControlsAlpha);
|
tcMenuMain->setAlpha(droidinput.gameControlsAlpha);
|
||||||
|
|
||||||
|
|
||||||
tcGameMain->setXMLFile((std::string)graphics_path + "/game.xml");
|
tcGameMain->setXMLFile((std::string)graphics_path + "/game.xml");
|
||||||
|
@ -595,14 +602,12 @@ void updateTouchScreenMode(touchscreemode_t mode)
|
||||||
|
|
||||||
static touchscreemode_t lastMode = TOUCH_SCREEN_BLANK;
|
static touchscreemode_t lastMode = TOUCH_SCREEN_BLANK;
|
||||||
|
|
||||||
|
if (mode != lastMode)
|
||||||
if (mode != lastMode){
|
{
|
||||||
|
|
||||||
// first disable the last screen and fade out is necessary
|
// first disable the last screen and fade out is necessary
|
||||||
switch(lastMode){
|
switch (lastMode)
|
||||||
case TOUCH_SCREEN_BLANK:
|
{
|
||||||
//Does not exist yet
|
case TOUCH_SCREEN_BLANK: // Does not exist yet break;
|
||||||
break;
|
|
||||||
case TOUCH_SCREEN_BLANK_TAP:
|
case TOUCH_SCREEN_BLANK_TAP:
|
||||||
tcBlankTap->resetOutput();
|
tcBlankTap->resetOutput();
|
||||||
tcBlankTap->setEnabled(false); // Dont fade out as no graphics
|
tcBlankTap->setEnabled(false); // Dont fade out as no graphics
|
||||||
|
@ -620,24 +625,19 @@ void updateTouchScreenMode(touchscreemode_t mode)
|
||||||
|
|
||||||
tcGameMain->fade(touchcontrols::FADE_OUT, DEFAULT_FADE_FRAMES);
|
tcGameMain->fade(touchcontrols::FADE_OUT, DEFAULT_FADE_FRAMES);
|
||||||
tcGameWeapons->setEnabled(false);
|
tcGameWeapons->setEnabled(false);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case TOUCH_SCREEN_AUTOMAP:
|
case TOUCH_SCREEN_AUTOMAP:
|
||||||
tcAutomap->resetOutput();
|
tcAutomap->resetOutput();
|
||||||
tcAutomap->fade(touchcontrols::FADE_OUT, DEFAULT_FADE_FRAMES);
|
tcAutomap->fade(touchcontrols::FADE_OUT, DEFAULT_FADE_FRAMES);
|
||||||
break;
|
break;
|
||||||
case TOUCH_SCREEN_CONSOLE:
|
case TOUCH_SCREEN_CONSOLE: break;
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Enable the current new screen
|
// Enable the current new screen
|
||||||
switch(mode){
|
switch (mode)
|
||||||
case TOUCH_SCREEN_BLANK:
|
{
|
||||||
//Does not exist yet
|
case TOUCH_SCREEN_BLANK: // Does not exist yet break;
|
||||||
break;
|
case TOUCH_SCREEN_BLANK_TAP: tcBlankTap->setEnabled(true); break;
|
||||||
case TOUCH_SCREEN_BLANK_TAP:
|
|
||||||
tcBlankTap->setEnabled(true);
|
|
||||||
break;
|
|
||||||
case TOUCH_SCREEN_YES_NO:
|
case TOUCH_SCREEN_YES_NO:
|
||||||
tcYesNo->setEnabled(true);
|
tcYesNo->setEnabled(true);
|
||||||
tcYesNo->fade(touchcontrols::FADE_IN, DEFAULT_FADE_FRAMES);
|
tcYesNo->fade(touchcontrols::FADE_IN, DEFAULT_FADE_FRAMES);
|
||||||
|
@ -646,7 +646,8 @@ void updateTouchScreenMode(touchscreemode_t mode)
|
||||||
tcMenuMain->setEnabled(true);
|
tcMenuMain->setEnabled(true);
|
||||||
tcMenuMain->fade(touchcontrols::FADE_IN, DEFAULT_FADE_FRAMES);
|
tcMenuMain->fade(touchcontrols::FADE_IN, DEFAULT_FADE_FRAMES);
|
||||||
|
|
||||||
//This is a bit of a hack, we need to enable the inventory buttons so they can be edited, they will not be seen anyway
|
// This is a bit of a hack, we need to enable the inventory buttons so they can be edited, they will not
|
||||||
|
// be seen anyway
|
||||||
showWeaponsInventory(true);
|
showWeaponsInventory(true);
|
||||||
break;
|
break;
|
||||||
case TOUCH_SCREEN_GAME:
|
case TOUCH_SCREEN_GAME:
|
||||||
|
@ -658,15 +659,18 @@ void updateTouchScreenMode(touchscreemode_t mode)
|
||||||
case TOUCH_SCREEN_AUTOMAP:
|
case TOUCH_SCREEN_AUTOMAP:
|
||||||
tcAutomap->setEnabled(true);
|
tcAutomap->setEnabled(true);
|
||||||
tcAutomap->fade(touchcontrols::FADE_IN, DEFAULT_FADE_FRAMES);
|
tcAutomap->fade(touchcontrols::FADE_IN, DEFAULT_FADE_FRAMES);
|
||||||
|
|
||||||
break;
|
|
||||||
case TOUCH_SCREEN_CONSOLE:
|
|
||||||
break;
|
break;
|
||||||
|
case TOUCH_SCREEN_CONSOLE: break;
|
||||||
}
|
}
|
||||||
|
|
||||||
lastMode = mode;
|
lastMode = mode;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int inv = PortableRead(READ_INVENTORY);
|
||||||
|
|
||||||
|
for (int i = 0; i < GET_MAX; ++i)
|
||||||
|
if (inv_buttons[i])
|
||||||
|
inv_buttons[i]->setAlpha(tcGameWeapons->getFadedAlpha() * ((inv & (1 << i)) ? 1.f : 0.3f));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -675,27 +679,46 @@ void updateTouchScreenMode(touchscreemode_t mode)
|
||||||
#include "s-setup/gp_lic_include.h"
|
#include "s-setup/gp_lic_include.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
extern char videomodereset;
|
||||||
|
extern int mobile_halted;
|
||||||
|
|
||||||
void frameControls()
|
void frameControls()
|
||||||
{
|
{
|
||||||
|
if (mobile_halted) return;
|
||||||
|
|
||||||
static int loadedGLImages = 0;
|
static int loadedGLImages = 0;
|
||||||
|
|
||||||
LOGI("frameControls");
|
if (videomodereset)
|
||||||
|
{
|
||||||
|
loadedGLImages = -1;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// We need to do this here now because duke loads a new gl context
|
// We need to do this here now because duke loads a new gl context
|
||||||
if (!loadedGLImages)
|
|
||||||
|
if (loadedGLImages <= 0)
|
||||||
{
|
{
|
||||||
controlsContainer.initGL();
|
controlsContainer.initGL(loadedGLImages == -1);
|
||||||
loadedGLImages = 1;
|
loadedGLImages = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
// LOGI("frameControls");
|
// LOGI("frameControls");
|
||||||
|
|
||||||
curRenderer = (PortableRead(READ_RENDERER) != REND_CLASSIC);
|
curRenderer = (PortableRead(READ_RENDERER) != REND_CLASSIC);
|
||||||
|
|
||||||
updateTouchScreenMode((touchscreemode_t)PortableRead(READ_SCREEN_MODE));
|
updateTouchScreenMode((touchscreemode_t)PortableRead(READ_SCREEN_MODE));
|
||||||
|
|
||||||
|
setHideSticks(droidinput.hideStick);
|
||||||
|
|
||||||
|
if (tcGameMain)
|
||||||
|
{
|
||||||
|
tcGameMain->setAlpha(droidinput.gameControlsAlpha);
|
||||||
|
controlsContainer.editButtonAlpha = droidinput.gameControlsAlpha;
|
||||||
|
tcGameWeapons->setAlpha(droidinput.gameControlsAlpha);
|
||||||
|
tcMenuMain->setAlpha(droidinput.gameControlsAlpha);
|
||||||
|
// tcInventory->setAlpha(droidinput.gameControlsAlpha);
|
||||||
|
}
|
||||||
|
|
||||||
setHideSticks(!showSticks);
|
|
||||||
controlsContainer.draw();
|
controlsContainer.draw();
|
||||||
|
|
||||||
#ifdef GP_LIC
|
#ifdef GP_LIC
|
||||||
|
@ -703,44 +726,20 @@ void frameControls()
|
||||||
#define GP_LIC_INC 2
|
#define GP_LIC_INC 2
|
||||||
#include "s-setup/gp_lic_include.h"
|
#include "s-setup/gp_lic_include.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void setTouchSettings(float alpha,float strafe,float fwd,float pitch,float yaw,int other)
|
void setTouchSettings(int other)
|
||||||
{
|
{
|
||||||
|
|
||||||
gameControlsAlpha = MINCONTROLALPHA + (alpha * (1.0f - MINCONTROLALPHA));
|
|
||||||
|
|
||||||
if (tcGameMain)
|
|
||||||
{
|
|
||||||
tcGameMain->setAlpha(gameControlsAlpha);
|
|
||||||
controlsContainer.editButtonAlpha = gameControlsAlpha;
|
|
||||||
tcGameWeapons->setAlpha(gameControlsAlpha);
|
|
||||||
tcMenuMain->setAlpha(gameControlsAlpha);
|
|
||||||
// tcInventory->setAlpha(gameControlsAlpha);
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: defined names for these values
|
// TODO: defined names for these values
|
||||||
selectLastWeap = other & 0x1 ? true : false;
|
|
||||||
toggleCrouch = other & 0x2 ? true : false;
|
|
||||||
invertLook = other & 0x4 ? true : false;
|
|
||||||
precisionShoot = other & 0x8 ? true : false;
|
|
||||||
showSticks = other & 0x1000 ? true : false;
|
|
||||||
|
|
||||||
hideTouchControls = other & 0x80000000 ? true : false;
|
hideTouchControls = other & 0x80000000 ? true : false;
|
||||||
|
|
||||||
int doubletap_options[6] = {0,gamefunc_Fire,gamefunc_Jump,gamefunc_Quick_Kick,gamefunc_MedKit,gamefunc_Jetpack};
|
// keep in sync with Duke3d/res/values/strings.xml
|
||||||
|
int doubletap_options[5] = { -1, gamefunc_Quick_Kick, gamefunc_AutoRun, gamefunc_MedKit, gamefunc_Jetpack };
|
||||||
|
|
||||||
droidinput.left_double_action = doubletap_options[((other >> 4) & 0xF)];
|
droidinput.left_double_action = doubletap_options[((other >> 4) & 0xF)];
|
||||||
droidinput.right_double_action = doubletap_options[((other >> 8) & 0xF)];
|
droidinput.right_double_action = doubletap_options[((other >> 8) & 0xF)];
|
||||||
|
|
||||||
|
LOGI("setTouchSettings left_double_action = %d", droidinput.left_double_action);
|
||||||
droidinput.strafe_sens = strafe;
|
|
||||||
droidinput.forward_sens = fwd;
|
|
||||||
droidinput.pitch_sens = pitch;
|
|
||||||
droidinput.yaw_sens = yaw;
|
|
||||||
|
|
||||||
LOGI("setTouchSettings alpha = %f, left_double_action = %d",alpha,droidinput.left_double_action);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#define EXPORT_ME __NDK_FPABI__ __attribute__((visibility("default")))
|
#define EXPORT_ME __NDK_FPABI__ __attribute__((visibility("default")))
|
||||||
|
@ -750,17 +749,14 @@ JNIEnv* env_;
|
||||||
int argc = 1;
|
int argc = 1;
|
||||||
const char *argv[32];
|
const char *argv[32];
|
||||||
std::string graphicpath;
|
std::string graphicpath;
|
||||||
std::string doom_path;
|
std::string duke3d_path;
|
||||||
|
|
||||||
static const char * getGamePath()
|
static inline const char *getGamePath() { return duke3d_path.c_str(); }
|
||||||
{
|
|
||||||
return doom_path.c_str();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
jint EXPORT_ME Java_com_voidpoint_duke3d_engine_NativeLib_init(JNIEnv *env, jobject thiz, jstring graphics_dir,
|
||||||
jint EXPORT_ME
|
jint audio_rate, jint audio_buffer_size,
|
||||||
Java_com_beloko_duke_engine_NativeLib_init( JNIEnv* env,
|
jobjectArray argsArray, jint renderer,
|
||||||
jobject thiz,jstring graphics_dir,jint audio_rate,jint audio_buffer_size,jobjectArray argsArray,jint renderer,jstring doom_path_ )
|
jstring jduke3d_path)
|
||||||
{
|
{
|
||||||
env_ = env;
|
env_ = env;
|
||||||
|
|
||||||
|
@ -771,21 +767,21 @@ Java_com_beloko_duke_engine_NativeLib_init( JNIEnv* env,
|
||||||
droidinfo.audio_sample_rate = audio_rate;
|
droidinfo.audio_sample_rate = audio_rate;
|
||||||
droidinfo.audio_buffer_size = audio_buffer_size;
|
droidinfo.audio_buffer_size = audio_buffer_size;
|
||||||
|
|
||||||
curRenderer = renderer;
|
// curRenderer = renderer;
|
||||||
//curRenderer = REND_SOFT;
|
|
||||||
curRenderer = REND_GL;
|
curRenderer = REND_GL;
|
||||||
|
|
||||||
argv[0] = "eduke32";
|
argv[0] = "eduke32";
|
||||||
int argCount = (env)->GetArrayLength(argsArray);
|
int argCount = (env)->GetArrayLength(argsArray);
|
||||||
LOGI("argCount = %d", argCount);
|
LOGI("argCount = %d", argCount);
|
||||||
for (int i=0; i<argCount; i++) {
|
for (int i = 0; i < argCount; i++)
|
||||||
|
{
|
||||||
jstring string = (jstring)(env)->GetObjectArrayElement(argsArray, i);
|
jstring string = (jstring)(env)->GetObjectArrayElement(argsArray, i);
|
||||||
argv[argc] = (char *)(env)->GetStringUTFChars(string, 0);
|
argv[argc] = (char *)(env)->GetStringUTFChars(string, 0);
|
||||||
LOGI("arg = %s", argv[argc]);
|
LOGI("arg = %s", argv[argc]);
|
||||||
argc++;
|
argc++;
|
||||||
}
|
}
|
||||||
|
|
||||||
doom_path = (char *)(env)->GetStringUTFChars( doom_path_, 0);
|
duke3d_path = (char *)(env)->GetStringUTFChars(jduke3d_path, 0);
|
||||||
|
|
||||||
// Change working dir, save games etc
|
// Change working dir, save games etc
|
||||||
// FIXME: potentially conflicts with chdirs in -game_dir support
|
// FIXME: potentially conflicts with chdirs in -game_dir support
|
||||||
|
@ -793,30 +789,15 @@ Java_com_beloko_duke_engine_NativeLib_init( JNIEnv* env,
|
||||||
char timidity_env[512];
|
char timidity_env[512];
|
||||||
|
|
||||||
sprintf(timidity_env, "TIMIDITY_CFG=%s/../timidity.cfg", getGamePath());
|
sprintf(timidity_env, "TIMIDITY_CFG=%s/../timidity.cfg", getGamePath());
|
||||||
//putenv("TIMIDITY_CFG=../timidity.cfg");
|
|
||||||
putenv(timidity_env);
|
putenv(timidity_env);
|
||||||
|
|
||||||
LOGI("doom_path = %s",getGamePath());
|
LOGI("duke3d_path = %s", getGamePath());
|
||||||
|
|
||||||
const char *p = env->GetStringUTFChars(graphics_dir, NULL);
|
const char *p = env->GetStringUTFChars(graphics_dir, NULL);
|
||||||
graphicpath = std::string(p);
|
graphicpath = std::string(p);
|
||||||
|
|
||||||
initControls(droidinfo.screen_width, -droidinfo.screen_height,
|
initControls(droidinfo.screen_width, -droidinfo.screen_height, graphicpath.c_str(),
|
||||||
graphicpath.c_str(),(graphicpath + "/touch_controls.xml").c_str());
|
(graphicpath + "/touch_controls.xml").c_str());
|
||||||
|
|
||||||
/*
|
|
||||||
if (renderer != REND_SOFT)
|
|
||||||
SDL_SetSwapBufferCallBack(frameControls);
|
|
||||||
|
|
||||||
if (renderer == REND_SOFT)// In soft mode SDL calls swap buffer, disable so it does not flicker
|
|
||||||
SDL_SwapBufferPerformsSwap(false);
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
SDL_SetSwapBufferCallBack(frameControls);
|
|
||||||
|
|
||||||
//Now doen in java to keep context etc
|
|
||||||
//SDL_SwapBufferPerformsSwap(false);
|
|
||||||
|
|
||||||
PortableInit(argc, argv);
|
PortableInit(argc, argv);
|
||||||
|
|
||||||
|
@ -824,13 +805,11 @@ Java_com_beloko_duke_engine_NativeLib_init( JNIEnv* env,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
jint EXPORT_ME
|
jint EXPORT_ME Java_com_voidpoint_duke3d_engine_NativeLib_frame(JNIEnv *env, jobject thiz)
|
||||||
Java_com_beloko_duke_engine_NativeLib_frame( JNIEnv* env,
|
|
||||||
jobject thiz )
|
|
||||||
{
|
{
|
||||||
LOGI("Java_com_beloko_duke_engine_NativeLib_frame");
|
LOGI("Java_com_voidpoint_duke3d_engine_NativeLib_frame");
|
||||||
|
|
||||||
frameControls();
|
// frameControls();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -844,8 +823,7 @@ __attribute__((visibility("default"))) jint JNI_OnLoad(JavaVM* vm, void* reserve
|
||||||
|
|
||||||
|
|
||||||
void EXPORT_ME
|
void EXPORT_ME
|
||||||
Java_com_beloko_duke_engine_NativeLib_keypress(JNIEnv *env, jobject obj,
|
Java_com_voidpoint_duke3d_engine_NativeLib_keypress(JNIEnv *env, jobject obj, jint down, jint keycode, jint unicode)
|
||||||
jint down, jint keycode, jint unicode)
|
|
||||||
{
|
{
|
||||||
LOGI("keypress %d", keycode);
|
LOGI("keypress %d", keycode);
|
||||||
if (controlsContainer.isEditing())
|
if (controlsContainer.isEditing())
|
||||||
|
@ -859,17 +837,15 @@ Java_com_beloko_duke_engine_NativeLib_keypress(JNIEnv *env, jobject obj,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void EXPORT_ME
|
void EXPORT_ME Java_com_voidpoint_duke3d_engine_NativeLib_touchEvent(JNIEnv *env, jobject obj, jint action, jint pid,
|
||||||
Java_com_beloko_duke_engine_NativeLib_touchEvent(JNIEnv *env, jobject obj,
|
jfloat x, jfloat y)
|
||||||
jint action, jint pid, jdouble x, jdouble y)
|
|
||||||
{
|
{
|
||||||
// LOGI("TOUCHED");
|
// LOGI("TOUCHED");
|
||||||
controlsContainer.processPointer(action, pid, x, y);
|
controlsContainer.processPointer(action, pid, x, y);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void EXPORT_ME Java_com_beloko_duke_engine_NativeLib_doAction(JNIEnv *env, jobject obj,
|
void EXPORT_ME Java_com_voidpoint_duke3d_engine_NativeLib_doAction(JNIEnv *env, jobject obj, jint state, jint action)
|
||||||
jint state, jint action)
|
|
||||||
{
|
{
|
||||||
LOGI("doAction %d %d", state, action);
|
LOGI("doAction %d %d", state, action);
|
||||||
|
|
||||||
|
@ -886,45 +862,40 @@ void EXPORT_ME Java_com_beloko_duke_engine_NativeLib_doAction(JNIEnv *env, jobje
|
||||||
PortableAction(state, action);
|
PortableAction(state, action);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EXPORT_ME Java_com_beloko_duke_engine_NativeLib_analogFwd(JNIEnv *env, jobject obj,
|
void EXPORT_ME Java_com_voidpoint_duke3d_engine_NativeLib_analogFwd(JNIEnv *env, jobject obj, jfloat v)
|
||||||
jfloat v)
|
|
||||||
{
|
{
|
||||||
PortableMove(v, NAN);
|
PortableMove(v, NAN);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EXPORT_ME Java_com_beloko_duke_engine_NativeLib_analogSide(JNIEnv *env, jobject obj,
|
void EXPORT_ME Java_com_voidpoint_duke3d_engine_NativeLib_analogSide(JNIEnv *env, jobject obj, jfloat v)
|
||||||
jfloat v)
|
|
||||||
{
|
{
|
||||||
PortableMove(NAN, v);
|
PortableMove(NAN, v);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EXPORT_ME Java_com_beloko_duke_engine_NativeLib_analogPitch(JNIEnv *env, jobject obj,
|
void EXPORT_ME Java_com_voidpoint_duke3d_engine_NativeLib_analogPitch(JNIEnv *env, jobject obj, jint mode, jfloat v)
|
||||||
jint mode,jfloat v)
|
|
||||||
{
|
{
|
||||||
PortableLookJoystick(NAN, v);
|
PortableLookJoystick(NAN, v);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EXPORT_ME Java_com_beloko_duke_engine_NativeLib_analogYaw(JNIEnv *env, jobject obj,
|
void EXPORT_ME Java_com_voidpoint_duke3d_engine_NativeLib_analogYaw(JNIEnv *env, jobject obj, jint mode, jfloat v)
|
||||||
jint mode,jfloat v)
|
|
||||||
{
|
{
|
||||||
PortableLookJoystick(v, NAN);
|
PortableLookJoystick(v, NAN);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EXPORT_ME Java_com_beloko_duke_engine_NativeLib_setTouchSettings(JNIEnv *env, jobject obj,
|
void EXPORT_ME
|
||||||
jfloat alpha,jfloat strafe,jfloat fwd,jfloat pitch,jfloat yaw,int other)
|
Java_com_voidpoint_duke3d_engine_NativeLib_setTouchSettings(JNIEnv *env, jobject obj, int other)
|
||||||
{
|
{
|
||||||
setTouchSettings(alpha,strafe,fwd,pitch,yaw,other);
|
setTouchSettings(other);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EXPORT_ME Java_com_beloko_duke_engine_NativeLib_resetTouchSettings(JNIEnv *env, jobject obj)
|
void EXPORT_ME Java_com_voidpoint_duke3d_engine_NativeLib_resetTouchSettings(JNIEnv *env, jobject obj)
|
||||||
{
|
{
|
||||||
controlsContainer.resetDefaults();
|
controlsContainer.resetDefaults();
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string quickCommandString;
|
std::string quickCommandString;
|
||||||
jint EXPORT_ME
|
|
||||||
Java_com_beloko_duke_engine_NativeLib_quickCommand(JNIEnv *env, jobject obj,
|
jint EXPORT_ME Java_com_voidpoint_duke3d_engine_NativeLib_quickCommand(JNIEnv *env, jobject obj, jstring command)
|
||||||
jstring command)
|
|
||||||
{
|
{
|
||||||
const char *p = env->GetStringUTFChars(command, NULL);
|
const char *p = env->GetStringUTFChars(command, NULL);
|
||||||
quickCommandString = std::string(p) + "\n";
|
quickCommandString = std::string(p) + "\n";
|
||||||
|
@ -933,8 +904,7 @@ Java_com_beloko_duke_engine_NativeLib_quickCommand(JNIEnv *env, jobject obj,
|
||||||
}
|
}
|
||||||
|
|
||||||
void EXPORT_ME
|
void EXPORT_ME
|
||||||
Java_com_beloko_duke_engine_NativeLib_setScreenSize( JNIEnv* env,
|
Java_com_voidpoint_duke3d_engine_NativeLib_setScreenSize(JNIEnv *env, jobject thiz, jint width, jint height)
|
||||||
jobject thiz, jint width, jint height)
|
|
||||||
{
|
{
|
||||||
droidinfo.screen_width = width;
|
droidinfo.screen_width = width;
|
||||||
droidinfo.screen_height = height;
|
droidinfo.screen_height = height;
|
||||||
|
@ -948,6 +918,31 @@ void EXPORT_ME Java_org_libsdl_app_SDLActivity_nativeInit(JNIEnv* env, jclass c
|
||||||
// SDL_EventState(SDL_TEXTINPUT,SDL_ENABLE);
|
// SDL_EventState(SDL_TEXTINPUT,SDL_ENABLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
jstring EXPORT_ME
|
||||||
|
Java_com_voidpoint_duke3d_engine_NativeLib_getSavetext(JNIEnv *env, jobject obj, jstring jfile, jint type)
|
||||||
|
{
|
||||||
|
const char *p = env->GetStringUTFChars(jfile, NULL);
|
||||||
|
|
||||||
|
jstring ret = env->NewStringUTF(G_GetStringFromSavegame(p, type));
|
||||||
|
env->ReleaseStringUTFChars(jfile, p);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
jint EXPORT_ME Java_com_voidpoint_duke3d_engine_NativeLib_getScreenshot(JNIEnv *env, jobject obj, jstring jfile,
|
||||||
|
jobject jpal, jobject jdataOut)
|
||||||
|
{
|
||||||
|
const char *p = env->GetStringUTFChars(jfile, NULL);
|
||||||
|
|
||||||
|
jbyte *bb = (jbyte *)env->GetDirectBufferAddress(jdataOut);
|
||||||
|
jbyte *pb = (jbyte *)env->GetDirectBufferAddress(jpal);
|
||||||
|
|
||||||
|
int ret = G_GetScreenshotFromSavegame(p, (char *)pb, (char *)bb);
|
||||||
|
|
||||||
|
env->ReleaseStringUTFChars(jfile, p);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef GP_LIC
|
#ifdef GP_LIC
|
||||||
#undef GP_LIC_INC
|
#undef GP_LIC_INC
|
||||||
#define GP_LIC_INC 3
|
#define GP_LIC_INC 3
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
#include "compat.h"
|
||||||
#include "sdl_inc.h"
|
#include "sdl_inc.h"
|
||||||
#include "baselayer.h"
|
#include "baselayer.h"
|
||||||
#include "keys.h"
|
#include "keys.h"
|
||||||
|
@ -7,34 +8,45 @@
|
||||||
#include "player.h"
|
#include "player.h"
|
||||||
#include "game.h"
|
#include "game.h"
|
||||||
#include "build.h"
|
#include "build.h"
|
||||||
|
#include "anim.h"
|
||||||
|
#include "player.h"
|
||||||
|
|
||||||
#include "jmact/keyboard.h"
|
#include "jmact/keyboard.h"
|
||||||
#include "jmact/control.h"
|
#include "jmact/control.h"
|
||||||
|
#include "jmact/_control.h"
|
||||||
|
|
||||||
#include "menus.h"
|
#include "menus.h"
|
||||||
|
|
||||||
#include "../src/video/android/SDL_androidkeyboard.h" // FIXME: include header locally if necessary
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
// #include "../src/video/android/SDL_androidkeyboard.h" // FIXME: include header locally if necessary
|
||||||
|
//#include "../src/events/SDL_mouse_c.h"
|
||||||
|
extern int SDL_SendKeyboardKey(Uint8 state, SDL_Scancode scancode);
|
||||||
|
extern int SDL_SendKeyboardText(const char *text);
|
||||||
|
extern int SDL_SendMouseMotion(SDL_Window * window, Uint32 mouseID, int relative, int x, int y);
|
||||||
|
extern int SDL_SendMouseButton(SDL_Window * window, Uint32 mouseID, Uint8 state, Uint8 button);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "in_android.h"
|
#include "in_android.h"
|
||||||
|
|
||||||
#include <android/log.h>
|
#include <android/log.h>
|
||||||
|
|
||||||
#define LOGI(...) ((void)__android_log_print(ANDROID_LOG_INFO,"DUKE", __VA_ARGS__))
|
#define LOGI(...) ((void)__android_log_print(ANDROID_LOG_INFO,"DUKE", __VA_ARGS__))
|
||||||
|
|
||||||
extern int32_t main(int32_t argc, char *argv []);
|
extern int32_t main(int32_t argc, char *argv []);
|
||||||
|
|
||||||
extern int SDL_SendKeyboardKey(Uint8 state, SDL_Scancode scancode);
|
|
||||||
extern int SDL_SendKeyboardText(const char *text);
|
|
||||||
|
|
||||||
static char sdl_text[2];
|
static char sdl_text[2];
|
||||||
|
|
||||||
droidinput_t droidinput;
|
droidinput_t droidinput;
|
||||||
|
|
||||||
int PortableKeyEvent(int state, int code,int unicode)
|
int PortableKeyEvent(int state, int code,int unicode)
|
||||||
{
|
{
|
||||||
LOGI("PortableKeyEvent %d %d %d",state,code,unicode);
|
LOGI("PortableKeyEvent %d %d %d",state,(SDL_Scancode)code,unicode);
|
||||||
|
|
||||||
SDL_SendKeyboardKey(state ? SDL_PRESSED : SDL_RELEASED, code);
|
SDL_SendKeyboardKey(state ? SDL_PRESSED : SDL_RELEASED, (SDL_Scancode)code);
|
||||||
SDL_EventState(SDL_TEXTINPUT, SDL_ENABLE);
|
SDL_EventState(SDL_TEXTINPUT, SDL_ENABLE);
|
||||||
|
|
||||||
// if (code == 42)
|
// if (code == 42)
|
||||||
|
@ -58,6 +70,16 @@ int PortableKeyEvent(int state, int code,int unicode)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void PortableMouseMenu(float x,float y)
|
||||||
|
{
|
||||||
|
SDL_SendMouseMotion(NULL,0,0,x,y);
|
||||||
|
}
|
||||||
|
|
||||||
|
void PortableMouseMenuButton(int state,int button)
|
||||||
|
{
|
||||||
|
SDL_SendMouseButton(NULL, SDL_TOUCH_MOUSEID, state?SDL_PRESSED:SDL_RELEASED, SDL_BUTTON_LEFT);
|
||||||
|
}
|
||||||
|
|
||||||
void changeActionState(int state, int action)
|
void changeActionState(int state, int action)
|
||||||
{
|
{
|
||||||
if (state)
|
if (state)
|
||||||
|
@ -102,13 +124,22 @@ void PortableAction(int state, int action)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
//Special toggle for crouch, NOT when using jetpack or in water
|
//Special toggle for crouch, NOT when using jetpack or in water
|
||||||
if (!g_player[myconnectindex].ps->jetpack_on &&
|
if (droidinput.toggleCrouch)
|
||||||
g_player[myconnectindex].ps->on_ground &&
|
|
||||||
(sector[g_player[myconnectindex].ps->cursectnum].lotag != ST_2_UNDERWATER))
|
|
||||||
{
|
{
|
||||||
if (toggleCrouch)
|
int lotag = sector[g_player[myconnectindex].ps->cursectnum].lotag;
|
||||||
|
|
||||||
|
if (droidinput.crouchToggleState && (lotag == ST_2_UNDERWATER || lotag == ST_1_ABOVE_WATER))
|
||||||
{
|
{
|
||||||
|
droidinput.crouchToggleState = 0;
|
||||||
if (action == gamefunc_Crouch)
|
if (action == gamefunc_Crouch)
|
||||||
|
state = 0;
|
||||||
|
else PortableAction(0, gamefunc_Crouch);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (action == gamefunc_Crouch)
|
||||||
|
{
|
||||||
|
if (!g_player[myconnectindex].ps->jetpack_on && g_player[myconnectindex].ps->on_ground &&
|
||||||
|
lotag != ST_2_UNDERWATER && lotag != ST_1_ABOVE_WATER)
|
||||||
{
|
{
|
||||||
if (state)
|
if (state)
|
||||||
droidinput.crouchToggleState = !droidinput.crouchToggleState;
|
droidinput.crouchToggleState = !droidinput.crouchToggleState;
|
||||||
|
@ -116,15 +147,21 @@ void PortableAction(int state, int action)
|
||||||
state = droidinput.crouchToggleState;
|
state = droidinput.crouchToggleState;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Check if jumping while crouched
|
//Check if jumping while crouched
|
||||||
if (action == gamefunc_Jump)
|
if (action == gamefunc_Jump)
|
||||||
|
{
|
||||||
|
if (droidinput.crouchToggleState)
|
||||||
{
|
{
|
||||||
droidinput.crouchToggleState = 0;
|
droidinput.crouchToggleState = 0;
|
||||||
changeActionState(0, gamefunc_Crouch);
|
changeActionState(0, gamefunc_Crouch);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
changeActionState(state, action);
|
||||||
|
}
|
||||||
|
else
|
||||||
changeActionState(state, action);
|
changeActionState(state, action);
|
||||||
|
|
||||||
if (state == 2)
|
if (state == 2)
|
||||||
|
@ -137,6 +174,12 @@ void PortableAction(int state, int action)
|
||||||
//Need these NAN check as not cumulative.
|
//Need these NAN check as not cumulative.
|
||||||
void PortableMove(float fwd, float strafe)
|
void PortableMove(float fwd, float strafe)
|
||||||
{
|
{
|
||||||
|
if (!ud.auto_run)
|
||||||
|
{
|
||||||
|
fwd *= 0.5f;
|
||||||
|
strafe *= 0.5f;
|
||||||
|
}
|
||||||
|
|
||||||
if (!isnan(fwd))
|
if (!isnan(fwd))
|
||||||
droidinput.forwardmove = fclamp2(fwd, -1.f, 1.f);
|
droidinput.forwardmove = fclamp2(fwd, -1.f, 1.f);
|
||||||
|
|
||||||
|
@ -167,10 +210,7 @@ void PortableCommand(const char * cmd)
|
||||||
|
|
||||||
void PortableInit(int argc, const char ** argv)
|
void PortableInit(int argc, const char ** argv)
|
||||||
{
|
{
|
||||||
//droidinput.left_double_action = -1;
|
main(argc, ( char **)argv);
|
||||||
//droidinput.right_double_action = -1;
|
|
||||||
|
|
||||||
main(argc, argv);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int consoleShown = 0;
|
int consoleShown = 0;
|
||||||
|
@ -179,62 +219,63 @@ void AndroidSetConsoleShown(int onf)
|
||||||
consoleShown = onf;
|
consoleShown = onf;
|
||||||
}
|
}
|
||||||
|
|
||||||
extern int animation_playing;
|
|
||||||
extern int inExtraScreens; //In game.c
|
extern int inExtraScreens; //In game.c
|
||||||
int32_t PortableRead(portableread_t r)
|
int32_t PortableRead(portableread_t r)
|
||||||
{
|
{
|
||||||
|
int32_t rv;
|
||||||
|
|
||||||
switch (r)
|
switch (r)
|
||||||
{
|
{
|
||||||
case READ_SCREEN_MODE:
|
case READ_SCREEN_MODE:
|
||||||
|
if (g_animPtr || inExtraScreens)
|
||||||
if (animation_playing)
|
rv = TOUCH_SCREEN_BLANK_TAP;
|
||||||
return TOUCH_SCREEN_BLANK_TAP;
|
|
||||||
else if (inExtraScreens)
|
|
||||||
return TOUCH_SCREEN_BLANK_TAP;
|
|
||||||
else if (consoleShown)
|
else if (consoleShown)
|
||||||
return TOUCH_SCREEN_CONSOLE;
|
rv = TOUCH_SCREEN_CONSOLE;
|
||||||
else if ((g_player[myconnectindex].ps->gm & MODE_MENU) == MODE_MENU)
|
else if ((g_player[myconnectindex].ps->gm & MODE_MENU) == MODE_MENU)
|
||||||
{
|
rv = (m_currentMenu->type == Verify) ? TOUCH_SCREEN_YES_NO : TOUCH_SCREEN_MENU;
|
||||||
//Then check if Yes/No menu
|
|
||||||
if ((g_currentMenu == MENU_QUITTOTITLE) ||
|
|
||||||
(g_currentMenu == MENU_RESETPLAYER ) ||
|
|
||||||
((g_currentMenu == MENU_LOADVERIFY )) ||
|
|
||||||
(g_currentMenu == MENU_NEWVERIFY ) ||
|
|
||||||
((g_currentMenu == MENU_SAVEVERIFY )) ||
|
|
||||||
(g_currentMenu == MENU_QUIT ) ||
|
|
||||||
(g_currentMenu == MENU_QUITTOTITLE )
|
|
||||||
)
|
|
||||||
return TOUCH_SCREEN_YES_NO;
|
|
||||||
else
|
|
||||||
return TOUCH_SCREEN_MENU;
|
|
||||||
}
|
|
||||||
else if (ud.overhead_on == 2)
|
else if (ud.overhead_on == 2)
|
||||||
return TOUCH_SCREEN_AUTOMAP;
|
rv = TOUCH_SCREEN_AUTOMAP;
|
||||||
else if ((g_player[myconnectindex].ps->gm & MODE_GAME))
|
else if ((g_player[myconnectindex].ps->gm & MODE_GAME))
|
||||||
if (PortableRead(READ_IS_DEAD))
|
if (PortableRead(READ_IS_DEAD))
|
||||||
return TOUCH_SCREEN_BLANK_TAP;
|
rv = TOUCH_SCREEN_BLANK_TAP;
|
||||||
else
|
else
|
||||||
return TOUCH_SCREEN_GAME;
|
rv = TOUCH_SCREEN_GAME;
|
||||||
else
|
else
|
||||||
return TOUCH_SCREEN_BLANK_TAP;
|
rv = TOUCH_SCREEN_BLANK_TAP;
|
||||||
|
break;
|
||||||
case READ_WEAPONS:
|
case READ_WEAPONS:
|
||||||
return g_player[myconnectindex].ps->gotweapon;
|
rv = g_player[myconnectindex].ps->gotweapon; break;
|
||||||
case READ_AUTOMAP:
|
case READ_AUTOMAP:
|
||||||
return ud.overhead_on != 0; // ud.overhead_on ranges from 0-2
|
rv = ud.overhead_on != 0; break;// ud.overhead_on ranges from 0-2
|
||||||
case READ_MAPFOLLOWMODE:
|
case READ_MAPFOLLOWMODE:
|
||||||
return ud.scrollmode;
|
rv = ud.scrollmode; break;
|
||||||
case READ_RENDERER:
|
case READ_RENDERER:
|
||||||
return getrendermode();
|
rv = getrendermode(); break;
|
||||||
case READ_LASTWEAPON:
|
case READ_LASTWEAPON:
|
||||||
return droidinput.lastWeapon;
|
rv = droidinput.lastWeapon;
|
||||||
|
if ((unsigned)rv < MAX_WEAPONS && !g_player[myconnectindex].ps->ammo_amount[rv])
|
||||||
|
rv = -1;
|
||||||
|
break;
|
||||||
case READ_PAUSED:
|
case READ_PAUSED:
|
||||||
return ud.pause_on != 0;
|
rv = ud.pause_on != 0; break;
|
||||||
case READ_IS_DEAD:
|
case READ_IS_DEAD:
|
||||||
return g_player[myconnectindex].ps->dead_flag;
|
rv = g_player[myconnectindex].ps->dead_flag; break;
|
||||||
default:
|
case READ_INVENTORY:
|
||||||
return 0;
|
rv = 0;
|
||||||
|
for (int i = 0; i < GET_MAX; i++)
|
||||||
|
{
|
||||||
|
if (g_player[myconnectindex].ps->inv_amount[i])
|
||||||
|
rv += (1 << i);
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
|
case READ_SOMETHINGONPLAYER:
|
||||||
|
rv = g_player[myconnectindex].ps->somethingonplayer != -1;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
rv = 0; break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return rv;
|
||||||
}
|
}
|
||||||
|
|
||||||
static float map_zoom,map_dx,map_dy = 0;
|
static float map_zoom,map_dx,map_dy = 0;
|
||||||
|
@ -254,7 +295,7 @@ extern void CONTROL_Android_ScrollMap(int32_t *angle,int32_t *x, int32_t *y, ui
|
||||||
*x += ((int)(map_dx * -30000)*sintable[(512+2048-*angle)&2047])>>14;
|
*x += ((int)(map_dx * -30000)*sintable[(512+2048-*angle)&2047])>>14;
|
||||||
*y += ((int)(map_dy * -30000)*sintable[(512+1024-512-*angle)&2047])>>14;
|
*y += ((int)(map_dy * -30000)*sintable[(512+1024-512-*angle)&2047])>>14;
|
||||||
|
|
||||||
*zoom += map_zoom * 2000;
|
// *zoom += map_zoom * 2000;
|
||||||
//*angle = 0;
|
//*angle = 0;
|
||||||
map_dx = map_dy = map_zoom = 0;
|
map_dx = map_dy = map_zoom = 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,8 +24,8 @@ extern "C"
|
||||||
#define KEY_QUICK_KEY3 0x1013
|
#define KEY_QUICK_KEY3 0x1013
|
||||||
#define KEY_QUICK_KEY4 0x1014
|
#define KEY_QUICK_KEY4 0x1014
|
||||||
|
|
||||||
#define BUTTONSET(x,value) (CONTROL_ButtonState |= ((uint64_t)value<<((uint64_t)(x))))
|
// #define BUTTONSET(x,value) (CONTROL_ButtonState |= ((uint64_t)value<<((uint64_t)(x))))
|
||||||
#define BUTTONCLEAR(x) (CONTROL_ButtonState &= ~((uint64_t)1<<((uint64_t)(x))))
|
// #define BUTTONCLEAR(x) (CONTROL_ButtonState &= ~((uint64_t)1<<((uint64_t)(x))))
|
||||||
|
|
||||||
#define PRECISIONSHOOTFACTOR 0.3f
|
#define PRECISIONSHOOTFACTOR 0.3f
|
||||||
|
|
||||||
|
@ -49,7 +49,9 @@ typedef enum {
|
||||||
READ_RENDERER,
|
READ_RENDERER,
|
||||||
READ_LASTWEAPON,
|
READ_LASTWEAPON,
|
||||||
READ_PAUSED,
|
READ_PAUSED,
|
||||||
READ_IS_DEAD
|
READ_IS_DEAD,
|
||||||
|
READ_INVENTORY,
|
||||||
|
READ_SOMETHINGONPLAYER
|
||||||
} portableread_t;
|
} portableread_t;
|
||||||
|
|
||||||
|
|
||||||
|
@ -68,6 +70,8 @@ typedef struct
|
||||||
{
|
{
|
||||||
int32_t crouchToggleState;
|
int32_t crouchToggleState;
|
||||||
int32_t lastWeapon;
|
int32_t lastWeapon;
|
||||||
|
int32_t toggleCrouch;
|
||||||
|
int32_t quickSelectWeapon;
|
||||||
|
|
||||||
uint64_t functionSticky; //To let at least one tick
|
uint64_t functionSticky; //To let at least one tick
|
||||||
uint64_t functionHeld;
|
uint64_t functionHeld;
|
||||||
|
@ -75,6 +79,8 @@ typedef struct
|
||||||
int32_t left_double_action;
|
int32_t left_double_action;
|
||||||
int32_t right_double_action;
|
int32_t right_double_action;
|
||||||
|
|
||||||
|
int32_t invertLook, hideStick;
|
||||||
|
|
||||||
double pitch, yaw;
|
double pitch, yaw;
|
||||||
double pitch_joystick, yaw_joystick;
|
double pitch_joystick, yaw_joystick;
|
||||||
float forwardmove, sidemove;
|
float forwardmove, sidemove;
|
||||||
|
@ -82,6 +88,8 @@ typedef struct
|
||||||
// set by configuration UI
|
// set by configuration UI
|
||||||
float strafe_sens, forward_sens;
|
float strafe_sens, forward_sens;
|
||||||
float pitch_sens, yaw_sens;
|
float pitch_sens, yaw_sens;
|
||||||
|
|
||||||
|
float gameControlsAlpha;
|
||||||
} droidinput_t;
|
} droidinput_t;
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
|
@ -93,8 +101,6 @@ typedef struct
|
||||||
|
|
||||||
extern droidinput_t droidinput;
|
extern droidinput_t droidinput;
|
||||||
extern droidsysinfo_t droidinfo;
|
extern droidsysinfo_t droidinfo;
|
||||||
extern char toggleCrouch;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int PortableKeyEvent(int state, int code, int unicode);
|
int PortableKeyEvent(int state, int code, int unicode);
|
||||||
|
@ -102,6 +108,9 @@ int PortableRead(portableread_t r);
|
||||||
|
|
||||||
void PortableAction(int state, int action);
|
void PortableAction(int state, int action);
|
||||||
|
|
||||||
|
void PortableMouseMenu(float x,float y);
|
||||||
|
void PortableMouseMenuButton(int state,int button);
|
||||||
|
|
||||||
void PortableMove(float fwd, float strafe);
|
void PortableMove(float fwd, float strafe);
|
||||||
void PortableLook(double yaw, double pitch);
|
void PortableLook(double yaw, double pitch);
|
||||||
void PortableLookJoystick(double yaw, double pitch);
|
void PortableLookJoystick(double yaw, double pitch);
|
||||||
|
|
|
@ -368,10 +368,10 @@ void G_ExtInit(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void G_ExtPreStartupWindow(void)
|
void G_ScanGroups(void)
|
||||||
{
|
{
|
||||||
ScanGroups();
|
ScanGroups();
|
||||||
{
|
|
||||||
// try and identify the 'defaultgamegrp' in the set of GRPs.
|
// try and identify the 'defaultgamegrp' in the set of GRPs.
|
||||||
// if it is found, set up the environment accordingly for the game it represents.
|
// if it is found, set up the environment accordingly for the game it represents.
|
||||||
// if it is not found, choose the first GRP from the list
|
// if it is not found, choose the first GRP from the list
|
||||||
|
@ -407,9 +407,8 @@ void G_ExtPreStartupWindow(void)
|
||||||
}
|
}
|
||||||
else if (!fg) g_gameNamePtr = NULL;
|
else if (!fg) g_gameNamePtr = NULL;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void G_ExtPostStartupWindow(int32_t autoload)
|
void G_LoadGroups(int32_t autoload)
|
||||||
{
|
{
|
||||||
if (g_modDir[0] != '/')
|
if (g_modDir[0] != '/')
|
||||||
{
|
{
|
||||||
|
@ -425,7 +424,8 @@ void G_ExtPostStartupWindow(int32_t autoload)
|
||||||
if (!Bstrcmp(g_rootDir, cwd))
|
if (!Bstrcmp(g_rootDir, cwd))
|
||||||
{
|
{
|
||||||
if (addsearchpath(cwd) == -2)
|
if (addsearchpath(cwd) == -2)
|
||||||
if (Bmkdir(cwd,S_IRWXU) == 0) addsearchpath(cwd);
|
if (Bmkdir(cwd, S_IRWXU) == 0)
|
||||||
|
addsearchpath(cwd);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -438,7 +438,6 @@ void G_ExtPostStartupWindow(int32_t autoload)
|
||||||
if (g_usingAddon)
|
if (g_usingAddon)
|
||||||
G_LoadAddon();
|
G_LoadAddon();
|
||||||
|
|
||||||
{
|
|
||||||
int32_t i;
|
int32_t i;
|
||||||
const char *grpfile = G_GrpFile();
|
const char *grpfile = G_GrpFile();
|
||||||
|
|
||||||
|
@ -466,7 +465,6 @@ void G_ExtPostStartupWindow(int32_t autoload)
|
||||||
if (i != -1)
|
if (i != -1)
|
||||||
G_DoAutoload(grpfile);
|
G_DoAutoload(grpfile);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (g_modDir[0] != '/')
|
if (g_modDir[0] != '/')
|
||||||
G_LoadGroupsInDir(g_modDir);
|
G_LoadGroupsInDir(g_modDir);
|
||||||
|
@ -484,7 +482,6 @@ void G_ExtPostStartupWindow(int32_t autoload)
|
||||||
|
|
||||||
loaddefinitions_game(G_DefFile(), TRUE);
|
loaddefinitions_game(G_DefFile(), TRUE);
|
||||||
|
|
||||||
{
|
|
||||||
struct strllist *s;
|
struct strllist *s;
|
||||||
|
|
||||||
pathsearchmode = 1;
|
pathsearchmode = 1;
|
||||||
|
@ -510,7 +507,6 @@ void G_ExtPostStartupWindow(int32_t autoload)
|
||||||
}
|
}
|
||||||
pathsearchmode = 0;
|
pathsearchmode = 0;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
const char * G_GetInstallPath(int32_t insttype)
|
const char * G_GetInstallPath(int32_t insttype)
|
||||||
|
|
|
@ -60,6 +60,10 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
#include "input.h"
|
#include "input.h"
|
||||||
#include "compat.h"
|
#include "compat.h"
|
||||||
|
|
||||||
|
#ifdef __ANDROID__
|
||||||
|
#include "android.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef LUNATIC
|
#ifdef LUNATIC
|
||||||
# include "lunatic_game.h"
|
# include "lunatic_game.h"
|
||||||
#endif
|
#endif
|
||||||
|
@ -2884,6 +2888,10 @@ static void fadepaltile(int32_t r, int32_t g, int32_t b, int32_t start, int32_t
|
||||||
int32_t g_logoFlags = 255;
|
int32_t g_logoFlags = 255;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef __ANDROID__
|
||||||
|
int inExtraScreens = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
static void G_DisplayExtraScreens(void)
|
static void G_DisplayExtraScreens(void)
|
||||||
{
|
{
|
||||||
int32_t flags = G_GetLogoFlags();
|
int32_t flags = G_GetLogoFlags();
|
||||||
|
@ -2893,6 +2901,9 @@ static void G_DisplayExtraScreens(void)
|
||||||
|
|
||||||
if (!DUKEBETA && (!VOLUMEALL || flags & LOGO_SHAREWARESCREENS))
|
if (!DUKEBETA && (!VOLUMEALL || flags & LOGO_SHAREWARESCREENS))
|
||||||
{
|
{
|
||||||
|
#ifdef __ANDROID__
|
||||||
|
inExtraScreens = 1;
|
||||||
|
#endif
|
||||||
setview(0,0,xdim-1,ydim-1);
|
setview(0,0,xdim-1,ydim-1);
|
||||||
flushperms();
|
flushperms();
|
||||||
//g_player[myconnectindex].ps->palette = palette;
|
//g_player[myconnectindex].ps->palette = palette;
|
||||||
|
@ -2910,10 +2921,17 @@ static void G_DisplayExtraScreens(void)
|
||||||
fadepaltile(0,0,0, 63,0,-7,3290);
|
fadepaltile(0,0,0, 63,0,-7,3290);
|
||||||
while (!I_CheckAllInput())
|
while (!I_CheckAllInput())
|
||||||
G_HandleAsync();
|
G_HandleAsync();
|
||||||
|
|
||||||
|
#ifdef __ANDROID__
|
||||||
|
inExtraScreens = 0;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
if (flags & LOGO_TENSCREEN)
|
if (flags & LOGO_TENSCREEN)
|
||||||
{
|
{
|
||||||
|
#ifdef __ANDROID__
|
||||||
|
inExtraScreens = 1;
|
||||||
|
#endif
|
||||||
setview(0,0,xdim-1,ydim-1);
|
setview(0,0,xdim-1,ydim-1);
|
||||||
flushperms();
|
flushperms();
|
||||||
//g_player[myconnectindex].ps->palette = palette;
|
//g_player[myconnectindex].ps->palette = palette;
|
||||||
|
@ -2928,6 +2946,9 @@ static void G_DisplayExtraScreens(void)
|
||||||
|
|
||||||
fadepaltile(0,0,0, 0,63,7, TENSCREEN);
|
fadepaltile(0,0,0, 0,63,7, TENSCREEN);
|
||||||
I_ClearAllInput();
|
I_ClearAllInput();
|
||||||
|
#ifdef __ANDROID__
|
||||||
|
inExtraScreens = 0;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2976,8 +2997,6 @@ void G_GameExit(const char *msg)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
uninitgroupfile();
|
|
||||||
|
|
||||||
Bfflush(NULL);
|
Bfflush(NULL);
|
||||||
|
|
||||||
exit(0);
|
exit(0);
|
||||||
|
@ -3666,12 +3685,16 @@ void G_DisplayRest(int32_t smoothratio)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
#ifdef __ANDROID__
|
||||||
|
CONTROL_Android_ScrollMap(&ud.fola,& ud.folx,&ud.foly,&pp->zoom);
|
||||||
|
#else
|
||||||
if (!ud.pause_on)
|
if (!ud.pause_on)
|
||||||
{
|
{
|
||||||
ud.fola += ud.folavel>>3;
|
ud.fola += ud.folavel>>3;
|
||||||
ud.folx += (ud.folfvel*sintable[(512+2048-ud.fola)&2047])>>14;
|
ud.folx += (ud.folfvel*sintable[(512+2048-ud.fola)&2047])>>14;
|
||||||
ud.foly += (ud.folfvel*sintable[(512+1024-512-ud.fola)&2047])>>14;
|
ud.foly += (ud.folfvel*sintable[(512+1024-512-ud.fola)&2047])>>14;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
cposx = ud.folx;
|
cposx = ud.folx;
|
||||||
cposy = ud.foly;
|
cposy = ud.foly;
|
||||||
cang = ud.fola;
|
cang = ud.fola;
|
||||||
|
@ -4413,6 +4436,11 @@ void G_DrawRooms(int32_t snum, int32_t smoothratio)
|
||||||
|
|
||||||
if (pub > 0 || getrendermode() >= REND_POLYMOST) // JBF 20040101: redraw background always
|
if (pub > 0 || getrendermode() >= REND_POLYMOST) // JBF 20040101: redraw background always
|
||||||
{
|
{
|
||||||
|
#ifdef __ANDROID__
|
||||||
|
// HACK: this is needed or else we get leftover UI texture crap where we'd get HOM on PC
|
||||||
|
clearallviews(0L);
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef EDUKE32_TOUCH_DEVICES
|
#ifndef EDUKE32_TOUCH_DEVICES
|
||||||
if (ud.screen_size >= 8)
|
if (ud.screen_size >= 8)
|
||||||
#endif
|
#endif
|
||||||
|
@ -7502,8 +7530,11 @@ void G_DoSpriteAnimations(int32_t ourx, int32_t oury, int32_t oura, int32_t smoo
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
t->picnum = TILE_VIEWSCR;
|
t->picnum = TILE_VIEWSCR;
|
||||||
t->xrepeat = t->xrepeat & 1 ? (t->xrepeat>>2) + 1 : t->xrepeat>>2;
|
|
||||||
t->yrepeat = t->yrepeat & 1 ? (t->yrepeat>>2) + 1 : t->yrepeat>>2;
|
#if VIEWSCREENFACTOR > 0
|
||||||
|
t->xrepeat = (t->xrepeat>>VIEWSCREENFACTOR) + (t->xrepeat & 1);
|
||||||
|
t->yrepeat = (t->yrepeat>>VIEWSCREENFACTOR) + (t->yrepeat & 1);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
@ -9164,6 +9195,18 @@ FAKE_F3:
|
||||||
if (ud.overhead_on == 3) ud.overhead_on = 0;
|
if (ud.overhead_on == 3) ud.overhead_on = 0;
|
||||||
ud.last_overhead = ud.overhead_on;
|
ud.last_overhead = ud.overhead_on;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef __ANDROID__
|
||||||
|
if (ud.overhead_on == 1)
|
||||||
|
ud.scrollmode = 0;
|
||||||
|
else if (ud.overhead_on == 2)
|
||||||
|
{
|
||||||
|
ud.scrollmode = 1;
|
||||||
|
ud.folx = g_player[screenpeek].ps->opos.x;
|
||||||
|
ud.foly = g_player[screenpeek].ps->opos.y;
|
||||||
|
ud.fola = g_player[screenpeek].ps->oang;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
g_restorePalette = 1;
|
g_restorePalette = 1;
|
||||||
G_UpdateScreenArea();
|
G_UpdateScreenArea();
|
||||||
}
|
}
|
||||||
|
@ -10735,6 +10778,7 @@ void G_Shutdown(void)
|
||||||
G_Cleanup();
|
G_Cleanup();
|
||||||
FreeGroups();
|
FreeGroups();
|
||||||
OSD_Cleanup();
|
OSD_Cleanup();
|
||||||
|
uninitgroupfile();
|
||||||
Bfflush(NULL);
|
Bfflush(NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11067,7 +11111,10 @@ static void G_Startup(void)
|
||||||
G_GameExit("Failed loading art.");
|
G_GameExit("Failed loading art.");
|
||||||
}
|
}
|
||||||
Bchdir(cwd);
|
Bchdir(cwd);
|
||||||
|
#ifndef __ANDROID__ //This crashes on *some* Android devices. Small onetime memory leak. TODO fix above function
|
||||||
Bfree(cwd);
|
Bfree(cwd);
|
||||||
|
#endif
|
||||||
|
|
||||||
}
|
}
|
||||||
else if (loadpics("tiles000.art",MAXCACHE1DSIZE) < 0)
|
else if (loadpics("tiles000.art",MAXCACHE1DSIZE) < 0)
|
||||||
G_GameExit("Failed loading art.");
|
G_GameExit("Failed loading art.");
|
||||||
|
@ -11409,7 +11456,7 @@ int32_t app_main(int32_t argc, const char **argv)
|
||||||
if (Bstrcmp(setupfilename, SETUPFILENAME))
|
if (Bstrcmp(setupfilename, SETUPFILENAME))
|
||||||
initprintf("Using config file \"%s\".\n",setupfilename);
|
initprintf("Using config file \"%s\".\n",setupfilename);
|
||||||
|
|
||||||
G_ExtPreStartupWindow();
|
G_ScanGroups();
|
||||||
|
|
||||||
#ifdef STARTUP_SETUP_WINDOW
|
#ifdef STARTUP_SETUP_WINDOW
|
||||||
if (i < 0 || (!g_noSetup && (ud.configversion != BYTEVERSION_JF || ud.config.ForceSetup)) || g_commandSetup)
|
if (i < 0 || (!g_noSetup && (ud.configversion != BYTEVERSION_JF || ud.config.ForceSetup)) || g_commandSetup)
|
||||||
|
@ -11429,7 +11476,7 @@ int32_t app_main(int32_t argc, const char **argv)
|
||||||
}
|
}
|
||||||
|
|
||||||
flushlogwindow = 0;
|
flushlogwindow = 0;
|
||||||
G_ExtPostStartupWindow(!g_noAutoLoad && !ud.config.NoAutoLoad);
|
G_LoadGroups(!g_noAutoLoad && !ud.config.NoAutoLoad);
|
||||||
// flushlogwindow = 1;
|
// flushlogwindow = 1;
|
||||||
|
|
||||||
if (!usecwd)
|
if (!usecwd)
|
||||||
|
|
|
@ -42,6 +42,14 @@ extern "C" {
|
||||||
#define MAXPWLOCKOUT 128
|
#define MAXPWLOCKOUT 128
|
||||||
#define MAXRTSNAME 128
|
#define MAXRTSNAME 128
|
||||||
|
|
||||||
|
#if defined(GEKKO) || defined(__OPENDINGUX__)
|
||||||
|
# define VIEWSCREENFACTOR 0
|
||||||
|
#elif defined(__ANDROID__)
|
||||||
|
# define VIEWSCREENFACTOR 1
|
||||||
|
#else
|
||||||
|
# define VIEWSCREENFACTOR 2
|
||||||
|
#endif
|
||||||
|
|
||||||
enum GametypeFlags_t {
|
enum GametypeFlags_t {
|
||||||
GAMETYPE_COOP = 0x00000001,
|
GAMETYPE_COOP = 0x00000001,
|
||||||
GAMETYPE_WEAPSTAY = 0x00000002,
|
GAMETYPE_WEAPSTAY = 0x00000002,
|
||||||
|
|
|
@ -405,7 +405,7 @@ void G_AnimateCamSprite(int32_t smoothratio)
|
||||||
if (OW >= 0 && dist(&sprite[ps->i], &sprite[i]) < VIEWSCREEN_ACTIVE_DISTANCE)
|
if (OW >= 0 && dist(&sprite[ps->i], &sprite[i]) < VIEWSCREEN_ACTIVE_DISTANCE)
|
||||||
{
|
{
|
||||||
if (waloff[TILE_VIEWSCR] == 0)
|
if (waloff[TILE_VIEWSCR] == 0)
|
||||||
allocatepermanenttile(TILE_VIEWSCR, tilesiz[PN].x<<2, tilesiz[PN].y<<2);
|
allocatepermanenttile(TILE_VIEWSCR, tilesiz[PN].x<<VIEWSCREENFACTOR, tilesiz[PN].y<<VIEWSCREENFACTOR);
|
||||||
else
|
else
|
||||||
walock[TILE_VIEWSCR] = 255;
|
walock[TILE_VIEWSCR] = 255;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue