Compare commits
27 Commits
android-mk
...
master-ndk
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
cee1bebc51 | ||
|
|
5c899b511c | ||
|
|
2bdfbfa7d1 | ||
|
|
7d1c97cf84 | ||
|
|
64de5b07eb | ||
|
|
796aea2488 | ||
|
|
772ee8db97 | ||
|
|
416f16322b | ||
|
|
d55f0bac81 | ||
|
|
d4e548990a | ||
|
|
02f95a5a01 | ||
|
|
7c0281d4d2 | ||
|
|
cccf80274f | ||
|
|
02a67d7619 | ||
|
|
c2d9869503 | ||
|
|
8051c36fcd | ||
|
|
e074dc937b | ||
|
|
3514dfb2f4 | ||
|
|
1ba6d3113e | ||
|
|
c17ef2c53a | ||
|
|
347273726c | ||
|
|
7dd67599df | ||
|
|
2685ef24f4 | ||
|
|
8568f1b4df | ||
|
|
13e70f1e27 | ||
|
|
25f4ef4bb9 | ||
|
|
af8cb48a25 |
9
.gitignore
vendored
Normal file
@@ -0,0 +1,9 @@
|
||||
.gradle
|
||||
local.properties
|
||||
.idea
|
||||
.DS_Store
|
||||
build
|
||||
*.iml
|
||||
.DS_Store
|
||||
.externalNativeBuild
|
||||
externalNativeBuild
|
||||
24
MoreTeapots/app/build.gradle
Normal file
@@ -0,0 +1,24 @@
|
||||
apply plugin: 'com.android.application'
|
||||
|
||||
android {
|
||||
compileSdkVersion 23
|
||||
buildToolsVersion '25.0.0'
|
||||
|
||||
defaultConfig {
|
||||
applicationId "com.sample.moreteapots"
|
||||
minSdkVersion 14
|
||||
targetSdkVersion 23
|
||||
}
|
||||
|
||||
buildTypes {
|
||||
release {
|
||||
minifyEnabled false
|
||||
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt'
|
||||
}
|
||||
}
|
||||
externalNativeBuild {
|
||||
ndkBuild {
|
||||
path 'src/main/cpp/Android.mk'
|
||||
}
|
||||
}
|
||||
}
|
||||
3
MoreTeapots/app/lint.xml
Normal file
@@ -0,0 +1,3 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<lint>
|
||||
</lint>
|
||||
@@ -17,7 +17,7 @@
|
||||
//
|
||||
|
||||
uniform lowp vec3 vMaterialAmbient;
|
||||
uniform mediump vec4 vMaterialSpecular;
|
||||
uniform lowp vec4 vMaterialSpecular;
|
||||
|
||||
varying lowp vec4 colorDiffuse;
|
||||
|
||||
@@ -17,7 +17,7 @@
|
||||
#version 300 es
|
||||
precision mediump float;
|
||||
|
||||
uniform mediump vec4 vMaterialSpecular;
|
||||
uniform lowp vec4 vMaterialSpecular;
|
||||
uniform highp vec3 vLight0;
|
||||
|
||||
in lowp vec4 colorDiffuse;
|
||||
@@ -14,6 +14,7 @@ LOCAL_STATIC_LIBRARIES := cpufeatures android_native_app_glue ndk_helper
|
||||
|
||||
include $(BUILD_SHARED_LIBRARY)
|
||||
|
||||
$(call import-module,android/ndk_helper)
|
||||
$(call import-add-path, $(LOCAL_PATH))
|
||||
$(call import-module,ndk_helper)
|
||||
$(call import-module,android/native_app_glue)
|
||||
$(call import-module,android/cpufeatures)
|
||||
4
MoreTeapots/app/src/main/cpp/Application.mk
Normal file
@@ -0,0 +1,4 @@
|
||||
APP_PLATFORM := android-14
|
||||
APP_ABI := all
|
||||
|
||||
APP_STL := stlport_static
|
||||
@@ -443,7 +443,6 @@ Engine g_engine;
|
||||
*/
|
||||
void android_main( android_app* state )
|
||||
{
|
||||
app_dummy();
|
||||
|
||||
g_engine.SetState( state );
|
||||
|
||||
17
MoreTeapots/app/src/main/cpp/ndk_helper/Android.mk
Normal file
@@ -0,0 +1,17 @@
|
||||
LOCAL_PATH:= $(call my-dir)
|
||||
|
||||
include $(CLEAR_VARS)
|
||||
|
||||
LOCAL_MODULE:= ndk_helper
|
||||
LOCAL_SRC_FILES:= JNIHelper.cpp interpolator.cpp tapCamera.cpp gestureDetector.cpp perfMonitor.cpp vecmath.cpp GLContext.cpp shader.cpp gl3stub.c
|
||||
|
||||
LOCAL_CPPFLAGS +=-std=c++11
|
||||
LOCAL_EXPORT_C_INCLUDES := $(LOCAL_PATH)
|
||||
LOCAL_EXPORT_LDLIBS := -llog -landroid -lEGL -lGLESv2
|
||||
|
||||
LOCAL_STATIC_LIBRARIES := cpufeatures android_native_app_glue
|
||||
|
||||
include $(BUILD_STATIC_LIBRARY)
|
||||
|
||||
#$(call import-module,android/native_app_glue)
|
||||
#$(call import-module,android/cpufeatures)
|
||||
13
MoreTeapots/app/src/main/cpp/ndk_helper/CMakeLists.txt
Normal file
@@ -0,0 +1,13 @@
|
||||
add_library(ndk-helper STATIC
|
||||
gestureDetector.cpp
|
||||
gl3stub.c
|
||||
GLContext.cpp
|
||||
interpolator.cpp
|
||||
JNIHelper.cpp
|
||||
perfMonitor.cpp
|
||||
shader.cpp
|
||||
tapCamera.cpp
|
||||
vecmath.cpp)
|
||||
|
||||
target_include_directories(ndk-helper PRIVATE
|
||||
${ANDROID_NDK}/sources/android/native_app_glue)
|
||||
248
MoreTeapots/app/src/main/cpp/ndk_helper/GLContext.cpp
Normal file
@@ -0,0 +1,248 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// GLContext.cpp
|
||||
//--------------------------------------------------------------------------------
|
||||
//--------------------------------------------------------------------------------
|
||||
// includes
|
||||
//--------------------------------------------------------------------------------
|
||||
#include <unistd.h>
|
||||
#include "GLContext.h"
|
||||
#include "gl3stub.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// eGLContext
|
||||
//--------------------------------------------------------------------------------
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// Ctor
|
||||
//--------------------------------------------------------------------------------
|
||||
GLContext::GLContext()
|
||||
: display_(EGL_NO_DISPLAY),
|
||||
surface_(EGL_NO_SURFACE),
|
||||
context_(EGL_NO_CONTEXT),
|
||||
screen_width_(0),
|
||||
screen_height_(0),
|
||||
gles_initialized_(false),
|
||||
egl_context_initialized_(false),
|
||||
es3_supported_(false) {}
|
||||
|
||||
void GLContext::InitGLES() {
|
||||
if (gles_initialized_) return;
|
||||
//
|
||||
// Initialize OpenGL ES 3 if available
|
||||
//
|
||||
const char* versionStr = (const char*)glGetString(GL_VERSION);
|
||||
if (strstr(versionStr, "OpenGL ES 3.") && gl3stubInit()) {
|
||||
es3_supported_ = true;
|
||||
gl_version_ = 3.0f;
|
||||
} else {
|
||||
gl_version_ = 2.0f;
|
||||
}
|
||||
|
||||
gles_initialized_ = true;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// Dtor
|
||||
//--------------------------------------------------------------------------------
|
||||
GLContext::~GLContext() { Terminate(); }
|
||||
|
||||
bool GLContext::Init(ANativeWindow* window) {
|
||||
if (egl_context_initialized_) return true;
|
||||
|
||||
//
|
||||
// Initialize EGL
|
||||
//
|
||||
window_ = window;
|
||||
InitEGLSurface();
|
||||
InitEGLContext();
|
||||
InitGLES();
|
||||
|
||||
egl_context_initialized_ = true;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool GLContext::InitEGLSurface() {
|
||||
display_ = eglGetDisplay(EGL_DEFAULT_DISPLAY);
|
||||
eglInitialize(display_, 0, 0);
|
||||
|
||||
/*
|
||||
* Here specify the attributes of the desired configuration.
|
||||
* Below, we select an EGLConfig with at least 8 bits per color
|
||||
* component compatible with on-screen windows
|
||||
*/
|
||||
const EGLint attribs[] = {
|
||||
EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT, // Request opengl ES2.0
|
||||
EGL_SURFACE_TYPE, EGL_WINDOW_BIT, EGL_BLUE_SIZE, 8,
|
||||
EGL_GREEN_SIZE, 8, EGL_RED_SIZE, 8,
|
||||
EGL_DEPTH_SIZE, 24, EGL_NONE};
|
||||
color_size_ = 8;
|
||||
depth_size_ = 24;
|
||||
|
||||
EGLint num_configs;
|
||||
eglChooseConfig(display_, attribs, &config_, 1, &num_configs);
|
||||
|
||||
if (!num_configs) {
|
||||
// Fall back to 16bit depth buffer
|
||||
const EGLint attribs[] = {
|
||||
EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT, // Request opengl ES2.0
|
||||
EGL_SURFACE_TYPE, EGL_WINDOW_BIT, EGL_BLUE_SIZE, 8,
|
||||
EGL_GREEN_SIZE, 8, EGL_RED_SIZE, 8,
|
||||
EGL_DEPTH_SIZE, 16, EGL_NONE};
|
||||
eglChooseConfig(display_, attribs, &config_, 1, &num_configs);
|
||||
depth_size_ = 16;
|
||||
}
|
||||
|
||||
if (!num_configs) {
|
||||
LOGW("Unable to retrieve EGL config");
|
||||
return false;
|
||||
}
|
||||
|
||||
surface_ = eglCreateWindowSurface(display_, config_, window_, NULL);
|
||||
eglQuerySurface(display_, surface_, EGL_WIDTH, &screen_width_);
|
||||
eglQuerySurface(display_, surface_, EGL_HEIGHT, &screen_height_);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool GLContext::InitEGLContext() {
|
||||
const EGLint context_attribs[] = {EGL_CONTEXT_CLIENT_VERSION,
|
||||
2, // Request opengl ES2.0
|
||||
EGL_NONE};
|
||||
context_ = eglCreateContext(display_, config_, NULL, context_attribs);
|
||||
|
||||
if (eglMakeCurrent(display_, surface_, surface_, context_) == EGL_FALSE) {
|
||||
LOGW("Unable to eglMakeCurrent");
|
||||
return false;
|
||||
}
|
||||
|
||||
context_valid_ = true;
|
||||
return true;
|
||||
}
|
||||
|
||||
EGLint GLContext::Swap() {
|
||||
bool b = eglSwapBuffers(display_, surface_);
|
||||
if (!b) {
|
||||
EGLint err = eglGetError();
|
||||
if (err == EGL_BAD_SURFACE) {
|
||||
// Recreate surface
|
||||
InitEGLSurface();
|
||||
return EGL_SUCCESS; // Still consider glContext is valid
|
||||
} else if (err == EGL_CONTEXT_LOST || err == EGL_BAD_CONTEXT) {
|
||||
// Context has been lost!!
|
||||
context_valid_ = false;
|
||||
Terminate();
|
||||
InitEGLContext();
|
||||
}
|
||||
return err;
|
||||
}
|
||||
return EGL_SUCCESS;
|
||||
}
|
||||
|
||||
void GLContext::Terminate() {
|
||||
if (display_ != EGL_NO_DISPLAY) {
|
||||
eglMakeCurrent(display_, EGL_NO_SURFACE, EGL_NO_SURFACE, EGL_NO_CONTEXT);
|
||||
if (context_ != EGL_NO_CONTEXT) {
|
||||
eglDestroyContext(display_, context_);
|
||||
}
|
||||
|
||||
if (surface_ != EGL_NO_SURFACE) {
|
||||
eglDestroySurface(display_, surface_);
|
||||
}
|
||||
eglTerminate(display_);
|
||||
}
|
||||
|
||||
display_ = EGL_NO_DISPLAY;
|
||||
context_ = EGL_NO_CONTEXT;
|
||||
surface_ = EGL_NO_SURFACE;
|
||||
context_valid_ = false;
|
||||
}
|
||||
|
||||
EGLint GLContext::Resume(ANativeWindow* window) {
|
||||
if (egl_context_initialized_ == false) {
|
||||
Init(window);
|
||||
return EGL_SUCCESS;
|
||||
}
|
||||
|
||||
int32_t original_widhth = screen_width_;
|
||||
int32_t original_height = screen_height_;
|
||||
|
||||
// Create surface
|
||||
window_ = window;
|
||||
surface_ = eglCreateWindowSurface(display_, config_, window_, NULL);
|
||||
eglQuerySurface(display_, surface_, EGL_WIDTH, &screen_width_);
|
||||
eglQuerySurface(display_, surface_, EGL_HEIGHT, &screen_height_);
|
||||
|
||||
if (screen_width_ != original_widhth || screen_height_ != original_height) {
|
||||
// Screen resized
|
||||
LOGI("Screen resized");
|
||||
}
|
||||
|
||||
if (eglMakeCurrent(display_, surface_, surface_, context_) == EGL_TRUE)
|
||||
return EGL_SUCCESS;
|
||||
|
||||
EGLint err = eglGetError();
|
||||
LOGW("Unable to eglMakeCurrent %d", err);
|
||||
|
||||
if (err == EGL_CONTEXT_LOST) {
|
||||
// Recreate context
|
||||
LOGI("Re-creating egl context");
|
||||
InitEGLContext();
|
||||
} else {
|
||||
// Recreate surface
|
||||
Terminate();
|
||||
InitEGLSurface();
|
||||
InitEGLContext();
|
||||
}
|
||||
|
||||
return err;
|
||||
}
|
||||
|
||||
void GLContext::Suspend() {
|
||||
if (surface_ != EGL_NO_SURFACE) {
|
||||
eglDestroySurface(display_, surface_);
|
||||
surface_ = EGL_NO_SURFACE;
|
||||
}
|
||||
}
|
||||
|
||||
bool GLContext::Invalidate() {
|
||||
Terminate();
|
||||
|
||||
egl_context_initialized_ = false;
|
||||
return true;
|
||||
}
|
||||
|
||||
bool GLContext::CheckExtension(const char* extension) {
|
||||
if (extension == NULL) return false;
|
||||
|
||||
std::string extensions = std::string((char*)glGetString(GL_EXTENSIONS));
|
||||
std::string str = std::string(extension);
|
||||
str.append(" ");
|
||||
|
||||
size_t pos = 0;
|
||||
if (extensions.find(extension, pos) != std::string::npos) {
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
} // namespace ndkHelper
|
||||
111
MoreTeapots/app/src/main/cpp/ndk_helper/GLContext.h
Normal file
@@ -0,0 +1,111 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// GLContext.h
|
||||
//--------------------------------------------------------------------------------
|
||||
#ifndef GLCONTEXT_H_
|
||||
#define GLCONTEXT_H_
|
||||
|
||||
#include <EGL/egl.h>
|
||||
#include <GLES2/gl2.h>
|
||||
#include <android/log.h>
|
||||
|
||||
#include "JNIHelper.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// Constants
|
||||
//--------------------------------------------------------------------------------
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// Class
|
||||
//--------------------------------------------------------------------------------
|
||||
|
||||
/******************************************************************
|
||||
* OpenGL context handler
|
||||
* The class handles OpenGL and EGL context based on Android activity life cycle
|
||||
* The caller needs to call corresponding methods for each activity life cycle
|
||||
*events as it's done in sample codes.
|
||||
*
|
||||
* Also the class initializes OpenGL ES3 when the compatible driver is installed
|
||||
*in the device.
|
||||
* getGLVersion() returns 3.0~ when the device supports OpenGLES3.0
|
||||
*
|
||||
* Thread safety: OpenGL context is expecting used within dedicated single
|
||||
*thread,
|
||||
* thus GLContext class is not designed as a thread-safe
|
||||
*/
|
||||
class GLContext {
|
||||
private:
|
||||
// EGL configurations
|
||||
ANativeWindow* window_;
|
||||
EGLDisplay display_;
|
||||
EGLSurface surface_;
|
||||
EGLContext context_;
|
||||
EGLConfig config_;
|
||||
|
||||
// Screen parameters
|
||||
int32_t screen_width_;
|
||||
int32_t screen_height_;
|
||||
int32_t color_size_;
|
||||
int32_t depth_size_;
|
||||
|
||||
// Flags
|
||||
bool gles_initialized_;
|
||||
bool egl_context_initialized_;
|
||||
bool es3_supported_;
|
||||
float gl_version_;
|
||||
bool context_valid_;
|
||||
|
||||
void InitGLES();
|
||||
void Terminate();
|
||||
bool InitEGLSurface();
|
||||
bool InitEGLContext();
|
||||
|
||||
GLContext(GLContext const&);
|
||||
void operator=(GLContext const&);
|
||||
GLContext();
|
||||
virtual ~GLContext();
|
||||
|
||||
public:
|
||||
static GLContext* GetInstance() {
|
||||
// Singleton
|
||||
static GLContext instance;
|
||||
|
||||
return &instance;
|
||||
}
|
||||
|
||||
bool Init(ANativeWindow* window);
|
||||
EGLint Swap();
|
||||
bool Invalidate();
|
||||
|
||||
void Suspend();
|
||||
EGLint Resume(ANativeWindow* window);
|
||||
|
||||
int32_t GetScreenWidth() { return screen_width_; }
|
||||
int32_t GetScreenHeight() { return screen_height_; }
|
||||
|
||||
int32_t GetBufferColorSize() { return color_size_; }
|
||||
int32_t GetBufferDepthSize() { return depth_size_; }
|
||||
float GetGLVersion() { return gl_version_; }
|
||||
bool CheckExtension(const char* extension);
|
||||
};
|
||||
|
||||
} // namespace ndkHelper
|
||||
|
||||
#endif /* GLCONTEXT_H_ */
|
||||
365
MoreTeapots/app/src/main/cpp/ndk_helper/JNIHelper.cpp
Normal file
@@ -0,0 +1,365 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#include <EGL/egl.h>
|
||||
#include <GLES2/gl2.h>
|
||||
#include <fstream>
|
||||
#include <iostream>
|
||||
|
||||
#include "JNIHelper.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
#define CLASS_NAME "android/app/NativeActivity"
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
// JNI Helper functions
|
||||
//---------------------------------------------------------------------------
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
// Singleton
|
||||
//---------------------------------------------------------------------------
|
||||
JNIHelper* JNIHelper::GetInstance() {
|
||||
static JNIHelper helper;
|
||||
return &helper;
|
||||
}
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
// Ctor
|
||||
//---------------------------------------------------------------------------
|
||||
JNIHelper::JNIHelper() { pthread_mutex_init(&mutex_, NULL); }
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
// Dtor
|
||||
//---------------------------------------------------------------------------
|
||||
JNIHelper::~JNIHelper() {
|
||||
pthread_mutex_lock(&mutex_);
|
||||
|
||||
JNIEnv* env;
|
||||
activity_->vm->AttachCurrentThread(&env, NULL);
|
||||
|
||||
env->DeleteGlobalRef(jni_helper_java_ref_);
|
||||
env->DeleteGlobalRef(jni_helper_java_class_);
|
||||
|
||||
activity_->vm->DetachCurrentThread();
|
||||
|
||||
pthread_mutex_destroy(&mutex_);
|
||||
}
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
// Init
|
||||
//---------------------------------------------------------------------------
|
||||
void JNIHelper::Init(ANativeActivity* activity, const char* helper_class_name) {
|
||||
JNIHelper& helper = *GetInstance();
|
||||
pthread_mutex_lock(&helper.mutex_);
|
||||
|
||||
helper.activity_ = activity;
|
||||
|
||||
JNIEnv* env;
|
||||
helper.activity_->vm->AttachCurrentThread(&env, NULL);
|
||||
|
||||
// Retrieve app name
|
||||
jclass android_content_Context = env->GetObjectClass(helper.activity_->clazz);
|
||||
jmethodID midGetPackageName = env->GetMethodID(
|
||||
android_content_Context, "getPackageName", "()Ljava/lang/String;");
|
||||
|
||||
jstring packageName = (jstring)env->CallObjectMethod(helper.activity_->clazz,
|
||||
midGetPackageName);
|
||||
const char* appname = env->GetStringUTFChars(packageName, NULL);
|
||||
helper.app_name_ = std::string(appname);
|
||||
|
||||
jclass cls = helper.RetrieveClass(env, helper_class_name);
|
||||
helper.jni_helper_java_class_ = (jclass)env->NewGlobalRef(cls);
|
||||
|
||||
jmethodID constructor =
|
||||
env->GetMethodID(helper.jni_helper_java_class_, "<init>", "()V");
|
||||
helper.jni_helper_java_ref_ =
|
||||
env->NewObject(helper.jni_helper_java_class_, constructor);
|
||||
helper.jni_helper_java_ref_ = env->NewGlobalRef(helper.jni_helper_java_ref_);
|
||||
|
||||
env->ReleaseStringUTFChars(packageName, appname);
|
||||
helper.activity_->vm->DetachCurrentThread();
|
||||
|
||||
pthread_mutex_unlock(&helper.mutex_);
|
||||
}
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
// readFile
|
||||
//---------------------------------------------------------------------------
|
||||
bool JNIHelper::ReadFile(const char* fileName,
|
||||
std::vector<uint8_t>* buffer_ref) {
|
||||
if (activity_ == NULL) {
|
||||
LOGI(
|
||||
"JNIHelper has not been initialized.Call init() to initialize the "
|
||||
"helper");
|
||||
return false;
|
||||
}
|
||||
|
||||
// First, try reading from externalFileDir;
|
||||
JNIEnv* env;
|
||||
|
||||
pthread_mutex_lock(&mutex_);
|
||||
activity_->vm->AttachCurrentThread(&env, NULL);
|
||||
|
||||
jstring str_path = GetExternalFilesDirJString(env);
|
||||
const char* path = env->GetStringUTFChars(str_path, NULL);
|
||||
std::string s(path);
|
||||
|
||||
if (fileName[0] != '/') {
|
||||
s.append("/");
|
||||
}
|
||||
s.append(fileName);
|
||||
std::ifstream f(s.c_str(), std::ios::binary);
|
||||
|
||||
env->ReleaseStringUTFChars(str_path, path);
|
||||
env->DeleteLocalRef(str_path);
|
||||
activity_->vm->DetachCurrentThread();
|
||||
|
||||
if (f) {
|
||||
LOGI("reading:%s", s.c_str());
|
||||
f.seekg(0, std::ifstream::end);
|
||||
int32_t fileSize = f.tellg();
|
||||
f.seekg(0, std::ifstream::beg);
|
||||
buffer_ref->reserve(fileSize);
|
||||
buffer_ref->assign(std::istreambuf_iterator<char>(f),
|
||||
std::istreambuf_iterator<char>());
|
||||
f.close();
|
||||
pthread_mutex_unlock(&mutex_);
|
||||
return true;
|
||||
} else {
|
||||
// Fallback to assetManager
|
||||
AAssetManager* assetManager = activity_->assetManager;
|
||||
AAsset* assetFile =
|
||||
AAssetManager_open(assetManager, fileName, AASSET_MODE_BUFFER);
|
||||
if (!assetFile) {
|
||||
pthread_mutex_unlock(&mutex_);
|
||||
return false;
|
||||
}
|
||||
uint8_t* data = (uint8_t*)AAsset_getBuffer(assetFile);
|
||||
int32_t size = AAsset_getLength(assetFile);
|
||||
if (data == NULL) {
|
||||
AAsset_close(assetFile);
|
||||
|
||||
LOGI("Failed to load:%s", fileName);
|
||||
pthread_mutex_unlock(&mutex_);
|
||||
return false;
|
||||
}
|
||||
|
||||
buffer_ref->reserve(size);
|
||||
buffer_ref->assign(data, data + size);
|
||||
|
||||
AAsset_close(assetFile);
|
||||
pthread_mutex_unlock(&mutex_);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
std::string JNIHelper::GetExternalFilesDir() {
|
||||
if (activity_ == NULL) {
|
||||
LOGI(
|
||||
"JNIHelper has not been initialized. Call init() to initialize the "
|
||||
"helper");
|
||||
return std::string("");
|
||||
}
|
||||
|
||||
pthread_mutex_lock(&mutex_);
|
||||
|
||||
// First, try reading from externalFileDir;
|
||||
JNIEnv* env;
|
||||
|
||||
activity_->vm->AttachCurrentThread(&env, NULL);
|
||||
|
||||
jstring strPath = GetExternalFilesDirJString(env);
|
||||
const char* path = env->GetStringUTFChars(strPath, NULL);
|
||||
std::string s(path);
|
||||
|
||||
env->ReleaseStringUTFChars(strPath, path);
|
||||
env->DeleteLocalRef(strPath);
|
||||
activity_->vm->DetachCurrentThread();
|
||||
|
||||
pthread_mutex_unlock(&mutex_);
|
||||
return s;
|
||||
}
|
||||
|
||||
uint32_t JNIHelper::LoadTexture(const char* file_name) {
|
||||
if (activity_ == NULL) {
|
||||
LOGI(
|
||||
"JNIHelper has not been initialized. Call init() to initialize the "
|
||||
"helper");
|
||||
return 0;
|
||||
}
|
||||
|
||||
JNIEnv* env;
|
||||
jmethodID mid;
|
||||
|
||||
pthread_mutex_lock(&mutex_);
|
||||
activity_->vm->AttachCurrentThread(&env, NULL);
|
||||
|
||||
jstring name = env->NewStringUTF(file_name);
|
||||
|
||||
GLuint tex;
|
||||
glGenTextures(1, &tex);
|
||||
glBindTexture(GL_TEXTURE_2D, tex);
|
||||
|
||||
glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER,
|
||||
GL_LINEAR_MIPMAP_NEAREST);
|
||||
glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
|
||||
|
||||
mid = env->GetMethodID(jni_helper_java_class_, "loadTexture",
|
||||
"(Ljava/lang/String;)Z");
|
||||
jboolean ret = env->CallBooleanMethod(jni_helper_java_ref_, mid, name);
|
||||
if (!ret) {
|
||||
glDeleteTextures(1, &tex);
|
||||
tex = -1;
|
||||
LOGI("Texture load failed %s", file_name);
|
||||
}
|
||||
|
||||
// Generate mipmap
|
||||
glGenerateMipmap(GL_TEXTURE_2D);
|
||||
|
||||
env->DeleteLocalRef(name);
|
||||
activity_->vm->DetachCurrentThread();
|
||||
pthread_mutex_unlock(&mutex_);
|
||||
|
||||
return tex;
|
||||
}
|
||||
|
||||
std::string JNIHelper::ConvertString(const char* str, const char* encode) {
|
||||
if (activity_ == NULL) {
|
||||
LOGI(
|
||||
"JNIHelper has not been initialized. Call init() to initialize the "
|
||||
"helper");
|
||||
return std::string("");
|
||||
}
|
||||
|
||||
JNIEnv* env;
|
||||
|
||||
pthread_mutex_lock(&mutex_);
|
||||
activity_->vm->AttachCurrentThread(&env, NULL);
|
||||
|
||||
int32_t iLength = strlen((const char*)str);
|
||||
|
||||
jbyteArray array = env->NewByteArray(iLength);
|
||||
env->SetByteArrayRegion(array, 0, iLength, (const signed char*)str);
|
||||
|
||||
jstring strEncode = env->NewStringUTF(encode);
|
||||
|
||||
jclass cls = env->FindClass("java/lang/String");
|
||||
jmethodID ctor = env->GetMethodID(cls, "<init>", "([BLjava/lang/String;)V");
|
||||
jstring object = (jstring)env->NewObject(cls, ctor, array, strEncode);
|
||||
|
||||
const char* cparam = env->GetStringUTFChars(object, NULL);
|
||||
|
||||
std::string s = std::string(cparam);
|
||||
|
||||
env->ReleaseStringUTFChars(object, cparam);
|
||||
env->DeleteLocalRef(strEncode);
|
||||
env->DeleteLocalRef(object);
|
||||
activity_->vm->DetachCurrentThread();
|
||||
pthread_mutex_unlock(&mutex_);
|
||||
|
||||
return s;
|
||||
}
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
// Audio helpers
|
||||
//---------------------------------------------------------------------------
|
||||
int32_t JNIHelper::GetNativeAudioBufferSize() {
|
||||
if (activity_ == NULL) {
|
||||
LOGI(
|
||||
"JNIHelper has not been initialized. Call init() to initialize the "
|
||||
"helper");
|
||||
return 0;
|
||||
}
|
||||
|
||||
JNIEnv* env;
|
||||
jmethodID mid;
|
||||
|
||||
pthread_mutex_lock(&mutex_);
|
||||
activity_->vm->AttachCurrentThread(&env, NULL);
|
||||
|
||||
mid = env->GetMethodID(jni_helper_java_class_, "getNativeAudioBufferSize",
|
||||
"()I");
|
||||
int32_t i = env->CallIntMethod(jni_helper_java_ref_, mid);
|
||||
activity_->vm->DetachCurrentThread();
|
||||
pthread_mutex_unlock(&mutex_);
|
||||
|
||||
return i;
|
||||
}
|
||||
|
||||
int32_t JNIHelper::GetNativeAudioSampleRate() {
|
||||
if (activity_ == NULL) {
|
||||
LOGI(
|
||||
"JNIHelper has not been initialized. Call init() to initialize the "
|
||||
"helper");
|
||||
return 0;
|
||||
}
|
||||
|
||||
JNIEnv* env;
|
||||
jmethodID mid;
|
||||
|
||||
pthread_mutex_lock(&mutex_);
|
||||
activity_->vm->AttachCurrentThread(&env, NULL);
|
||||
|
||||
mid = env->GetMethodID(jni_helper_java_class_, "getNativeAudioSampleRate",
|
||||
"()I");
|
||||
int32_t i = env->CallIntMethod(jni_helper_java_ref_, mid);
|
||||
activity_->vm->DetachCurrentThread();
|
||||
pthread_mutex_unlock(&mutex_);
|
||||
|
||||
return i;
|
||||
}
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
// Misc implementations
|
||||
//---------------------------------------------------------------------------
|
||||
jclass JNIHelper::RetrieveClass(JNIEnv* jni, const char* class_name) {
|
||||
jclass activity_class = jni->FindClass(CLASS_NAME);
|
||||
jmethodID get_class_loader = jni->GetMethodID(
|
||||
activity_class, "getClassLoader", "()Ljava/lang/ClassLoader;");
|
||||
jobject cls = jni->CallObjectMethod(activity_->clazz, get_class_loader);
|
||||
jclass class_loader = jni->FindClass("java/lang/ClassLoader");
|
||||
jmethodID find_class = jni->GetMethodID(
|
||||
class_loader, "loadClass", "(Ljava/lang/String;)Ljava/lang/Class;");
|
||||
|
||||
jstring str_class_name = jni->NewStringUTF(class_name);
|
||||
jclass class_retrieved =
|
||||
(jclass)jni->CallObjectMethod(cls, find_class, str_class_name);
|
||||
jni->DeleteLocalRef(str_class_name);
|
||||
return class_retrieved;
|
||||
}
|
||||
|
||||
jstring JNIHelper::GetExternalFilesDirJString(JNIEnv* env) {
|
||||
if (activity_ == NULL) {
|
||||
LOGI(
|
||||
"JNIHelper has not been initialized. Call init() to initialize the "
|
||||
"helper");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
// Invoking getExternalFilesDir() java API
|
||||
jclass cls_Env = env->FindClass(CLASS_NAME);
|
||||
jmethodID mid = env->GetMethodID(cls_Env, "getExternalFilesDir",
|
||||
"(Ljava/lang/String;)Ljava/io/File;");
|
||||
jobject obj_File = env->CallObjectMethod(activity_->clazz, mid, NULL);
|
||||
jclass cls_File = env->FindClass("java/io/File");
|
||||
jmethodID mid_getPath =
|
||||
env->GetMethodID(cls_File, "getPath", "()Ljava/lang/String;");
|
||||
jstring obj_Path = (jstring)env->CallObjectMethod(obj_File, mid_getPath);
|
||||
|
||||
return obj_Path;
|
||||
}
|
||||
|
||||
} // namespace ndkHelper
|
||||
183
MoreTeapots/app/src/main/cpp/ndk_helper/JNIHelper.h
Normal file
@@ -0,0 +1,183 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include <jni.h>
|
||||
#include <vector>
|
||||
#include <string>
|
||||
|
||||
#include <android/log.h>
|
||||
#include <android_native_app_glue.h>
|
||||
|
||||
#define LOGI(...) \
|
||||
((void)__android_log_print( \
|
||||
ANDROID_LOG_INFO, ndk_helper::JNIHelper::GetInstance()->GetAppName(), \
|
||||
__VA_ARGS__))
|
||||
#define LOGW(...) \
|
||||
((void)__android_log_print( \
|
||||
ANDROID_LOG_WARN, ndk_helper::JNIHelper::GetInstance()->GetAppName(), \
|
||||
__VA_ARGS__))
|
||||
#define LOGE(...) \
|
||||
((void)__android_log_print( \
|
||||
ANDROID_LOG_ERROR, ndk_helper::JNIHelper::GetInstance()->GetAppName(), \
|
||||
__VA_ARGS__))
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
/******************************************************************
|
||||
* Helper functions for JNI calls
|
||||
* This class wraps JNI calls and provides handy interface calling commonly used
|
||||
*features
|
||||
* in Java SDK.
|
||||
* Such as
|
||||
* - loading graphics files (e.g. PNG, JPG)
|
||||
* - character code conversion
|
||||
* - retrieving system properties which only supported in Java SDK
|
||||
*
|
||||
* NOTE: To use this class, add NDKHelper.java as a corresponding helpers in
|
||||
*Java code
|
||||
*/
|
||||
class JNIHelper {
|
||||
private:
|
||||
std::string app_name_;
|
||||
|
||||
ANativeActivity* activity_;
|
||||
jobject jni_helper_java_ref_;
|
||||
jclass jni_helper_java_class_;
|
||||
|
||||
// mutex for synchronization
|
||||
// This class uses singleton pattern and can be invoked from multiple threads,
|
||||
// each methods locks the mutex for a thread safety
|
||||
mutable pthread_mutex_t mutex_;
|
||||
|
||||
jstring GetExternalFilesDirJString(JNIEnv* env);
|
||||
jclass RetrieveClass(JNIEnv* jni, const char* class_name);
|
||||
|
||||
JNIHelper();
|
||||
~JNIHelper();
|
||||
JNIHelper(const JNIHelper& rhs);
|
||||
JNIHelper& operator=(const JNIHelper& rhs);
|
||||
|
||||
public:
|
||||
/*
|
||||
* To load your own Java classes, JNIHelper requires to be initialized with a
|
||||
*ANativeActivity handle.
|
||||
* This methods need to be called before any call to the helper class.
|
||||
* Static member of the class
|
||||
*
|
||||
* arguments:
|
||||
* in: activity, pointer to ANativeActivity. Used internally to set up JNI
|
||||
*environment
|
||||
* in: helper_class_name, pointer to Java side helper class name. (e.g.
|
||||
*"com/sample/helper/NDKHelper" in samples )
|
||||
*/
|
||||
static void Init(ANativeActivity* activity, const char* helper_class_name);
|
||||
|
||||
/*
|
||||
* Retrieve the singleton object of the helper.
|
||||
* Static member of the class
|
||||
|
||||
* Methods in the class are designed as thread safe.
|
||||
*/
|
||||
static JNIHelper* GetInstance();
|
||||
|
||||
/*
|
||||
* Read a file from a strorage.
|
||||
* First, the method tries to read the file from an external storage.
|
||||
* If it fails to read, it falls back to use assset manager and try to read
|
||||
*the file from APK asset.
|
||||
*
|
||||
* arguments:
|
||||
* in: file_name, file name to read
|
||||
* out: buffer_ref, pointer to a vector buffer to read a file.
|
||||
* when the call succeeded, the buffer includes contents of specified
|
||||
*file
|
||||
* when the call failed, contents of the buffer remains same
|
||||
* return:
|
||||
* true when file read succeeded
|
||||
* false when it failed to read the file
|
||||
*/
|
||||
bool ReadFile(const char* file_name, std::vector<uint8_t>* buffer_ref);
|
||||
|
||||
/*
|
||||
* Load and create OpenGL texture from given file name.
|
||||
* The method invokes BitmapFactory in Java so it can read jpeg/png formatted
|
||||
*files
|
||||
*
|
||||
* The methods creates mip-map and set texture parameters like this,
|
||||
* glTexParameterf( GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER,
|
||||
*GL_LINEAR_MIPMAP_NEAREST );
|
||||
* glTexParameterf( GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR );
|
||||
* glGenerateMipmap( GL_TEXTURE_2D );
|
||||
*
|
||||
* arguments:
|
||||
* in: file_name, file name to read, PNG&JPG is supported
|
||||
* return:
|
||||
* OpenGL texture name when the call succeeded
|
||||
* When it failed to load the texture, it returns -1
|
||||
*/
|
||||
uint32_t LoadTexture(const char* file_name);
|
||||
|
||||
/*
|
||||
* Convert string from character code other than UTF-8
|
||||
*
|
||||
* arguments:
|
||||
* in: str, pointer to a string which is encoded other than UTF-8
|
||||
* in: encoding, pointer to a character encoding string.
|
||||
* The encoding string can be any valid java.nio.charset.Charset name
|
||||
* e.g. "UTF-16", "Shift_JIS"
|
||||
* return: converted input string as an UTF-8 std::string
|
||||
*/
|
||||
std::string ConvertString(const char* str, const char* encode);
|
||||
/*
|
||||
* Retrieve external file directory through JNI call
|
||||
*
|
||||
* return: std::string containing external file diretory
|
||||
*/
|
||||
std::string GetExternalFilesDir();
|
||||
|
||||
/*
|
||||
* Audio helper
|
||||
* Retrieves native audio buffer size which is required to achieve low latency
|
||||
*audio
|
||||
*
|
||||
* return: Native audio buffer size which is a hint to achieve low latency
|
||||
*audio
|
||||
* If the API is not supported (API level < 17), it returns 0
|
||||
*/
|
||||
int32_t GetNativeAudioBufferSize();
|
||||
|
||||
/*
|
||||
* Audio helper
|
||||
* Retrieves native audio sample rate which is required to achieve low latency
|
||||
*audio
|
||||
*
|
||||
* return: Native audio sample rate which is a hint to achieve low latency
|
||||
*audio
|
||||
*/
|
||||
int32_t GetNativeAudioSampleRate();
|
||||
|
||||
/*
|
||||
* Retrieves application bundle name
|
||||
*
|
||||
* return: pointer to an app name string
|
||||
*
|
||||
*/
|
||||
const char* GetAppName() { return app_name_.c_str(); }
|
||||
};
|
||||
|
||||
} // namespace ndkHelper
|
||||
40
MoreTeapots/app/src/main/cpp/ndk_helper/NDKHelper.h
Normal file
@@ -0,0 +1,40 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#ifndef _NDKSUPPORT_H
|
||||
#define _NDKSUPPORT_H
|
||||
|
||||
/******************************************************************
|
||||
* NDK support helpers
|
||||
* Utility module to provide misc functionalities that is used widely in native
|
||||
*applications,
|
||||
* such as gesture detection, jni bridge, openGL context etc.
|
||||
*
|
||||
* The purpose of this module is,
|
||||
* - Provide best practices using NDK
|
||||
* - Provide handy utility functions for NDK development
|
||||
* - Make NDK samples more simpler and readable
|
||||
*/
|
||||
#include "gl3stub.h" //GLES3 stubs
|
||||
#include "GLContext.h" //EGL & OpenGL manager
|
||||
#include "shader.h" //Shader compiler support
|
||||
#include "vecmath.h" //Vector math support, C++ implementation n current version
|
||||
#include "tapCamera.h" //Tap/Pinch camera control
|
||||
#include "JNIHelper.h" //JNI support
|
||||
#include "gestureDetector.h" //Tap/Doubletap/Pinch detector
|
||||
#include "perfMonitor.h" //FPS counter
|
||||
#include "interpolator.h" //Interpolator
|
||||
#endif
|
||||
296
MoreTeapots/app/src/main/cpp/ndk_helper/gestureDetector.cpp
Normal file
@@ -0,0 +1,296 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include "gestureDetector.h"
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// gestureDetector.cpp
|
||||
//--------------------------------------------------------------------------------
|
||||
namespace ndk_helper {
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// includes
|
||||
//--------------------------------------------------------------------------------
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// GestureDetector
|
||||
//--------------------------------------------------------------------------------
|
||||
GestureDetector::GestureDetector() { dp_factor_ = 1.f; }
|
||||
|
||||
void GestureDetector::SetConfiguration(AConfiguration* config) {
|
||||
dp_factor_ = 160.f / AConfiguration_getDensity(config);
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// TapDetector
|
||||
//--------------------------------------------------------------------------------
|
||||
GESTURE_STATE TapDetector::Detect(const AInputEvent* motion_event) {
|
||||
if (AMotionEvent_getPointerCount(motion_event) > 1) {
|
||||
// Only support single touch
|
||||
return false;
|
||||
}
|
||||
|
||||
int32_t action = AMotionEvent_getAction(motion_event);
|
||||
unsigned int flags = action & AMOTION_EVENT_ACTION_MASK;
|
||||
switch (flags) {
|
||||
case AMOTION_EVENT_ACTION_DOWN:
|
||||
down_pointer_id_ = AMotionEvent_getPointerId(motion_event, 0);
|
||||
down_x_ = AMotionEvent_getX(motion_event, 0);
|
||||
down_y_ = AMotionEvent_getY(motion_event, 0);
|
||||
break;
|
||||
case AMOTION_EVENT_ACTION_UP: {
|
||||
int64_t eventTime = AMotionEvent_getEventTime(motion_event);
|
||||
int64_t downTime = AMotionEvent_getDownTime(motion_event);
|
||||
if (eventTime - downTime <= TAP_TIMEOUT) {
|
||||
if (down_pointer_id_ == AMotionEvent_getPointerId(motion_event, 0)) {
|
||||
float x = AMotionEvent_getX(motion_event, 0) - down_x_;
|
||||
float y = AMotionEvent_getY(motion_event, 0) - down_y_;
|
||||
if (x * x + y * y < TOUCH_SLOP * TOUCH_SLOP * dp_factor_) {
|
||||
LOGI("TapDetector: Tap detected");
|
||||
return GESTURE_STATE_ACTION;
|
||||
}
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
return GESTURE_STATE_NONE;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// DoubletapDetector
|
||||
//--------------------------------------------------------------------------------
|
||||
GESTURE_STATE DoubletapDetector::Detect(const AInputEvent* motion_event) {
|
||||
if (AMotionEvent_getPointerCount(motion_event) > 1) {
|
||||
// Only support single double tap
|
||||
return false;
|
||||
}
|
||||
|
||||
bool tap_detected = tap_detector_.Detect(motion_event);
|
||||
|
||||
int32_t action = AMotionEvent_getAction(motion_event);
|
||||
unsigned int flags = action & AMOTION_EVENT_ACTION_MASK;
|
||||
switch (flags) {
|
||||
case AMOTION_EVENT_ACTION_DOWN: {
|
||||
int64_t eventTime = AMotionEvent_getEventTime(motion_event);
|
||||
if (eventTime - last_tap_time_ <= DOUBLE_TAP_TIMEOUT) {
|
||||
float x = AMotionEvent_getX(motion_event, 0) - last_tap_x_;
|
||||
float y = AMotionEvent_getY(motion_event, 0) - last_tap_y_;
|
||||
if (x * x + y * y < DOUBLE_TAP_SLOP * DOUBLE_TAP_SLOP * dp_factor_) {
|
||||
LOGI("DoubletapDetector: Doubletap detected");
|
||||
return GESTURE_STATE_ACTION;
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
case AMOTION_EVENT_ACTION_UP:
|
||||
if (tap_detected) {
|
||||
last_tap_time_ = AMotionEvent_getEventTime(motion_event);
|
||||
last_tap_x_ = AMotionEvent_getX(motion_event, 0);
|
||||
last_tap_y_ = AMotionEvent_getY(motion_event, 0);
|
||||
}
|
||||
break;
|
||||
}
|
||||
return GESTURE_STATE_NONE;
|
||||
}
|
||||
|
||||
void DoubletapDetector::SetConfiguration(AConfiguration* config) {
|
||||
dp_factor_ = 160.f / AConfiguration_getDensity(config);
|
||||
tap_detector_.SetConfiguration(config);
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// PinchDetector
|
||||
//--------------------------------------------------------------------------------
|
||||
|
||||
int32_t PinchDetector::FindIndex(const AInputEvent* event, int32_t id) {
|
||||
int32_t count = AMotionEvent_getPointerCount(event);
|
||||
for (auto i = 0; i < count; ++i) {
|
||||
if (id == AMotionEvent_getPointerId(event, i)) return i;
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
|
||||
GESTURE_STATE PinchDetector::Detect(const AInputEvent* event) {
|
||||
GESTURE_STATE ret = GESTURE_STATE_NONE;
|
||||
int32_t action = AMotionEvent_getAction(event);
|
||||
uint32_t flags = action & AMOTION_EVENT_ACTION_MASK;
|
||||
event_ = event;
|
||||
|
||||
int32_t count = AMotionEvent_getPointerCount(event);
|
||||
switch (flags) {
|
||||
case AMOTION_EVENT_ACTION_DOWN:
|
||||
vec_pointers_.push_back(AMotionEvent_getPointerId(event, 0));
|
||||
break;
|
||||
case AMOTION_EVENT_ACTION_POINTER_DOWN: {
|
||||
int32_t iIndex = (action & AMOTION_EVENT_ACTION_POINTER_INDEX_MASK) >>
|
||||
AMOTION_EVENT_ACTION_POINTER_INDEX_SHIFT;
|
||||
vec_pointers_.push_back(AMotionEvent_getPointerId(event, iIndex));
|
||||
if (count == 2) {
|
||||
// Start new pinch
|
||||
ret = GESTURE_STATE_START;
|
||||
}
|
||||
} break;
|
||||
case AMOTION_EVENT_ACTION_UP:
|
||||
vec_pointers_.pop_back();
|
||||
break;
|
||||
case AMOTION_EVENT_ACTION_POINTER_UP: {
|
||||
int32_t index = (action & AMOTION_EVENT_ACTION_POINTER_INDEX_MASK) >>
|
||||
AMOTION_EVENT_ACTION_POINTER_INDEX_SHIFT;
|
||||
int32_t released_pointer_id = AMotionEvent_getPointerId(event, index);
|
||||
|
||||
std::vector<int32_t>::iterator it = vec_pointers_.begin();
|
||||
std::vector<int32_t>::iterator it_end = vec_pointers_.end();
|
||||
int32_t i = 0;
|
||||
for (; it != it_end; ++it, ++i) {
|
||||
if (*it == released_pointer_id) {
|
||||
vec_pointers_.erase(it);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (i <= 1) {
|
||||
// Reset pinch or drag
|
||||
if (count != 2) {
|
||||
// Start new pinch
|
||||
ret = GESTURE_STATE_START | GESTURE_STATE_END;
|
||||
}
|
||||
}
|
||||
} break;
|
||||
case AMOTION_EVENT_ACTION_MOVE:
|
||||
switch (count) {
|
||||
case 1:
|
||||
break;
|
||||
default:
|
||||
// Multi touch
|
||||
ret = GESTURE_STATE_MOVE;
|
||||
break;
|
||||
}
|
||||
break;
|
||||
case AMOTION_EVENT_ACTION_CANCEL:
|
||||
break;
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
bool PinchDetector::GetPointers(Vec2& v1, Vec2& v2) {
|
||||
if (vec_pointers_.size() < 2) return false;
|
||||
|
||||
int32_t index = FindIndex(event_, vec_pointers_[0]);
|
||||
if (index == -1) return false;
|
||||
|
||||
float x = AMotionEvent_getX(event_, index);
|
||||
float y = AMotionEvent_getY(event_, index);
|
||||
|
||||
index = FindIndex(event_, vec_pointers_[1]);
|
||||
if (index == -1) return false;
|
||||
|
||||
float x2 = AMotionEvent_getX(event_, index);
|
||||
float y2 = AMotionEvent_getY(event_, index);
|
||||
|
||||
v1 = Vec2(x, y);
|
||||
v2 = Vec2(x2, y2);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// DragDetector
|
||||
//--------------------------------------------------------------------------------
|
||||
|
||||
int32_t DragDetector::FindIndex(const AInputEvent* event, int32_t id) {
|
||||
int32_t count = AMotionEvent_getPointerCount(event);
|
||||
for (auto i = 0; i < count; ++i) {
|
||||
if (id == AMotionEvent_getPointerId(event, i)) return i;
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
|
||||
GESTURE_STATE DragDetector::Detect(const AInputEvent* event) {
|
||||
GESTURE_STATE ret = GESTURE_STATE_NONE;
|
||||
int32_t action = AMotionEvent_getAction(event);
|
||||
int32_t index = (action & AMOTION_EVENT_ACTION_POINTER_INDEX_MASK) >>
|
||||
AMOTION_EVENT_ACTION_POINTER_INDEX_SHIFT;
|
||||
uint32_t flags = action & AMOTION_EVENT_ACTION_MASK;
|
||||
event_ = event;
|
||||
|
||||
int32_t count = AMotionEvent_getPointerCount(event);
|
||||
switch (flags) {
|
||||
case AMOTION_EVENT_ACTION_DOWN:
|
||||
vec_pointers_.push_back(AMotionEvent_getPointerId(event, 0));
|
||||
ret = GESTURE_STATE_START;
|
||||
break;
|
||||
case AMOTION_EVENT_ACTION_POINTER_DOWN:
|
||||
vec_pointers_.push_back(AMotionEvent_getPointerId(event, index));
|
||||
break;
|
||||
case AMOTION_EVENT_ACTION_UP:
|
||||
vec_pointers_.pop_back();
|
||||
ret = GESTURE_STATE_END;
|
||||
break;
|
||||
case AMOTION_EVENT_ACTION_POINTER_UP: {
|
||||
int32_t released_pointer_id = AMotionEvent_getPointerId(event, index);
|
||||
|
||||
auto it = vec_pointers_.begin();
|
||||
auto it_end = vec_pointers_.end();
|
||||
int32_t i = 0;
|
||||
for (; it != it_end; ++it, ++i) {
|
||||
if (*it == released_pointer_id) {
|
||||
vec_pointers_.erase(it);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (i <= 1) {
|
||||
// Reset pinch or drag
|
||||
if (count == 2) {
|
||||
ret = GESTURE_STATE_START;
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
case AMOTION_EVENT_ACTION_MOVE:
|
||||
switch (count) {
|
||||
case 1:
|
||||
// Drag
|
||||
ret = GESTURE_STATE_MOVE;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
break;
|
||||
case AMOTION_EVENT_ACTION_CANCEL:
|
||||
break;
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
bool DragDetector::GetPointer(Vec2& v) {
|
||||
if (vec_pointers_.size() < 1) return false;
|
||||
|
||||
int32_t iIndex = FindIndex(event_, vec_pointers_[0]);
|
||||
if (iIndex == -1) return false;
|
||||
|
||||
float x = AMotionEvent_getX(event_, iIndex);
|
||||
float y = AMotionEvent_getY(event_, iIndex);
|
||||
|
||||
v = Vec2(x, y);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
} // namespace ndkHelper
|
||||
144
MoreTeapots/app/src/main/cpp/ndk_helper/gestureDetector.h
Normal file
@@ -0,0 +1,144 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// gestureDetector.h
|
||||
//--------------------------------------------------------------------------------
|
||||
#ifndef GESTUREDETECTOR_H_
|
||||
#define GESTUREDETECTOR_H_
|
||||
|
||||
#include <vector>
|
||||
|
||||
#include <android/sensor.h>
|
||||
#include <android/log.h>
|
||||
#include <android_native_app_glue.h>
|
||||
#include <android/native_window_jni.h>
|
||||
#include "JNIHelper.h"
|
||||
#include "vecmath.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
//--------------------------------------------------------------------------------
|
||||
// Constants
|
||||
//--------------------------------------------------------------------------------
|
||||
const int32_t DOUBLE_TAP_TIMEOUT = 300 * 1000000;
|
||||
const int32_t TAP_TIMEOUT = 180 * 1000000;
|
||||
const int32_t DOUBLE_TAP_SLOP = 100;
|
||||
const int32_t TOUCH_SLOP = 8;
|
||||
|
||||
enum {
|
||||
GESTURE_STATE_NONE = 0,
|
||||
GESTURE_STATE_START = 1,
|
||||
GESTURE_STATE_MOVE = 2,
|
||||
GESTURE_STATE_END = 4,
|
||||
GESTURE_STATE_ACTION = (GESTURE_STATE_START | GESTURE_STATE_END),
|
||||
};
|
||||
typedef int32_t GESTURE_STATE;
|
||||
|
||||
/******************************************************************
|
||||
* Base class of Gesture Detectors
|
||||
* GestureDetectors handles input events and detect gestures
|
||||
* Note that different detectors may detect gestures with an event at
|
||||
* same time. The caller needs to manage gesture priority accordingly
|
||||
*
|
||||
*/
|
||||
class GestureDetector {
|
||||
protected:
|
||||
float dp_factor_;
|
||||
|
||||
public:
|
||||
GestureDetector();
|
||||
virtual ~GestureDetector() {}
|
||||
virtual void SetConfiguration(AConfiguration* config);
|
||||
|
||||
virtual GESTURE_STATE Detect(const AInputEvent* motion_event) = 0;
|
||||
};
|
||||
|
||||
/******************************************************************
|
||||
* Tap gesture detector
|
||||
* Returns GESTURE_STATE_ACTION when a tap gesture is detected
|
||||
*
|
||||
*/
|
||||
class TapDetector : public GestureDetector {
|
||||
private:
|
||||
int32_t down_pointer_id_;
|
||||
float down_x_;
|
||||
float down_y_;
|
||||
|
||||
public:
|
||||
TapDetector() {}
|
||||
virtual ~TapDetector() {}
|
||||
virtual GESTURE_STATE Detect(const AInputEvent* motion_event);
|
||||
};
|
||||
|
||||
/******************************************************************
|
||||
* Pinch gesture detector
|
||||
* Returns GESTURE_STATE_ACTION when a double-tap gesture is detected
|
||||
*
|
||||
*/
|
||||
class DoubletapDetector : public GestureDetector {
|
||||
private:
|
||||
TapDetector tap_detector_;
|
||||
int64_t last_tap_time_;
|
||||
float last_tap_x_;
|
||||
float last_tap_y_;
|
||||
|
||||
public:
|
||||
DoubletapDetector() {}
|
||||
virtual ~DoubletapDetector() {}
|
||||
virtual GESTURE_STATE Detect(const AInputEvent* motion_event);
|
||||
virtual void SetConfiguration(AConfiguration* config);
|
||||
};
|
||||
|
||||
/******************************************************************
|
||||
* Double gesture detector
|
||||
* Returns pinch gesture state when a pinch gesture is detected
|
||||
* The class handles multiple touches more than 2
|
||||
* When the finger 1,2,3 are tapped and then finger 1 is released,
|
||||
* the detector start new pinch gesture with finger 2 & 3.
|
||||
*/
|
||||
class PinchDetector : public GestureDetector {
|
||||
private:
|
||||
int32_t FindIndex(const AInputEvent* event, int32_t id);
|
||||
const AInputEvent* event_;
|
||||
std::vector<int32_t> vec_pointers_;
|
||||
|
||||
public:
|
||||
PinchDetector() {}
|
||||
virtual ~PinchDetector() {}
|
||||
virtual GESTURE_STATE Detect(const AInputEvent* event);
|
||||
bool GetPointers(Vec2& v1, Vec2& v2);
|
||||
};
|
||||
|
||||
/******************************************************************
|
||||
* Drag gesture detector
|
||||
* Returns drag gesture state when a drag-tap gesture is detected
|
||||
*
|
||||
*/
|
||||
class DragDetector : public GestureDetector {
|
||||
private:
|
||||
int32_t FindIndex(const AInputEvent* event, int32_t id);
|
||||
const AInputEvent* event_;
|
||||
std::vector<int32_t> vec_pointers_;
|
||||
|
||||
public:
|
||||
DragDetector() {}
|
||||
virtual ~DragDetector() {}
|
||||
virtual GESTURE_STATE Detect(const AInputEvent* event);
|
||||
bool GetPointer(Vec2& v);
|
||||
};
|
||||
|
||||
} // namespace ndkHelper
|
||||
#endif /* GESTUREDETECTOR_H_ */
|
||||
512
MoreTeapots/app/src/main/cpp/ndk_helper/gl3stub.c
Normal file
@@ -0,0 +1,512 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include <EGL/egl.h>
|
||||
#include "gl3stub.h"
|
||||
|
||||
GLboolean gl3stubInit()
|
||||
{
|
||||
#define FIND_PROC(s) s = (void*)eglGetProcAddress(#s);
|
||||
FIND_PROC( glReadBuffer );
|
||||
FIND_PROC( glDrawRangeElements );
|
||||
FIND_PROC( glTexImage3D );
|
||||
FIND_PROC( glTexSubImage3D );
|
||||
FIND_PROC( glCopyTexSubImage3D );
|
||||
FIND_PROC( glCompressedTexImage3D );
|
||||
FIND_PROC( glCompressedTexSubImage3D );
|
||||
FIND_PROC( glGenQueries );
|
||||
FIND_PROC( glDeleteQueries );
|
||||
FIND_PROC( glIsQuery );
|
||||
FIND_PROC( glBeginQuery );
|
||||
FIND_PROC( glEndQuery );
|
||||
FIND_PROC( glGetQueryiv );
|
||||
FIND_PROC( glGetQueryObjectuiv );
|
||||
FIND_PROC( glUnmapBuffer );
|
||||
FIND_PROC( glGetBufferPointerv );
|
||||
FIND_PROC( glDrawBuffers );
|
||||
FIND_PROC( glUniformMatrix2x3fv );
|
||||
FIND_PROC( glUniformMatrix3x2fv );
|
||||
FIND_PROC( glUniformMatrix2x4fv );
|
||||
FIND_PROC( glUniformMatrix4x2fv );
|
||||
FIND_PROC( glUniformMatrix3x4fv );
|
||||
FIND_PROC( glUniformMatrix4x3fv );
|
||||
FIND_PROC( glBlitFramebuffer );
|
||||
FIND_PROC( glRenderbufferStorageMultisample );
|
||||
FIND_PROC( glFramebufferTextureLayer );
|
||||
FIND_PROC( glMapBufferRange );
|
||||
FIND_PROC( glFlushMappedBufferRange );
|
||||
FIND_PROC( glBindVertexArray );
|
||||
FIND_PROC( glDeleteVertexArrays );
|
||||
FIND_PROC( glGenVertexArrays );
|
||||
FIND_PROC( glIsVertexArray );
|
||||
FIND_PROC( glGetIntegeri_v );
|
||||
FIND_PROC( glBeginTransformFeedback );
|
||||
FIND_PROC( glEndTransformFeedback );
|
||||
FIND_PROC( glBindBufferRange );
|
||||
FIND_PROC( glBindBufferBase );
|
||||
FIND_PROC( glTransformFeedbackVaryings );
|
||||
FIND_PROC( glGetTransformFeedbackVarying );
|
||||
FIND_PROC( glVertexAttribIPointer );
|
||||
FIND_PROC( glGetVertexAttribIiv );
|
||||
FIND_PROC( glGetVertexAttribIuiv );
|
||||
FIND_PROC( glVertexAttribI4i );
|
||||
FIND_PROC( glVertexAttribI4ui );
|
||||
FIND_PROC( glVertexAttribI4iv );
|
||||
FIND_PROC( glVertexAttribI4uiv );
|
||||
FIND_PROC( glGetUniformuiv );
|
||||
FIND_PROC( glGetFragDataLocation );
|
||||
FIND_PROC( glUniform1ui );
|
||||
FIND_PROC( glUniform2ui );
|
||||
FIND_PROC( glUniform3ui );
|
||||
FIND_PROC( glUniform4ui );
|
||||
FIND_PROC( glUniform1uiv );
|
||||
FIND_PROC( glUniform2uiv );
|
||||
FIND_PROC( glUniform3uiv );
|
||||
FIND_PROC( glUniform4uiv );
|
||||
FIND_PROC( glClearBufferiv );
|
||||
FIND_PROC( glClearBufferuiv );
|
||||
FIND_PROC( glClearBufferfv );
|
||||
FIND_PROC( glClearBufferfi );
|
||||
FIND_PROC( glGetStringi );
|
||||
FIND_PROC( glCopyBufferSubData );
|
||||
FIND_PROC( glGetUniformIndices );
|
||||
FIND_PROC( glGetActiveUniformsiv );
|
||||
FIND_PROC( glGetUniformBlockIndex );
|
||||
FIND_PROC( glGetActiveUniformBlockiv );
|
||||
FIND_PROC( glGetActiveUniformBlockName );
|
||||
FIND_PROC( glUniformBlockBinding );
|
||||
FIND_PROC( glDrawArraysInstanced );
|
||||
FIND_PROC( glDrawElementsInstanced );
|
||||
FIND_PROC( glFenceSync );
|
||||
FIND_PROC( glIsSync );
|
||||
FIND_PROC( glDeleteSync );
|
||||
FIND_PROC( glClientWaitSync );
|
||||
FIND_PROC( glWaitSync );
|
||||
FIND_PROC( glGetInteger64v );
|
||||
FIND_PROC( glGetSynciv );
|
||||
FIND_PROC( glGetInteger64i_v );
|
||||
FIND_PROC( glGetBufferParameteri64v );
|
||||
FIND_PROC( glGenSamplers );
|
||||
FIND_PROC( glDeleteSamplers );
|
||||
FIND_PROC( glIsSampler );
|
||||
FIND_PROC( glBindSampler );
|
||||
FIND_PROC( glSamplerParameteri );
|
||||
FIND_PROC( glSamplerParameteriv );
|
||||
FIND_PROC( glSamplerParameterf );
|
||||
FIND_PROC( glSamplerParameterfv );
|
||||
FIND_PROC( glGetSamplerParameteriv );
|
||||
FIND_PROC( glGetSamplerParameterfv );
|
||||
FIND_PROC( glVertexAttribDivisor );
|
||||
FIND_PROC( glBindTransformFeedback );
|
||||
FIND_PROC( glDeleteTransformFeedbacks );
|
||||
FIND_PROC( glGenTransformFeedbacks );
|
||||
FIND_PROC( glIsTransformFeedback );
|
||||
FIND_PROC( glPauseTransformFeedback );
|
||||
FIND_PROC( glResumeTransformFeedback );
|
||||
FIND_PROC( glGetProgramBinary );
|
||||
FIND_PROC( glProgramBinary );
|
||||
FIND_PROC( glProgramParameteri );
|
||||
FIND_PROC( glInvalidateFramebuffer );
|
||||
FIND_PROC( glInvalidateSubFramebuffer );
|
||||
FIND_PROC( glTexStorage2D );
|
||||
FIND_PROC( glTexStorage3D );
|
||||
FIND_PROC( glGetInternalformativ );
|
||||
#undef FIND_PROC
|
||||
|
||||
if( !glReadBuffer || !glDrawRangeElements || !glTexImage3D || !glTexSubImage3D
|
||||
|| !glCopyTexSubImage3D || !glCompressedTexImage3D
|
||||
|| !glCompressedTexSubImage3D || !glGenQueries || !glDeleteQueries
|
||||
|| !glIsQuery || !glBeginQuery || !glEndQuery || !glGetQueryiv
|
||||
|| !glGetQueryObjectuiv || !glUnmapBuffer || !glGetBufferPointerv
|
||||
|| !glDrawBuffers || !glUniformMatrix2x3fv || !glUniformMatrix3x2fv
|
||||
|| !glUniformMatrix2x4fv || !glUniformMatrix4x2fv || !glUniformMatrix3x4fv
|
||||
|| !glUniformMatrix4x3fv || !glBlitFramebuffer
|
||||
|| !glRenderbufferStorageMultisample || !glFramebufferTextureLayer
|
||||
|| !glMapBufferRange || !glFlushMappedBufferRange || !glBindVertexArray
|
||||
|| !glDeleteVertexArrays || !glGenVertexArrays || !glIsVertexArray
|
||||
|| !glGetIntegeri_v || !glBeginTransformFeedback || !glEndTransformFeedback
|
||||
|| !glBindBufferRange || !glBindBufferBase || !glTransformFeedbackVaryings
|
||||
|| !glGetTransformFeedbackVarying || !glVertexAttribIPointer
|
||||
|| !glGetVertexAttribIiv || !glGetVertexAttribIuiv || !glVertexAttribI4i
|
||||
|| !glVertexAttribI4ui || !glVertexAttribI4iv || !glVertexAttribI4uiv
|
||||
|| !glGetUniformuiv || !glGetFragDataLocation || !glUniform1ui
|
||||
|| !glUniform2ui || !glUniform3ui || !glUniform4ui || !glUniform1uiv
|
||||
|| !glUniform2uiv || !glUniform3uiv || !glUniform4uiv || !glClearBufferiv
|
||||
|| !glClearBufferuiv || !glClearBufferfv || !glClearBufferfi || !glGetStringi
|
||||
|| !glCopyBufferSubData || !glGetUniformIndices || !glGetActiveUniformsiv
|
||||
|| !glGetUniformBlockIndex || !glGetActiveUniformBlockiv
|
||||
|| !glGetActiveUniformBlockName || !glUniformBlockBinding
|
||||
|| !glDrawArraysInstanced || !glDrawElementsInstanced || !glFenceSync
|
||||
|| !glIsSync || !glDeleteSync || !glClientWaitSync || !glWaitSync
|
||||
|| !glGetInteger64v || !glGetSynciv || !glGetInteger64i_v
|
||||
|| !glGetBufferParameteri64v || !glGenSamplers || !glDeleteSamplers
|
||||
|| !glIsSampler || !glBindSampler || !glSamplerParameteri
|
||||
|| !glSamplerParameteriv || !glSamplerParameterf || !glSamplerParameterfv
|
||||
|| !glGetSamplerParameteriv || !glGetSamplerParameterfv
|
||||
|| !glVertexAttribDivisor || !glBindTransformFeedback
|
||||
|| !glDeleteTransformFeedbacks || !glGenTransformFeedbacks
|
||||
|| !glIsTransformFeedback || !glPauseTransformFeedback
|
||||
|| !glResumeTransformFeedback || !glGetProgramBinary || !glProgramBinary
|
||||
|| !glProgramParameteri || !glInvalidateFramebuffer
|
||||
|| !glInvalidateSubFramebuffer || !glTexStorage2D || !glTexStorage3D
|
||||
|| !glGetInternalformativ )
|
||||
{
|
||||
return GL_FALSE;
|
||||
}
|
||||
|
||||
return GL_TRUE;
|
||||
}
|
||||
|
||||
/* Function pointer definitions */GL_APICALL void (* GL_APIENTRY glReadBuffer)( GLenum mode );
|
||||
GL_APICALL void (* GL_APIENTRY glDrawRangeElements)( GLenum mode,
|
||||
GLuint start,
|
||||
GLuint end,
|
||||
GLsizei count,
|
||||
GLenum type,
|
||||
const GLvoid* indices );
|
||||
GL_APICALL void (* GL_APIENTRY glTexImage3D)( GLenum target,
|
||||
GLint level,
|
||||
GLint internalformat,
|
||||
GLsizei width,
|
||||
GLsizei height,
|
||||
GLsizei depth,
|
||||
GLint border,
|
||||
GLenum format,
|
||||
GLenum type,
|
||||
const GLvoid* pixels );
|
||||
GL_APICALL void (* GL_APIENTRY glTexSubImage3D)( GLenum target,
|
||||
GLint level,
|
||||
GLint xoffset,
|
||||
GLint yoffset,
|
||||
GLint zoffset,
|
||||
GLsizei width,
|
||||
GLsizei height,
|
||||
GLsizei depth,
|
||||
GLenum format,
|
||||
GLenum type,
|
||||
const GLvoid* pixels );
|
||||
GL_APICALL void (* GL_APIENTRY glCopyTexSubImage3D)( GLenum target,
|
||||
GLint level,
|
||||
GLint xoffset,
|
||||
GLint yoffset,
|
||||
GLint zoffset,
|
||||
GLint x,
|
||||
GLint y,
|
||||
GLsizei width,
|
||||
GLsizei height );
|
||||
GL_APICALL void (* GL_APIENTRY glCompressedTexImage3D)( GLenum target,
|
||||
GLint level,
|
||||
GLenum internalformat,
|
||||
GLsizei width,
|
||||
GLsizei height,
|
||||
GLsizei depth,
|
||||
GLint border,
|
||||
GLsizei imageSize,
|
||||
const GLvoid* data );
|
||||
GL_APICALL void (* GL_APIENTRY glCompressedTexSubImage3D)( GLenum target,
|
||||
GLint level,
|
||||
GLint xoffset,
|
||||
GLint yoffset,
|
||||
GLint zoffset,
|
||||
GLsizei width,
|
||||
GLsizei height,
|
||||
GLsizei depth,
|
||||
GLenum format,
|
||||
GLsizei imageSize,
|
||||
const GLvoid* data );
|
||||
GL_APICALL void (* GL_APIENTRY glGenQueries)( GLsizei n, GLuint* ids );
|
||||
GL_APICALL void (* GL_APIENTRY glDeleteQueries)( GLsizei n, const GLuint* ids );
|
||||
GL_APICALL GLboolean (* GL_APIENTRY glIsQuery)( GLuint id );
|
||||
GL_APICALL void (* GL_APIENTRY glBeginQuery)( GLenum target, GLuint id );
|
||||
GL_APICALL void (* GL_APIENTRY glEndQuery)( GLenum target );
|
||||
GL_APICALL void (* GL_APIENTRY glGetQueryiv)( GLenum target, GLenum pname, GLint* params );
|
||||
GL_APICALL void (* GL_APIENTRY glGetQueryObjectuiv)( GLuint id,
|
||||
GLenum pname,
|
||||
GLuint* params );
|
||||
GL_APICALL GLboolean (* GL_APIENTRY glUnmapBuffer)( GLenum target );
|
||||
GL_APICALL void (* GL_APIENTRY glGetBufferPointerv)( GLenum target,
|
||||
GLenum pname,
|
||||
GLvoid** params );
|
||||
GL_APICALL void (* GL_APIENTRY glDrawBuffers)( GLsizei n, const GLenum* bufs );
|
||||
GL_APICALL void (* GL_APIENTRY glUniformMatrix2x3fv)( GLint location,
|
||||
GLsizei count,
|
||||
GLboolean transpose,
|
||||
const GLfloat* value );
|
||||
GL_APICALL void (* GL_APIENTRY glUniformMatrix3x2fv)( GLint location,
|
||||
GLsizei count,
|
||||
GLboolean transpose,
|
||||
const GLfloat* value );
|
||||
GL_APICALL void (* GL_APIENTRY glUniformMatrix2x4fv)( GLint location,
|
||||
GLsizei count,
|
||||
GLboolean transpose,
|
||||
const GLfloat* value );
|
||||
GL_APICALL void (* GL_APIENTRY glUniformMatrix4x2fv)( GLint location,
|
||||
GLsizei count,
|
||||
GLboolean transpose,
|
||||
const GLfloat* value );
|
||||
GL_APICALL void (* GL_APIENTRY glUniformMatrix3x4fv)( GLint location,
|
||||
GLsizei count,
|
||||
GLboolean transpose,
|
||||
const GLfloat* value );
|
||||
GL_APICALL void (* GL_APIENTRY glUniformMatrix4x3fv)( GLint location,
|
||||
GLsizei count,
|
||||
GLboolean transpose,
|
||||
const GLfloat* value );
|
||||
GL_APICALL void (* GL_APIENTRY glBlitFramebuffer)( GLint srcX0,
|
||||
GLint srcY0,
|
||||
GLint srcX1,
|
||||
GLint srcY1,
|
||||
GLint dstX0,
|
||||
GLint dstY0,
|
||||
GLint dstX1,
|
||||
GLint dstY1,
|
||||
GLbitfield mask,
|
||||
GLenum filter );
|
||||
GL_APICALL void (* GL_APIENTRY glRenderbufferStorageMultisample)( GLenum target,
|
||||
GLsizei samples,
|
||||
GLenum internalformat,
|
||||
GLsizei width,
|
||||
GLsizei height );
|
||||
GL_APICALL void (* GL_APIENTRY glFramebufferTextureLayer)( GLenum target,
|
||||
GLenum attachment,
|
||||
GLuint texture,
|
||||
GLint level,
|
||||
GLint layer );
|
||||
GL_APICALL GLvoid* (* GL_APIENTRY glMapBufferRange)( GLenum target,
|
||||
GLintptr offset,
|
||||
GLsizeiptr length,
|
||||
GLbitfield access );
|
||||
GL_APICALL void (* GL_APIENTRY glFlushMappedBufferRange)( GLenum target,
|
||||
GLintptr offset,
|
||||
GLsizeiptr length );
|
||||
GL_APICALL void (* GL_APIENTRY glBindVertexArray)( GLuint array );
|
||||
GL_APICALL void (* GL_APIENTRY glDeleteVertexArrays)( GLsizei n, const GLuint* arrays );
|
||||
GL_APICALL void (* GL_APIENTRY glGenVertexArrays)( GLsizei n, GLuint* arrays );
|
||||
GL_APICALL GLboolean (* GL_APIENTRY glIsVertexArray)( GLuint array );
|
||||
GL_APICALL void (* GL_APIENTRY glGetIntegeri_v)( GLenum target,
|
||||
GLuint index,
|
||||
GLint* data );
|
||||
GL_APICALL void (* GL_APIENTRY glBeginTransformFeedback)( GLenum primitiveMode );
|
||||
GL_APICALL void (* GL_APIENTRY glEndTransformFeedback)( void );
|
||||
GL_APICALL void (* GL_APIENTRY glBindBufferRange)( GLenum target,
|
||||
GLuint index,
|
||||
GLuint buffer,
|
||||
GLintptr offset,
|
||||
GLsizeiptr size );
|
||||
GL_APICALL void (* GL_APIENTRY glBindBufferBase)( GLenum target,
|
||||
GLuint index,
|
||||
GLuint buffer );
|
||||
GL_APICALL void (* GL_APIENTRY glTransformFeedbackVaryings)( GLuint program,
|
||||
GLsizei count,
|
||||
const GLchar* const * varyings,
|
||||
GLenum bufferMode );
|
||||
GL_APICALL void (* GL_APIENTRY glGetTransformFeedbackVarying)( GLuint program,
|
||||
GLuint index,
|
||||
GLsizei bufSize,
|
||||
GLsizei* length,
|
||||
GLsizei* size,
|
||||
GLenum* type,
|
||||
GLchar* name );
|
||||
GL_APICALL void (* GL_APIENTRY glVertexAttribIPointer)( GLuint index,
|
||||
GLint size,
|
||||
GLenum type,
|
||||
GLsizei stride,
|
||||
const GLvoid* pointer );
|
||||
GL_APICALL void (* GL_APIENTRY glGetVertexAttribIiv)( GLuint index,
|
||||
GLenum pname,
|
||||
GLint* params );
|
||||
GL_APICALL void (* GL_APIENTRY glGetVertexAttribIuiv)( GLuint index,
|
||||
GLenum pname,
|
||||
GLuint* params );
|
||||
GL_APICALL void (* GL_APIENTRY glVertexAttribI4i)( GLuint index,
|
||||
GLint x,
|
||||
GLint y,
|
||||
GLint z,
|
||||
GLint w );
|
||||
GL_APICALL void (* GL_APIENTRY glVertexAttribI4ui)( GLuint index,
|
||||
GLuint x,
|
||||
GLuint y,
|
||||
GLuint z,
|
||||
GLuint w );
|
||||
GL_APICALL void (* GL_APIENTRY glVertexAttribI4iv)( GLuint index, const GLint* v );
|
||||
GL_APICALL void (* GL_APIENTRY glVertexAttribI4uiv)( GLuint index, const GLuint* v );
|
||||
GL_APICALL void (* GL_APIENTRY glGetUniformuiv)( GLuint program,
|
||||
GLint location,
|
||||
GLuint* params );
|
||||
GL_APICALL GLint (* GL_APIENTRY glGetFragDataLocation)( GLuint program,
|
||||
const GLchar *name );
|
||||
GL_APICALL void (* GL_APIENTRY glUniform1ui)( GLint location, GLuint v0 );
|
||||
GL_APICALL void (* GL_APIENTRY glUniform2ui)( GLint location, GLuint v0, GLuint v1 );
|
||||
GL_APICALL void (* GL_APIENTRY glUniform3ui)( GLint location,
|
||||
GLuint v0,
|
||||
GLuint v1,
|
||||
GLuint v2 );
|
||||
GL_APICALL void (* GL_APIENTRY glUniform4ui)( GLint location,
|
||||
GLuint v0,
|
||||
GLuint v1,
|
||||
GLuint v2,
|
||||
GLuint v3 );
|
||||
GL_APICALL void (* GL_APIENTRY glUniform1uiv)( GLint location,
|
||||
GLsizei count,
|
||||
const GLuint* value );
|
||||
GL_APICALL void (* GL_APIENTRY glUniform2uiv)( GLint location,
|
||||
GLsizei count,
|
||||
const GLuint* value );
|
||||
GL_APICALL void (* GL_APIENTRY glUniform3uiv)( GLint location,
|
||||
GLsizei count,
|
||||
const GLuint* value );
|
||||
GL_APICALL void (* GL_APIENTRY glUniform4uiv)( GLint location,
|
||||
GLsizei count,
|
||||
const GLuint* value );
|
||||
GL_APICALL void (* GL_APIENTRY glClearBufferiv)( GLenum buffer,
|
||||
GLint drawbuffer,
|
||||
const GLint* value );
|
||||
GL_APICALL void (* GL_APIENTRY glClearBufferuiv)( GLenum buffer,
|
||||
GLint drawbuffer,
|
||||
const GLuint* value );
|
||||
GL_APICALL void (* GL_APIENTRY glClearBufferfv)( GLenum buffer,
|
||||
GLint drawbuffer,
|
||||
const GLfloat* value );
|
||||
GL_APICALL void (* GL_APIENTRY glClearBufferfi)( GLenum buffer,
|
||||
GLint drawbuffer,
|
||||
GLfloat depth,
|
||||
GLint stencil );
|
||||
GL_APICALL const GLubyte* (* GL_APIENTRY glGetStringi)( GLenum name, GLuint index );
|
||||
GL_APICALL void (* GL_APIENTRY glCopyBufferSubData)( GLenum readTarget,
|
||||
GLenum writeTarget,
|
||||
GLintptr readOffset,
|
||||
GLintptr writeOffset,
|
||||
GLsizeiptr size );
|
||||
GL_APICALL void (* GL_APIENTRY glGetUniformIndices)( GLuint program,
|
||||
GLsizei uniformCount,
|
||||
const GLchar* const * uniformNames,
|
||||
GLuint* uniformIndices );
|
||||
GL_APICALL void (* GL_APIENTRY glGetActiveUniformsiv)( GLuint program,
|
||||
GLsizei uniformCount,
|
||||
const GLuint* uniformIndices,
|
||||
GLenum pname,
|
||||
GLint* params );
|
||||
GL_APICALL GLuint (* GL_APIENTRY glGetUniformBlockIndex)( GLuint program,
|
||||
const GLchar* uniformBlockName );
|
||||
GL_APICALL void (* GL_APIENTRY glGetActiveUniformBlockiv)( GLuint program,
|
||||
GLuint uniformBlockIndex,
|
||||
GLenum pname,
|
||||
GLint* params );
|
||||
GL_APICALL void (* GL_APIENTRY glGetActiveUniformBlockName)( GLuint program,
|
||||
GLuint uniformBlockIndex,
|
||||
GLsizei bufSize,
|
||||
GLsizei* length,
|
||||
GLchar* uniformBlockName );
|
||||
GL_APICALL void (* GL_APIENTRY glUniformBlockBinding)( GLuint program,
|
||||
GLuint uniformBlockIndex,
|
||||
GLuint uniformBlockBinding );
|
||||
GL_APICALL void (* GL_APIENTRY glDrawArraysInstanced)( GLenum mode,
|
||||
GLint first,
|
||||
GLsizei count,
|
||||
GLsizei instanceCount );
|
||||
GL_APICALL void (* GL_APIENTRY glDrawElementsInstanced)( GLenum mode,
|
||||
GLsizei count,
|
||||
GLenum type,
|
||||
const GLvoid* indices,
|
||||
GLsizei instanceCount );
|
||||
GL_APICALL GLsync (* GL_APIENTRY glFenceSync)( GLenum condition, GLbitfield flags );
|
||||
GL_APICALL GLboolean (* GL_APIENTRY glIsSync)( GLsync sync );
|
||||
GL_APICALL void (* GL_APIENTRY glDeleteSync)( GLsync sync );
|
||||
GL_APICALL GLenum (* GL_APIENTRY glClientWaitSync)( GLsync sync,
|
||||
GLbitfield flags,
|
||||
GLuint64 timeout );
|
||||
GL_APICALL void (* GL_APIENTRY glWaitSync)( GLsync sync,
|
||||
GLbitfield flags,
|
||||
GLuint64 timeout );
|
||||
GL_APICALL void (* GL_APIENTRY glGetInteger64v)( GLenum pname, GLint64* params );
|
||||
GL_APICALL void (* GL_APIENTRY glGetSynciv)( GLsync sync,
|
||||
GLenum pname,
|
||||
GLsizei bufSize,
|
||||
GLsizei* length,
|
||||
GLint* values );
|
||||
GL_APICALL void (* GL_APIENTRY glGetInteger64i_v)( GLenum target,
|
||||
GLuint index,
|
||||
GLint64* data );
|
||||
GL_APICALL void (* GL_APIENTRY glGetBufferParameteri64v)( GLenum target,
|
||||
GLenum pname,
|
||||
GLint64* params );
|
||||
GL_APICALL void (* GL_APIENTRY glGenSamplers)( GLsizei count, GLuint* samplers );
|
||||
GL_APICALL void (* GL_APIENTRY glDeleteSamplers)( GLsizei count, const GLuint* samplers );
|
||||
GL_APICALL GLboolean (* GL_APIENTRY glIsSampler)( GLuint sampler );
|
||||
GL_APICALL void (* GL_APIENTRY glBindSampler)( GLuint unit, GLuint sampler );
|
||||
GL_APICALL void (* GL_APIENTRY glSamplerParameteri)( GLuint sampler,
|
||||
GLenum pname,
|
||||
GLint param );
|
||||
GL_APICALL void (* GL_APIENTRY glSamplerParameteriv)( GLuint sampler,
|
||||
GLenum pname,
|
||||
const GLint* param );
|
||||
GL_APICALL void (* GL_APIENTRY glSamplerParameterf)( GLuint sampler,
|
||||
GLenum pname,
|
||||
GLfloat param );
|
||||
GL_APICALL void (* GL_APIENTRY glSamplerParameterfv)( GLuint sampler,
|
||||
GLenum pname,
|
||||
const GLfloat* param );
|
||||
GL_APICALL void (* GL_APIENTRY glGetSamplerParameteriv)( GLuint sampler,
|
||||
GLenum pname,
|
||||
GLint* params );
|
||||
GL_APICALL void (* GL_APIENTRY glGetSamplerParameterfv)( GLuint sampler,
|
||||
GLenum pname,
|
||||
GLfloat* params );
|
||||
GL_APICALL void (* GL_APIENTRY glVertexAttribDivisor)( GLuint index, GLuint divisor );
|
||||
GL_APICALL void (* GL_APIENTRY glBindTransformFeedback)( GLenum target, GLuint id );
|
||||
GL_APICALL void (* GL_APIENTRY glDeleteTransformFeedbacks)( GLsizei n, const GLuint* ids );
|
||||
GL_APICALL void (* GL_APIENTRY glGenTransformFeedbacks)( GLsizei n, GLuint* ids );
|
||||
GL_APICALL GLboolean (* GL_APIENTRY glIsTransformFeedback)( GLuint id );
|
||||
GL_APICALL void (* GL_APIENTRY glPauseTransformFeedback)( void );
|
||||
GL_APICALL void (* GL_APIENTRY glResumeTransformFeedback)( void );
|
||||
GL_APICALL void (* GL_APIENTRY glGetProgramBinary)( GLuint program,
|
||||
GLsizei bufSize,
|
||||
GLsizei* length,
|
||||
GLenum* binaryFormat,
|
||||
GLvoid* binary );
|
||||
GL_APICALL void (* GL_APIENTRY glProgramBinary)( GLuint program,
|
||||
GLenum binaryFormat,
|
||||
const GLvoid* binary,
|
||||
GLsizei length );
|
||||
GL_APICALL void (* GL_APIENTRY glProgramParameteri)( GLuint program,
|
||||
GLenum pname,
|
||||
GLint value );
|
||||
GL_APICALL void (* GL_APIENTRY glInvalidateFramebuffer)( GLenum target,
|
||||
GLsizei numAttachments,
|
||||
const GLenum* attachments );
|
||||
GL_APICALL void (* GL_APIENTRY glInvalidateSubFramebuffer)( GLenum target,
|
||||
GLsizei numAttachments,
|
||||
const GLenum* attachments,
|
||||
GLint x,
|
||||
GLint y,
|
||||
GLsizei width,
|
||||
GLsizei height );
|
||||
GL_APICALL void (* GL_APIENTRY glTexStorage2D)( GLenum target,
|
||||
GLsizei levels,
|
||||
GLenum internalformat,
|
||||
GLsizei width,
|
||||
GLsizei height );
|
||||
GL_APICALL void (* GL_APIENTRY glTexStorage3D)( GLenum target,
|
||||
GLsizei levels,
|
||||
GLenum internalformat,
|
||||
GLsizei width,
|
||||
GLsizei height,
|
||||
GLsizei depth );
|
||||
GL_APICALL void (* GL_APIENTRY glGetInternalformativ)( GLenum target,
|
||||
GLenum internalformat,
|
||||
GLenum pname,
|
||||
GLsizei bufSize,
|
||||
GLint* params );
|
||||
663
MoreTeapots/app/src/main/cpp/ndk_helper/gl3stub.h
Normal file
@@ -0,0 +1,663 @@
|
||||
#ifndef __gl3_h_
|
||||
#define __gl3_h_
|
||||
|
||||
/*
|
||||
* stub gl3.h for dynamic loading, based on:
|
||||
* gl3.h last updated on $Date: 2013-02-12 14:37:24 -0800 (Tue, 12 Feb 2013) $
|
||||
*
|
||||
* Changes:
|
||||
* - Added #include <GLES2/gl2.h>
|
||||
* - Removed duplicate OpenGL ES 2.0 declarations
|
||||
* - Converted OpenGL ES 3.0 function prototypes to function pointer
|
||||
* declarations
|
||||
* - Added gl3stubInit() declaration
|
||||
*/
|
||||
|
||||
#include <GLES2/gl2.h>
|
||||
#include <android/api-level.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
/*
|
||||
** Copyright (c) 2007-2013 The Khronos Group Inc.
|
||||
**
|
||||
** Permission is hereby granted, free of charge, to any person obtaining a
|
||||
** copy of this software and/or associated documentation files (the
|
||||
** "Materials"), to deal in the Materials without restriction, including
|
||||
** without limitation the rights to use, copy, modify, merge, publish,
|
||||
** distribute, sublicense, and/or sell copies of the Materials, and to
|
||||
** permit persons to whom the Materials are furnished to do so, subject to
|
||||
** the following conditions:
|
||||
**
|
||||
** The above copyright notice and this permission notice shall be included
|
||||
** in all copies or substantial portions of the Materials.
|
||||
**
|
||||
** THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||
** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||
** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
||||
** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
||||
** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
||||
** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||
** MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.
|
||||
*/
|
||||
|
||||
/*
|
||||
* This files is for apps that want to use ES3 if present,
|
||||
* but continue to work on pre-API-18 devices. They can't just link to -lGLESv3
|
||||
*since
|
||||
* that library doesn't exist on pre-API-18 devices.
|
||||
* The function dynamically check if OpenGLES3.0 APIs are present and fill in if
|
||||
*there are.
|
||||
* Also the header defines some extra variables for OpenGLES3.0.
|
||||
*
|
||||
*/
|
||||
|
||||
/* Call this function before calling any OpenGL ES 3.0 functions. It will
|
||||
* return GL_TRUE if the OpenGL ES 3.0 was successfully initialized, GL_FALSE
|
||||
* otherwise. */
|
||||
GLboolean gl3stubInit();
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Data type definitions
|
||||
*-----------------------------------------------------------------------*/
|
||||
|
||||
/* OpenGL ES 3.0 */
|
||||
|
||||
typedef unsigned short GLhalf;
|
||||
#if __ANDROID_API__ <= 19
|
||||
typedef khronos_int64_t GLint64;
|
||||
typedef khronos_uint64_t GLuint64;
|
||||
typedef struct __GLsync* GLsync;
|
||||
#endif
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Token definitions
|
||||
*-----------------------------------------------------------------------*/
|
||||
|
||||
/* OpenGL ES core versions */
|
||||
#define GL_ES_VERSION_3_0 1
|
||||
|
||||
/* OpenGL ES 3.0 */
|
||||
|
||||
#define GL_READ_BUFFER 0x0C02
|
||||
#define GL_UNPACK_ROW_LENGTH 0x0CF2
|
||||
#define GL_UNPACK_SKIP_ROWS 0x0CF3
|
||||
#define GL_UNPACK_SKIP_PIXELS 0x0CF4
|
||||
#define GL_PACK_ROW_LENGTH 0x0D02
|
||||
#define GL_PACK_SKIP_ROWS 0x0D03
|
||||
#define GL_PACK_SKIP_PIXELS 0x0D04
|
||||
#define GL_COLOR 0x1800
|
||||
#define GL_DEPTH 0x1801
|
||||
#define GL_STENCIL 0x1802
|
||||
#define GL_RED 0x1903
|
||||
#define GL_RGB8 0x8051
|
||||
#define GL_RGBA8 0x8058
|
||||
#define GL_RGB10_A2 0x8059
|
||||
#define GL_TEXTURE_BINDING_3D 0x806A
|
||||
#define GL_UNPACK_SKIP_IMAGES 0x806D
|
||||
#define GL_UNPACK_IMAGE_HEIGHT 0x806E
|
||||
#define GL_TEXTURE_3D 0x806F
|
||||
#define GL_TEXTURE_WRAP_R 0x8072
|
||||
#define GL_MAX_3D_TEXTURE_SIZE 0x8073
|
||||
#define GL_UNSIGNED_INT_2_10_10_10_REV 0x8368
|
||||
#define GL_MAX_ELEMENTS_VERTICES 0x80E8
|
||||
#define GL_MAX_ELEMENTS_INDICES 0x80E9
|
||||
#define GL_TEXTURE_MIN_LOD 0x813A
|
||||
#define GL_TEXTURE_MAX_LOD 0x813B
|
||||
#define GL_TEXTURE_BASE_LEVEL 0x813C
|
||||
#define GL_TEXTURE_MAX_LEVEL 0x813D
|
||||
#define GL_MIN 0x8007
|
||||
#define GL_MAX 0x8008
|
||||
#define GL_DEPTH_COMPONENT24 0x81A6
|
||||
#define GL_MAX_TEXTURE_LOD_BIAS 0x84FD
|
||||
#define GL_TEXTURE_COMPARE_MODE 0x884C
|
||||
#define GL_TEXTURE_COMPARE_FUNC 0x884D
|
||||
#define GL_CURRENT_QUERY 0x8865
|
||||
#define GL_QUERY_RESULT 0x8866
|
||||
#define GL_QUERY_RESULT_AVAILABLE 0x8867
|
||||
#define GL_BUFFER_MAPPED 0x88BC
|
||||
#define GL_BUFFER_MAP_POINTER 0x88BD
|
||||
#define GL_STREAM_READ 0x88E1
|
||||
#define GL_STREAM_COPY 0x88E2
|
||||
#define GL_STATIC_READ 0x88E5
|
||||
#define GL_STATIC_COPY 0x88E6
|
||||
#define GL_DYNAMIC_READ 0x88E9
|
||||
#define GL_DYNAMIC_COPY 0x88EA
|
||||
#define GL_MAX_DRAW_BUFFERS 0x8824
|
||||
#define GL_DRAW_BUFFER0 0x8825
|
||||
#define GL_DRAW_BUFFER1 0x8826
|
||||
#define GL_DRAW_BUFFER2 0x8827
|
||||
#define GL_DRAW_BUFFER3 0x8828
|
||||
#define GL_DRAW_BUFFER4 0x8829
|
||||
#define GL_DRAW_BUFFER5 0x882A
|
||||
#define GL_DRAW_BUFFER6 0x882B
|
||||
#define GL_DRAW_BUFFER7 0x882C
|
||||
#define GL_DRAW_BUFFER8 0x882D
|
||||
#define GL_DRAW_BUFFER9 0x882E
|
||||
#define GL_DRAW_BUFFER10 0x882F
|
||||
#define GL_DRAW_BUFFER11 0x8830
|
||||
#define GL_DRAW_BUFFER12 0x8831
|
||||
#define GL_DRAW_BUFFER13 0x8832
|
||||
#define GL_DRAW_BUFFER14 0x8833
|
||||
#define GL_DRAW_BUFFER15 0x8834
|
||||
#define GL_MAX_FRAGMENT_UNIFORM_COMPONENTS 0x8B49
|
||||
#define GL_MAX_VERTEX_UNIFORM_COMPONENTS 0x8B4A
|
||||
#define GL_SAMPLER_3D 0x8B5F
|
||||
#define GL_SAMPLER_2D_SHADOW 0x8B62
|
||||
#define GL_FRAGMENT_SHADER_DERIVATIVE_HINT 0x8B8B
|
||||
#define GL_PIXEL_PACK_BUFFER 0x88EB
|
||||
#define GL_PIXEL_UNPACK_BUFFER 0x88EC
|
||||
#define GL_PIXEL_PACK_BUFFER_BINDING 0x88ED
|
||||
#define GL_PIXEL_UNPACK_BUFFER_BINDING 0x88EF
|
||||
#define GL_FLOAT_MAT2x3 0x8B65
|
||||
#define GL_FLOAT_MAT2x4 0x8B66
|
||||
#define GL_FLOAT_MAT3x2 0x8B67
|
||||
#define GL_FLOAT_MAT3x4 0x8B68
|
||||
#define GL_FLOAT_MAT4x2 0x8B69
|
||||
#define GL_FLOAT_MAT4x3 0x8B6A
|
||||
#define GL_SRGB 0x8C40
|
||||
#define GL_SRGB8 0x8C41
|
||||
#define GL_SRGB8_ALPHA8 0x8C43
|
||||
#define GL_COMPARE_REF_TO_TEXTURE 0x884E
|
||||
#define GL_MAJOR_VERSION 0x821B
|
||||
#define GL_MINOR_VERSION 0x821C
|
||||
#define GL_NUM_EXTENSIONS 0x821D
|
||||
#define GL_RGBA32F 0x8814
|
||||
#define GL_RGB32F 0x8815
|
||||
#define GL_RGBA16F 0x881A
|
||||
#define GL_RGB16F 0x881B
|
||||
#define GL_VERTEX_ATTRIB_ARRAY_INTEGER 0x88FD
|
||||
#define GL_MAX_ARRAY_TEXTURE_LAYERS 0x88FF
|
||||
#define GL_MIN_PROGRAM_TEXEL_OFFSET 0x8904
|
||||
#define GL_MAX_PROGRAM_TEXEL_OFFSET 0x8905
|
||||
#define GL_MAX_VARYING_COMPONENTS 0x8B4B
|
||||
#define GL_TEXTURE_2D_ARRAY 0x8C1A
|
||||
#define GL_TEXTURE_BINDING_2D_ARRAY 0x8C1D
|
||||
#define GL_R11F_G11F_B10F 0x8C3A
|
||||
#define GL_UNSIGNED_INT_10F_11F_11F_REV 0x8C3B
|
||||
#define GL_RGB9_E5 0x8C3D
|
||||
#define GL_UNSIGNED_INT_5_9_9_9_REV 0x8C3E
|
||||
#define GL_TRANSFORM_FEEDBACK_VARYING_MAX_LENGTH 0x8C76
|
||||
#define GL_TRANSFORM_FEEDBACK_BUFFER_MODE 0x8C7F
|
||||
#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS 0x8C80
|
||||
#define GL_TRANSFORM_FEEDBACK_VARYINGS 0x8C83
|
||||
#define GL_TRANSFORM_FEEDBACK_BUFFER_START 0x8C84
|
||||
#define GL_TRANSFORM_FEEDBACK_BUFFER_SIZE 0x8C85
|
||||
#define GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN 0x8C88
|
||||
#define GL_RASTERIZER_DISCARD 0x8C89
|
||||
#define GL_MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS 0x8C8A
|
||||
#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS 0x8C8B
|
||||
#define GL_INTERLEAVED_ATTRIBS 0x8C8C
|
||||
#define GL_SEPARATE_ATTRIBS 0x8C8D
|
||||
#define GL_TRANSFORM_FEEDBACK_BUFFER 0x8C8E
|
||||
#define GL_TRANSFORM_FEEDBACK_BUFFER_BINDING 0x8C8F
|
||||
#define GL_RGBA32UI 0x8D70
|
||||
#define GL_RGB32UI 0x8D71
|
||||
#define GL_RGBA16UI 0x8D76
|
||||
#define GL_RGB16UI 0x8D77
|
||||
#define GL_RGBA8UI 0x8D7C
|
||||
#define GL_RGB8UI 0x8D7D
|
||||
#define GL_RGBA32I 0x8D82
|
||||
#define GL_RGB32I 0x8D83
|
||||
#define GL_RGBA16I 0x8D88
|
||||
#define GL_RGB16I 0x8D89
|
||||
#define GL_RGBA8I 0x8D8E
|
||||
#define GL_RGB8I 0x8D8F
|
||||
#define GL_RED_INTEGER 0x8D94
|
||||
#define GL_RGB_INTEGER 0x8D98
|
||||
#define GL_RGBA_INTEGER 0x8D99
|
||||
#define GL_SAMPLER_2D_ARRAY 0x8DC1
|
||||
#define GL_SAMPLER_2D_ARRAY_SHADOW 0x8DC4
|
||||
#define GL_SAMPLER_CUBE_SHADOW 0x8DC5
|
||||
#define GL_UNSIGNED_INT_VEC2 0x8DC6
|
||||
#define GL_UNSIGNED_INT_VEC3 0x8DC7
|
||||
#define GL_UNSIGNED_INT_VEC4 0x8DC8
|
||||
#define GL_INT_SAMPLER_2D 0x8DCA
|
||||
#define GL_INT_SAMPLER_3D 0x8DCB
|
||||
#define GL_INT_SAMPLER_CUBE 0x8DCC
|
||||
#define GL_INT_SAMPLER_2D_ARRAY 0x8DCF
|
||||
#define GL_UNSIGNED_INT_SAMPLER_2D 0x8DD2
|
||||
#define GL_UNSIGNED_INT_SAMPLER_3D 0x8DD3
|
||||
#define GL_UNSIGNED_INT_SAMPLER_CUBE 0x8DD4
|
||||
#define GL_UNSIGNED_INT_SAMPLER_2D_ARRAY 0x8DD7
|
||||
#define GL_BUFFER_ACCESS_FLAGS 0x911F
|
||||
#define GL_BUFFER_MAP_LENGTH 0x9120
|
||||
#define GL_BUFFER_MAP_OFFSET 0x9121
|
||||
#define GL_DEPTH_COMPONENT32F 0x8CAC
|
||||
#define GL_DEPTH32F_STENCIL8 0x8CAD
|
||||
#define GL_FLOAT_32_UNSIGNED_INT_24_8_REV 0x8DAD
|
||||
#define GL_FRAMEBUFFER_ATTACHMENT_COLOR_ENCODING 0x8210
|
||||
#define GL_FRAMEBUFFER_ATTACHMENT_COMPONENT_TYPE 0x8211
|
||||
#define GL_FRAMEBUFFER_ATTACHMENT_RED_SIZE 0x8212
|
||||
#define GL_FRAMEBUFFER_ATTACHMENT_GREEN_SIZE 0x8213
|
||||
#define GL_FRAMEBUFFER_ATTACHMENT_BLUE_SIZE 0x8214
|
||||
#define GL_FRAMEBUFFER_ATTACHMENT_ALPHA_SIZE 0x8215
|
||||
#define GL_FRAMEBUFFER_ATTACHMENT_DEPTH_SIZE 0x8216
|
||||
#define GL_FRAMEBUFFER_ATTACHMENT_STENCIL_SIZE 0x8217
|
||||
#define GL_FRAMEBUFFER_DEFAULT 0x8218
|
||||
#define GL_FRAMEBUFFER_UNDEFINED 0x8219
|
||||
#define GL_DEPTH_STENCIL_ATTACHMENT 0x821A
|
||||
#define GL_DEPTH_STENCIL 0x84F9
|
||||
#define GL_UNSIGNED_INT_24_8 0x84FA
|
||||
#define GL_DEPTH24_STENCIL8 0x88F0
|
||||
#define GL_UNSIGNED_NORMALIZED 0x8C17
|
||||
#define GL_DRAW_FRAMEBUFFER_BINDING GL_FRAMEBUFFER_BINDING
|
||||
#define GL_READ_FRAMEBUFFER 0x8CA8
|
||||
#define GL_DRAW_FRAMEBUFFER 0x8CA9
|
||||
#define GL_READ_FRAMEBUFFER_BINDING 0x8CAA
|
||||
#define GL_RENDERBUFFER_SAMPLES 0x8CAB
|
||||
#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER 0x8CD4
|
||||
#define GL_MAX_COLOR_ATTACHMENTS 0x8CDF
|
||||
#define GL_COLOR_ATTACHMENT1 0x8CE1
|
||||
#define GL_COLOR_ATTACHMENT2 0x8CE2
|
||||
#define GL_COLOR_ATTACHMENT3 0x8CE3
|
||||
#define GL_COLOR_ATTACHMENT4 0x8CE4
|
||||
#define GL_COLOR_ATTACHMENT5 0x8CE5
|
||||
#define GL_COLOR_ATTACHMENT6 0x8CE6
|
||||
#define GL_COLOR_ATTACHMENT7 0x8CE7
|
||||
#define GL_COLOR_ATTACHMENT8 0x8CE8
|
||||
#define GL_COLOR_ATTACHMENT9 0x8CE9
|
||||
#define GL_COLOR_ATTACHMENT10 0x8CEA
|
||||
#define GL_COLOR_ATTACHMENT11 0x8CEB
|
||||
#define GL_COLOR_ATTACHMENT12 0x8CEC
|
||||
#define GL_COLOR_ATTACHMENT13 0x8CED
|
||||
#define GL_COLOR_ATTACHMENT14 0x8CEE
|
||||
#define GL_COLOR_ATTACHMENT15 0x8CEF
|
||||
#define GL_FRAMEBUFFER_INCOMPLETE_MULTISAMPLE 0x8D56
|
||||
#define GL_MAX_SAMPLES 0x8D57
|
||||
#define GL_HALF_FLOAT 0x140B
|
||||
#define GL_MAP_READ_BIT 0x0001
|
||||
#define GL_MAP_WRITE_BIT 0x0002
|
||||
#define GL_MAP_INVALIDATE_RANGE_BIT 0x0004
|
||||
#define GL_MAP_INVALIDATE_BUFFER_BIT 0x0008
|
||||
#define GL_MAP_FLUSH_EXPLICIT_BIT 0x0010
|
||||
#define GL_MAP_UNSYNCHRONIZED_BIT 0x0020
|
||||
#define GL_RG 0x8227
|
||||
#define GL_RG_INTEGER 0x8228
|
||||
#define GL_R8 0x8229
|
||||
#define GL_RG8 0x822B
|
||||
#define GL_R16F 0x822D
|
||||
#define GL_R32F 0x822E
|
||||
#define GL_RG16F 0x822F
|
||||
#define GL_RG32F 0x8230
|
||||
#define GL_R8I 0x8231
|
||||
#define GL_R8UI 0x8232
|
||||
#define GL_R16I 0x8233
|
||||
#define GL_R16UI 0x8234
|
||||
#define GL_R32I 0x8235
|
||||
#define GL_R32UI 0x8236
|
||||
#define GL_RG8I 0x8237
|
||||
#define GL_RG8UI 0x8238
|
||||
#define GL_RG16I 0x8239
|
||||
#define GL_RG16UI 0x823A
|
||||
#define GL_RG32I 0x823B
|
||||
#define GL_RG32UI 0x823C
|
||||
#define GL_VERTEX_ARRAY_BINDING 0x85B5
|
||||
#define GL_R8_SNORM 0x8F94
|
||||
#define GL_RG8_SNORM 0x8F95
|
||||
#define GL_RGB8_SNORM 0x8F96
|
||||
#define GL_RGBA8_SNORM 0x8F97
|
||||
#define GL_SIGNED_NORMALIZED 0x8F9C
|
||||
#define GL_PRIMITIVE_RESTART_FIXED_INDEX 0x8D69
|
||||
#define GL_COPY_READ_BUFFER 0x8F36
|
||||
#define GL_COPY_WRITE_BUFFER 0x8F37
|
||||
#define GL_COPY_READ_BUFFER_BINDING GL_COPY_READ_BUFFER
|
||||
#define GL_COPY_WRITE_BUFFER_BINDING GL_COPY_WRITE_BUFFER
|
||||
#define GL_UNIFORM_BUFFER 0x8A11
|
||||
#define GL_UNIFORM_BUFFER_BINDING 0x8A28
|
||||
#define GL_UNIFORM_BUFFER_START 0x8A29
|
||||
#define GL_UNIFORM_BUFFER_SIZE 0x8A2A
|
||||
#define GL_MAX_VERTEX_UNIFORM_BLOCKS 0x8A2B
|
||||
#define GL_MAX_FRAGMENT_UNIFORM_BLOCKS 0x8A2D
|
||||
#define GL_MAX_COMBINED_UNIFORM_BLOCKS 0x8A2E
|
||||
#define GL_MAX_UNIFORM_BUFFER_BINDINGS 0x8A2F
|
||||
#define GL_MAX_UNIFORM_BLOCK_SIZE 0x8A30
|
||||
#define GL_MAX_COMBINED_VERTEX_UNIFORM_COMPONENTS 0x8A31
|
||||
#define GL_MAX_COMBINED_FRAGMENT_UNIFORM_COMPONENTS 0x8A33
|
||||
#define GL_UNIFORM_BUFFER_OFFSET_ALIGNMENT 0x8A34
|
||||
#define GL_ACTIVE_UNIFORM_BLOCK_MAX_NAME_LENGTH 0x8A35
|
||||
#define GL_ACTIVE_UNIFORM_BLOCKS 0x8A36
|
||||
#define GL_UNIFORM_TYPE 0x8A37
|
||||
#define GL_UNIFORM_SIZE 0x8A38
|
||||
#define GL_UNIFORM_NAME_LENGTH 0x8A39
|
||||
#define GL_UNIFORM_BLOCK_INDEX 0x8A3A
|
||||
#define GL_UNIFORM_OFFSET 0x8A3B
|
||||
#define GL_UNIFORM_ARRAY_STRIDE 0x8A3C
|
||||
#define GL_UNIFORM_MATRIX_STRIDE 0x8A3D
|
||||
#define GL_UNIFORM_IS_ROW_MAJOR 0x8A3E
|
||||
#define GL_UNIFORM_BLOCK_BINDING 0x8A3F
|
||||
#define GL_UNIFORM_BLOCK_DATA_SIZE 0x8A40
|
||||
#define GL_UNIFORM_BLOCK_NAME_LENGTH 0x8A41
|
||||
#define GL_UNIFORM_BLOCK_ACTIVE_UNIFORMS 0x8A42
|
||||
#define GL_UNIFORM_BLOCK_ACTIVE_UNIFORM_INDICES 0x8A43
|
||||
#define GL_UNIFORM_BLOCK_REFERENCED_BY_VERTEX_SHADER 0x8A44
|
||||
#define GL_UNIFORM_BLOCK_REFERENCED_BY_FRAGMENT_SHADER 0x8A46
|
||||
#define GL_INVALID_INDEX 0xFFFFFFFFu
|
||||
#define GL_MAX_VERTEX_OUTPUT_COMPONENTS 0x9122
|
||||
#define GL_MAX_FRAGMENT_INPUT_COMPONENTS 0x9125
|
||||
#define GL_MAX_SERVER_WAIT_TIMEOUT 0x9111
|
||||
#define GL_OBJECT_TYPE 0x9112
|
||||
#define GL_SYNC_CONDITION 0x9113
|
||||
#define GL_SYNC_STATUS 0x9114
|
||||
#define GL_SYNC_FLAGS 0x9115
|
||||
#define GL_SYNC_FENCE 0x9116
|
||||
#define GL_SYNC_GPU_COMMANDS_COMPLETE 0x9117
|
||||
#define GL_UNSIGNALED 0x9118
|
||||
#define GL_SIGNALED 0x9119
|
||||
#define GL_ALREADY_SIGNALED 0x911A
|
||||
#define GL_TIMEOUT_EXPIRED 0x911B
|
||||
#define GL_CONDITION_SATISFIED 0x911C
|
||||
#define GL_WAIT_FAILED 0x911D
|
||||
#define GL_SYNC_FLUSH_COMMANDS_BIT 0x00000001
|
||||
#define GL_TIMEOUT_IGNORED 0xFFFFFFFFFFFFFFFFull
|
||||
#define GL_VERTEX_ATTRIB_ARRAY_DIVISOR 0x88FE
|
||||
#define GL_ANY_SAMPLES_PASSED 0x8C2F
|
||||
#define GL_ANY_SAMPLES_PASSED_CONSERVATIVE 0x8D6A
|
||||
#define GL_SAMPLER_BINDING 0x8919
|
||||
#define GL_RGB10_A2UI 0x906F
|
||||
#define GL_TEXTURE_SWIZZLE_R 0x8E42
|
||||
#define GL_TEXTURE_SWIZZLE_G 0x8E43
|
||||
#define GL_TEXTURE_SWIZZLE_B 0x8E44
|
||||
#define GL_TEXTURE_SWIZZLE_A 0x8E45
|
||||
#define GL_GREEN 0x1904
|
||||
#define GL_BLUE 0x1905
|
||||
#define GL_INT_2_10_10_10_REV 0x8D9F
|
||||
#define GL_TRANSFORM_FEEDBACK 0x8E22
|
||||
#define GL_TRANSFORM_FEEDBACK_PAUSED 0x8E23
|
||||
#define GL_TRANSFORM_FEEDBACK_ACTIVE 0x8E24
|
||||
#define GL_TRANSFORM_FEEDBACK_BINDING 0x8E25
|
||||
#define GL_PROGRAM_BINARY_RETRIEVABLE_HINT 0x8257
|
||||
#define GL_PROGRAM_BINARY_LENGTH 0x8741
|
||||
#define GL_NUM_PROGRAM_BINARY_FORMATS 0x87FE
|
||||
#define GL_PROGRAM_BINARY_FORMATS 0x87FF
|
||||
#define GL_COMPRESSED_R11_EAC 0x9270
|
||||
#define GL_COMPRESSED_SIGNED_R11_EAC 0x9271
|
||||
#define GL_COMPRESSED_RG11_EAC 0x9272
|
||||
#define GL_COMPRESSED_SIGNED_RG11_EAC 0x9273
|
||||
#define GL_COMPRESSED_RGB8_ETC2 0x9274
|
||||
#define GL_COMPRESSED_SRGB8_ETC2 0x9275
|
||||
#define GL_COMPRESSED_RGB8_PUNCHTHROUGH_ALPHA1_ETC2 0x9276
|
||||
#define GL_COMPRESSED_SRGB8_PUNCHTHROUGH_ALPHA1_ETC2 0x9277
|
||||
#define GL_COMPRESSED_RGBA8_ETC2_EAC 0x9278
|
||||
#define GL_COMPRESSED_SRGB8_ALPHA8_ETC2_EAC 0x9279
|
||||
#define GL_TEXTURE_IMMUTABLE_FORMAT 0x912F
|
||||
#define GL_MAX_ELEMENT_INDEX 0x8D6B
|
||||
#define GL_NUM_SAMPLE_COUNTS 0x9380
|
||||
#define GL_TEXTURE_IMMUTABLE_LEVELS 0x82DF
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Entrypoint definitions
|
||||
*-----------------------------------------------------------------------*/
|
||||
|
||||
/* OpenGL ES 3.0 */
|
||||
|
||||
extern GL_APICALL void (*GL_APIENTRY glReadBuffer)(GLenum mode);
|
||||
extern GL_APICALL void (*GL_APIENTRY glDrawRangeElements)(
|
||||
GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type,
|
||||
const GLvoid* indices);
|
||||
extern GL_APICALL void (*GL_APIENTRY glTexImage3D)(
|
||||
GLenum target, GLint level, GLint internalformat, GLsizei width,
|
||||
GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type,
|
||||
const GLvoid* pixels);
|
||||
extern GL_APICALL void (*GL_APIENTRY glTexSubImage3D)(
|
||||
GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset,
|
||||
GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type,
|
||||
const GLvoid* pixels);
|
||||
extern GL_APICALL void (*GL_APIENTRY glCopyTexSubImage3D)(
|
||||
GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset,
|
||||
GLint x, GLint y, GLsizei width, GLsizei height);
|
||||
extern GL_APICALL void (*GL_APIENTRY glCompressedTexImage3D)(
|
||||
GLenum target, GLint level, GLenum internalformat, GLsizei width,
|
||||
GLsizei height, GLsizei depth, GLint border, GLsizei imageSize,
|
||||
const GLvoid* data);
|
||||
extern GL_APICALL void (*GL_APIENTRY glCompressedTexSubImage3D)(
|
||||
GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset,
|
||||
GLsizei width, GLsizei height, GLsizei depth, GLenum format,
|
||||
GLsizei imageSize, const GLvoid* data);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGenQueries)(GLsizei n, GLuint* ids);
|
||||
extern GL_APICALL void (*GL_APIENTRY glDeleteQueries)(GLsizei n,
|
||||
const GLuint* ids);
|
||||
extern GL_APICALL GLboolean (*GL_APIENTRY glIsQuery)(GLuint id);
|
||||
extern GL_APICALL void (*GL_APIENTRY glBeginQuery)(GLenum target, GLuint id);
|
||||
extern GL_APICALL void (*GL_APIENTRY glEndQuery)(GLenum target);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetQueryiv)(GLenum target, GLenum pname,
|
||||
GLint* params);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetQueryObjectuiv)(GLuint id,
|
||||
GLenum pname,
|
||||
GLuint* params);
|
||||
extern GL_APICALL GLboolean (*GL_APIENTRY glUnmapBuffer)(GLenum target);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetBufferPointerv)(GLenum target,
|
||||
GLenum pname,
|
||||
GLvoid** params);
|
||||
extern GL_APICALL void (*GL_APIENTRY glDrawBuffers)(GLsizei n,
|
||||
const GLenum* bufs);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniformMatrix2x3fv)(
|
||||
GLint location, GLsizei count, GLboolean transpose, const GLfloat* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniformMatrix3x2fv)(
|
||||
GLint location, GLsizei count, GLboolean transpose, const GLfloat* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniformMatrix2x4fv)(
|
||||
GLint location, GLsizei count, GLboolean transpose, const GLfloat* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniformMatrix4x2fv)(
|
||||
GLint location, GLsizei count, GLboolean transpose, const GLfloat* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniformMatrix3x4fv)(
|
||||
GLint location, GLsizei count, GLboolean transpose, const GLfloat* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniformMatrix4x3fv)(
|
||||
GLint location, GLsizei count, GLboolean transpose, const GLfloat* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glBlitFramebuffer)(
|
||||
GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0,
|
||||
GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter);
|
||||
extern GL_APICALL void (*GL_APIENTRY glRenderbufferStorageMultisample)(
|
||||
GLenum target, GLsizei samples, GLenum internalformat, GLsizei width,
|
||||
GLsizei height);
|
||||
extern GL_APICALL void (*GL_APIENTRY glFramebufferTextureLayer)(
|
||||
GLenum target, GLenum attachment, GLuint texture, GLint level, GLint layer);
|
||||
extern GL_APICALL GLvoid* (*GL_APIENTRY glMapBufferRange)(GLenum target,
|
||||
GLintptr offset,
|
||||
GLsizeiptr length,
|
||||
GLbitfield access);
|
||||
extern GL_APICALL void (*GL_APIENTRY glFlushMappedBufferRange)(
|
||||
GLenum target, GLintptr offset, GLsizeiptr length);
|
||||
extern GL_APICALL void (*GL_APIENTRY glBindVertexArray)(GLuint array);
|
||||
extern GL_APICALL void (*GL_APIENTRY
|
||||
glDeleteVertexArrays)(GLsizei n,
|
||||
const GLuint* arrays);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGenVertexArrays)(GLsizei n,
|
||||
GLuint* arrays);
|
||||
extern GL_APICALL GLboolean (*GL_APIENTRY glIsVertexArray)(GLuint array);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetIntegeri_v)(GLenum target,
|
||||
GLuint index,
|
||||
GLint* data);
|
||||
extern GL_APICALL void (*GL_APIENTRY
|
||||
glBeginTransformFeedback)(GLenum primitiveMode);
|
||||
extern GL_APICALL void (*GL_APIENTRY glEndTransformFeedback)(void);
|
||||
extern GL_APICALL void (*GL_APIENTRY
|
||||
glBindBufferRange)(GLenum target, GLuint index,
|
||||
GLuint buffer, GLintptr offset,
|
||||
GLsizeiptr size);
|
||||
extern GL_APICALL void (*GL_APIENTRY glBindBufferBase)(GLenum target,
|
||||
GLuint index,
|
||||
GLuint buffer);
|
||||
extern GL_APICALL void (*GL_APIENTRY glTransformFeedbackVaryings)(
|
||||
GLuint program, GLsizei count, const GLchar* const* varyings,
|
||||
GLenum bufferMode);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetTransformFeedbackVarying)(
|
||||
GLuint program, GLuint index, GLsizei bufSize, GLsizei* length,
|
||||
GLsizei* size, GLenum* type, GLchar* name);
|
||||
extern GL_APICALL void (*GL_APIENTRY
|
||||
glVertexAttribIPointer)(GLuint index, GLint size,
|
||||
GLenum type, GLsizei stride,
|
||||
const GLvoid* pointer);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetVertexAttribIiv)(GLuint index,
|
||||
GLenum pname,
|
||||
GLint* params);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetVertexAttribIuiv)(GLuint index,
|
||||
GLenum pname,
|
||||
GLuint* params);
|
||||
extern GL_APICALL void (*GL_APIENTRY glVertexAttribI4i)(GLuint index, GLint x,
|
||||
GLint y, GLint z,
|
||||
GLint w);
|
||||
extern GL_APICALL void (*GL_APIENTRY glVertexAttribI4ui)(GLuint index, GLuint x,
|
||||
GLuint y, GLuint z,
|
||||
GLuint w);
|
||||
extern GL_APICALL void (*GL_APIENTRY glVertexAttribI4iv)(GLuint index,
|
||||
const GLint* v);
|
||||
extern GL_APICALL void (*GL_APIENTRY glVertexAttribI4uiv)(GLuint index,
|
||||
const GLuint* v);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetUniformuiv)(GLuint program,
|
||||
GLint location,
|
||||
GLuint* params);
|
||||
extern GL_APICALL GLint (*GL_APIENTRY
|
||||
glGetFragDataLocation)(GLuint program,
|
||||
const GLchar* name);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniform1ui)(GLint location, GLuint v0);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniform2ui)(GLint location, GLuint v0,
|
||||
GLuint v1);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniform3ui)(GLint location, GLuint v0,
|
||||
GLuint v1, GLuint v2);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniform4ui)(GLint location, GLuint v0,
|
||||
GLuint v1, GLuint v2,
|
||||
GLuint v3);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniform1uiv)(GLint location,
|
||||
GLsizei count,
|
||||
const GLuint* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniform2uiv)(GLint location,
|
||||
GLsizei count,
|
||||
const GLuint* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniform3uiv)(GLint location,
|
||||
GLsizei count,
|
||||
const GLuint* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniform4uiv)(GLint location,
|
||||
GLsizei count,
|
||||
const GLuint* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glClearBufferiv)(GLenum buffer,
|
||||
GLint drawbuffer,
|
||||
const GLint* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glClearBufferuiv)(GLenum buffer,
|
||||
GLint drawbuffer,
|
||||
const GLuint* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glClearBufferfv)(GLenum buffer,
|
||||
GLint drawbuffer,
|
||||
const GLfloat* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY
|
||||
glClearBufferfi)(GLenum buffer, GLint drawbuffer,
|
||||
GLfloat depth, GLint stencil);
|
||||
extern GL_APICALL const GLubyte* (*GL_APIENTRY glGetStringi)(GLenum name,
|
||||
GLuint index);
|
||||
extern GL_APICALL void (*GL_APIENTRY glCopyBufferSubData)(GLenum readTarget,
|
||||
GLenum writeTarget,
|
||||
GLintptr readOffset,
|
||||
GLintptr writeOffset,
|
||||
GLsizeiptr size);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetUniformIndices)(
|
||||
GLuint program, GLsizei uniformCount, const GLchar* const* uniformNames,
|
||||
GLuint* uniformIndices);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetActiveUniformsiv)(
|
||||
GLuint program, GLsizei uniformCount, const GLuint* uniformIndices,
|
||||
GLenum pname, GLint* params);
|
||||
extern GL_APICALL GLuint (*GL_APIENTRY glGetUniformBlockIndex)(
|
||||
GLuint program, const GLchar* uniformBlockName);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetActiveUniformBlockiv)(
|
||||
GLuint program, GLuint uniformBlockIndex, GLenum pname, GLint* params);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetActiveUniformBlockName)(
|
||||
GLuint program, GLuint uniformBlockIndex, GLsizei bufSize, GLsizei* length,
|
||||
GLchar* uniformBlockName);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniformBlockBinding)(
|
||||
GLuint program, GLuint uniformBlockIndex, GLuint uniformBlockBinding);
|
||||
extern GL_APICALL void (*GL_APIENTRY glDrawArraysInstanced)(
|
||||
GLenum mode, GLint first, GLsizei count, GLsizei instanceCount);
|
||||
extern GL_APICALL void (*GL_APIENTRY glDrawElementsInstanced)(
|
||||
GLenum mode, GLsizei count, GLenum type, const GLvoid* indices,
|
||||
GLsizei instanceCount);
|
||||
extern GL_APICALL GLsync (*GL_APIENTRY glFenceSync)(GLenum condition,
|
||||
GLbitfield flags);
|
||||
extern GL_APICALL GLboolean (*GL_APIENTRY glIsSync)(GLsync sync);
|
||||
extern GL_APICALL void (*GL_APIENTRY glDeleteSync)(GLsync sync);
|
||||
extern GL_APICALL GLenum (*GL_APIENTRY glClientWaitSync)(GLsync sync,
|
||||
GLbitfield flags,
|
||||
GLuint64 timeout);
|
||||
extern GL_APICALL void (*GL_APIENTRY glWaitSync)(GLsync sync, GLbitfield flags,
|
||||
GLuint64 timeout);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetInteger64v)(GLenum pname,
|
||||
GLint64* params);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetSynciv)(GLsync sync, GLenum pname,
|
||||
GLsizei bufSize,
|
||||
GLsizei* length,
|
||||
GLint* values);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetInteger64i_v)(GLenum target,
|
||||
GLuint index,
|
||||
GLint64* data);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetBufferParameteri64v)(GLenum target,
|
||||
GLenum pname,
|
||||
GLint64* params);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGenSamplers)(GLsizei count,
|
||||
GLuint* samplers);
|
||||
extern GL_APICALL void (*GL_APIENTRY glDeleteSamplers)(GLsizei count,
|
||||
const GLuint* samplers);
|
||||
extern GL_APICALL GLboolean (*GL_APIENTRY glIsSampler)(GLuint sampler);
|
||||
extern GL_APICALL void (*GL_APIENTRY glBindSampler)(GLuint unit,
|
||||
GLuint sampler);
|
||||
extern GL_APICALL void (*GL_APIENTRY glSamplerParameteri)(GLuint sampler,
|
||||
GLenum pname,
|
||||
GLint param);
|
||||
extern GL_APICALL void (*GL_APIENTRY glSamplerParameteriv)(GLuint sampler,
|
||||
GLenum pname,
|
||||
const GLint* param);
|
||||
extern GL_APICALL void (*GL_APIENTRY glSamplerParameterf)(GLuint sampler,
|
||||
GLenum pname,
|
||||
GLfloat param);
|
||||
extern GL_APICALL void (*GL_APIENTRY
|
||||
glSamplerParameterfv)(GLuint sampler, GLenum pname,
|
||||
const GLfloat* param);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetSamplerParameteriv)(GLuint sampler,
|
||||
GLenum pname,
|
||||
GLint* params);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetSamplerParameterfv)(GLuint sampler,
|
||||
GLenum pname,
|
||||
GLfloat* params);
|
||||
extern GL_APICALL void (*GL_APIENTRY glVertexAttribDivisor)(GLuint index,
|
||||
GLuint divisor);
|
||||
extern GL_APICALL void (*GL_APIENTRY glBindTransformFeedback)(GLenum target,
|
||||
GLuint id);
|
||||
extern GL_APICALL void (*GL_APIENTRY
|
||||
glDeleteTransformFeedbacks)(GLsizei n,
|
||||
const GLuint* ids);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGenTransformFeedbacks)(GLsizei n,
|
||||
GLuint* ids);
|
||||
extern GL_APICALL GLboolean (*GL_APIENTRY glIsTransformFeedback)(GLuint id);
|
||||
extern GL_APICALL void (*GL_APIENTRY glPauseTransformFeedback)(void);
|
||||
extern GL_APICALL void (*GL_APIENTRY glResumeTransformFeedback)(void);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetProgramBinary)(GLuint program,
|
||||
GLsizei bufSize,
|
||||
GLsizei* length,
|
||||
GLenum* binaryFormat,
|
||||
GLvoid* binary);
|
||||
extern GL_APICALL void (*GL_APIENTRY glProgramBinary)(GLuint program,
|
||||
GLenum binaryFormat,
|
||||
const GLvoid* binary,
|
||||
GLsizei length);
|
||||
extern GL_APICALL void (*GL_APIENTRY glProgramParameteri)(GLuint program,
|
||||
GLenum pname,
|
||||
GLint value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glInvalidateFramebuffer)(
|
||||
GLenum target, GLsizei numAttachments, const GLenum* attachments);
|
||||
extern GL_APICALL void (*GL_APIENTRY glInvalidateSubFramebuffer)(
|
||||
GLenum target, GLsizei numAttachments, const GLenum* attachments, GLint x,
|
||||
GLint y, GLsizei width, GLsizei height);
|
||||
extern GL_APICALL void (*GL_APIENTRY
|
||||
glTexStorage2D)(GLenum target, GLsizei levels,
|
||||
GLenum internalformat,
|
||||
GLsizei width, GLsizei height);
|
||||
extern GL_APICALL void (*GL_APIENTRY glTexStorage3D)(
|
||||
GLenum target, GLsizei levels, GLenum internalformat, GLsizei width,
|
||||
GLsizei height, GLsizei depth);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetInternalformativ)(
|
||||
GLenum target, GLenum internalformat, GLenum pname, GLsizei bufSize,
|
||||
GLint* params);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
153
MoreTeapots/app/src/main/cpp/ndk_helper/interpolator.cpp
Normal file
@@ -0,0 +1,153 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include "interpolator.h"
|
||||
#include <math.h>
|
||||
#include "interpolator.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
//-------------------------------------------------
|
||||
// Ctor
|
||||
//-------------------------------------------------
|
||||
Interpolator::Interpolator() { list_params_.clear(); }
|
||||
|
||||
//-------------------------------------------------
|
||||
// Dtor
|
||||
//-------------------------------------------------
|
||||
Interpolator::~Interpolator() { list_params_.clear(); }
|
||||
|
||||
void Interpolator::Clear() { list_params_.clear(); }
|
||||
|
||||
Interpolator& Interpolator::Set(const float start, const float dest,
|
||||
const INTERPOLATOR_TYPE type,
|
||||
const double duration) {
|
||||
// init the parameters for the interpolation process
|
||||
start_time_ = PerfMonitor::GetCurrentTime();
|
||||
dest_time_ = start_time_ + duration;
|
||||
type_ = type;
|
||||
|
||||
start_value_ = start;
|
||||
dest_value_ = dest;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Interpolator& Interpolator::Add(const float dest, const INTERPOLATOR_TYPE type,
|
||||
const double duration) {
|
||||
InterpolatorParams param;
|
||||
param.dest_value_ = dest;
|
||||
param.type_ = type;
|
||||
param.duration_ = duration;
|
||||
list_params_.push_back(param);
|
||||
return *this;
|
||||
}
|
||||
|
||||
bool Interpolator::Update(const double current_time, float& p) {
|
||||
bool bContinue;
|
||||
if (current_time >= dest_time_) {
|
||||
p = dest_value_;
|
||||
if (list_params_.size()) {
|
||||
InterpolatorParams& item = list_params_.front();
|
||||
Set(dest_value_, item.dest_value_, item.type_, item.duration_);
|
||||
list_params_.pop_front();
|
||||
|
||||
bContinue = true;
|
||||
} else {
|
||||
bContinue = false;
|
||||
}
|
||||
} else {
|
||||
float t = (float)(current_time - start_time_);
|
||||
float d = (float)(dest_time_ - start_time_);
|
||||
float b = start_value_;
|
||||
float c = dest_value_ - start_value_;
|
||||
p = GetFormula(type_, t, b, d, c);
|
||||
|
||||
bContinue = true;
|
||||
}
|
||||
return bContinue;
|
||||
}
|
||||
|
||||
float Interpolator::GetFormula(const INTERPOLATOR_TYPE type, const float t,
|
||||
const float b, const float d, const float c) {
|
||||
float t1;
|
||||
switch (type) {
|
||||
case INTERPOLATOR_TYPE_LINEAR:
|
||||
// simple linear interpolation - no easing
|
||||
return (c * t / d + b);
|
||||
|
||||
case INTERPOLATOR_TYPE_EASEINQUAD:
|
||||
// quadratic (t^2) easing in - accelerating from zero velocity
|
||||
t1 = t / d;
|
||||
return (c * t1 * t1 + b);
|
||||
|
||||
case INTERPOLATOR_TYPE_EASEOUTQUAD:
|
||||
// quadratic (t^2) easing out - decelerating to zero velocity
|
||||
t1 = t / d;
|
||||
return (-c * t1 * (t1 - 2) + b);
|
||||
|
||||
case INTERPOLATOR_TYPE_EASEINOUTQUAD:
|
||||
// quadratic easing in/out - acceleration until halfway, then deceleration
|
||||
t1 = t / d / 2;
|
||||
if (t1 < 1)
|
||||
return (c / 2 * t1 * t1 + b);
|
||||
else {
|
||||
t1 = t1 - 1;
|
||||
return (-c / 2 * (t1 * (t1 - 2) - 1) + b);
|
||||
}
|
||||
case INTERPOLATOR_TYPE_EASEINCUBIC:
|
||||
// cubic easing in - accelerating from zero velocity
|
||||
t1 = t / d;
|
||||
return (c * t1 * t1 * t1 + b);
|
||||
|
||||
case INTERPOLATOR_TYPE_EASEOUTCUBIC:
|
||||
// cubic easing in - accelerating from zero velocity
|
||||
t1 = t / d - 1;
|
||||
return (c * (t1 * t1 * t1 + 1) + b);
|
||||
|
||||
case INTERPOLATOR_TYPE_EASEINOUTCUBIC:
|
||||
// cubic easing in - accelerating from zero velocity
|
||||
t1 = t / d / 2;
|
||||
|
||||
if (t1 < 1)
|
||||
return (c / 2 * t1 * t1 * t1 + b);
|
||||
else {
|
||||
t1 -= 2;
|
||||
return (c / 2 * (t1 * t1 * t1 + 2) + b);
|
||||
}
|
||||
case INTERPOLATOR_TYPE_EASEINQUART:
|
||||
// quartic easing in - accelerating from zero velocity
|
||||
t1 = t / d;
|
||||
return (c * t1 * t1 * t1 * t1 + b);
|
||||
|
||||
case INTERPOLATOR_TYPE_EASEINEXPO:
|
||||
// exponential (2^t) easing in - accelerating from zero velocity
|
||||
if (t == 0)
|
||||
return b;
|
||||
else
|
||||
return (c * powf(2, (10 * (t / d - 1))) + b);
|
||||
|
||||
case INTERPOLATOR_TYPE_EASEOUTEXPO:
|
||||
// exponential (2^t) easing out - decelerating to zero velocity
|
||||
if (t == d)
|
||||
return (b + c);
|
||||
else
|
||||
return (c * (-powf(2, -10 * t / d) + 1) + b);
|
||||
default:
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
} // namespace ndkHelper
|
||||
80
MoreTeapots/app/src/main/cpp/ndk_helper/interpolator.h
Normal file
@@ -0,0 +1,80 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#ifndef INTERPOLATOR_H_
|
||||
#define INTERPOLATOR_H_
|
||||
|
||||
#include <jni.h>
|
||||
#include <errno.h>
|
||||
#include <time.h>
|
||||
#include "JNIHelper.h"
|
||||
#include "perfMonitor.h"
|
||||
#include <list>
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
enum INTERPOLATOR_TYPE {
|
||||
INTERPOLATOR_TYPE_LINEAR,
|
||||
INTERPOLATOR_TYPE_EASEINQUAD,
|
||||
INTERPOLATOR_TYPE_EASEOUTQUAD,
|
||||
INTERPOLATOR_TYPE_EASEINOUTQUAD,
|
||||
INTERPOLATOR_TYPE_EASEINCUBIC,
|
||||
INTERPOLATOR_TYPE_EASEOUTCUBIC,
|
||||
INTERPOLATOR_TYPE_EASEINOUTCUBIC,
|
||||
INTERPOLATOR_TYPE_EASEINQUART,
|
||||
INTERPOLATOR_TYPE_EASEINEXPO,
|
||||
INTERPOLATOR_TYPE_EASEOUTEXPO,
|
||||
};
|
||||
|
||||
struct InterpolatorParams {
|
||||
float dest_value_;
|
||||
INTERPOLATOR_TYPE type_;
|
||||
double duration_;
|
||||
};
|
||||
|
||||
/******************************************************************
|
||||
* Interpolates values with several interpolation methods
|
||||
*/
|
||||
class Interpolator {
|
||||
private:
|
||||
double start_time_;
|
||||
double dest_time_;
|
||||
INTERPOLATOR_TYPE type_;
|
||||
|
||||
float start_value_;
|
||||
float dest_value_;
|
||||
std::list<InterpolatorParams> list_params_;
|
||||
|
||||
float GetFormula(const INTERPOLATOR_TYPE type, const float t, const float b,
|
||||
const float d, const float c);
|
||||
|
||||
public:
|
||||
Interpolator();
|
||||
~Interpolator();
|
||||
|
||||
Interpolator& Set(const float start, const float dest,
|
||||
const INTERPOLATOR_TYPE type, double duration);
|
||||
|
||||
Interpolator& Add(const float dest, const INTERPOLATOR_TYPE type,
|
||||
const double duration);
|
||||
|
||||
bool Update(const double currentTime, float& p);
|
||||
|
||||
void Clear();
|
||||
};
|
||||
|
||||
} // namespace ndkHelper
|
||||
#endif /* INTERPOLATOR_H_ */
|
||||
57
MoreTeapots/app/src/main/cpp/ndk_helper/perfMonitor.cpp
Normal file
@@ -0,0 +1,57 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include "perfMonitor.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
PerfMonitor::PerfMonitor()
|
||||
: tv_last_sec_(0), last_tick_(0.f), tickindex_(0), ticksum_(0) {
|
||||
for (int32_t i = 0; i < NUM_SAMPLES; ++i) ticklist_[i] = 0;
|
||||
}
|
||||
|
||||
PerfMonitor::~PerfMonitor() {}
|
||||
|
||||
double PerfMonitor::UpdateTick(double currentTick) {
|
||||
ticksum_ -= ticklist_[tickindex_];
|
||||
ticksum_ += currentTick;
|
||||
ticklist_[tickindex_] = currentTick;
|
||||
tickindex_ = (tickindex_ + 1) % NUM_SAMPLES;
|
||||
|
||||
return ((double)ticksum_ / NUM_SAMPLES);
|
||||
}
|
||||
|
||||
bool PerfMonitor::Update(float &fFPS) {
|
||||
struct timeval Time;
|
||||
gettimeofday(&Time, NULL);
|
||||
|
||||
double time = Time.tv_sec + Time.tv_usec * 1.0 / 1000000.0;
|
||||
double tick = time - last_tick_;
|
||||
double d = UpdateTick(tick);
|
||||
last_tick_ = time;
|
||||
|
||||
if (Time.tv_sec - tv_last_sec_ >= 1) {
|
||||
current_FPS_ = 1.f / d;
|
||||
tv_last_sec_ = Time.tv_sec;
|
||||
fFPS = current_FPS_;
|
||||
return true;
|
||||
} else {
|
||||
fFPS = current_FPS_;
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
} // namespace ndkHelper
|
||||
59
MoreTeapots/app/src/main/cpp/ndk_helper/perfMonitor.h
Normal file
@@ -0,0 +1,59 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#ifndef PERFMONITOR_H_
|
||||
#define PERFMONITOR_H_
|
||||
|
||||
#include <jni.h>
|
||||
#include <errno.h>
|
||||
#include <time.h>
|
||||
#include "JNIHelper.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
const int32_t NUM_SAMPLES = 100;
|
||||
|
||||
/******************************************************************
|
||||
* Helper class for a performance monitoring and get current tick time
|
||||
*/
|
||||
class PerfMonitor {
|
||||
private:
|
||||
float current_FPS_;
|
||||
time_t tv_last_sec_;
|
||||
|
||||
double last_tick_;
|
||||
int32_t tickindex_;
|
||||
double ticksum_;
|
||||
double ticklist_[NUM_SAMPLES];
|
||||
|
||||
double UpdateTick(double current_tick);
|
||||
|
||||
public:
|
||||
PerfMonitor();
|
||||
virtual ~PerfMonitor();
|
||||
|
||||
bool Update(float &fFPS);
|
||||
|
||||
static double GetCurrentTime() {
|
||||
struct timeval time;
|
||||
gettimeofday(&time, NULL);
|
||||
double ret = time.tv_sec + time.tv_usec * 1.0 / 1000000.0;
|
||||
return ret;
|
||||
}
|
||||
};
|
||||
|
||||
} // namespace ndkHelper
|
||||
#endif /* PERFMONITOR_H_ */
|
||||
167
MoreTeapots/app/src/main/cpp/ndk_helper/shader.cpp
Normal file
@@ -0,0 +1,167 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include <EGL/egl.h>
|
||||
#include <GLES2/gl2.h>
|
||||
|
||||
#include "shader.h"
|
||||
#include "JNIHelper.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
#define DEBUG (1)
|
||||
|
||||
bool shader::CompileShader(
|
||||
GLuint *shader, const GLenum type, const char *str_file_name,
|
||||
const std::map<std::string, std::string> &map_parameters) {
|
||||
std::vector<uint8_t> data;
|
||||
if (!JNIHelper::GetInstance()->ReadFile(str_file_name, &data)) {
|
||||
LOGI("Can not open a file:%s", str_file_name);
|
||||
return false;
|
||||
}
|
||||
|
||||
const char REPLACEMENT_TAG = '*';
|
||||
// Fill-in parameters
|
||||
std::string str(data.begin(), data.end());
|
||||
std::string str_replacement_map(data.size(), ' ');
|
||||
|
||||
std::map<std::string, std::string>::const_iterator it =
|
||||
map_parameters.begin();
|
||||
std::map<std::string, std::string>::const_iterator itEnd =
|
||||
map_parameters.end();
|
||||
while (it != itEnd) {
|
||||
size_t pos = 0;
|
||||
while ((pos = str.find(it->first, pos)) != std::string::npos) {
|
||||
// Check if the sub string is already touched
|
||||
|
||||
size_t replaced_pos = str_replacement_map.find(REPLACEMENT_TAG, pos);
|
||||
if (replaced_pos == std::string::npos || replaced_pos > pos) {
|
||||
|
||||
str.replace(pos, it->first.length(), it->second);
|
||||
str_replacement_map.replace(pos, it->first.length(), it->first.length(),
|
||||
REPLACEMENT_TAG);
|
||||
pos += it->second.length();
|
||||
} else {
|
||||
// The replacement target has been touched by other tag, skipping them
|
||||
pos += it->second.length();
|
||||
}
|
||||
}
|
||||
it++;
|
||||
}
|
||||
|
||||
LOGI("Patched Shdader:\n%s", str.c_str());
|
||||
|
||||
std::vector<uint8_t> v(str.begin(), str.end());
|
||||
str.clear();
|
||||
return shader::CompileShader(shader, type, v);
|
||||
}
|
||||
|
||||
bool shader::CompileShader(GLuint *shader, const GLenum type,
|
||||
const GLchar *source, const int32_t iSize) {
|
||||
if (source == NULL || iSize <= 0) return false;
|
||||
|
||||
*shader = glCreateShader(type);
|
||||
glShaderSource(*shader, 1, &source, &iSize); // Not specifying 3rd parameter
|
||||
// (size) could be troublesome..
|
||||
|
||||
glCompileShader(*shader);
|
||||
|
||||
#if defined(DEBUG)
|
||||
GLint logLength;
|
||||
glGetShaderiv(*shader, GL_INFO_LOG_LENGTH, &logLength);
|
||||
if (logLength > 0) {
|
||||
GLchar *log = (GLchar *)malloc(logLength);
|
||||
glGetShaderInfoLog(*shader, logLength, &logLength, log);
|
||||
LOGI("Shader compile log:\n%s", log);
|
||||
free(log);
|
||||
}
|
||||
#endif
|
||||
|
||||
GLint status;
|
||||
glGetShaderiv(*shader, GL_COMPILE_STATUS, &status);
|
||||
if (status == 0) {
|
||||
glDeleteShader(*shader);
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool shader::CompileShader(GLuint *shader, const GLenum type,
|
||||
std::vector<uint8_t> &data) {
|
||||
if (!data.size()) return false;
|
||||
|
||||
const GLchar *source = (GLchar *)&data[0];
|
||||
int32_t iSize = data.size();
|
||||
return shader::CompileShader(shader, type, source, iSize);
|
||||
}
|
||||
|
||||
bool shader::CompileShader(GLuint *shader, const GLenum type,
|
||||
const char *strFileName) {
|
||||
std::vector<uint8_t> data;
|
||||
bool b = JNIHelper::GetInstance()->ReadFile(strFileName, &data);
|
||||
if (!b) {
|
||||
LOGI("Can not open a file:%s", strFileName);
|
||||
return false;
|
||||
}
|
||||
|
||||
return shader::CompileShader(shader, type, data);
|
||||
}
|
||||
|
||||
bool shader::LinkProgram(const GLuint prog) {
|
||||
GLint status;
|
||||
|
||||
glLinkProgram(prog);
|
||||
|
||||
#if defined(DEBUG)
|
||||
GLint logLength;
|
||||
glGetProgramiv(prog, GL_INFO_LOG_LENGTH, &logLength);
|
||||
if (logLength > 0) {
|
||||
GLchar *log = (GLchar *)malloc(logLength);
|
||||
glGetProgramInfoLog(prog, logLength, &logLength, log);
|
||||
LOGI("Program link log:\n%s", log);
|
||||
free(log);
|
||||
}
|
||||
#endif
|
||||
|
||||
glGetProgramiv(prog, GL_LINK_STATUS, &status);
|
||||
if (status == 0) {
|
||||
LOGI("Program link failed\n");
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool shader::ValidateProgram(const GLuint prog) {
|
||||
GLint logLength, status;
|
||||
|
||||
glValidateProgram(prog);
|
||||
glGetProgramiv(prog, GL_INFO_LOG_LENGTH, &logLength);
|
||||
if (logLength > 0) {
|
||||
GLchar *log = (GLchar *)malloc(logLength);
|
||||
glGetProgramInfoLog(prog, logLength, &logLength, log);
|
||||
LOGI("Program validate log:\n%s", log);
|
||||
free(log);
|
||||
}
|
||||
|
||||
glGetProgramiv(prog, GL_VALIDATE_STATUS, &status);
|
||||
if (status == 0) return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
} // namespace ndkHelper
|
||||
120
MoreTeapots/app/src/main/cpp/ndk_helper/shader.h
Normal file
@@ -0,0 +1,120 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#ifndef SHADER_H_
|
||||
#define SHADER_H_
|
||||
|
||||
#include <jni.h>
|
||||
|
||||
#include <vector>
|
||||
#include <map>
|
||||
#include <string>
|
||||
|
||||
#include <EGL/egl.h>
|
||||
#include <GLES/gl.h>
|
||||
|
||||
#include <android/log.h>
|
||||
|
||||
#include "JNIHelper.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
namespace shader {
|
||||
|
||||
/******************************************************************
|
||||
* Shader compiler helper
|
||||
* namespace: ndkHelper::shader
|
||||
*
|
||||
*/
|
||||
|
||||
/******************************************************************
|
||||
* CompileShader() with vector
|
||||
*
|
||||
* arguments:
|
||||
* out: shader, shader variable
|
||||
* in: type, shader type (i.e. GL_VERTEX_SHADER/GL_FRAGMENT_SHADER)
|
||||
* in: data, source vector
|
||||
* return: true if a shader compilation succeeded, false if it failed
|
||||
*
|
||||
*/
|
||||
bool CompileShader(GLuint *shader, const GLenum type,
|
||||
std::vector<uint8_t> &data);
|
||||
|
||||
/******************************************************************
|
||||
* CompileShader() with buffer
|
||||
*
|
||||
* arguments:
|
||||
* out: shader, shader variable
|
||||
* in: type, shader type (i.e. GL_VERTEX_SHADER/GL_FRAGMENT_SHADER)
|
||||
* in: source, source buffer
|
||||
* in: iSize, buffer size
|
||||
* return: true if a shader compilation succeeded, false if it failed
|
||||
*
|
||||
*/
|
||||
bool CompileShader(GLuint *shader, const GLenum type, const GLchar *source,
|
||||
const int32_t iSize);
|
||||
|
||||
/******************************************************************
|
||||
* CompileShader() with filename
|
||||
*
|
||||
* arguments:
|
||||
* out: shader, shader variable
|
||||
* in: type, shader type (i.e. GL_VERTEX_SHADER/GL_FRAGMENT_SHADER)
|
||||
* in: strFilename, filename
|
||||
* return: true if a shader compilation succeeded, false if it failed
|
||||
*
|
||||
*/
|
||||
bool CompileShader(GLuint *shader, const GLenum type, const char *strFileName);
|
||||
|
||||
/******************************************************************
|
||||
* CompileShader() with std::map helps patching on a shader on the fly.
|
||||
*
|
||||
* arguments:
|
||||
* out: shader, shader variable
|
||||
* in: type, shader type (i.e. GL_VERTEX_SHADER/GL_FRAGMENT_SHADER)
|
||||
* in: mapParameters
|
||||
* For a example,
|
||||
* map : %KEY% -> %VALUE% replaces all %KEY% entries in the given shader
|
||||
*code to %VALUE"
|
||||
* return: true if a shader compilation succeeded, false if it failed
|
||||
*
|
||||
*/
|
||||
bool CompileShader(GLuint *shader, const GLenum type, const char *str_file_name,
|
||||
const std::map<std::string, std::string> &map_parameters);
|
||||
|
||||
/******************************************************************
|
||||
* LinkProgram()
|
||||
*
|
||||
* arguments:
|
||||
* in: program, program
|
||||
* return: true if a shader linkage succeeded, false if it failed
|
||||
*
|
||||
*/
|
||||
bool LinkProgram(const GLuint prog);
|
||||
|
||||
/******************************************************************
|
||||
* validateProgram()
|
||||
*
|
||||
* arguments:
|
||||
* in: program, program
|
||||
* return: true if a shader validation succeeded, false if it failed
|
||||
*
|
||||
*/
|
||||
bool ValidateProgram(const GLuint prog);
|
||||
} // namespace shader
|
||||
|
||||
} // namespace ndkHelper
|
||||
#endif /* SHADER_H_ */
|
||||
281
MoreTeapots/app/src/main/cpp/ndk_helper/tapCamera.cpp
Normal file
@@ -0,0 +1,281 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
//----------------------------------------------------------
|
||||
// tapCamera.cpp
|
||||
// Camera control with tap
|
||||
//
|
||||
//----------------------------------------------------------
|
||||
#include <fstream>
|
||||
#include "tapCamera.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
const float TRANSFORM_FACTOR = 15.f;
|
||||
const float TRANSFORM_FACTORZ = 10.f;
|
||||
|
||||
const float MOMENTUM_FACTOR_DECREASE = 0.85f;
|
||||
const float MOMENTUM_FACTOR_DECREASE_SHIFT = 0.9f;
|
||||
const float MOMENTUM_FACTOR = 0.8f;
|
||||
const float MOMENTUM_FACTOR_THRESHOLD = 0.001f;
|
||||
|
||||
//----------------------------------------------------------
|
||||
// Ctor
|
||||
//----------------------------------------------------------
|
||||
TapCamera::TapCamera()
|
||||
: ball_radius_(0.75f),
|
||||
dragging_(false),
|
||||
pinching_(false),
|
||||
pinch_start_distance_SQ_(0.f),
|
||||
camera_rotation_(0.f),
|
||||
camera_rotation_start_(0.f),
|
||||
camera_rotation_now_(0.f),
|
||||
momentum_(false),
|
||||
momemtum_steps_(0.f),
|
||||
flip_z_(0.f) {
|
||||
// Init offset
|
||||
InitParameters();
|
||||
|
||||
vec_flip_ = Vec2(1.f, -1.f);
|
||||
flip_z_ = -1.f;
|
||||
vec_pinch_transform_factor_ = Vec3(1.f, 1.f, 1.f);
|
||||
|
||||
vec_ball_center_ = Vec2(0, 0);
|
||||
vec_ball_now_ = Vec2(0, 0);
|
||||
vec_ball_down_ = Vec2(0, 0);
|
||||
|
||||
vec_pinch_start_ = Vec2(0, 0);
|
||||
vec_pinch_start_center_ = Vec2(0, 0);
|
||||
|
||||
vec_flip_ = Vec2(0, 0);
|
||||
}
|
||||
|
||||
void TapCamera::InitParameters() {
|
||||
// Init parameters
|
||||
vec_offset_ = Vec3();
|
||||
vec_offset_now_ = Vec3();
|
||||
|
||||
quat_ball_rot_ = Quaternion();
|
||||
quat_ball_now_ = Quaternion();
|
||||
quat_ball_now_.ToMatrix(mat_rotation_);
|
||||
camera_rotation_ = 0.f;
|
||||
|
||||
vec_drag_delta_ = Vec2();
|
||||
vec_offset_delta_ = Vec3();
|
||||
|
||||
momentum_ = false;
|
||||
}
|
||||
|
||||
//----------------------------------------------------------
|
||||
// Dtor
|
||||
//----------------------------------------------------------
|
||||
TapCamera::~TapCamera() {}
|
||||
|
||||
void TapCamera::Update() {
|
||||
if (momentum_) {
|
||||
float momenttum_steps = momemtum_steps_;
|
||||
|
||||
// Momentum rotation
|
||||
Vec2 v = vec_drag_delta_;
|
||||
BeginDrag(Vec2()); // NOTE:This call reset _VDragDelta
|
||||
Drag(v * vec_flip_);
|
||||
|
||||
// Momentum shift
|
||||
vec_offset_ += vec_offset_delta_;
|
||||
|
||||
BallUpdate();
|
||||
EndDrag();
|
||||
|
||||
// Decrease deltas
|
||||
vec_drag_delta_ = v * MOMENTUM_FACTOR_DECREASE;
|
||||
vec_offset_delta_ = vec_offset_delta_ * MOMENTUM_FACTOR_DECREASE_SHIFT;
|
||||
|
||||
// Count steps
|
||||
momemtum_steps_ = momenttum_steps * MOMENTUM_FACTOR_DECREASE;
|
||||
if (momemtum_steps_ < MOMENTUM_FACTOR_THRESHOLD) {
|
||||
momentum_ = false;
|
||||
}
|
||||
} else {
|
||||
vec_drag_delta_ *= MOMENTUM_FACTOR;
|
||||
vec_offset_delta_ = vec_offset_delta_ * MOMENTUM_FACTOR;
|
||||
BallUpdate();
|
||||
}
|
||||
|
||||
Vec3 vec = vec_offset_ + vec_offset_now_;
|
||||
Vec3 vec_tmp(TRANSFORM_FACTOR, -TRANSFORM_FACTOR, TRANSFORM_FACTORZ);
|
||||
|
||||
vec *= vec_tmp * vec_pinch_transform_factor_;
|
||||
|
||||
mat_transform_ = Mat4::Translation(vec);
|
||||
}
|
||||
|
||||
Mat4& TapCamera::GetRotationMatrix() { return mat_rotation_; }
|
||||
|
||||
Mat4& TapCamera::GetTransformMatrix() { return mat_transform_; }
|
||||
|
||||
void TapCamera::Reset(const bool bAnimate) {
|
||||
InitParameters();
|
||||
Update();
|
||||
}
|
||||
|
||||
//----------------------------------------------------------
|
||||
// Drag control
|
||||
//----------------------------------------------------------
|
||||
void TapCamera::BeginDrag(const Vec2& v) {
|
||||
if (dragging_) EndDrag();
|
||||
|
||||
if (pinching_) EndPinch();
|
||||
|
||||
Vec2 vec = v * vec_flip_;
|
||||
vec_ball_now_ = vec;
|
||||
vec_ball_down_ = vec_ball_now_;
|
||||
|
||||
dragging_ = true;
|
||||
momentum_ = false;
|
||||
vec_last_input_ = vec;
|
||||
vec_drag_delta_ = Vec2();
|
||||
}
|
||||
|
||||
void TapCamera::EndDrag() {
|
||||
quat_ball_down_ = quat_ball_now_;
|
||||
quat_ball_rot_ = Quaternion();
|
||||
|
||||
dragging_ = false;
|
||||
momentum_ = true;
|
||||
momemtum_steps_ = 1.0f;
|
||||
}
|
||||
|
||||
void TapCamera::Drag(const Vec2& v) {
|
||||
if (!dragging_) return;
|
||||
|
||||
Vec2 vec = v * vec_flip_;
|
||||
vec_ball_now_ = vec;
|
||||
|
||||
vec_drag_delta_ = vec_drag_delta_ * MOMENTUM_FACTOR + (vec - vec_last_input_);
|
||||
vec_last_input_ = vec;
|
||||
}
|
||||
|
||||
//----------------------------------------------------------
|
||||
// Pinch controll
|
||||
//----------------------------------------------------------
|
||||
void TapCamera::BeginPinch(const Vec2& v1, const Vec2& v2) {
|
||||
if (dragging_) EndDrag();
|
||||
|
||||
if (pinching_) EndPinch();
|
||||
|
||||
BeginDrag(Vec2());
|
||||
|
||||
vec_pinch_start_center_ = (v1 + v2) / 2.f;
|
||||
|
||||
Vec2 vec = v1 - v2;
|
||||
float x_diff;
|
||||
float y_diff;
|
||||
vec.Value(x_diff, y_diff);
|
||||
|
||||
pinch_start_distance_SQ_ = x_diff * x_diff + y_diff * y_diff;
|
||||
camera_rotation_start_ = atan2f(y_diff, x_diff);
|
||||
camera_rotation_now_ = 0;
|
||||
|
||||
pinching_ = true;
|
||||
momentum_ = false;
|
||||
|
||||
// Init momentum factors
|
||||
vec_offset_delta_ = Vec3();
|
||||
}
|
||||
|
||||
void TapCamera::EndPinch() {
|
||||
pinching_ = false;
|
||||
momentum_ = true;
|
||||
momemtum_steps_ = 1.f;
|
||||
vec_offset_ += vec_offset_now_;
|
||||
camera_rotation_ += camera_rotation_now_;
|
||||
vec_offset_now_ = Vec3();
|
||||
|
||||
camera_rotation_now_ = 0;
|
||||
|
||||
EndDrag();
|
||||
}
|
||||
|
||||
void TapCamera::Pinch(const Vec2& v1, const Vec2& v2) {
|
||||
if (!pinching_) return;
|
||||
|
||||
// Update momentum factor
|
||||
vec_offset_last_ = vec_offset_now_;
|
||||
|
||||
float x_diff, y_diff;
|
||||
Vec2 vec = v1 - v2;
|
||||
vec.Value(x_diff, y_diff);
|
||||
|
||||
float fDistanceSQ = x_diff * x_diff + y_diff * y_diff;
|
||||
|
||||
float f = pinch_start_distance_SQ_ / fDistanceSQ;
|
||||
if (f < 1.f)
|
||||
f = -1.f / f + 1.0f;
|
||||
else
|
||||
f = f - 1.f;
|
||||
if (isnan(f)) f = 0.f;
|
||||
|
||||
vec = (v1 + v2) / 2.f - vec_pinch_start_center_;
|
||||
vec_offset_now_ = Vec3(vec, flip_z_ * f);
|
||||
|
||||
// Update momentum factor
|
||||
vec_offset_delta_ = vec_offset_delta_ * MOMENTUM_FACTOR +
|
||||
(vec_offset_now_ - vec_offset_last_);
|
||||
|
||||
//
|
||||
// Update ration quaternion
|
||||
float fRotation = atan2f(y_diff, x_diff);
|
||||
camera_rotation_now_ = fRotation - camera_rotation_start_;
|
||||
|
||||
// Trackball rotation
|
||||
quat_ball_rot_ = Quaternion(0.f, 0.f, sinf(-camera_rotation_now_ * 0.5f),
|
||||
cosf(-camera_rotation_now_ * 0.5f));
|
||||
}
|
||||
|
||||
//----------------------------------------------------------
|
||||
// Trackball controll
|
||||
//----------------------------------------------------------
|
||||
void TapCamera::BallUpdate() {
|
||||
if (dragging_) {
|
||||
Vec3 vec_from = PointOnSphere(vec_ball_down_);
|
||||
Vec3 vec_to = PointOnSphere(vec_ball_now_);
|
||||
|
||||
Vec3 vec = vec_from.Cross(vec_to);
|
||||
float w = vec_from.Dot(vec_to);
|
||||
|
||||
Quaternion qDrag = Quaternion(vec, w);
|
||||
qDrag = qDrag * quat_ball_down_;
|
||||
quat_ball_now_ = quat_ball_rot_ * qDrag;
|
||||
}
|
||||
quat_ball_now_.ToMatrix(mat_rotation_);
|
||||
}
|
||||
|
||||
Vec3 TapCamera::PointOnSphere(Vec2& point) {
|
||||
Vec3 ball_mouse;
|
||||
float mag;
|
||||
Vec2 vec = (point - vec_ball_center_) / ball_radius_;
|
||||
mag = vec.Dot(vec);
|
||||
if (mag > 1.f) {
|
||||
float scale = 1.f / sqrtf(mag);
|
||||
vec *= scale;
|
||||
ball_mouse = Vec3(vec, 0.f);
|
||||
} else {
|
||||
ball_mouse = Vec3(vec, sqrtf(1.f - mag));
|
||||
}
|
||||
return ball_mouse;
|
||||
}
|
||||
|
||||
} // namespace ndkHelper
|
||||
108
MoreTeapots/app/src/main/cpp/ndk_helper/tapCamera.h
Normal file
@@ -0,0 +1,108 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include <vector>
|
||||
#include <string>
|
||||
#include <GLES2/gl2.h>
|
||||
|
||||
#include "JNIHelper.h"
|
||||
#include "vecmath.h"
|
||||
#include "interpolator.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
/******************************************************************
|
||||
* Camera control helper class with a tap gesture
|
||||
* This class is mainly used for 3D space camera control in samples.
|
||||
*
|
||||
*/
|
||||
class TapCamera {
|
||||
private:
|
||||
// Trackball
|
||||
Vec2 vec_ball_center_;
|
||||
float ball_radius_;
|
||||
Quaternion quat_ball_now_;
|
||||
Quaternion quat_ball_down_;
|
||||
Vec2 vec_ball_now_;
|
||||
Vec2 vec_ball_down_;
|
||||
Quaternion quat_ball_rot_;
|
||||
|
||||
bool dragging_;
|
||||
bool pinching_;
|
||||
|
||||
// Pinch related info
|
||||
Vec2 vec_pinch_start_;
|
||||
Vec2 vec_pinch_start_center_;
|
||||
float pinch_start_distance_SQ_;
|
||||
|
||||
// Camera shift
|
||||
Vec3 vec_offset_;
|
||||
Vec3 vec_offset_now_;
|
||||
|
||||
// Camera Rotation
|
||||
float camera_rotation_;
|
||||
float camera_rotation_start_;
|
||||
float camera_rotation_now_;
|
||||
|
||||
// Momentum support
|
||||
bool momentum_;
|
||||
Vec2 vec_drag_delta_;
|
||||
Vec2 vec_last_input_;
|
||||
Vec3 vec_offset_last_;
|
||||
Vec3 vec_offset_delta_;
|
||||
float momemtum_steps_;
|
||||
|
||||
Vec2 vec_flip_;
|
||||
float flip_z_;
|
||||
|
||||
Mat4 mat_rotation_;
|
||||
Mat4 mat_transform_;
|
||||
|
||||
Vec3 vec_pinch_transform_factor_;
|
||||
|
||||
Vec3 PointOnSphere(Vec2& point);
|
||||
void BallUpdate();
|
||||
void InitParameters();
|
||||
|
||||
public:
|
||||
TapCamera();
|
||||
virtual ~TapCamera();
|
||||
void BeginDrag(const Vec2& vec);
|
||||
void EndDrag();
|
||||
void Drag(const Vec2& vec);
|
||||
void Update();
|
||||
|
||||
Mat4& GetRotationMatrix();
|
||||
Mat4& GetTransformMatrix();
|
||||
|
||||
void BeginPinch(const Vec2& v1, const Vec2& v2);
|
||||
void EndPinch();
|
||||
void Pinch(const Vec2& v1, const Vec2& v2);
|
||||
|
||||
void SetFlip(const float x, const float y, const float z) {
|
||||
vec_flip_ = Vec2(x, y);
|
||||
flip_z_ = z;
|
||||
}
|
||||
|
||||
void SetPinchTransformFactor(const float x, const float y, const float z) {
|
||||
vec_pinch_transform_factor_ = Vec3(x, y, z);
|
||||
}
|
||||
|
||||
void Reset(const bool bAnimate);
|
||||
};
|
||||
|
||||
} // namespace ndkHelper
|
||||
362
MoreTeapots/app/src/main/cpp/ndk_helper/vecmath.cpp
Normal file
@@ -0,0 +1,362 @@
|
||||
/*
|
||||
* Copy_right 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* y_ou may_ not use this file ex_cept in compliance with the License.
|
||||
* You may_ obtain a copy_ of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by_ applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either ex_press or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// vecmath.cpp
|
||||
//--------------------------------------------------------------------------------
|
||||
#include "vecmath.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// vec3
|
||||
//--------------------------------------------------------------------------------
|
||||
Vec3::Vec3(const Vec4& vec) {
|
||||
x_ = vec.x_;
|
||||
y_ = vec.y_;
|
||||
z_ = vec.z_;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// vec4
|
||||
//--------------------------------------------------------------------------------
|
||||
Vec4 Vec4::operator*(const Mat4& rhs) const {
|
||||
Vec4 out;
|
||||
out.x_ = x_ * rhs.f_[0] + y_ * rhs.f_[1] + z_ * rhs.f_[2] + w_ * rhs.f_[3];
|
||||
out.y_ = x_ * rhs.f_[4] + y_ * rhs.f_[5] + z_ * rhs.f_[6] + w_ * rhs.f_[7];
|
||||
out.z_ = x_ * rhs.f_[8] + y_ * rhs.f_[9] + z_ * rhs.f_[10] + w_ * rhs.f_[11];
|
||||
out.w_ =
|
||||
x_ * rhs.f_[12] + y_ * rhs.f_[13] + z_ * rhs.f_[14] + w_ * rhs.f_[15];
|
||||
return out;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// mat4
|
||||
//--------------------------------------------------------------------------------
|
||||
Mat4::Mat4() {
|
||||
for (int32_t i = 0; i < 16; ++i) f_[i] = 0.f;
|
||||
}
|
||||
|
||||
Mat4::Mat4(const float* mIn) {
|
||||
for (int32_t i = 0; i < 16; ++i) f_[i] = mIn[i];
|
||||
}
|
||||
|
||||
Mat4 Mat4::operator*(const Mat4& rhs) const {
|
||||
Mat4 ret;
|
||||
ret.f_[0] = f_[0] * rhs.f_[0] + f_[4] * rhs.f_[1] + f_[8] * rhs.f_[2] +
|
||||
f_[12] * rhs.f_[3];
|
||||
ret.f_[1] = f_[1] * rhs.f_[0] + f_[5] * rhs.f_[1] + f_[9] * rhs.f_[2] +
|
||||
f_[13] * rhs.f_[3];
|
||||
ret.f_[2] = f_[2] * rhs.f_[0] + f_[6] * rhs.f_[1] + f_[10] * rhs.f_[2] +
|
||||
f_[14] * rhs.f_[3];
|
||||
ret.f_[3] = f_[3] * rhs.f_[0] + f_[7] * rhs.f_[1] + f_[11] * rhs.f_[2] +
|
||||
f_[15] * rhs.f_[3];
|
||||
|
||||
ret.f_[4] = f_[0] * rhs.f_[4] + f_[4] * rhs.f_[5] + f_[8] * rhs.f_[6] +
|
||||
f_[12] * rhs.f_[7];
|
||||
ret.f_[5] = f_[1] * rhs.f_[4] + f_[5] * rhs.f_[5] + f_[9] * rhs.f_[6] +
|
||||
f_[13] * rhs.f_[7];
|
||||
ret.f_[6] = f_[2] * rhs.f_[4] + f_[6] * rhs.f_[5] + f_[10] * rhs.f_[6] +
|
||||
f_[14] * rhs.f_[7];
|
||||
ret.f_[7] = f_[3] * rhs.f_[4] + f_[7] * rhs.f_[5] + f_[11] * rhs.f_[6] +
|
||||
f_[15] * rhs.f_[7];
|
||||
|
||||
ret.f_[8] = f_[0] * rhs.f_[8] + f_[4] * rhs.f_[9] + f_[8] * rhs.f_[10] +
|
||||
f_[12] * rhs.f_[11];
|
||||
ret.f_[9] = f_[1] * rhs.f_[8] + f_[5] * rhs.f_[9] + f_[9] * rhs.f_[10] +
|
||||
f_[13] * rhs.f_[11];
|
||||
ret.f_[10] = f_[2] * rhs.f_[8] + f_[6] * rhs.f_[9] + f_[10] * rhs.f_[10] +
|
||||
f_[14] * rhs.f_[11];
|
||||
ret.f_[11] = f_[3] * rhs.f_[8] + f_[7] * rhs.f_[9] + f_[11] * rhs.f_[10] +
|
||||
f_[15] * rhs.f_[11];
|
||||
|
||||
ret.f_[12] = f_[0] * rhs.f_[12] + f_[4] * rhs.f_[13] + f_[8] * rhs.f_[14] +
|
||||
f_[12] * rhs.f_[15];
|
||||
ret.f_[13] = f_[1] * rhs.f_[12] + f_[5] * rhs.f_[13] + f_[9] * rhs.f_[14] +
|
||||
f_[13] * rhs.f_[15];
|
||||
ret.f_[14] = f_[2] * rhs.f_[12] + f_[6] * rhs.f_[13] + f_[10] * rhs.f_[14] +
|
||||
f_[14] * rhs.f_[15];
|
||||
ret.f_[15] = f_[3] * rhs.f_[12] + f_[7] * rhs.f_[13] + f_[11] * rhs.f_[14] +
|
||||
f_[15] * rhs.f_[15];
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec4 Mat4::operator*(const Vec4& rhs) const {
|
||||
Vec4 ret;
|
||||
ret.x_ = rhs.x_ * f_[0] + rhs.y_ * f_[4] + rhs.z_ * f_[8] + rhs.w_ * f_[12];
|
||||
ret.y_ = rhs.x_ * f_[1] + rhs.y_ * f_[5] + rhs.z_ * f_[9] + rhs.w_ * f_[13];
|
||||
ret.z_ = rhs.x_ * f_[2] + rhs.y_ * f_[6] + rhs.z_ * f_[10] + rhs.w_ * f_[14];
|
||||
ret.w_ = rhs.x_ * f_[3] + rhs.y_ * f_[7] + rhs.z_ * f_[11] + rhs.w_ * f_[15];
|
||||
return ret;
|
||||
}
|
||||
|
||||
Mat4 Mat4::Inverse() {
|
||||
Mat4 ret;
|
||||
float det_1;
|
||||
float pos = 0;
|
||||
float neg = 0;
|
||||
float temp;
|
||||
|
||||
temp = f_[0] * f_[5] * f_[10];
|
||||
if (temp >= 0)
|
||||
pos += temp;
|
||||
else
|
||||
neg += temp;
|
||||
temp = f_[4] * f_[9] * f_[2];
|
||||
if (temp >= 0)
|
||||
pos += temp;
|
||||
else
|
||||
neg += temp;
|
||||
temp = f_[8] * f_[1] * f_[6];
|
||||
if (temp >= 0)
|
||||
pos += temp;
|
||||
else
|
||||
neg += temp;
|
||||
temp = -f_[8] * f_[5] * f_[2];
|
||||
if (temp >= 0)
|
||||
pos += temp;
|
||||
else
|
||||
neg += temp;
|
||||
temp = -f_[4] * f_[1] * f_[10];
|
||||
if (temp >= 0)
|
||||
pos += temp;
|
||||
else
|
||||
neg += temp;
|
||||
temp = -f_[0] * f_[9] * f_[6];
|
||||
if (temp >= 0)
|
||||
pos += temp;
|
||||
else
|
||||
neg += temp;
|
||||
det_1 = pos + neg;
|
||||
|
||||
if (det_1 == 0.0) {
|
||||
// Error
|
||||
} else {
|
||||
det_1 = 1.0f / det_1;
|
||||
ret.f_[0] = (f_[5] * f_[10] - f_[9] * f_[6]) * det_1;
|
||||
ret.f_[1] = -(f_[1] * f_[10] - f_[9] * f_[2]) * det_1;
|
||||
ret.f_[2] = (f_[1] * f_[6] - f_[5] * f_[2]) * det_1;
|
||||
ret.f_[4] = -(f_[4] * f_[10] - f_[8] * f_[6]) * det_1;
|
||||
ret.f_[5] = (f_[0] * f_[10] - f_[8] * f_[2]) * det_1;
|
||||
ret.f_[6] = -(f_[0] * f_[6] - f_[4] * f_[2]) * det_1;
|
||||
ret.f_[8] = (f_[4] * f_[9] - f_[8] * f_[5]) * det_1;
|
||||
ret.f_[9] = -(f_[0] * f_[9] - f_[8] * f_[1]) * det_1;
|
||||
ret.f_[10] = (f_[0] * f_[5] - f_[4] * f_[1]) * det_1;
|
||||
|
||||
/* Calculate -C * inverse(A) */
|
||||
ret.f_[12] =
|
||||
-(f_[12] * ret.f_[0] + f_[13] * ret.f_[4] + f_[14] * ret.f_[8]);
|
||||
ret.f_[13] =
|
||||
-(f_[12] * ret.f_[1] + f_[13] * ret.f_[5] + f_[14] * ret.f_[9]);
|
||||
ret.f_[14] =
|
||||
-(f_[12] * ret.f_[2] + f_[13] * ret.f_[6] + f_[14] * ret.f_[10]);
|
||||
|
||||
ret.f_[3] = 0.0f;
|
||||
ret.f_[7] = 0.0f;
|
||||
ret.f_[11] = 0.0f;
|
||||
ret.f_[15] = 1.0f;
|
||||
}
|
||||
|
||||
*this = ret;
|
||||
return *this;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// Misc
|
||||
//--------------------------------------------------------------------------------
|
||||
Mat4 Mat4::RotationX(const float fAngle) {
|
||||
Mat4 ret;
|
||||
float fCosine, fSine;
|
||||
|
||||
fCosine = cosf(fAngle);
|
||||
fSine = sinf(fAngle);
|
||||
|
||||
ret.f_[0] = 1.0f;
|
||||
ret.f_[4] = 0.0f;
|
||||
ret.f_[8] = 0.0f;
|
||||
ret.f_[12] = 0.0f;
|
||||
ret.f_[1] = 0.0f;
|
||||
ret.f_[5] = fCosine;
|
||||
ret.f_[9] = fSine;
|
||||
ret.f_[13] = 0.0f;
|
||||
ret.f_[2] = 0.0f;
|
||||
ret.f_[6] = -fSine;
|
||||
ret.f_[10] = fCosine;
|
||||
ret.f_[14] = 0.0f;
|
||||
ret.f_[3] = 0.0f;
|
||||
ret.f_[7] = 0.0f;
|
||||
ret.f_[11] = 0.0f;
|
||||
ret.f_[15] = 1.0f;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Mat4 Mat4::RotationY(const float fAngle) {
|
||||
Mat4 ret;
|
||||
float fCosine, fSine;
|
||||
|
||||
fCosine = cosf(fAngle);
|
||||
fSine = sinf(fAngle);
|
||||
|
||||
ret.f_[0] = fCosine;
|
||||
ret.f_[4] = 0.0f;
|
||||
ret.f_[8] = -fSine;
|
||||
ret.f_[12] = 0.0f;
|
||||
ret.f_[1] = 0.0f;
|
||||
ret.f_[5] = 1.0f;
|
||||
ret.f_[9] = 0.0f;
|
||||
ret.f_[13] = 0.0f;
|
||||
ret.f_[2] = fSine;
|
||||
ret.f_[6] = 0.0f;
|
||||
ret.f_[10] = fCosine;
|
||||
ret.f_[14] = 0.0f;
|
||||
ret.f_[3] = 0.0f;
|
||||
ret.f_[7] = 0.0f;
|
||||
ret.f_[11] = 0.0f;
|
||||
ret.f_[15] = 1.0f;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Mat4 Mat4::RotationZ(const float fAngle) {
|
||||
Mat4 ret;
|
||||
float fCosine, fSine;
|
||||
|
||||
fCosine = cosf(fAngle);
|
||||
fSine = sinf(fAngle);
|
||||
|
||||
ret.f_[0] = fCosine;
|
||||
ret.f_[4] = fSine;
|
||||
ret.f_[8] = 0.0f;
|
||||
ret.f_[12] = 0.0f;
|
||||
ret.f_[1] = -fSine;
|
||||
ret.f_[5] = fCosine;
|
||||
ret.f_[9] = 0.0f;
|
||||
ret.f_[13] = 0.0f;
|
||||
ret.f_[2] = 0.0f;
|
||||
ret.f_[6] = 0.0f;
|
||||
ret.f_[10] = 1.0f;
|
||||
ret.f_[14] = 0.0f;
|
||||
ret.f_[3] = 0.0f;
|
||||
ret.f_[7] = 0.0f;
|
||||
ret.f_[11] = 0.0f;
|
||||
ret.f_[15] = 1.0f;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Mat4 Mat4::Translation(const float fX, const float fY, const float fZ) {
|
||||
Mat4 ret;
|
||||
ret.f_[0] = 1.0f;
|
||||
ret.f_[4] = 0.0f;
|
||||
ret.f_[8] = 0.0f;
|
||||
ret.f_[12] = fX;
|
||||
ret.f_[1] = 0.0f;
|
||||
ret.f_[5] = 1.0f;
|
||||
ret.f_[9] = 0.0f;
|
||||
ret.f_[13] = fY;
|
||||
ret.f_[2] = 0.0f;
|
||||
ret.f_[6] = 0.0f;
|
||||
ret.f_[10] = 1.0f;
|
||||
ret.f_[14] = fZ;
|
||||
ret.f_[3] = 0.0f;
|
||||
ret.f_[7] = 0.0f;
|
||||
ret.f_[11] = 0.0f;
|
||||
ret.f_[15] = 1.0f;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Mat4 Mat4::Translation(const Vec3 vec) {
|
||||
Mat4 ret;
|
||||
ret.f_[0] = 1.0f;
|
||||
ret.f_[4] = 0.0f;
|
||||
ret.f_[8] = 0.0f;
|
||||
ret.f_[12] = vec.x_;
|
||||
ret.f_[1] = 0.0f;
|
||||
ret.f_[5] = 1.0f;
|
||||
ret.f_[9] = 0.0f;
|
||||
ret.f_[13] = vec.y_;
|
||||
ret.f_[2] = 0.0f;
|
||||
ret.f_[6] = 0.0f;
|
||||
ret.f_[10] = 1.0f;
|
||||
ret.f_[14] = vec.z_;
|
||||
ret.f_[3] = 0.0f;
|
||||
ret.f_[7] = 0.0f;
|
||||
ret.f_[11] = 0.0f;
|
||||
ret.f_[15] = 1.0f;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Mat4 Mat4::Perspective(float width, float height, float nearPlane,
|
||||
float farPlane) {
|
||||
float n2 = 2.0f * nearPlane;
|
||||
float rcpnmf = 1.f / (nearPlane - farPlane);
|
||||
|
||||
Mat4 result;
|
||||
result.f_[0] = n2 / width;
|
||||
result.f_[4] = 0;
|
||||
result.f_[8] = 0;
|
||||
result.f_[12] = 0;
|
||||
result.f_[1] = 0;
|
||||
result.f_[5] = n2 / height;
|
||||
result.f_[9] = 0;
|
||||
result.f_[13] = 0;
|
||||
result.f_[2] = 0;
|
||||
result.f_[6] = 0;
|
||||
result.f_[10] = (farPlane + nearPlane) * rcpnmf;
|
||||
result.f_[14] = farPlane * rcpnmf * n2;
|
||||
result.f_[3] = 0;
|
||||
result.f_[7] = 0;
|
||||
result.f_[11] = -1.0;
|
||||
result.f_[15] = 0;
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
Mat4 Mat4::LookAt(const Vec3& vec_eye, const Vec3& vec_at, const Vec3& vec_up) {
|
||||
Vec3 vec_forward, vec_up_norm, vec_side;
|
||||
Mat4 result;
|
||||
|
||||
vec_forward.x_ = vec_eye.x_ - vec_at.x_;
|
||||
vec_forward.y_ = vec_eye.y_ - vec_at.y_;
|
||||
vec_forward.z_ = vec_eye.z_ - vec_at.z_;
|
||||
|
||||
vec_forward.Normalize();
|
||||
vec_up_norm = vec_up;
|
||||
vec_up_norm.Normalize();
|
||||
vec_side = vec_up_norm.Cross(vec_forward);
|
||||
vec_up_norm = vec_forward.Cross(vec_side);
|
||||
|
||||
result.f_[0] = vec_side.x_;
|
||||
result.f_[4] = vec_side.y_;
|
||||
result.f_[8] = vec_side.z_;
|
||||
result.f_[12] = 0;
|
||||
result.f_[1] = vec_up_norm.x_;
|
||||
result.f_[5] = vec_up_norm.y_;
|
||||
result.f_[9] = vec_up_norm.z_;
|
||||
result.f_[13] = 0;
|
||||
result.f_[2] = vec_forward.x_;
|
||||
result.f_[6] = vec_forward.y_;
|
||||
result.f_[10] = vec_forward.z_;
|
||||
result.f_[14] = 0;
|
||||
result.f_[3] = 0;
|
||||
result.f_[7] = 0;
|
||||
result.f_[11] = 0;
|
||||
result.f_[15] = 1.0;
|
||||
|
||||
result.PostTranslate(-vec_eye.x_, -vec_eye.y_, -vec_eye.z_);
|
||||
return result;
|
||||
}
|
||||
|
||||
} // namespace ndkHelper
|
||||
959
MoreTeapots/app/src/main/cpp/ndk_helper/vecmath.h
Normal file
@@ -0,0 +1,959 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#ifndef VECMATH_H_
|
||||
#define VECMATH_H_
|
||||
|
||||
#include <math.h>
|
||||
#include "JNIHelper.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
/******************************************************************
|
||||
* Helper class for vector math operations
|
||||
* Currently all implementations are in pure C++.
|
||||
* Each class is an opaque class so caller does not have a direct access
|
||||
* to each element. This is for an ease of future optimization to use vector
|
||||
*operations.
|
||||
*
|
||||
*/
|
||||
|
||||
class Vec2;
|
||||
class Vec3;
|
||||
class Vec4;
|
||||
class Mat4;
|
||||
|
||||
/******************************************************************
|
||||
* 2 elements vector class
|
||||
*
|
||||
*/
|
||||
class Vec2 {
|
||||
private:
|
||||
float x_;
|
||||
float y_;
|
||||
|
||||
public:
|
||||
friend class Vec3;
|
||||
friend class Vec4;
|
||||
friend class Mat4;
|
||||
friend class Quaternion;
|
||||
|
||||
Vec2() { x_ = y_ = 0.f; }
|
||||
|
||||
Vec2(const float fX, const float fY) {
|
||||
x_ = fX;
|
||||
y_ = fY;
|
||||
}
|
||||
|
||||
Vec2(const Vec2& vec) {
|
||||
x_ = vec.x_;
|
||||
y_ = vec.y_;
|
||||
}
|
||||
|
||||
Vec2(const float* pVec) {
|
||||
x_ = (*pVec++);
|
||||
y_ = (*pVec++);
|
||||
}
|
||||
|
||||
// Operators
|
||||
Vec2 operator*(const Vec2& rhs) const {
|
||||
Vec2 ret;
|
||||
ret.x_ = x_ * rhs.x_;
|
||||
ret.y_ = y_ * rhs.y_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec2 operator/(const Vec2& rhs) const {
|
||||
Vec2 ret;
|
||||
ret.x_ = x_ / rhs.x_;
|
||||
ret.y_ = y_ / rhs.y_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec2 operator+(const Vec2& rhs) const {
|
||||
Vec2 ret;
|
||||
ret.x_ = x_ + rhs.x_;
|
||||
ret.y_ = y_ + rhs.y_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec2 operator-(const Vec2& rhs) const {
|
||||
Vec2 ret;
|
||||
ret.x_ = x_ - rhs.x_;
|
||||
ret.y_ = y_ - rhs.y_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec2& operator+=(const Vec2& rhs) {
|
||||
x_ += rhs.x_;
|
||||
y_ += rhs.y_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec2& operator-=(const Vec2& rhs) {
|
||||
x_ -= rhs.x_;
|
||||
y_ -= rhs.y_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec2& operator*=(const Vec2& rhs) {
|
||||
x_ *= rhs.x_;
|
||||
y_ *= rhs.y_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec2& operator/=(const Vec2& rhs) {
|
||||
x_ /= rhs.x_;
|
||||
y_ /= rhs.y_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
// External operators
|
||||
friend Vec2 operator-(const Vec2& rhs) { return Vec2(rhs) *= -1; }
|
||||
|
||||
friend Vec2 operator*(const float lhs, const Vec2& rhs) {
|
||||
Vec2 ret;
|
||||
ret.x_ = lhs * rhs.x_;
|
||||
ret.y_ = lhs * rhs.y_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
friend Vec2 operator/(const float lhs, const Vec2& rhs) {
|
||||
Vec2 ret;
|
||||
ret.x_ = lhs / rhs.x_;
|
||||
ret.y_ = lhs / rhs.y_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
// Operators with float
|
||||
Vec2 operator*(const float& rhs) const {
|
||||
Vec2 ret;
|
||||
ret.x_ = x_ * rhs;
|
||||
ret.y_ = y_ * rhs;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec2& operator*=(const float& rhs) {
|
||||
x_ = x_ * rhs;
|
||||
y_ = y_ * rhs;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec2 operator/(const float& rhs) const {
|
||||
Vec2 ret;
|
||||
ret.x_ = x_ / rhs;
|
||||
ret.y_ = y_ / rhs;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec2& operator/=(const float& rhs) {
|
||||
x_ = x_ / rhs;
|
||||
y_ = y_ / rhs;
|
||||
return *this;
|
||||
}
|
||||
|
||||
// Compare
|
||||
bool operator==(const Vec2& rhs) const {
|
||||
if (x_ != rhs.x_ || y_ != rhs.y_) return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
bool operator!=(const Vec2& rhs) const {
|
||||
if (x_ == rhs.x_) return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
float Length() const { return sqrtf(x_ * x_ + y_ * y_); }
|
||||
|
||||
Vec2 Normalize() {
|
||||
float len = Length();
|
||||
x_ = x_ / len;
|
||||
y_ = y_ / len;
|
||||
return *this;
|
||||
}
|
||||
|
||||
float Dot(const Vec2& rhs) { return x_ * rhs.x_ + y_ * rhs.y_; }
|
||||
|
||||
bool Validate() {
|
||||
if (isnan(x_) || isnan(y_)) return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
void Value(float& fX, float& fY) {
|
||||
fX = x_;
|
||||
fY = y_;
|
||||
}
|
||||
|
||||
void Dump() { LOGI("Vec2 %f %f", x_, y_); }
|
||||
};
|
||||
|
||||
/******************************************************************
|
||||
* 3 elements vector class
|
||||
*
|
||||
*/
|
||||
class Vec3 {
|
||||
private:
|
||||
float x_, y_, z_;
|
||||
|
||||
public:
|
||||
friend class Vec4;
|
||||
friend class Mat4;
|
||||
friend class Quaternion;
|
||||
|
||||
Vec3() { x_ = y_ = z_ = 0.f; }
|
||||
|
||||
Vec3(const float fX, const float fY, const float fZ) {
|
||||
x_ = fX;
|
||||
y_ = fY;
|
||||
z_ = fZ;
|
||||
}
|
||||
|
||||
Vec3(const Vec3& vec) {
|
||||
x_ = vec.x_;
|
||||
y_ = vec.y_;
|
||||
z_ = vec.z_;
|
||||
}
|
||||
|
||||
Vec3(const float* pVec) {
|
||||
x_ = (*pVec++);
|
||||
y_ = (*pVec++);
|
||||
z_ = *pVec;
|
||||
}
|
||||
|
||||
Vec3(const Vec2& vec, float f) {
|
||||
x_ = vec.x_;
|
||||
y_ = vec.y_;
|
||||
z_ = f;
|
||||
}
|
||||
|
||||
Vec3(const Vec4& vec);
|
||||
|
||||
// Operators
|
||||
Vec3 operator*(const Vec3& rhs) const {
|
||||
Vec3 ret;
|
||||
ret.x_ = x_ * rhs.x_;
|
||||
ret.y_ = y_ * rhs.y_;
|
||||
ret.z_ = z_ * rhs.z_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec3 operator/(const Vec3& rhs) const {
|
||||
Vec3 ret;
|
||||
ret.x_ = x_ / rhs.x_;
|
||||
ret.y_ = y_ / rhs.y_;
|
||||
ret.z_ = z_ / rhs.z_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec3 operator+(const Vec3& rhs) const {
|
||||
Vec3 ret;
|
||||
ret.x_ = x_ + rhs.x_;
|
||||
ret.y_ = y_ + rhs.y_;
|
||||
ret.z_ = z_ + rhs.z_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec3 operator-(const Vec3& rhs) const {
|
||||
Vec3 ret;
|
||||
ret.x_ = x_ - rhs.x_;
|
||||
ret.y_ = y_ - rhs.y_;
|
||||
ret.z_ = z_ - rhs.z_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec3& operator+=(const Vec3& rhs) {
|
||||
x_ += rhs.x_;
|
||||
y_ += rhs.y_;
|
||||
z_ += rhs.z_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec3& operator-=(const Vec3& rhs) {
|
||||
x_ -= rhs.x_;
|
||||
y_ -= rhs.y_;
|
||||
z_ -= rhs.z_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec3& operator*=(const Vec3& rhs) {
|
||||
x_ *= rhs.x_;
|
||||
y_ *= rhs.y_;
|
||||
z_ *= rhs.z_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec3& operator/=(const Vec3& rhs) {
|
||||
x_ /= rhs.x_;
|
||||
y_ /= rhs.y_;
|
||||
z_ /= rhs.z_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
// External operators
|
||||
friend Vec3 operator-(const Vec3& rhs) { return Vec3(rhs) *= -1; }
|
||||
|
||||
friend Vec3 operator*(const float lhs, const Vec3& rhs) {
|
||||
Vec3 ret;
|
||||
ret.x_ = lhs * rhs.x_;
|
||||
ret.y_ = lhs * rhs.y_;
|
||||
ret.z_ = lhs * rhs.z_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
friend Vec3 operator/(const float lhs, const Vec3& rhs) {
|
||||
Vec3 ret;
|
||||
ret.x_ = lhs / rhs.x_;
|
||||
ret.y_ = lhs / rhs.y_;
|
||||
ret.z_ = lhs / rhs.z_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
// Operators with float
|
||||
Vec3 operator*(const float& rhs) const {
|
||||
Vec3 ret;
|
||||
ret.x_ = x_ * rhs;
|
||||
ret.y_ = y_ * rhs;
|
||||
ret.z_ = z_ * rhs;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec3& operator*=(const float& rhs) {
|
||||
x_ = x_ * rhs;
|
||||
y_ = y_ * rhs;
|
||||
z_ = z_ * rhs;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec3 operator/(const float& rhs) const {
|
||||
Vec3 ret;
|
||||
ret.x_ = x_ / rhs;
|
||||
ret.y_ = y_ / rhs;
|
||||
ret.z_ = z_ / rhs;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec3& operator/=(const float& rhs) {
|
||||
x_ = x_ / rhs;
|
||||
y_ = y_ / rhs;
|
||||
z_ = z_ / rhs;
|
||||
return *this;
|
||||
}
|
||||
|
||||
// Compare
|
||||
bool operator==(const Vec3& rhs) const {
|
||||
if (x_ != rhs.x_ || y_ != rhs.y_ || z_ != rhs.z_) return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
bool operator!=(const Vec3& rhs) const {
|
||||
if (x_ == rhs.x_) return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
float Length() const { return sqrtf(x_ * x_ + y_ * y_ + z_ * z_); }
|
||||
|
||||
Vec3 Normalize() {
|
||||
float len = Length();
|
||||
x_ = x_ / len;
|
||||
y_ = y_ / len;
|
||||
z_ = z_ / len;
|
||||
return *this;
|
||||
}
|
||||
|
||||
float Dot(const Vec3& rhs) { return x_ * rhs.x_ + y_ * rhs.y_ + z_ * rhs.z_; }
|
||||
|
||||
Vec3 Cross(const Vec3& rhs) {
|
||||
Vec3 ret;
|
||||
ret.x_ = y_ * rhs.z_ - z_ * rhs.y_;
|
||||
ret.y_ = z_ * rhs.x_ - x_ * rhs.z_;
|
||||
ret.z_ = x_ * rhs.y_ - y_ * rhs.x_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
bool Validate() {
|
||||
if (isnan(x_) || isnan(y_) || isnan(z_)) return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
void Value(float& fX, float& fY, float& fZ) {
|
||||
fX = x_;
|
||||
fY = y_;
|
||||
fZ = z_;
|
||||
}
|
||||
|
||||
void Dump() { LOGI("Vec3 %f %f %f", x_, y_, z_); }
|
||||
};
|
||||
|
||||
/******************************************************************
|
||||
* 4 elements vector class
|
||||
*
|
||||
*/
|
||||
class Vec4 {
|
||||
private:
|
||||
float x_, y_, z_, w_;
|
||||
|
||||
public:
|
||||
friend class Vec3;
|
||||
friend class Mat4;
|
||||
friend class Quaternion;
|
||||
|
||||
Vec4() { x_ = y_ = z_ = w_ = 0.f; }
|
||||
|
||||
Vec4(const float fX, const float fY, const float fZ, const float fW) {
|
||||
x_ = fX;
|
||||
y_ = fY;
|
||||
z_ = fZ;
|
||||
w_ = fW;
|
||||
}
|
||||
|
||||
Vec4(const Vec4& vec) {
|
||||
x_ = vec.x_;
|
||||
y_ = vec.y_;
|
||||
z_ = vec.z_;
|
||||
w_ = vec.w_;
|
||||
}
|
||||
|
||||
Vec4(const Vec3& vec, const float fW) {
|
||||
x_ = vec.x_;
|
||||
y_ = vec.y_;
|
||||
z_ = vec.z_;
|
||||
w_ = fW;
|
||||
}
|
||||
|
||||
Vec4(const float* pVec) {
|
||||
x_ = (*pVec++);
|
||||
y_ = (*pVec++);
|
||||
z_ = *pVec;
|
||||
w_ = *pVec;
|
||||
}
|
||||
|
||||
// Operators
|
||||
Vec4 operator*(const Vec4& rhs) const {
|
||||
Vec4 ret;
|
||||
ret.x_ = x_ * rhs.x_;
|
||||
ret.y_ = y_ * rhs.y_;
|
||||
ret.z_ = z_ * rhs.z_;
|
||||
ret.w_ = z_ * rhs.w_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec4 operator/(const Vec4& rhs) const {
|
||||
Vec4 ret;
|
||||
ret.x_ = x_ / rhs.x_;
|
||||
ret.y_ = y_ / rhs.y_;
|
||||
ret.z_ = z_ / rhs.z_;
|
||||
ret.w_ = z_ / rhs.w_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec4 operator+(const Vec4& rhs) const {
|
||||
Vec4 ret;
|
||||
ret.x_ = x_ + rhs.x_;
|
||||
ret.y_ = y_ + rhs.y_;
|
||||
ret.z_ = z_ + rhs.z_;
|
||||
ret.w_ = z_ + rhs.w_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec4 operator-(const Vec4& rhs) const {
|
||||
Vec4 ret;
|
||||
ret.x_ = x_ - rhs.x_;
|
||||
ret.y_ = y_ - rhs.y_;
|
||||
ret.z_ = z_ - rhs.z_;
|
||||
ret.w_ = z_ - rhs.w_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec4& operator+=(const Vec4& rhs) {
|
||||
x_ += rhs.x_;
|
||||
y_ += rhs.y_;
|
||||
z_ += rhs.z_;
|
||||
w_ += rhs.w_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec4& operator-=(const Vec4& rhs) {
|
||||
x_ -= rhs.x_;
|
||||
y_ -= rhs.y_;
|
||||
z_ -= rhs.z_;
|
||||
w_ -= rhs.w_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec4& operator*=(const Vec4& rhs) {
|
||||
x_ *= rhs.x_;
|
||||
y_ *= rhs.y_;
|
||||
z_ *= rhs.z_;
|
||||
w_ *= rhs.w_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec4& operator/=(const Vec4& rhs) {
|
||||
x_ /= rhs.x_;
|
||||
y_ /= rhs.y_;
|
||||
z_ /= rhs.z_;
|
||||
w_ /= rhs.w_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
// External operators
|
||||
friend Vec4 operator-(const Vec4& rhs) { return Vec4(rhs) *= -1; }
|
||||
|
||||
friend Vec4 operator*(const float lhs, const Vec4& rhs) {
|
||||
Vec4 ret;
|
||||
ret.x_ = lhs * rhs.x_;
|
||||
ret.y_ = lhs * rhs.y_;
|
||||
ret.z_ = lhs * rhs.z_;
|
||||
ret.w_ = lhs * rhs.w_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
friend Vec4 operator/(const float lhs, const Vec4& rhs) {
|
||||
Vec4 ret;
|
||||
ret.x_ = lhs / rhs.x_;
|
||||
ret.y_ = lhs / rhs.y_;
|
||||
ret.z_ = lhs / rhs.z_;
|
||||
ret.w_ = lhs / rhs.w_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
// Operators with float
|
||||
Vec4 operator*(const float& rhs) const {
|
||||
Vec4 ret;
|
||||
ret.x_ = x_ * rhs;
|
||||
ret.y_ = y_ * rhs;
|
||||
ret.z_ = z_ * rhs;
|
||||
ret.w_ = w_ * rhs;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec4& operator*=(const float& rhs) {
|
||||
x_ = x_ * rhs;
|
||||
y_ = y_ * rhs;
|
||||
z_ = z_ * rhs;
|
||||
w_ = w_ * rhs;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec4 operator/(const float& rhs) const {
|
||||
Vec4 ret;
|
||||
ret.x_ = x_ / rhs;
|
||||
ret.y_ = y_ / rhs;
|
||||
ret.z_ = z_ / rhs;
|
||||
ret.w_ = w_ / rhs;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec4& operator/=(const float& rhs) {
|
||||
x_ = x_ / rhs;
|
||||
y_ = y_ / rhs;
|
||||
z_ = z_ / rhs;
|
||||
w_ = w_ / rhs;
|
||||
return *this;
|
||||
}
|
||||
|
||||
// Compare
|
||||
bool operator==(const Vec4& rhs) const {
|
||||
if (x_ != rhs.x_ || y_ != rhs.y_ || z_ != rhs.z_ || w_ != rhs.w_)
|
||||
return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
bool operator!=(const Vec4& rhs) const {
|
||||
if (x_ == rhs.x_) return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
Vec4 operator*(const Mat4& rhs) const;
|
||||
|
||||
float Length() const { return sqrtf(x_ * x_ + y_ * y_ + z_ * z_ + w_ * w_); }
|
||||
|
||||
Vec4 Normalize() {
|
||||
float len = Length();
|
||||
x_ = x_ / len;
|
||||
y_ = y_ / len;
|
||||
z_ = z_ / len;
|
||||
w_ = w_ / len;
|
||||
return *this;
|
||||
}
|
||||
|
||||
float Dot(const Vec3& rhs) { return x_ * rhs.x_ + y_ * rhs.y_ + z_ * rhs.z_; }
|
||||
|
||||
Vec3 Cross(const Vec3& rhs) {
|
||||
Vec3 ret;
|
||||
ret.x_ = y_ * rhs.z_ - z_ * rhs.y_;
|
||||
ret.y_ = z_ * rhs.x_ - x_ * rhs.z_;
|
||||
ret.z_ = x_ * rhs.y_ - y_ * rhs.x_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
bool Validate() {
|
||||
if (isnan(x_) || isnan(y_) || isnan(z_) || isnan(w_)) return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
void Value(float& fX, float& fY, float& fZ, float& fW) {
|
||||
fX = x_;
|
||||
fY = y_;
|
||||
fZ = z_;
|
||||
fW = w_;
|
||||
}
|
||||
};
|
||||
|
||||
/******************************************************************
|
||||
* 4x4 matrix
|
||||
*
|
||||
*/
|
||||
class Mat4 {
|
||||
private:
|
||||
float f_[16];
|
||||
|
||||
public:
|
||||
friend class Vec3;
|
||||
friend class Vec4;
|
||||
friend class Quaternion;
|
||||
|
||||
Mat4();
|
||||
Mat4(const float*);
|
||||
|
||||
Mat4 operator*(const Mat4& rhs) const;
|
||||
Vec4 operator*(const Vec4& rhs) const;
|
||||
|
||||
Mat4 operator+(const Mat4& rhs) const {
|
||||
Mat4 ret;
|
||||
for (int32_t i = 0; i < 16; ++i) {
|
||||
ret.f_[i] = f_[i] + rhs.f_[i];
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
||||
Mat4 operator-(const Mat4& rhs) const {
|
||||
Mat4 ret;
|
||||
for (int32_t i = 0; i < 16; ++i) {
|
||||
ret.f_[i] = f_[i] - rhs.f_[i];
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
||||
Mat4& operator+=(const Mat4& rhs) {
|
||||
for (int32_t i = 0; i < 16; ++i) {
|
||||
f_[i] += rhs.f_[i];
|
||||
}
|
||||
return *this;
|
||||
}
|
||||
|
||||
Mat4& operator-=(const Mat4& rhs) {
|
||||
for (int32_t i = 0; i < 16; ++i) {
|
||||
f_[i] -= rhs.f_[i];
|
||||
}
|
||||
return *this;
|
||||
}
|
||||
|
||||
Mat4& operator*=(const Mat4& rhs) {
|
||||
Mat4 ret;
|
||||
ret.f_[0] = f_[0] * rhs.f_[0] + f_[4] * rhs.f_[1] + f_[8] * rhs.f_[2] +
|
||||
f_[12] * rhs.f_[3];
|
||||
ret.f_[1] = f_[1] * rhs.f_[0] + f_[5] * rhs.f_[1] + f_[9] * rhs.f_[2] +
|
||||
f_[13] * rhs.f_[3];
|
||||
ret.f_[2] = f_[2] * rhs.f_[0] + f_[6] * rhs.f_[1] + f_[10] * rhs.f_[2] +
|
||||
f_[14] * rhs.f_[3];
|
||||
ret.f_[3] = f_[3] * rhs.f_[0] + f_[7] * rhs.f_[1] + f_[11] * rhs.f_[2] +
|
||||
f_[15] * rhs.f_[3];
|
||||
|
||||
ret.f_[4] = f_[0] * rhs.f_[4] + f_[4] * rhs.f_[5] + f_[8] * rhs.f_[6] +
|
||||
f_[12] * rhs.f_[7];
|
||||
ret.f_[5] = f_[1] * rhs.f_[4] + f_[5] * rhs.f_[5] + f_[9] * rhs.f_[6] +
|
||||
f_[13] * rhs.f_[7];
|
||||
ret.f_[6] = f_[2] * rhs.f_[4] + f_[6] * rhs.f_[5] + f_[10] * rhs.f_[6] +
|
||||
f_[14] * rhs.f_[7];
|
||||
ret.f_[7] = f_[3] * rhs.f_[4] + f_[7] * rhs.f_[5] + f_[11] * rhs.f_[6] +
|
||||
f_[15] * rhs.f_[7];
|
||||
|
||||
ret.f_[8] = f_[0] * rhs.f_[8] + f_[4] * rhs.f_[9] + f_[8] * rhs.f_[10] +
|
||||
f_[12] * rhs.f_[11];
|
||||
ret.f_[9] = f_[1] * rhs.f_[8] + f_[5] * rhs.f_[9] + f_[9] * rhs.f_[10] +
|
||||
f_[13] * rhs.f_[11];
|
||||
ret.f_[10] = f_[2] * rhs.f_[8] + f_[6] * rhs.f_[9] + f_[10] * rhs.f_[10] +
|
||||
f_[14] * rhs.f_[11];
|
||||
ret.f_[11] = f_[3] * rhs.f_[8] + f_[7] * rhs.f_[9] + f_[11] * rhs.f_[10] +
|
||||
f_[15] * rhs.f_[11];
|
||||
|
||||
ret.f_[12] = f_[0] * rhs.f_[12] + f_[4] * rhs.f_[13] + f_[8] * rhs.f_[14] +
|
||||
f_[12] * rhs.f_[15];
|
||||
ret.f_[13] = f_[1] * rhs.f_[12] + f_[5] * rhs.f_[13] + f_[9] * rhs.f_[14] +
|
||||
f_[13] * rhs.f_[15];
|
||||
ret.f_[14] = f_[2] * rhs.f_[12] + f_[6] * rhs.f_[13] + f_[10] * rhs.f_[14] +
|
||||
f_[14] * rhs.f_[15];
|
||||
ret.f_[15] = f_[3] * rhs.f_[12] + f_[7] * rhs.f_[13] + f_[11] * rhs.f_[14] +
|
||||
f_[15] * rhs.f_[15];
|
||||
|
||||
*this = ret;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Mat4 operator*(const float rhs) {
|
||||
Mat4 ret;
|
||||
for (int32_t i = 0; i < 16; ++i) {
|
||||
ret.f_[i] = f_[i] * rhs;
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
||||
Mat4& operator*=(const float rhs) {
|
||||
for (int32_t i = 0; i < 16; ++i) {
|
||||
f_[i] *= rhs;
|
||||
}
|
||||
return *this;
|
||||
}
|
||||
|
||||
Mat4& operator=(const Mat4& rhs) {
|
||||
for (int32_t i = 0; i < 16; ++i) {
|
||||
f_[i] = rhs.f_[i];
|
||||
}
|
||||
return *this;
|
||||
}
|
||||
|
||||
Mat4 Inverse();
|
||||
|
||||
Mat4 Transpose() {
|
||||
Mat4 ret;
|
||||
ret.f_[0] = f_[0];
|
||||
ret.f_[1] = f_[4];
|
||||
ret.f_[2] = f_[8];
|
||||
ret.f_[3] = f_[12];
|
||||
ret.f_[4] = f_[1];
|
||||
ret.f_[5] = f_[5];
|
||||
ret.f_[6] = f_[9];
|
||||
ret.f_[7] = f_[13];
|
||||
ret.f_[8] = f_[2];
|
||||
ret.f_[9] = f_[6];
|
||||
ret.f_[10] = f_[10];
|
||||
ret.f_[11] = f_[14];
|
||||
ret.f_[12] = f_[3];
|
||||
ret.f_[13] = f_[7];
|
||||
ret.f_[14] = f_[11];
|
||||
ret.f_[15] = f_[15];
|
||||
*this = ret;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Mat4& PostTranslate(float tx, float ty, float tz) {
|
||||
f_[12] += (tx * f_[0]) + (ty * f_[4]) + (tz * f_[8]);
|
||||
f_[13] += (tx * f_[1]) + (ty * f_[5]) + (tz * f_[9]);
|
||||
f_[14] += (tx * f_[2]) + (ty * f_[6]) + (tz * f_[10]);
|
||||
f_[15] += (tx * f_[3]) + (ty * f_[7]) + (tz * f_[11]);
|
||||
return *this;
|
||||
}
|
||||
|
||||
float* Ptr() { return f_; }
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// Misc
|
||||
//--------------------------------------------------------------------------------
|
||||
static Mat4 Perspective(float width, float height, float nearPlane,
|
||||
float farPlane);
|
||||
|
||||
static Mat4 LookAt(const Vec3& vEye, const Vec3& vAt, const Vec3& vUp);
|
||||
|
||||
static Mat4 Translation(const float fX, const float fY, const float fZ);
|
||||
static Mat4 Translation(const Vec3 vec);
|
||||
|
||||
static Mat4 RotationX(const float angle);
|
||||
|
||||
static Mat4 RotationY(const float angle);
|
||||
|
||||
static Mat4 RotationZ(const float angle);
|
||||
|
||||
static Mat4 Identity() {
|
||||
Mat4 ret;
|
||||
ret.f_[0] = 1.f;
|
||||
ret.f_[1] = 0;
|
||||
ret.f_[2] = 0;
|
||||
ret.f_[3] = 0;
|
||||
ret.f_[4] = 0;
|
||||
ret.f_[5] = 1.f;
|
||||
ret.f_[6] = 0;
|
||||
ret.f_[7] = 0;
|
||||
ret.f_[8] = 0;
|
||||
ret.f_[9] = 0;
|
||||
ret.f_[10] = 1.f;
|
||||
ret.f_[11] = 0;
|
||||
ret.f_[12] = 0;
|
||||
ret.f_[13] = 0;
|
||||
ret.f_[14] = 0;
|
||||
ret.f_[15] = 1.f;
|
||||
return ret;
|
||||
}
|
||||
|
||||
void Dump() {
|
||||
LOGI("%f %f %f %f", f_[0], f_[1], f_[2], f_[3]);
|
||||
LOGI("%f %f %f %f", f_[4], f_[5], f_[6], f_[7]);
|
||||
LOGI("%f %f %f %f", f_[8], f_[9], f_[10], f_[11]);
|
||||
LOGI("%f %f %f %f", f_[12], f_[13], f_[14], f_[15]);
|
||||
}
|
||||
};
|
||||
|
||||
/******************************************************************
|
||||
* Quaternion class
|
||||
*
|
||||
*/
|
||||
class Quaternion {
|
||||
private:
|
||||
float x_, y_, z_, w_;
|
||||
|
||||
public:
|
||||
friend class Vec3;
|
||||
friend class Vec4;
|
||||
friend class Mat4;
|
||||
|
||||
Quaternion() {
|
||||
x_ = 0.f;
|
||||
y_ = 0.f;
|
||||
z_ = 0.f;
|
||||
w_ = 1.f;
|
||||
}
|
||||
|
||||
Quaternion(const float fX, const float fY, const float fZ, const float fW) {
|
||||
x_ = fX;
|
||||
y_ = fY;
|
||||
z_ = fZ;
|
||||
w_ = fW;
|
||||
}
|
||||
|
||||
Quaternion(const Vec3 vec, const float fW) {
|
||||
x_ = vec.x_;
|
||||
y_ = vec.y_;
|
||||
z_ = vec.z_;
|
||||
w_ = fW;
|
||||
}
|
||||
|
||||
Quaternion(const float* p) {
|
||||
x_ = *p++;
|
||||
y_ = *p++;
|
||||
z_ = *p++;
|
||||
w_ = *p++;
|
||||
}
|
||||
|
||||
Quaternion operator*(const Quaternion rhs) {
|
||||
Quaternion ret;
|
||||
ret.x_ = x_ * rhs.w_ + y_ * rhs.z_ - z_ * rhs.y_ + w_ * rhs.x_;
|
||||
ret.y_ = -x_ * rhs.z_ + y_ * rhs.w_ + z_ * rhs.x_ + w_ * rhs.y_;
|
||||
ret.z_ = x_ * rhs.y_ - y_ * rhs.x_ + z_ * rhs.w_ + w_ * rhs.z_;
|
||||
ret.w_ = -x_ * rhs.x_ - y_ * rhs.y_ - z_ * rhs.z_ + w_ * rhs.w_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Quaternion& operator*=(const Quaternion rhs) {
|
||||
Quaternion ret;
|
||||
ret.x_ = x_ * rhs.w_ + y_ * rhs.z_ - z_ * rhs.y_ + w_ * rhs.x_;
|
||||
ret.y_ = -x_ * rhs.z_ + y_ * rhs.w_ + z_ * rhs.x_ + w_ * rhs.y_;
|
||||
ret.z_ = x_ * rhs.y_ - y_ * rhs.x_ + z_ * rhs.w_ + w_ * rhs.z_;
|
||||
ret.w_ = -x_ * rhs.x_ - y_ * rhs.y_ - z_ * rhs.z_ + w_ * rhs.w_;
|
||||
*this = ret;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Quaternion Conjugate() {
|
||||
x_ = -x_;
|
||||
y_ = -y_;
|
||||
z_ = -z_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
// Non destuctive version
|
||||
Quaternion Conjugated() {
|
||||
Quaternion ret;
|
||||
ret.x_ = -x_;
|
||||
ret.y_ = -y_;
|
||||
ret.z_ = -z_;
|
||||
ret.w_ = w_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
void ToMatrix(Mat4& mat) {
|
||||
float x2 = x_ * x_ * 2.0f;
|
||||
float y2 = y_ * y_ * 2.0f;
|
||||
float z2 = z_ * z_ * 2.0f;
|
||||
float xy = x_ * y_ * 2.0f;
|
||||
float yz = y_ * z_ * 2.0f;
|
||||
float zx = z_ * x_ * 2.0f;
|
||||
float xw = x_ * w_ * 2.0f;
|
||||
float yw = y_ * w_ * 2.0f;
|
||||
float zw = z_ * w_ * 2.0f;
|
||||
|
||||
mat.f_[0] = 1.0f - y2 - z2;
|
||||
mat.f_[1] = xy + zw;
|
||||
mat.f_[2] = zx - yw;
|
||||
mat.f_[4] = xy - zw;
|
||||
mat.f_[5] = 1.0f - z2 - x2;
|
||||
mat.f_[6] = yz + xw;
|
||||
mat.f_[8] = zx + yw;
|
||||
mat.f_[9] = yz - xw;
|
||||
mat.f_[10] = 1.0f - x2 - y2;
|
||||
|
||||
mat.f_[3] = mat.f_[7] = mat.f_[11] = mat.f_[12] = mat.f_[13] = mat.f_[14] =
|
||||
0.0f;
|
||||
mat.f_[15] = 1.0f;
|
||||
}
|
||||
|
||||
void ToMatrixPreserveTranslate(Mat4& mat) {
|
||||
float x2 = x_ * x_ * 2.0f;
|
||||
float y2 = y_ * y_ * 2.0f;
|
||||
float z2 = z_ * z_ * 2.0f;
|
||||
float xy = x_ * y_ * 2.0f;
|
||||
float yz = y_ * z_ * 2.0f;
|
||||
float zx = z_ * x_ * 2.0f;
|
||||
float xw = x_ * w_ * 2.0f;
|
||||
float yw = y_ * w_ * 2.0f;
|
||||
float zw = z_ * w_ * 2.0f;
|
||||
|
||||
mat.f_[0] = 1.0f - y2 - z2;
|
||||
mat.f_[1] = xy + zw;
|
||||
mat.f_[2] = zx - yw;
|
||||
mat.f_[4] = xy - zw;
|
||||
mat.f_[5] = 1.0f - z2 - x2;
|
||||
mat.f_[6] = yz + xw;
|
||||
mat.f_[8] = zx + yw;
|
||||
mat.f_[9] = yz - xw;
|
||||
mat.f_[10] = 1.0f - x2 - y2;
|
||||
|
||||
mat.f_[3] = mat.f_[7] = mat.f_[11] = 0.0f;
|
||||
mat.f_[15] = 1.0f;
|
||||
}
|
||||
|
||||
static Quaternion RotationAxis(const Vec3 axis, const float angle) {
|
||||
Quaternion ret;
|
||||
float s = sinf(angle / 2);
|
||||
ret.x_ = s * axis.x_;
|
||||
ret.y_ = s * axis.y_;
|
||||
ret.z_ = s * axis.z_;
|
||||
ret.w_ = cosf(angle / 2);
|
||||
return ret;
|
||||
}
|
||||
|
||||
void Value(float& fX, float& fY, float& fZ, float& fW) {
|
||||
fX = x_;
|
||||
fY = y_;
|
||||
fZ = z_;
|
||||
fW = w_;
|
||||
}
|
||||
};
|
||||
|
||||
} // namespace ndk_helper
|
||||
#endif /* VECMATH_H_ */
|
||||
|
Before Width: | Height: | Size: 8.0 KiB After Width: | Height: | Size: 8.0 KiB |
|
Before Width: | Height: | Size: 2.5 KiB After Width: | Height: | Size: 2.5 KiB |
|
Before Width: | Height: | Size: 4.0 KiB After Width: | Height: | Size: 4.0 KiB |
|
Before Width: | Height: | Size: 13 KiB After Width: | Height: | Size: 13 KiB |
15
MoreTeapots/build.gradle
Normal file
@@ -0,0 +1,15 @@
|
||||
// Top-level build file where you can add configuration options common to all sub-projects/modules.
|
||||
buildscript {
|
||||
repositories {
|
||||
jcenter()
|
||||
}
|
||||
dependencies {
|
||||
classpath 'com.android.tools.build:gradle:2.3.0'
|
||||
}
|
||||
}
|
||||
|
||||
allprojects {
|
||||
repositories {
|
||||
jcenter()
|
||||
}
|
||||
}
|
||||
BIN
MoreTeapots/gradle/wrapper/gradle-wrapper.jar
vendored
Normal file
6
MoreTeapots/gradle/wrapper/gradle-wrapper.properties
vendored
Normal file
@@ -0,0 +1,6 @@
|
||||
#Thu Jul 27 17:16:04 PDT 2017
|
||||
distributionBase=GRADLE_USER_HOME
|
||||
distributionPath=wrapper/dists
|
||||
zipStoreBase=GRADLE_USER_HOME
|
||||
zipStorePath=wrapper/dists
|
||||
distributionUrl=https\://services.gradle.org/distributions/gradle-3.3-all.zip
|
||||
160
MoreTeapots/gradlew
vendored
Executable file
@@ -0,0 +1,160 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
##############################################################################
|
||||
##
|
||||
## Gradle start up script for UN*X
|
||||
##
|
||||
##############################################################################
|
||||
|
||||
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
||||
DEFAULT_JVM_OPTS=""
|
||||
|
||||
APP_NAME="Gradle"
|
||||
APP_BASE_NAME=`basename "$0"`
|
||||
|
||||
# Use the maximum available, or set MAX_FD != -1 to use that value.
|
||||
MAX_FD="maximum"
|
||||
|
||||
warn ( ) {
|
||||
echo "$*"
|
||||
}
|
||||
|
||||
die ( ) {
|
||||
echo
|
||||
echo "$*"
|
||||
echo
|
||||
exit 1
|
||||
}
|
||||
|
||||
# OS specific support (must be 'true' or 'false').
|
||||
cygwin=false
|
||||
msys=false
|
||||
darwin=false
|
||||
case "`uname`" in
|
||||
CYGWIN* )
|
||||
cygwin=true
|
||||
;;
|
||||
Darwin* )
|
||||
darwin=true
|
||||
;;
|
||||
MINGW* )
|
||||
msys=true
|
||||
;;
|
||||
esac
|
||||
|
||||
# Attempt to set APP_HOME
|
||||
# Resolve links: $0 may be a link
|
||||
PRG="$0"
|
||||
# Need this for relative symlinks.
|
||||
while [ -h "$PRG" ] ; do
|
||||
ls=`ls -ld "$PRG"`
|
||||
link=`expr "$ls" : '.*-> \(.*\)$'`
|
||||
if expr "$link" : '/.*' > /dev/null; then
|
||||
PRG="$link"
|
||||
else
|
||||
PRG=`dirname "$PRG"`"/$link"
|
||||
fi
|
||||
done
|
||||
SAVED="`pwd`"
|
||||
cd "`dirname \"$PRG\"`/" >/dev/null
|
||||
APP_HOME="`pwd -P`"
|
||||
cd "$SAVED" >/dev/null
|
||||
|
||||
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
|
||||
|
||||
# Determine the Java command to use to start the JVM.
|
||||
if [ -n "$JAVA_HOME" ] ; then
|
||||
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
|
||||
# IBM's JDK on AIX uses strange locations for the executables
|
||||
JAVACMD="$JAVA_HOME/jre/sh/java"
|
||||
else
|
||||
JAVACMD="$JAVA_HOME/bin/java"
|
||||
fi
|
||||
if [ ! -x "$JAVACMD" ] ; then
|
||||
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
|
||||
|
||||
Please set the JAVA_HOME variable in your environment to match the
|
||||
location of your Java installation."
|
||||
fi
|
||||
else
|
||||
JAVACMD="java"
|
||||
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
||||
|
||||
Please set the JAVA_HOME variable in your environment to match the
|
||||
location of your Java installation."
|
||||
fi
|
||||
|
||||
# Increase the maximum file descriptors if we can.
|
||||
if [ "$cygwin" = "false" -a "$darwin" = "false" ] ; then
|
||||
MAX_FD_LIMIT=`ulimit -H -n`
|
||||
if [ $? -eq 0 ] ; then
|
||||
if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
|
||||
MAX_FD="$MAX_FD_LIMIT"
|
||||
fi
|
||||
ulimit -n $MAX_FD
|
||||
if [ $? -ne 0 ] ; then
|
||||
warn "Could not set maximum file descriptor limit: $MAX_FD"
|
||||
fi
|
||||
else
|
||||
warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
|
||||
fi
|
||||
fi
|
||||
|
||||
# For Darwin, add options to specify how the application appears in the dock
|
||||
if $darwin; then
|
||||
GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
|
||||
fi
|
||||
|
||||
# For Cygwin, switch paths to Windows format before running java
|
||||
if $cygwin ; then
|
||||
APP_HOME=`cygpath --path --mixed "$APP_HOME"`
|
||||
CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
|
||||
JAVACMD=`cygpath --unix "$JAVACMD"`
|
||||
|
||||
# We build the pattern for arguments to be converted via cygpath
|
||||
ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
|
||||
SEP=""
|
||||
for dir in $ROOTDIRSRAW ; do
|
||||
ROOTDIRS="$ROOTDIRS$SEP$dir"
|
||||
SEP="|"
|
||||
done
|
||||
OURCYGPATTERN="(^($ROOTDIRS))"
|
||||
# Add a user-defined pattern to the cygpath arguments
|
||||
if [ "$GRADLE_CYGPATTERN" != "" ] ; then
|
||||
OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
|
||||
fi
|
||||
# Now convert the arguments - kludge to limit ourselves to /bin/sh
|
||||
i=0
|
||||
for arg in "$@" ; do
|
||||
CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
|
||||
CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
|
||||
|
||||
if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
|
||||
eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
|
||||
else
|
||||
eval `echo args$i`="\"$arg\""
|
||||
fi
|
||||
i=$((i+1))
|
||||
done
|
||||
case $i in
|
||||
(0) set -- ;;
|
||||
(1) set -- "$args0" ;;
|
||||
(2) set -- "$args0" "$args1" ;;
|
||||
(3) set -- "$args0" "$args1" "$args2" ;;
|
||||
(4) set -- "$args0" "$args1" "$args2" "$args3" ;;
|
||||
(5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
|
||||
(6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
|
||||
(7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
|
||||
(8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
|
||||
(9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
|
||||
esac
|
||||
fi
|
||||
|
||||
# Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules
|
||||
function splitJvmOpts() {
|
||||
JVM_OPTS=("$@")
|
||||
}
|
||||
eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS
|
||||
JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME"
|
||||
|
||||
exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@"
|
||||
90
MoreTeapots/gradlew.bat
vendored
Normal file
@@ -0,0 +1,90 @@
|
||||
@if "%DEBUG%" == "" @echo off
|
||||
@rem ##########################################################################
|
||||
@rem
|
||||
@rem Gradle startup script for Windows
|
||||
@rem
|
||||
@rem ##########################################################################
|
||||
|
||||
@rem Set local scope for the variables with windows NT shell
|
||||
if "%OS%"=="Windows_NT" setlocal
|
||||
|
||||
@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
||||
set DEFAULT_JVM_OPTS=
|
||||
|
||||
set DIRNAME=%~dp0
|
||||
if "%DIRNAME%" == "" set DIRNAME=.
|
||||
set APP_BASE_NAME=%~n0
|
||||
set APP_HOME=%DIRNAME%
|
||||
|
||||
@rem Find java.exe
|
||||
if defined JAVA_HOME goto findJavaFromJavaHome
|
||||
|
||||
set JAVA_EXE=java.exe
|
||||
%JAVA_EXE% -version >NUL 2>&1
|
||||
if "%ERRORLEVEL%" == "0" goto init
|
||||
|
||||
echo.
|
||||
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
||||
echo.
|
||||
echo Please set the JAVA_HOME variable in your environment to match the
|
||||
echo location of your Java installation.
|
||||
|
||||
goto fail
|
||||
|
||||
:findJavaFromJavaHome
|
||||
set JAVA_HOME=%JAVA_HOME:"=%
|
||||
set JAVA_EXE=%JAVA_HOME%/bin/java.exe
|
||||
|
||||
if exist "%JAVA_EXE%" goto init
|
||||
|
||||
echo.
|
||||
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
|
||||
echo.
|
||||
echo Please set the JAVA_HOME variable in your environment to match the
|
||||
echo location of your Java installation.
|
||||
|
||||
goto fail
|
||||
|
||||
:init
|
||||
@rem Get command-line arguments, handling Windowz variants
|
||||
|
||||
if not "%OS%" == "Windows_NT" goto win9xME_args
|
||||
if "%@eval[2+2]" == "4" goto 4NT_args
|
||||
|
||||
:win9xME_args
|
||||
@rem Slurp the command line arguments.
|
||||
set CMD_LINE_ARGS=
|
||||
set _SKIP=2
|
||||
|
||||
:win9xME_args_slurp
|
||||
if "x%~1" == "x" goto execute
|
||||
|
||||
set CMD_LINE_ARGS=%*
|
||||
goto execute
|
||||
|
||||
:4NT_args
|
||||
@rem Get arguments from the 4NT Shell from JP Software
|
||||
set CMD_LINE_ARGS=%$
|
||||
|
||||
:execute
|
||||
@rem Setup the command line
|
||||
|
||||
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
|
||||
|
||||
@rem Execute Gradle
|
||||
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
|
||||
|
||||
:end
|
||||
@rem End local scope for the variables with windows NT shell
|
||||
if "%ERRORLEVEL%"=="0" goto mainEnd
|
||||
|
||||
:fail
|
||||
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
|
||||
rem the _cmd.exe /c_ return code!
|
||||
if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
|
||||
exit /b 1
|
||||
|
||||
:mainEnd
|
||||
if "%OS%"=="Windows_NT" endlocal
|
||||
|
||||
:omega
|
||||
@@ -1,3 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<lint>
|
||||
</lint>
|
||||
@@ -1,14 +0,0 @@
|
||||
# This file is automatically generated by Android Tools.
|
||||
# Do not modify this file -- YOUR CHANGES WILL BE ERASED!
|
||||
#
|
||||
# This file must be checked in Version Control Systems.
|
||||
#
|
||||
# To customize properties used by the Ant build system edit
|
||||
# "ant.properties", and override values to adapt the script to your
|
||||
# project structure.
|
||||
#
|
||||
# To enable ProGuard to shrink and obfuscate your code, uncomment this (available properties: sdk.dir, user.home):
|
||||
#proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt:proguard-project.txt
|
||||
|
||||
# Project target.
|
||||
target=Google Inc.:Google APIs:19
|
||||
1
MoreTeapots/settings.gradle
Normal file
@@ -0,0 +1 @@
|
||||
include ':app'
|
||||
@@ -1,7 +1,11 @@
|
||||
NDK Samples
|
||||
===========
|
||||
|
||||
This repository contains samples for [Android NDK][0].
|
||||
This branch is DEPRECATED, may be UPDATED with critical bug fixes.
|
||||
For the latest samples with Android Studio + ndk-build support, please refer to master
|
||||
branch's [other-builds/ndk-build](https://github.com/googlesamples/android-ndk/tree/master/other-builds/ndkbuild) directory
|
||||
|
||||
The samples in this branch known to build with Android Studio 2.2.x and 2.3.x
|
||||
|
||||
Pre-requisites
|
||||
--------------
|
||||
@@ -29,7 +33,7 @@ submitting a pull request through GitHub. Please see [CONTRIBUTING.md](CONTRIBUT
|
||||
License
|
||||
-------
|
||||
|
||||
Copyright 2015 The Android Open Source Project, Inc.
|
||||
Copyright 2018 The Android Open Source Project, Inc.
|
||||
|
||||
Licensed to the Apache Software Foundation (ASF) under one or more contributor
|
||||
license agreements. See the NOTICE file distributed with this work for
|
||||
|
||||
25
Teapot/app/build.gradle
Normal file
@@ -0,0 +1,25 @@
|
||||
apply plugin: 'com.android.application'
|
||||
|
||||
android {
|
||||
compileSdkVersion 23
|
||||
buildToolsVersion "23.0.3"
|
||||
|
||||
defaultConfig {
|
||||
applicationId "com.sample.teapot"
|
||||
minSdkVersion 14
|
||||
targetSdkVersion 19
|
||||
|
||||
}
|
||||
|
||||
buildTypes {
|
||||
release {
|
||||
minifyEnabled false
|
||||
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt'
|
||||
}
|
||||
}
|
||||
externalNativeBuild {
|
||||
ndkBuild {
|
||||
path 'src/main/cpp/Android.mk'
|
||||
}
|
||||
}
|
||||
}
|
||||
3
Teapot/app/lint.xml
Normal file
@@ -0,0 +1,3 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<lint>
|
||||
</lint>
|
||||
@@ -19,7 +19,7 @@
|
||||
#define USE_PHONG (1)
|
||||
|
||||
uniform lowp vec3 vMaterialAmbient;
|
||||
uniform mediump vec4 vMaterialSpecular;
|
||||
uniform lowp vec4 vMaterialSpecular;
|
||||
|
||||
varying lowp vec4 colorDiffuse;
|
||||
|
||||
@@ -15,6 +15,7 @@ LOCAL_STATIC_LIBRARIES := cpufeatures android_native_app_glue ndk_helper
|
||||
|
||||
include $(BUILD_SHARED_LIBRARY)
|
||||
|
||||
$(call import-module,android/ndk_helper)
|
||||
$(call import-add-path, $(LOCAL_PATH))
|
||||
$(call import-module,ndk_helper)
|
||||
$(call import-module,android/native_app_glue)
|
||||
$(call import-module,android/cpufeatures)
|
||||
4
Teapot/app/src/main/cpp/Application.mk
Normal file
@@ -0,0 +1,4 @@
|
||||
APP_PLATFORM := android-14
|
||||
APP_ABI := all
|
||||
|
||||
APP_STL := stlport_static
|
||||
@@ -432,7 +432,6 @@ Engine g_engine;
|
||||
*/
|
||||
void android_main( android_app* state )
|
||||
{
|
||||
app_dummy();
|
||||
|
||||
g_engine.SetState( state );
|
||||
|
||||
17
Teapot/app/src/main/cpp/ndk_helper/Android.mk
Normal file
@@ -0,0 +1,17 @@
|
||||
LOCAL_PATH:= $(call my-dir)
|
||||
|
||||
include $(CLEAR_VARS)
|
||||
|
||||
LOCAL_MODULE:= ndk_helper
|
||||
LOCAL_SRC_FILES:= JNIHelper.cpp interpolator.cpp tapCamera.cpp gestureDetector.cpp perfMonitor.cpp vecmath.cpp GLContext.cpp shader.cpp gl3stub.c
|
||||
|
||||
LOCAL_CPPFLAGS +=-std=c++11
|
||||
LOCAL_EXPORT_C_INCLUDES := $(LOCAL_PATH)
|
||||
LOCAL_EXPORT_LDLIBS := -llog -landroid -lEGL -lGLESv2
|
||||
|
||||
LOCAL_STATIC_LIBRARIES := cpufeatures android_native_app_glue
|
||||
|
||||
include $(BUILD_STATIC_LIBRARY)
|
||||
|
||||
#$(call import-module,android/native_app_glue)
|
||||
#$(call import-module,android/cpufeatures)
|
||||
13
Teapot/app/src/main/cpp/ndk_helper/CMakeLists.txt
Normal file
@@ -0,0 +1,13 @@
|
||||
add_library(ndk-helper STATIC
|
||||
gestureDetector.cpp
|
||||
gl3stub.c
|
||||
GLContext.cpp
|
||||
interpolator.cpp
|
||||
JNIHelper.cpp
|
||||
perfMonitor.cpp
|
||||
shader.cpp
|
||||
tapCamera.cpp
|
||||
vecmath.cpp)
|
||||
|
||||
target_include_directories(ndk-helper PRIVATE
|
||||
${ANDROID_NDK}/sources/android/native_app_glue)
|
||||
248
Teapot/app/src/main/cpp/ndk_helper/GLContext.cpp
Normal file
@@ -0,0 +1,248 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// GLContext.cpp
|
||||
//--------------------------------------------------------------------------------
|
||||
//--------------------------------------------------------------------------------
|
||||
// includes
|
||||
//--------------------------------------------------------------------------------
|
||||
#include <unistd.h>
|
||||
#include "GLContext.h"
|
||||
#include "gl3stub.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// eGLContext
|
||||
//--------------------------------------------------------------------------------
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// Ctor
|
||||
//--------------------------------------------------------------------------------
|
||||
GLContext::GLContext()
|
||||
: display_(EGL_NO_DISPLAY),
|
||||
surface_(EGL_NO_SURFACE),
|
||||
context_(EGL_NO_CONTEXT),
|
||||
screen_width_(0),
|
||||
screen_height_(0),
|
||||
gles_initialized_(false),
|
||||
egl_context_initialized_(false),
|
||||
es3_supported_(false) {}
|
||||
|
||||
void GLContext::InitGLES() {
|
||||
if (gles_initialized_) return;
|
||||
//
|
||||
// Initialize OpenGL ES 3 if available
|
||||
//
|
||||
const char* versionStr = (const char*)glGetString(GL_VERSION);
|
||||
if (strstr(versionStr, "OpenGL ES 3.") && gl3stubInit()) {
|
||||
es3_supported_ = true;
|
||||
gl_version_ = 3.0f;
|
||||
} else {
|
||||
gl_version_ = 2.0f;
|
||||
}
|
||||
|
||||
gles_initialized_ = true;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// Dtor
|
||||
//--------------------------------------------------------------------------------
|
||||
GLContext::~GLContext() { Terminate(); }
|
||||
|
||||
bool GLContext::Init(ANativeWindow* window) {
|
||||
if (egl_context_initialized_) return true;
|
||||
|
||||
//
|
||||
// Initialize EGL
|
||||
//
|
||||
window_ = window;
|
||||
InitEGLSurface();
|
||||
InitEGLContext();
|
||||
InitGLES();
|
||||
|
||||
egl_context_initialized_ = true;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool GLContext::InitEGLSurface() {
|
||||
display_ = eglGetDisplay(EGL_DEFAULT_DISPLAY);
|
||||
eglInitialize(display_, 0, 0);
|
||||
|
||||
/*
|
||||
* Here specify the attributes of the desired configuration.
|
||||
* Below, we select an EGLConfig with at least 8 bits per color
|
||||
* component compatible with on-screen windows
|
||||
*/
|
||||
const EGLint attribs[] = {
|
||||
EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT, // Request opengl ES2.0
|
||||
EGL_SURFACE_TYPE, EGL_WINDOW_BIT, EGL_BLUE_SIZE, 8,
|
||||
EGL_GREEN_SIZE, 8, EGL_RED_SIZE, 8,
|
||||
EGL_DEPTH_SIZE, 24, EGL_NONE};
|
||||
color_size_ = 8;
|
||||
depth_size_ = 24;
|
||||
|
||||
EGLint num_configs;
|
||||
eglChooseConfig(display_, attribs, &config_, 1, &num_configs);
|
||||
|
||||
if (!num_configs) {
|
||||
// Fall back to 16bit depth buffer
|
||||
const EGLint attribs[] = {
|
||||
EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT, // Request opengl ES2.0
|
||||
EGL_SURFACE_TYPE, EGL_WINDOW_BIT, EGL_BLUE_SIZE, 8,
|
||||
EGL_GREEN_SIZE, 8, EGL_RED_SIZE, 8,
|
||||
EGL_DEPTH_SIZE, 16, EGL_NONE};
|
||||
eglChooseConfig(display_, attribs, &config_, 1, &num_configs);
|
||||
depth_size_ = 16;
|
||||
}
|
||||
|
||||
if (!num_configs) {
|
||||
LOGW("Unable to retrieve EGL config");
|
||||
return false;
|
||||
}
|
||||
|
||||
surface_ = eglCreateWindowSurface(display_, config_, window_, NULL);
|
||||
eglQuerySurface(display_, surface_, EGL_WIDTH, &screen_width_);
|
||||
eglQuerySurface(display_, surface_, EGL_HEIGHT, &screen_height_);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool GLContext::InitEGLContext() {
|
||||
const EGLint context_attribs[] = {EGL_CONTEXT_CLIENT_VERSION,
|
||||
2, // Request opengl ES2.0
|
||||
EGL_NONE};
|
||||
context_ = eglCreateContext(display_, config_, NULL, context_attribs);
|
||||
|
||||
if (eglMakeCurrent(display_, surface_, surface_, context_) == EGL_FALSE) {
|
||||
LOGW("Unable to eglMakeCurrent");
|
||||
return false;
|
||||
}
|
||||
|
||||
context_valid_ = true;
|
||||
return true;
|
||||
}
|
||||
|
||||
EGLint GLContext::Swap() {
|
||||
bool b = eglSwapBuffers(display_, surface_);
|
||||
if (!b) {
|
||||
EGLint err = eglGetError();
|
||||
if (err == EGL_BAD_SURFACE) {
|
||||
// Recreate surface
|
||||
InitEGLSurface();
|
||||
return EGL_SUCCESS; // Still consider glContext is valid
|
||||
} else if (err == EGL_CONTEXT_LOST || err == EGL_BAD_CONTEXT) {
|
||||
// Context has been lost!!
|
||||
context_valid_ = false;
|
||||
Terminate();
|
||||
InitEGLContext();
|
||||
}
|
||||
return err;
|
||||
}
|
||||
return EGL_SUCCESS;
|
||||
}
|
||||
|
||||
void GLContext::Terminate() {
|
||||
if (display_ != EGL_NO_DISPLAY) {
|
||||
eglMakeCurrent(display_, EGL_NO_SURFACE, EGL_NO_SURFACE, EGL_NO_CONTEXT);
|
||||
if (context_ != EGL_NO_CONTEXT) {
|
||||
eglDestroyContext(display_, context_);
|
||||
}
|
||||
|
||||
if (surface_ != EGL_NO_SURFACE) {
|
||||
eglDestroySurface(display_, surface_);
|
||||
}
|
||||
eglTerminate(display_);
|
||||
}
|
||||
|
||||
display_ = EGL_NO_DISPLAY;
|
||||
context_ = EGL_NO_CONTEXT;
|
||||
surface_ = EGL_NO_SURFACE;
|
||||
context_valid_ = false;
|
||||
}
|
||||
|
||||
EGLint GLContext::Resume(ANativeWindow* window) {
|
||||
if (egl_context_initialized_ == false) {
|
||||
Init(window);
|
||||
return EGL_SUCCESS;
|
||||
}
|
||||
|
||||
int32_t original_widhth = screen_width_;
|
||||
int32_t original_height = screen_height_;
|
||||
|
||||
// Create surface
|
||||
window_ = window;
|
||||
surface_ = eglCreateWindowSurface(display_, config_, window_, NULL);
|
||||
eglQuerySurface(display_, surface_, EGL_WIDTH, &screen_width_);
|
||||
eglQuerySurface(display_, surface_, EGL_HEIGHT, &screen_height_);
|
||||
|
||||
if (screen_width_ != original_widhth || screen_height_ != original_height) {
|
||||
// Screen resized
|
||||
LOGI("Screen resized");
|
||||
}
|
||||
|
||||
if (eglMakeCurrent(display_, surface_, surface_, context_) == EGL_TRUE)
|
||||
return EGL_SUCCESS;
|
||||
|
||||
EGLint err = eglGetError();
|
||||
LOGW("Unable to eglMakeCurrent %d", err);
|
||||
|
||||
if (err == EGL_CONTEXT_LOST) {
|
||||
// Recreate context
|
||||
LOGI("Re-creating egl context");
|
||||
InitEGLContext();
|
||||
} else {
|
||||
// Recreate surface
|
||||
Terminate();
|
||||
InitEGLSurface();
|
||||
InitEGLContext();
|
||||
}
|
||||
|
||||
return err;
|
||||
}
|
||||
|
||||
void GLContext::Suspend() {
|
||||
if (surface_ != EGL_NO_SURFACE) {
|
||||
eglDestroySurface(display_, surface_);
|
||||
surface_ = EGL_NO_SURFACE;
|
||||
}
|
||||
}
|
||||
|
||||
bool GLContext::Invalidate() {
|
||||
Terminate();
|
||||
|
||||
egl_context_initialized_ = false;
|
||||
return true;
|
||||
}
|
||||
|
||||
bool GLContext::CheckExtension(const char* extension) {
|
||||
if (extension == NULL) return false;
|
||||
|
||||
std::string extensions = std::string((char*)glGetString(GL_EXTENSIONS));
|
||||
std::string str = std::string(extension);
|
||||
str.append(" ");
|
||||
|
||||
size_t pos = 0;
|
||||
if (extensions.find(extension, pos) != std::string::npos) {
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
} // namespace ndkHelper
|
||||
111
Teapot/app/src/main/cpp/ndk_helper/GLContext.h
Normal file
@@ -0,0 +1,111 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// GLContext.h
|
||||
//--------------------------------------------------------------------------------
|
||||
#ifndef GLCONTEXT_H_
|
||||
#define GLCONTEXT_H_
|
||||
|
||||
#include <EGL/egl.h>
|
||||
#include <GLES2/gl2.h>
|
||||
#include <android/log.h>
|
||||
|
||||
#include "JNIHelper.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// Constants
|
||||
//--------------------------------------------------------------------------------
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// Class
|
||||
//--------------------------------------------------------------------------------
|
||||
|
||||
/******************************************************************
|
||||
* OpenGL context handler
|
||||
* The class handles OpenGL and EGL context based on Android activity life cycle
|
||||
* The caller needs to call corresponding methods for each activity life cycle
|
||||
*events as it's done in sample codes.
|
||||
*
|
||||
* Also the class initializes OpenGL ES3 when the compatible driver is installed
|
||||
*in the device.
|
||||
* getGLVersion() returns 3.0~ when the device supports OpenGLES3.0
|
||||
*
|
||||
* Thread safety: OpenGL context is expecting used within dedicated single
|
||||
*thread,
|
||||
* thus GLContext class is not designed as a thread-safe
|
||||
*/
|
||||
class GLContext {
|
||||
private:
|
||||
// EGL configurations
|
||||
ANativeWindow* window_;
|
||||
EGLDisplay display_;
|
||||
EGLSurface surface_;
|
||||
EGLContext context_;
|
||||
EGLConfig config_;
|
||||
|
||||
// Screen parameters
|
||||
int32_t screen_width_;
|
||||
int32_t screen_height_;
|
||||
int32_t color_size_;
|
||||
int32_t depth_size_;
|
||||
|
||||
// Flags
|
||||
bool gles_initialized_;
|
||||
bool egl_context_initialized_;
|
||||
bool es3_supported_;
|
||||
float gl_version_;
|
||||
bool context_valid_;
|
||||
|
||||
void InitGLES();
|
||||
void Terminate();
|
||||
bool InitEGLSurface();
|
||||
bool InitEGLContext();
|
||||
|
||||
GLContext(GLContext const&);
|
||||
void operator=(GLContext const&);
|
||||
GLContext();
|
||||
virtual ~GLContext();
|
||||
|
||||
public:
|
||||
static GLContext* GetInstance() {
|
||||
// Singleton
|
||||
static GLContext instance;
|
||||
|
||||
return &instance;
|
||||
}
|
||||
|
||||
bool Init(ANativeWindow* window);
|
||||
EGLint Swap();
|
||||
bool Invalidate();
|
||||
|
||||
void Suspend();
|
||||
EGLint Resume(ANativeWindow* window);
|
||||
|
||||
int32_t GetScreenWidth() { return screen_width_; }
|
||||
int32_t GetScreenHeight() { return screen_height_; }
|
||||
|
||||
int32_t GetBufferColorSize() { return color_size_; }
|
||||
int32_t GetBufferDepthSize() { return depth_size_; }
|
||||
float GetGLVersion() { return gl_version_; }
|
||||
bool CheckExtension(const char* extension);
|
||||
};
|
||||
|
||||
} // namespace ndkHelper
|
||||
|
||||
#endif /* GLCONTEXT_H_ */
|
||||
365
Teapot/app/src/main/cpp/ndk_helper/JNIHelper.cpp
Normal file
@@ -0,0 +1,365 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
#include <EGL/egl.h>
|
||||
#include <GLES2/gl2.h>
|
||||
#include <fstream>
|
||||
#include <iostream>
|
||||
|
||||
#include "JNIHelper.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
#define CLASS_NAME "android/app/NativeActivity"
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
// JNI Helper functions
|
||||
//---------------------------------------------------------------------------
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
// Singleton
|
||||
//---------------------------------------------------------------------------
|
||||
JNIHelper* JNIHelper::GetInstance() {
|
||||
static JNIHelper helper;
|
||||
return &helper;
|
||||
}
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
// Ctor
|
||||
//---------------------------------------------------------------------------
|
||||
JNIHelper::JNIHelper() { pthread_mutex_init(&mutex_, NULL); }
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
// Dtor
|
||||
//---------------------------------------------------------------------------
|
||||
JNIHelper::~JNIHelper() {
|
||||
pthread_mutex_lock(&mutex_);
|
||||
|
||||
JNIEnv* env;
|
||||
activity_->vm->AttachCurrentThread(&env, NULL);
|
||||
|
||||
env->DeleteGlobalRef(jni_helper_java_ref_);
|
||||
env->DeleteGlobalRef(jni_helper_java_class_);
|
||||
|
||||
activity_->vm->DetachCurrentThread();
|
||||
|
||||
pthread_mutex_destroy(&mutex_);
|
||||
}
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
// Init
|
||||
//---------------------------------------------------------------------------
|
||||
void JNIHelper::Init(ANativeActivity* activity, const char* helper_class_name) {
|
||||
JNIHelper& helper = *GetInstance();
|
||||
pthread_mutex_lock(&helper.mutex_);
|
||||
|
||||
helper.activity_ = activity;
|
||||
|
||||
JNIEnv* env;
|
||||
helper.activity_->vm->AttachCurrentThread(&env, NULL);
|
||||
|
||||
// Retrieve app name
|
||||
jclass android_content_Context = env->GetObjectClass(helper.activity_->clazz);
|
||||
jmethodID midGetPackageName = env->GetMethodID(
|
||||
android_content_Context, "getPackageName", "()Ljava/lang/String;");
|
||||
|
||||
jstring packageName = (jstring)env->CallObjectMethod(helper.activity_->clazz,
|
||||
midGetPackageName);
|
||||
const char* appname = env->GetStringUTFChars(packageName, NULL);
|
||||
helper.app_name_ = std::string(appname);
|
||||
|
||||
jclass cls = helper.RetrieveClass(env, helper_class_name);
|
||||
helper.jni_helper_java_class_ = (jclass)env->NewGlobalRef(cls);
|
||||
|
||||
jmethodID constructor =
|
||||
env->GetMethodID(helper.jni_helper_java_class_, "<init>", "()V");
|
||||
helper.jni_helper_java_ref_ =
|
||||
env->NewObject(helper.jni_helper_java_class_, constructor);
|
||||
helper.jni_helper_java_ref_ = env->NewGlobalRef(helper.jni_helper_java_ref_);
|
||||
|
||||
env->ReleaseStringUTFChars(packageName, appname);
|
||||
helper.activity_->vm->DetachCurrentThread();
|
||||
|
||||
pthread_mutex_unlock(&helper.mutex_);
|
||||
}
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
// readFile
|
||||
//---------------------------------------------------------------------------
|
||||
bool JNIHelper::ReadFile(const char* fileName,
|
||||
std::vector<uint8_t>* buffer_ref) {
|
||||
if (activity_ == NULL) {
|
||||
LOGI(
|
||||
"JNIHelper has not been initialized.Call init() to initialize the "
|
||||
"helper");
|
||||
return false;
|
||||
}
|
||||
|
||||
// First, try reading from externalFileDir;
|
||||
JNIEnv* env;
|
||||
|
||||
pthread_mutex_lock(&mutex_);
|
||||
activity_->vm->AttachCurrentThread(&env, NULL);
|
||||
|
||||
jstring str_path = GetExternalFilesDirJString(env);
|
||||
const char* path = env->GetStringUTFChars(str_path, NULL);
|
||||
std::string s(path);
|
||||
|
||||
if (fileName[0] != '/') {
|
||||
s.append("/");
|
||||
}
|
||||
s.append(fileName);
|
||||
std::ifstream f(s.c_str(), std::ios::binary);
|
||||
|
||||
env->ReleaseStringUTFChars(str_path, path);
|
||||
env->DeleteLocalRef(str_path);
|
||||
activity_->vm->DetachCurrentThread();
|
||||
|
||||
if (f) {
|
||||
LOGI("reading:%s", s.c_str());
|
||||
f.seekg(0, std::ifstream::end);
|
||||
int32_t fileSize = f.tellg();
|
||||
f.seekg(0, std::ifstream::beg);
|
||||
buffer_ref->reserve(fileSize);
|
||||
buffer_ref->assign(std::istreambuf_iterator<char>(f),
|
||||
std::istreambuf_iterator<char>());
|
||||
f.close();
|
||||
pthread_mutex_unlock(&mutex_);
|
||||
return true;
|
||||
} else {
|
||||
// Fallback to assetManager
|
||||
AAssetManager* assetManager = activity_->assetManager;
|
||||
AAsset* assetFile =
|
||||
AAssetManager_open(assetManager, fileName, AASSET_MODE_BUFFER);
|
||||
if (!assetFile) {
|
||||
pthread_mutex_unlock(&mutex_);
|
||||
return false;
|
||||
}
|
||||
uint8_t* data = (uint8_t*)AAsset_getBuffer(assetFile);
|
||||
int32_t size = AAsset_getLength(assetFile);
|
||||
if (data == NULL) {
|
||||
AAsset_close(assetFile);
|
||||
|
||||
LOGI("Failed to load:%s", fileName);
|
||||
pthread_mutex_unlock(&mutex_);
|
||||
return false;
|
||||
}
|
||||
|
||||
buffer_ref->reserve(size);
|
||||
buffer_ref->assign(data, data + size);
|
||||
|
||||
AAsset_close(assetFile);
|
||||
pthread_mutex_unlock(&mutex_);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
std::string JNIHelper::GetExternalFilesDir() {
|
||||
if (activity_ == NULL) {
|
||||
LOGI(
|
||||
"JNIHelper has not been initialized. Call init() to initialize the "
|
||||
"helper");
|
||||
return std::string("");
|
||||
}
|
||||
|
||||
pthread_mutex_lock(&mutex_);
|
||||
|
||||
// First, try reading from externalFileDir;
|
||||
JNIEnv* env;
|
||||
|
||||
activity_->vm->AttachCurrentThread(&env, NULL);
|
||||
|
||||
jstring strPath = GetExternalFilesDirJString(env);
|
||||
const char* path = env->GetStringUTFChars(strPath, NULL);
|
||||
std::string s(path);
|
||||
|
||||
env->ReleaseStringUTFChars(strPath, path);
|
||||
env->DeleteLocalRef(strPath);
|
||||
activity_->vm->DetachCurrentThread();
|
||||
|
||||
pthread_mutex_unlock(&mutex_);
|
||||
return s;
|
||||
}
|
||||
|
||||
uint32_t JNIHelper::LoadTexture(const char* file_name) {
|
||||
if (activity_ == NULL) {
|
||||
LOGI(
|
||||
"JNIHelper has not been initialized. Call init() to initialize the "
|
||||
"helper");
|
||||
return 0;
|
||||
}
|
||||
|
||||
JNIEnv* env;
|
||||
jmethodID mid;
|
||||
|
||||
pthread_mutex_lock(&mutex_);
|
||||
activity_->vm->AttachCurrentThread(&env, NULL);
|
||||
|
||||
jstring name = env->NewStringUTF(file_name);
|
||||
|
||||
GLuint tex;
|
||||
glGenTextures(1, &tex);
|
||||
glBindTexture(GL_TEXTURE_2D, tex);
|
||||
|
||||
glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER,
|
||||
GL_LINEAR_MIPMAP_NEAREST);
|
||||
glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
|
||||
|
||||
mid = env->GetMethodID(jni_helper_java_class_, "loadTexture",
|
||||
"(Ljava/lang/String;)Z");
|
||||
jboolean ret = env->CallBooleanMethod(jni_helper_java_ref_, mid, name);
|
||||
if (!ret) {
|
||||
glDeleteTextures(1, &tex);
|
||||
tex = -1;
|
||||
LOGI("Texture load failed %s", file_name);
|
||||
}
|
||||
|
||||
// Generate mipmap
|
||||
glGenerateMipmap(GL_TEXTURE_2D);
|
||||
|
||||
env->DeleteLocalRef(name);
|
||||
activity_->vm->DetachCurrentThread();
|
||||
pthread_mutex_unlock(&mutex_);
|
||||
|
||||
return tex;
|
||||
}
|
||||
|
||||
std::string JNIHelper::ConvertString(const char* str, const char* encode) {
|
||||
if (activity_ == NULL) {
|
||||
LOGI(
|
||||
"JNIHelper has not been initialized. Call init() to initialize the "
|
||||
"helper");
|
||||
return std::string("");
|
||||
}
|
||||
|
||||
JNIEnv* env;
|
||||
|
||||
pthread_mutex_lock(&mutex_);
|
||||
activity_->vm->AttachCurrentThread(&env, NULL);
|
||||
|
||||
int32_t iLength = strlen((const char*)str);
|
||||
|
||||
jbyteArray array = env->NewByteArray(iLength);
|
||||
env->SetByteArrayRegion(array, 0, iLength, (const signed char*)str);
|
||||
|
||||
jstring strEncode = env->NewStringUTF(encode);
|
||||
|
||||
jclass cls = env->FindClass("java/lang/String");
|
||||
jmethodID ctor = env->GetMethodID(cls, "<init>", "([BLjava/lang/String;)V");
|
||||
jstring object = (jstring)env->NewObject(cls, ctor, array, strEncode);
|
||||
|
||||
const char* cparam = env->GetStringUTFChars(object, NULL);
|
||||
|
||||
std::string s = std::string(cparam);
|
||||
|
||||
env->ReleaseStringUTFChars(object, cparam);
|
||||
env->DeleteLocalRef(strEncode);
|
||||
env->DeleteLocalRef(object);
|
||||
activity_->vm->DetachCurrentThread();
|
||||
pthread_mutex_unlock(&mutex_);
|
||||
|
||||
return s;
|
||||
}
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
// Audio helpers
|
||||
//---------------------------------------------------------------------------
|
||||
int32_t JNIHelper::GetNativeAudioBufferSize() {
|
||||
if (activity_ == NULL) {
|
||||
LOGI(
|
||||
"JNIHelper has not been initialized. Call init() to initialize the "
|
||||
"helper");
|
||||
return 0;
|
||||
}
|
||||
|
||||
JNIEnv* env;
|
||||
jmethodID mid;
|
||||
|
||||
pthread_mutex_lock(&mutex_);
|
||||
activity_->vm->AttachCurrentThread(&env, NULL);
|
||||
|
||||
mid = env->GetMethodID(jni_helper_java_class_, "getNativeAudioBufferSize",
|
||||
"()I");
|
||||
int32_t i = env->CallIntMethod(jni_helper_java_ref_, mid);
|
||||
activity_->vm->DetachCurrentThread();
|
||||
pthread_mutex_unlock(&mutex_);
|
||||
|
||||
return i;
|
||||
}
|
||||
|
||||
int32_t JNIHelper::GetNativeAudioSampleRate() {
|
||||
if (activity_ == NULL) {
|
||||
LOGI(
|
||||
"JNIHelper has not been initialized. Call init() to initialize the "
|
||||
"helper");
|
||||
return 0;
|
||||
}
|
||||
|
||||
JNIEnv* env;
|
||||
jmethodID mid;
|
||||
|
||||
pthread_mutex_lock(&mutex_);
|
||||
activity_->vm->AttachCurrentThread(&env, NULL);
|
||||
|
||||
mid = env->GetMethodID(jni_helper_java_class_, "getNativeAudioSampleRate",
|
||||
"()I");
|
||||
int32_t i = env->CallIntMethod(jni_helper_java_ref_, mid);
|
||||
activity_->vm->DetachCurrentThread();
|
||||
pthread_mutex_unlock(&mutex_);
|
||||
|
||||
return i;
|
||||
}
|
||||
|
||||
//---------------------------------------------------------------------------
|
||||
// Misc implementations
|
||||
//---------------------------------------------------------------------------
|
||||
jclass JNIHelper::RetrieveClass(JNIEnv* jni, const char* class_name) {
|
||||
jclass activity_class = jni->FindClass(CLASS_NAME);
|
||||
jmethodID get_class_loader = jni->GetMethodID(
|
||||
activity_class, "getClassLoader", "()Ljava/lang/ClassLoader;");
|
||||
jobject cls = jni->CallObjectMethod(activity_->clazz, get_class_loader);
|
||||
jclass class_loader = jni->FindClass("java/lang/ClassLoader");
|
||||
jmethodID find_class = jni->GetMethodID(
|
||||
class_loader, "loadClass", "(Ljava/lang/String;)Ljava/lang/Class;");
|
||||
|
||||
jstring str_class_name = jni->NewStringUTF(class_name);
|
||||
jclass class_retrieved =
|
||||
(jclass)jni->CallObjectMethod(cls, find_class, str_class_name);
|
||||
jni->DeleteLocalRef(str_class_name);
|
||||
return class_retrieved;
|
||||
}
|
||||
|
||||
jstring JNIHelper::GetExternalFilesDirJString(JNIEnv* env) {
|
||||
if (activity_ == NULL) {
|
||||
LOGI(
|
||||
"JNIHelper has not been initialized. Call init() to initialize the "
|
||||
"helper");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
// Invoking getExternalFilesDir() java API
|
||||
jclass cls_Env = env->FindClass(CLASS_NAME);
|
||||
jmethodID mid = env->GetMethodID(cls_Env, "getExternalFilesDir",
|
||||
"(Ljava/lang/String;)Ljava/io/File;");
|
||||
jobject obj_File = env->CallObjectMethod(activity_->clazz, mid, NULL);
|
||||
jclass cls_File = env->FindClass("java/io/File");
|
||||
jmethodID mid_getPath =
|
||||
env->GetMethodID(cls_File, "getPath", "()Ljava/lang/String;");
|
||||
jstring obj_Path = (jstring)env->CallObjectMethod(obj_File, mid_getPath);
|
||||
|
||||
return obj_Path;
|
||||
}
|
||||
|
||||
} // namespace ndkHelper
|
||||
183
Teapot/app/src/main/cpp/ndk_helper/JNIHelper.h
Normal file
@@ -0,0 +1,183 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include <jni.h>
|
||||
#include <vector>
|
||||
#include <string>
|
||||
|
||||
#include <android/log.h>
|
||||
#include <android_native_app_glue.h>
|
||||
|
||||
#define LOGI(...) \
|
||||
((void)__android_log_print( \
|
||||
ANDROID_LOG_INFO, ndk_helper::JNIHelper::GetInstance()->GetAppName(), \
|
||||
__VA_ARGS__))
|
||||
#define LOGW(...) \
|
||||
((void)__android_log_print( \
|
||||
ANDROID_LOG_WARN, ndk_helper::JNIHelper::GetInstance()->GetAppName(), \
|
||||
__VA_ARGS__))
|
||||
#define LOGE(...) \
|
||||
((void)__android_log_print( \
|
||||
ANDROID_LOG_ERROR, ndk_helper::JNIHelper::GetInstance()->GetAppName(), \
|
||||
__VA_ARGS__))
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
/******************************************************************
|
||||
* Helper functions for JNI calls
|
||||
* This class wraps JNI calls and provides handy interface calling commonly used
|
||||
*features
|
||||
* in Java SDK.
|
||||
* Such as
|
||||
* - loading graphics files (e.g. PNG, JPG)
|
||||
* - character code conversion
|
||||
* - retrieving system properties which only supported in Java SDK
|
||||
*
|
||||
* NOTE: To use this class, add NDKHelper.java as a corresponding helpers in
|
||||
*Java code
|
||||
*/
|
||||
class JNIHelper {
|
||||
private:
|
||||
std::string app_name_;
|
||||
|
||||
ANativeActivity* activity_;
|
||||
jobject jni_helper_java_ref_;
|
||||
jclass jni_helper_java_class_;
|
||||
|
||||
// mutex for synchronization
|
||||
// This class uses singleton pattern and can be invoked from multiple threads,
|
||||
// each methods locks the mutex for a thread safety
|
||||
mutable pthread_mutex_t mutex_;
|
||||
|
||||
jstring GetExternalFilesDirJString(JNIEnv* env);
|
||||
jclass RetrieveClass(JNIEnv* jni, const char* class_name);
|
||||
|
||||
JNIHelper();
|
||||
~JNIHelper();
|
||||
JNIHelper(const JNIHelper& rhs);
|
||||
JNIHelper& operator=(const JNIHelper& rhs);
|
||||
|
||||
public:
|
||||
/*
|
||||
* To load your own Java classes, JNIHelper requires to be initialized with a
|
||||
*ANativeActivity handle.
|
||||
* This methods need to be called before any call to the helper class.
|
||||
* Static member of the class
|
||||
*
|
||||
* arguments:
|
||||
* in: activity, pointer to ANativeActivity. Used internally to set up JNI
|
||||
*environment
|
||||
* in: helper_class_name, pointer to Java side helper class name. (e.g.
|
||||
*"com/sample/helper/NDKHelper" in samples )
|
||||
*/
|
||||
static void Init(ANativeActivity* activity, const char* helper_class_name);
|
||||
|
||||
/*
|
||||
* Retrieve the singleton object of the helper.
|
||||
* Static member of the class
|
||||
|
||||
* Methods in the class are designed as thread safe.
|
||||
*/
|
||||
static JNIHelper* GetInstance();
|
||||
|
||||
/*
|
||||
* Read a file from a strorage.
|
||||
* First, the method tries to read the file from an external storage.
|
||||
* If it fails to read, it falls back to use assset manager and try to read
|
||||
*the file from APK asset.
|
||||
*
|
||||
* arguments:
|
||||
* in: file_name, file name to read
|
||||
* out: buffer_ref, pointer to a vector buffer to read a file.
|
||||
* when the call succeeded, the buffer includes contents of specified
|
||||
*file
|
||||
* when the call failed, contents of the buffer remains same
|
||||
* return:
|
||||
* true when file read succeeded
|
||||
* false when it failed to read the file
|
||||
*/
|
||||
bool ReadFile(const char* file_name, std::vector<uint8_t>* buffer_ref);
|
||||
|
||||
/*
|
||||
* Load and create OpenGL texture from given file name.
|
||||
* The method invokes BitmapFactory in Java so it can read jpeg/png formatted
|
||||
*files
|
||||
*
|
||||
* The methods creates mip-map and set texture parameters like this,
|
||||
* glTexParameterf( GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER,
|
||||
*GL_LINEAR_MIPMAP_NEAREST );
|
||||
* glTexParameterf( GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR );
|
||||
* glGenerateMipmap( GL_TEXTURE_2D );
|
||||
*
|
||||
* arguments:
|
||||
* in: file_name, file name to read, PNG&JPG is supported
|
||||
* return:
|
||||
* OpenGL texture name when the call succeeded
|
||||
* When it failed to load the texture, it returns -1
|
||||
*/
|
||||
uint32_t LoadTexture(const char* file_name);
|
||||
|
||||
/*
|
||||
* Convert string from character code other than UTF-8
|
||||
*
|
||||
* arguments:
|
||||
* in: str, pointer to a string which is encoded other than UTF-8
|
||||
* in: encoding, pointer to a character encoding string.
|
||||
* The encoding string can be any valid java.nio.charset.Charset name
|
||||
* e.g. "UTF-16", "Shift_JIS"
|
||||
* return: converted input string as an UTF-8 std::string
|
||||
*/
|
||||
std::string ConvertString(const char* str, const char* encode);
|
||||
/*
|
||||
* Retrieve external file directory through JNI call
|
||||
*
|
||||
* return: std::string containing external file diretory
|
||||
*/
|
||||
std::string GetExternalFilesDir();
|
||||
|
||||
/*
|
||||
* Audio helper
|
||||
* Retrieves native audio buffer size which is required to achieve low latency
|
||||
*audio
|
||||
*
|
||||
* return: Native audio buffer size which is a hint to achieve low latency
|
||||
*audio
|
||||
* If the API is not supported (API level < 17), it returns 0
|
||||
*/
|
||||
int32_t GetNativeAudioBufferSize();
|
||||
|
||||
/*
|
||||
* Audio helper
|
||||
* Retrieves native audio sample rate which is required to achieve low latency
|
||||
*audio
|
||||
*
|
||||
* return: Native audio sample rate which is a hint to achieve low latency
|
||||
*audio
|
||||
*/
|
||||
int32_t GetNativeAudioSampleRate();
|
||||
|
||||
/*
|
||||
* Retrieves application bundle name
|
||||
*
|
||||
* return: pointer to an app name string
|
||||
*
|
||||
*/
|
||||
const char* GetAppName() { return app_name_.c_str(); }
|
||||
};
|
||||
|
||||
} // namespace ndkHelper
|
||||
40
Teapot/app/src/main/cpp/ndk_helper/NDKHelper.h
Normal file
@@ -0,0 +1,40 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#ifndef _NDKSUPPORT_H
|
||||
#define _NDKSUPPORT_H
|
||||
|
||||
/******************************************************************
|
||||
* NDK support helpers
|
||||
* Utility module to provide misc functionalities that is used widely in native
|
||||
*applications,
|
||||
* such as gesture detection, jni bridge, openGL context etc.
|
||||
*
|
||||
* The purpose of this module is,
|
||||
* - Provide best practices using NDK
|
||||
* - Provide handy utility functions for NDK development
|
||||
* - Make NDK samples more simpler and readable
|
||||
*/
|
||||
#include "gl3stub.h" //GLES3 stubs
|
||||
#include "GLContext.h" //EGL & OpenGL manager
|
||||
#include "shader.h" //Shader compiler support
|
||||
#include "vecmath.h" //Vector math support, C++ implementation n current version
|
||||
#include "tapCamera.h" //Tap/Pinch camera control
|
||||
#include "JNIHelper.h" //JNI support
|
||||
#include "gestureDetector.h" //Tap/Doubletap/Pinch detector
|
||||
#include "perfMonitor.h" //FPS counter
|
||||
#include "interpolator.h" //Interpolator
|
||||
#endif
|
||||
296
Teapot/app/src/main/cpp/ndk_helper/gestureDetector.cpp
Normal file
@@ -0,0 +1,296 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include "gestureDetector.h"
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// gestureDetector.cpp
|
||||
//--------------------------------------------------------------------------------
|
||||
namespace ndk_helper {
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// includes
|
||||
//--------------------------------------------------------------------------------
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// GestureDetector
|
||||
//--------------------------------------------------------------------------------
|
||||
GestureDetector::GestureDetector() { dp_factor_ = 1.f; }
|
||||
|
||||
void GestureDetector::SetConfiguration(AConfiguration* config) {
|
||||
dp_factor_ = 160.f / AConfiguration_getDensity(config);
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// TapDetector
|
||||
//--------------------------------------------------------------------------------
|
||||
GESTURE_STATE TapDetector::Detect(const AInputEvent* motion_event) {
|
||||
if (AMotionEvent_getPointerCount(motion_event) > 1) {
|
||||
// Only support single touch
|
||||
return false;
|
||||
}
|
||||
|
||||
int32_t action = AMotionEvent_getAction(motion_event);
|
||||
unsigned int flags = action & AMOTION_EVENT_ACTION_MASK;
|
||||
switch (flags) {
|
||||
case AMOTION_EVENT_ACTION_DOWN:
|
||||
down_pointer_id_ = AMotionEvent_getPointerId(motion_event, 0);
|
||||
down_x_ = AMotionEvent_getX(motion_event, 0);
|
||||
down_y_ = AMotionEvent_getY(motion_event, 0);
|
||||
break;
|
||||
case AMOTION_EVENT_ACTION_UP: {
|
||||
int64_t eventTime = AMotionEvent_getEventTime(motion_event);
|
||||
int64_t downTime = AMotionEvent_getDownTime(motion_event);
|
||||
if (eventTime - downTime <= TAP_TIMEOUT) {
|
||||
if (down_pointer_id_ == AMotionEvent_getPointerId(motion_event, 0)) {
|
||||
float x = AMotionEvent_getX(motion_event, 0) - down_x_;
|
||||
float y = AMotionEvent_getY(motion_event, 0) - down_y_;
|
||||
if (x * x + y * y < TOUCH_SLOP * TOUCH_SLOP * dp_factor_) {
|
||||
LOGI("TapDetector: Tap detected");
|
||||
return GESTURE_STATE_ACTION;
|
||||
}
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
return GESTURE_STATE_NONE;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// DoubletapDetector
|
||||
//--------------------------------------------------------------------------------
|
||||
GESTURE_STATE DoubletapDetector::Detect(const AInputEvent* motion_event) {
|
||||
if (AMotionEvent_getPointerCount(motion_event) > 1) {
|
||||
// Only support single double tap
|
||||
return false;
|
||||
}
|
||||
|
||||
bool tap_detected = tap_detector_.Detect(motion_event);
|
||||
|
||||
int32_t action = AMotionEvent_getAction(motion_event);
|
||||
unsigned int flags = action & AMOTION_EVENT_ACTION_MASK;
|
||||
switch (flags) {
|
||||
case AMOTION_EVENT_ACTION_DOWN: {
|
||||
int64_t eventTime = AMotionEvent_getEventTime(motion_event);
|
||||
if (eventTime - last_tap_time_ <= DOUBLE_TAP_TIMEOUT) {
|
||||
float x = AMotionEvent_getX(motion_event, 0) - last_tap_x_;
|
||||
float y = AMotionEvent_getY(motion_event, 0) - last_tap_y_;
|
||||
if (x * x + y * y < DOUBLE_TAP_SLOP * DOUBLE_TAP_SLOP * dp_factor_) {
|
||||
LOGI("DoubletapDetector: Doubletap detected");
|
||||
return GESTURE_STATE_ACTION;
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
case AMOTION_EVENT_ACTION_UP:
|
||||
if (tap_detected) {
|
||||
last_tap_time_ = AMotionEvent_getEventTime(motion_event);
|
||||
last_tap_x_ = AMotionEvent_getX(motion_event, 0);
|
||||
last_tap_y_ = AMotionEvent_getY(motion_event, 0);
|
||||
}
|
||||
break;
|
||||
}
|
||||
return GESTURE_STATE_NONE;
|
||||
}
|
||||
|
||||
void DoubletapDetector::SetConfiguration(AConfiguration* config) {
|
||||
dp_factor_ = 160.f / AConfiguration_getDensity(config);
|
||||
tap_detector_.SetConfiguration(config);
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// PinchDetector
|
||||
//--------------------------------------------------------------------------------
|
||||
|
||||
int32_t PinchDetector::FindIndex(const AInputEvent* event, int32_t id) {
|
||||
int32_t count = AMotionEvent_getPointerCount(event);
|
||||
for (auto i = 0; i < count; ++i) {
|
||||
if (id == AMotionEvent_getPointerId(event, i)) return i;
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
|
||||
GESTURE_STATE PinchDetector::Detect(const AInputEvent* event) {
|
||||
GESTURE_STATE ret = GESTURE_STATE_NONE;
|
||||
int32_t action = AMotionEvent_getAction(event);
|
||||
uint32_t flags = action & AMOTION_EVENT_ACTION_MASK;
|
||||
event_ = event;
|
||||
|
||||
int32_t count = AMotionEvent_getPointerCount(event);
|
||||
switch (flags) {
|
||||
case AMOTION_EVENT_ACTION_DOWN:
|
||||
vec_pointers_.push_back(AMotionEvent_getPointerId(event, 0));
|
||||
break;
|
||||
case AMOTION_EVENT_ACTION_POINTER_DOWN: {
|
||||
int32_t iIndex = (action & AMOTION_EVENT_ACTION_POINTER_INDEX_MASK) >>
|
||||
AMOTION_EVENT_ACTION_POINTER_INDEX_SHIFT;
|
||||
vec_pointers_.push_back(AMotionEvent_getPointerId(event, iIndex));
|
||||
if (count == 2) {
|
||||
// Start new pinch
|
||||
ret = GESTURE_STATE_START;
|
||||
}
|
||||
} break;
|
||||
case AMOTION_EVENT_ACTION_UP:
|
||||
vec_pointers_.pop_back();
|
||||
break;
|
||||
case AMOTION_EVENT_ACTION_POINTER_UP: {
|
||||
int32_t index = (action & AMOTION_EVENT_ACTION_POINTER_INDEX_MASK) >>
|
||||
AMOTION_EVENT_ACTION_POINTER_INDEX_SHIFT;
|
||||
int32_t released_pointer_id = AMotionEvent_getPointerId(event, index);
|
||||
|
||||
std::vector<int32_t>::iterator it = vec_pointers_.begin();
|
||||
std::vector<int32_t>::iterator it_end = vec_pointers_.end();
|
||||
int32_t i = 0;
|
||||
for (; it != it_end; ++it, ++i) {
|
||||
if (*it == released_pointer_id) {
|
||||
vec_pointers_.erase(it);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (i <= 1) {
|
||||
// Reset pinch or drag
|
||||
if (count != 2) {
|
||||
// Start new pinch
|
||||
ret = GESTURE_STATE_START | GESTURE_STATE_END;
|
||||
}
|
||||
}
|
||||
} break;
|
||||
case AMOTION_EVENT_ACTION_MOVE:
|
||||
switch (count) {
|
||||
case 1:
|
||||
break;
|
||||
default:
|
||||
// Multi touch
|
||||
ret = GESTURE_STATE_MOVE;
|
||||
break;
|
||||
}
|
||||
break;
|
||||
case AMOTION_EVENT_ACTION_CANCEL:
|
||||
break;
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
bool PinchDetector::GetPointers(Vec2& v1, Vec2& v2) {
|
||||
if (vec_pointers_.size() < 2) return false;
|
||||
|
||||
int32_t index = FindIndex(event_, vec_pointers_[0]);
|
||||
if (index == -1) return false;
|
||||
|
||||
float x = AMotionEvent_getX(event_, index);
|
||||
float y = AMotionEvent_getY(event_, index);
|
||||
|
||||
index = FindIndex(event_, vec_pointers_[1]);
|
||||
if (index == -1) return false;
|
||||
|
||||
float x2 = AMotionEvent_getX(event_, index);
|
||||
float y2 = AMotionEvent_getY(event_, index);
|
||||
|
||||
v1 = Vec2(x, y);
|
||||
v2 = Vec2(x2, y2);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// DragDetector
|
||||
//--------------------------------------------------------------------------------
|
||||
|
||||
int32_t DragDetector::FindIndex(const AInputEvent* event, int32_t id) {
|
||||
int32_t count = AMotionEvent_getPointerCount(event);
|
||||
for (auto i = 0; i < count; ++i) {
|
||||
if (id == AMotionEvent_getPointerId(event, i)) return i;
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
|
||||
GESTURE_STATE DragDetector::Detect(const AInputEvent* event) {
|
||||
GESTURE_STATE ret = GESTURE_STATE_NONE;
|
||||
int32_t action = AMotionEvent_getAction(event);
|
||||
int32_t index = (action & AMOTION_EVENT_ACTION_POINTER_INDEX_MASK) >>
|
||||
AMOTION_EVENT_ACTION_POINTER_INDEX_SHIFT;
|
||||
uint32_t flags = action & AMOTION_EVENT_ACTION_MASK;
|
||||
event_ = event;
|
||||
|
||||
int32_t count = AMotionEvent_getPointerCount(event);
|
||||
switch (flags) {
|
||||
case AMOTION_EVENT_ACTION_DOWN:
|
||||
vec_pointers_.push_back(AMotionEvent_getPointerId(event, 0));
|
||||
ret = GESTURE_STATE_START;
|
||||
break;
|
||||
case AMOTION_EVENT_ACTION_POINTER_DOWN:
|
||||
vec_pointers_.push_back(AMotionEvent_getPointerId(event, index));
|
||||
break;
|
||||
case AMOTION_EVENT_ACTION_UP:
|
||||
vec_pointers_.pop_back();
|
||||
ret = GESTURE_STATE_END;
|
||||
break;
|
||||
case AMOTION_EVENT_ACTION_POINTER_UP: {
|
||||
int32_t released_pointer_id = AMotionEvent_getPointerId(event, index);
|
||||
|
||||
auto it = vec_pointers_.begin();
|
||||
auto it_end = vec_pointers_.end();
|
||||
int32_t i = 0;
|
||||
for (; it != it_end; ++it, ++i) {
|
||||
if (*it == released_pointer_id) {
|
||||
vec_pointers_.erase(it);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (i <= 1) {
|
||||
// Reset pinch or drag
|
||||
if (count == 2) {
|
||||
ret = GESTURE_STATE_START;
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
case AMOTION_EVENT_ACTION_MOVE:
|
||||
switch (count) {
|
||||
case 1:
|
||||
// Drag
|
||||
ret = GESTURE_STATE_MOVE;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
break;
|
||||
case AMOTION_EVENT_ACTION_CANCEL:
|
||||
break;
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
bool DragDetector::GetPointer(Vec2& v) {
|
||||
if (vec_pointers_.size() < 1) return false;
|
||||
|
||||
int32_t iIndex = FindIndex(event_, vec_pointers_[0]);
|
||||
if (iIndex == -1) return false;
|
||||
|
||||
float x = AMotionEvent_getX(event_, iIndex);
|
||||
float y = AMotionEvent_getY(event_, iIndex);
|
||||
|
||||
v = Vec2(x, y);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
} // namespace ndkHelper
|
||||
144
Teapot/app/src/main/cpp/ndk_helper/gestureDetector.h
Normal file
@@ -0,0 +1,144 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// gestureDetector.h
|
||||
//--------------------------------------------------------------------------------
|
||||
#ifndef GESTUREDETECTOR_H_
|
||||
#define GESTUREDETECTOR_H_
|
||||
|
||||
#include <vector>
|
||||
|
||||
#include <android/sensor.h>
|
||||
#include <android/log.h>
|
||||
#include <android_native_app_glue.h>
|
||||
#include <android/native_window_jni.h>
|
||||
#include "JNIHelper.h"
|
||||
#include "vecmath.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
//--------------------------------------------------------------------------------
|
||||
// Constants
|
||||
//--------------------------------------------------------------------------------
|
||||
const int32_t DOUBLE_TAP_TIMEOUT = 300 * 1000000;
|
||||
const int32_t TAP_TIMEOUT = 180 * 1000000;
|
||||
const int32_t DOUBLE_TAP_SLOP = 100;
|
||||
const int32_t TOUCH_SLOP = 8;
|
||||
|
||||
enum {
|
||||
GESTURE_STATE_NONE = 0,
|
||||
GESTURE_STATE_START = 1,
|
||||
GESTURE_STATE_MOVE = 2,
|
||||
GESTURE_STATE_END = 4,
|
||||
GESTURE_STATE_ACTION = (GESTURE_STATE_START | GESTURE_STATE_END),
|
||||
};
|
||||
typedef int32_t GESTURE_STATE;
|
||||
|
||||
/******************************************************************
|
||||
* Base class of Gesture Detectors
|
||||
* GestureDetectors handles input events and detect gestures
|
||||
* Note that different detectors may detect gestures with an event at
|
||||
* same time. The caller needs to manage gesture priority accordingly
|
||||
*
|
||||
*/
|
||||
class GestureDetector {
|
||||
protected:
|
||||
float dp_factor_;
|
||||
|
||||
public:
|
||||
GestureDetector();
|
||||
virtual ~GestureDetector() {}
|
||||
virtual void SetConfiguration(AConfiguration* config);
|
||||
|
||||
virtual GESTURE_STATE Detect(const AInputEvent* motion_event) = 0;
|
||||
};
|
||||
|
||||
/******************************************************************
|
||||
* Tap gesture detector
|
||||
* Returns GESTURE_STATE_ACTION when a tap gesture is detected
|
||||
*
|
||||
*/
|
||||
class TapDetector : public GestureDetector {
|
||||
private:
|
||||
int32_t down_pointer_id_;
|
||||
float down_x_;
|
||||
float down_y_;
|
||||
|
||||
public:
|
||||
TapDetector() {}
|
||||
virtual ~TapDetector() {}
|
||||
virtual GESTURE_STATE Detect(const AInputEvent* motion_event);
|
||||
};
|
||||
|
||||
/******************************************************************
|
||||
* Pinch gesture detector
|
||||
* Returns GESTURE_STATE_ACTION when a double-tap gesture is detected
|
||||
*
|
||||
*/
|
||||
class DoubletapDetector : public GestureDetector {
|
||||
private:
|
||||
TapDetector tap_detector_;
|
||||
int64_t last_tap_time_;
|
||||
float last_tap_x_;
|
||||
float last_tap_y_;
|
||||
|
||||
public:
|
||||
DoubletapDetector() {}
|
||||
virtual ~DoubletapDetector() {}
|
||||
virtual GESTURE_STATE Detect(const AInputEvent* motion_event);
|
||||
virtual void SetConfiguration(AConfiguration* config);
|
||||
};
|
||||
|
||||
/******************************************************************
|
||||
* Double gesture detector
|
||||
* Returns pinch gesture state when a pinch gesture is detected
|
||||
* The class handles multiple touches more than 2
|
||||
* When the finger 1,2,3 are tapped and then finger 1 is released,
|
||||
* the detector start new pinch gesture with finger 2 & 3.
|
||||
*/
|
||||
class PinchDetector : public GestureDetector {
|
||||
private:
|
||||
int32_t FindIndex(const AInputEvent* event, int32_t id);
|
||||
const AInputEvent* event_;
|
||||
std::vector<int32_t> vec_pointers_;
|
||||
|
||||
public:
|
||||
PinchDetector() {}
|
||||
virtual ~PinchDetector() {}
|
||||
virtual GESTURE_STATE Detect(const AInputEvent* event);
|
||||
bool GetPointers(Vec2& v1, Vec2& v2);
|
||||
};
|
||||
|
||||
/******************************************************************
|
||||
* Drag gesture detector
|
||||
* Returns drag gesture state when a drag-tap gesture is detected
|
||||
*
|
||||
*/
|
||||
class DragDetector : public GestureDetector {
|
||||
private:
|
||||
int32_t FindIndex(const AInputEvent* event, int32_t id);
|
||||
const AInputEvent* event_;
|
||||
std::vector<int32_t> vec_pointers_;
|
||||
|
||||
public:
|
||||
DragDetector() {}
|
||||
virtual ~DragDetector() {}
|
||||
virtual GESTURE_STATE Detect(const AInputEvent* event);
|
||||
bool GetPointer(Vec2& v);
|
||||
};
|
||||
|
||||
} // namespace ndkHelper
|
||||
#endif /* GESTUREDETECTOR_H_ */
|
||||
512
Teapot/app/src/main/cpp/ndk_helper/gl3stub.c
Normal file
@@ -0,0 +1,512 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include <EGL/egl.h>
|
||||
#include "gl3stub.h"
|
||||
|
||||
GLboolean gl3stubInit()
|
||||
{
|
||||
#define FIND_PROC(s) s = (void*)eglGetProcAddress(#s);
|
||||
FIND_PROC( glReadBuffer );
|
||||
FIND_PROC( glDrawRangeElements );
|
||||
FIND_PROC( glTexImage3D );
|
||||
FIND_PROC( glTexSubImage3D );
|
||||
FIND_PROC( glCopyTexSubImage3D );
|
||||
FIND_PROC( glCompressedTexImage3D );
|
||||
FIND_PROC( glCompressedTexSubImage3D );
|
||||
FIND_PROC( glGenQueries );
|
||||
FIND_PROC( glDeleteQueries );
|
||||
FIND_PROC( glIsQuery );
|
||||
FIND_PROC( glBeginQuery );
|
||||
FIND_PROC( glEndQuery );
|
||||
FIND_PROC( glGetQueryiv );
|
||||
FIND_PROC( glGetQueryObjectuiv );
|
||||
FIND_PROC( glUnmapBuffer );
|
||||
FIND_PROC( glGetBufferPointerv );
|
||||
FIND_PROC( glDrawBuffers );
|
||||
FIND_PROC( glUniformMatrix2x3fv );
|
||||
FIND_PROC( glUniformMatrix3x2fv );
|
||||
FIND_PROC( glUniformMatrix2x4fv );
|
||||
FIND_PROC( glUniformMatrix4x2fv );
|
||||
FIND_PROC( glUniformMatrix3x4fv );
|
||||
FIND_PROC( glUniformMatrix4x3fv );
|
||||
FIND_PROC( glBlitFramebuffer );
|
||||
FIND_PROC( glRenderbufferStorageMultisample );
|
||||
FIND_PROC( glFramebufferTextureLayer );
|
||||
FIND_PROC( glMapBufferRange );
|
||||
FIND_PROC( glFlushMappedBufferRange );
|
||||
FIND_PROC( glBindVertexArray );
|
||||
FIND_PROC( glDeleteVertexArrays );
|
||||
FIND_PROC( glGenVertexArrays );
|
||||
FIND_PROC( glIsVertexArray );
|
||||
FIND_PROC( glGetIntegeri_v );
|
||||
FIND_PROC( glBeginTransformFeedback );
|
||||
FIND_PROC( glEndTransformFeedback );
|
||||
FIND_PROC( glBindBufferRange );
|
||||
FIND_PROC( glBindBufferBase );
|
||||
FIND_PROC( glTransformFeedbackVaryings );
|
||||
FIND_PROC( glGetTransformFeedbackVarying );
|
||||
FIND_PROC( glVertexAttribIPointer );
|
||||
FIND_PROC( glGetVertexAttribIiv );
|
||||
FIND_PROC( glGetVertexAttribIuiv );
|
||||
FIND_PROC( glVertexAttribI4i );
|
||||
FIND_PROC( glVertexAttribI4ui );
|
||||
FIND_PROC( glVertexAttribI4iv );
|
||||
FIND_PROC( glVertexAttribI4uiv );
|
||||
FIND_PROC( glGetUniformuiv );
|
||||
FIND_PROC( glGetFragDataLocation );
|
||||
FIND_PROC( glUniform1ui );
|
||||
FIND_PROC( glUniform2ui );
|
||||
FIND_PROC( glUniform3ui );
|
||||
FIND_PROC( glUniform4ui );
|
||||
FIND_PROC( glUniform1uiv );
|
||||
FIND_PROC( glUniform2uiv );
|
||||
FIND_PROC( glUniform3uiv );
|
||||
FIND_PROC( glUniform4uiv );
|
||||
FIND_PROC( glClearBufferiv );
|
||||
FIND_PROC( glClearBufferuiv );
|
||||
FIND_PROC( glClearBufferfv );
|
||||
FIND_PROC( glClearBufferfi );
|
||||
FIND_PROC( glGetStringi );
|
||||
FIND_PROC( glCopyBufferSubData );
|
||||
FIND_PROC( glGetUniformIndices );
|
||||
FIND_PROC( glGetActiveUniformsiv );
|
||||
FIND_PROC( glGetUniformBlockIndex );
|
||||
FIND_PROC( glGetActiveUniformBlockiv );
|
||||
FIND_PROC( glGetActiveUniformBlockName );
|
||||
FIND_PROC( glUniformBlockBinding );
|
||||
FIND_PROC( glDrawArraysInstanced );
|
||||
FIND_PROC( glDrawElementsInstanced );
|
||||
FIND_PROC( glFenceSync );
|
||||
FIND_PROC( glIsSync );
|
||||
FIND_PROC( glDeleteSync );
|
||||
FIND_PROC( glClientWaitSync );
|
||||
FIND_PROC( glWaitSync );
|
||||
FIND_PROC( glGetInteger64v );
|
||||
FIND_PROC( glGetSynciv );
|
||||
FIND_PROC( glGetInteger64i_v );
|
||||
FIND_PROC( glGetBufferParameteri64v );
|
||||
FIND_PROC( glGenSamplers );
|
||||
FIND_PROC( glDeleteSamplers );
|
||||
FIND_PROC( glIsSampler );
|
||||
FIND_PROC( glBindSampler );
|
||||
FIND_PROC( glSamplerParameteri );
|
||||
FIND_PROC( glSamplerParameteriv );
|
||||
FIND_PROC( glSamplerParameterf );
|
||||
FIND_PROC( glSamplerParameterfv );
|
||||
FIND_PROC( glGetSamplerParameteriv );
|
||||
FIND_PROC( glGetSamplerParameterfv );
|
||||
FIND_PROC( glVertexAttribDivisor );
|
||||
FIND_PROC( glBindTransformFeedback );
|
||||
FIND_PROC( glDeleteTransformFeedbacks );
|
||||
FIND_PROC( glGenTransformFeedbacks );
|
||||
FIND_PROC( glIsTransformFeedback );
|
||||
FIND_PROC( glPauseTransformFeedback );
|
||||
FIND_PROC( glResumeTransformFeedback );
|
||||
FIND_PROC( glGetProgramBinary );
|
||||
FIND_PROC( glProgramBinary );
|
||||
FIND_PROC( glProgramParameteri );
|
||||
FIND_PROC( glInvalidateFramebuffer );
|
||||
FIND_PROC( glInvalidateSubFramebuffer );
|
||||
FIND_PROC( glTexStorage2D );
|
||||
FIND_PROC( glTexStorage3D );
|
||||
FIND_PROC( glGetInternalformativ );
|
||||
#undef FIND_PROC
|
||||
|
||||
if( !glReadBuffer || !glDrawRangeElements || !glTexImage3D || !glTexSubImage3D
|
||||
|| !glCopyTexSubImage3D || !glCompressedTexImage3D
|
||||
|| !glCompressedTexSubImage3D || !glGenQueries || !glDeleteQueries
|
||||
|| !glIsQuery || !glBeginQuery || !glEndQuery || !glGetQueryiv
|
||||
|| !glGetQueryObjectuiv || !glUnmapBuffer || !glGetBufferPointerv
|
||||
|| !glDrawBuffers || !glUniformMatrix2x3fv || !glUniformMatrix3x2fv
|
||||
|| !glUniformMatrix2x4fv || !glUniformMatrix4x2fv || !glUniformMatrix3x4fv
|
||||
|| !glUniformMatrix4x3fv || !glBlitFramebuffer
|
||||
|| !glRenderbufferStorageMultisample || !glFramebufferTextureLayer
|
||||
|| !glMapBufferRange || !glFlushMappedBufferRange || !glBindVertexArray
|
||||
|| !glDeleteVertexArrays || !glGenVertexArrays || !glIsVertexArray
|
||||
|| !glGetIntegeri_v || !glBeginTransformFeedback || !glEndTransformFeedback
|
||||
|| !glBindBufferRange || !glBindBufferBase || !glTransformFeedbackVaryings
|
||||
|| !glGetTransformFeedbackVarying || !glVertexAttribIPointer
|
||||
|| !glGetVertexAttribIiv || !glGetVertexAttribIuiv || !glVertexAttribI4i
|
||||
|| !glVertexAttribI4ui || !glVertexAttribI4iv || !glVertexAttribI4uiv
|
||||
|| !glGetUniformuiv || !glGetFragDataLocation || !glUniform1ui
|
||||
|| !glUniform2ui || !glUniform3ui || !glUniform4ui || !glUniform1uiv
|
||||
|| !glUniform2uiv || !glUniform3uiv || !glUniform4uiv || !glClearBufferiv
|
||||
|| !glClearBufferuiv || !glClearBufferfv || !glClearBufferfi || !glGetStringi
|
||||
|| !glCopyBufferSubData || !glGetUniformIndices || !glGetActiveUniformsiv
|
||||
|| !glGetUniformBlockIndex || !glGetActiveUniformBlockiv
|
||||
|| !glGetActiveUniformBlockName || !glUniformBlockBinding
|
||||
|| !glDrawArraysInstanced || !glDrawElementsInstanced || !glFenceSync
|
||||
|| !glIsSync || !glDeleteSync || !glClientWaitSync || !glWaitSync
|
||||
|| !glGetInteger64v || !glGetSynciv || !glGetInteger64i_v
|
||||
|| !glGetBufferParameteri64v || !glGenSamplers || !glDeleteSamplers
|
||||
|| !glIsSampler || !glBindSampler || !glSamplerParameteri
|
||||
|| !glSamplerParameteriv || !glSamplerParameterf || !glSamplerParameterfv
|
||||
|| !glGetSamplerParameteriv || !glGetSamplerParameterfv
|
||||
|| !glVertexAttribDivisor || !glBindTransformFeedback
|
||||
|| !glDeleteTransformFeedbacks || !glGenTransformFeedbacks
|
||||
|| !glIsTransformFeedback || !glPauseTransformFeedback
|
||||
|| !glResumeTransformFeedback || !glGetProgramBinary || !glProgramBinary
|
||||
|| !glProgramParameteri || !glInvalidateFramebuffer
|
||||
|| !glInvalidateSubFramebuffer || !glTexStorage2D || !glTexStorage3D
|
||||
|| !glGetInternalformativ )
|
||||
{
|
||||
return GL_FALSE;
|
||||
}
|
||||
|
||||
return GL_TRUE;
|
||||
}
|
||||
|
||||
/* Function pointer definitions */GL_APICALL void (* GL_APIENTRY glReadBuffer)( GLenum mode );
|
||||
GL_APICALL void (* GL_APIENTRY glDrawRangeElements)( GLenum mode,
|
||||
GLuint start,
|
||||
GLuint end,
|
||||
GLsizei count,
|
||||
GLenum type,
|
||||
const GLvoid* indices );
|
||||
GL_APICALL void (* GL_APIENTRY glTexImage3D)( GLenum target,
|
||||
GLint level,
|
||||
GLint internalformat,
|
||||
GLsizei width,
|
||||
GLsizei height,
|
||||
GLsizei depth,
|
||||
GLint border,
|
||||
GLenum format,
|
||||
GLenum type,
|
||||
const GLvoid* pixels );
|
||||
GL_APICALL void (* GL_APIENTRY glTexSubImage3D)( GLenum target,
|
||||
GLint level,
|
||||
GLint xoffset,
|
||||
GLint yoffset,
|
||||
GLint zoffset,
|
||||
GLsizei width,
|
||||
GLsizei height,
|
||||
GLsizei depth,
|
||||
GLenum format,
|
||||
GLenum type,
|
||||
const GLvoid* pixels );
|
||||
GL_APICALL void (* GL_APIENTRY glCopyTexSubImage3D)( GLenum target,
|
||||
GLint level,
|
||||
GLint xoffset,
|
||||
GLint yoffset,
|
||||
GLint zoffset,
|
||||
GLint x,
|
||||
GLint y,
|
||||
GLsizei width,
|
||||
GLsizei height );
|
||||
GL_APICALL void (* GL_APIENTRY glCompressedTexImage3D)( GLenum target,
|
||||
GLint level,
|
||||
GLenum internalformat,
|
||||
GLsizei width,
|
||||
GLsizei height,
|
||||
GLsizei depth,
|
||||
GLint border,
|
||||
GLsizei imageSize,
|
||||
const GLvoid* data );
|
||||
GL_APICALL void (* GL_APIENTRY glCompressedTexSubImage3D)( GLenum target,
|
||||
GLint level,
|
||||
GLint xoffset,
|
||||
GLint yoffset,
|
||||
GLint zoffset,
|
||||
GLsizei width,
|
||||
GLsizei height,
|
||||
GLsizei depth,
|
||||
GLenum format,
|
||||
GLsizei imageSize,
|
||||
const GLvoid* data );
|
||||
GL_APICALL void (* GL_APIENTRY glGenQueries)( GLsizei n, GLuint* ids );
|
||||
GL_APICALL void (* GL_APIENTRY glDeleteQueries)( GLsizei n, const GLuint* ids );
|
||||
GL_APICALL GLboolean (* GL_APIENTRY glIsQuery)( GLuint id );
|
||||
GL_APICALL void (* GL_APIENTRY glBeginQuery)( GLenum target, GLuint id );
|
||||
GL_APICALL void (* GL_APIENTRY glEndQuery)( GLenum target );
|
||||
GL_APICALL void (* GL_APIENTRY glGetQueryiv)( GLenum target, GLenum pname, GLint* params );
|
||||
GL_APICALL void (* GL_APIENTRY glGetQueryObjectuiv)( GLuint id,
|
||||
GLenum pname,
|
||||
GLuint* params );
|
||||
GL_APICALL GLboolean (* GL_APIENTRY glUnmapBuffer)( GLenum target );
|
||||
GL_APICALL void (* GL_APIENTRY glGetBufferPointerv)( GLenum target,
|
||||
GLenum pname,
|
||||
GLvoid** params );
|
||||
GL_APICALL void (* GL_APIENTRY glDrawBuffers)( GLsizei n, const GLenum* bufs );
|
||||
GL_APICALL void (* GL_APIENTRY glUniformMatrix2x3fv)( GLint location,
|
||||
GLsizei count,
|
||||
GLboolean transpose,
|
||||
const GLfloat* value );
|
||||
GL_APICALL void (* GL_APIENTRY glUniformMatrix3x2fv)( GLint location,
|
||||
GLsizei count,
|
||||
GLboolean transpose,
|
||||
const GLfloat* value );
|
||||
GL_APICALL void (* GL_APIENTRY glUniformMatrix2x4fv)( GLint location,
|
||||
GLsizei count,
|
||||
GLboolean transpose,
|
||||
const GLfloat* value );
|
||||
GL_APICALL void (* GL_APIENTRY glUniformMatrix4x2fv)( GLint location,
|
||||
GLsizei count,
|
||||
GLboolean transpose,
|
||||
const GLfloat* value );
|
||||
GL_APICALL void (* GL_APIENTRY glUniformMatrix3x4fv)( GLint location,
|
||||
GLsizei count,
|
||||
GLboolean transpose,
|
||||
const GLfloat* value );
|
||||
GL_APICALL void (* GL_APIENTRY glUniformMatrix4x3fv)( GLint location,
|
||||
GLsizei count,
|
||||
GLboolean transpose,
|
||||
const GLfloat* value );
|
||||
GL_APICALL void (* GL_APIENTRY glBlitFramebuffer)( GLint srcX0,
|
||||
GLint srcY0,
|
||||
GLint srcX1,
|
||||
GLint srcY1,
|
||||
GLint dstX0,
|
||||
GLint dstY0,
|
||||
GLint dstX1,
|
||||
GLint dstY1,
|
||||
GLbitfield mask,
|
||||
GLenum filter );
|
||||
GL_APICALL void (* GL_APIENTRY glRenderbufferStorageMultisample)( GLenum target,
|
||||
GLsizei samples,
|
||||
GLenum internalformat,
|
||||
GLsizei width,
|
||||
GLsizei height );
|
||||
GL_APICALL void (* GL_APIENTRY glFramebufferTextureLayer)( GLenum target,
|
||||
GLenum attachment,
|
||||
GLuint texture,
|
||||
GLint level,
|
||||
GLint layer );
|
||||
GL_APICALL GLvoid* (* GL_APIENTRY glMapBufferRange)( GLenum target,
|
||||
GLintptr offset,
|
||||
GLsizeiptr length,
|
||||
GLbitfield access );
|
||||
GL_APICALL void (* GL_APIENTRY glFlushMappedBufferRange)( GLenum target,
|
||||
GLintptr offset,
|
||||
GLsizeiptr length );
|
||||
GL_APICALL void (* GL_APIENTRY glBindVertexArray)( GLuint array );
|
||||
GL_APICALL void (* GL_APIENTRY glDeleteVertexArrays)( GLsizei n, const GLuint* arrays );
|
||||
GL_APICALL void (* GL_APIENTRY glGenVertexArrays)( GLsizei n, GLuint* arrays );
|
||||
GL_APICALL GLboolean (* GL_APIENTRY glIsVertexArray)( GLuint array );
|
||||
GL_APICALL void (* GL_APIENTRY glGetIntegeri_v)( GLenum target,
|
||||
GLuint index,
|
||||
GLint* data );
|
||||
GL_APICALL void (* GL_APIENTRY glBeginTransformFeedback)( GLenum primitiveMode );
|
||||
GL_APICALL void (* GL_APIENTRY glEndTransformFeedback)( void );
|
||||
GL_APICALL void (* GL_APIENTRY glBindBufferRange)( GLenum target,
|
||||
GLuint index,
|
||||
GLuint buffer,
|
||||
GLintptr offset,
|
||||
GLsizeiptr size );
|
||||
GL_APICALL void (* GL_APIENTRY glBindBufferBase)( GLenum target,
|
||||
GLuint index,
|
||||
GLuint buffer );
|
||||
GL_APICALL void (* GL_APIENTRY glTransformFeedbackVaryings)( GLuint program,
|
||||
GLsizei count,
|
||||
const GLchar* const * varyings,
|
||||
GLenum bufferMode );
|
||||
GL_APICALL void (* GL_APIENTRY glGetTransformFeedbackVarying)( GLuint program,
|
||||
GLuint index,
|
||||
GLsizei bufSize,
|
||||
GLsizei* length,
|
||||
GLsizei* size,
|
||||
GLenum* type,
|
||||
GLchar* name );
|
||||
GL_APICALL void (* GL_APIENTRY glVertexAttribIPointer)( GLuint index,
|
||||
GLint size,
|
||||
GLenum type,
|
||||
GLsizei stride,
|
||||
const GLvoid* pointer );
|
||||
GL_APICALL void (* GL_APIENTRY glGetVertexAttribIiv)( GLuint index,
|
||||
GLenum pname,
|
||||
GLint* params );
|
||||
GL_APICALL void (* GL_APIENTRY glGetVertexAttribIuiv)( GLuint index,
|
||||
GLenum pname,
|
||||
GLuint* params );
|
||||
GL_APICALL void (* GL_APIENTRY glVertexAttribI4i)( GLuint index,
|
||||
GLint x,
|
||||
GLint y,
|
||||
GLint z,
|
||||
GLint w );
|
||||
GL_APICALL void (* GL_APIENTRY glVertexAttribI4ui)( GLuint index,
|
||||
GLuint x,
|
||||
GLuint y,
|
||||
GLuint z,
|
||||
GLuint w );
|
||||
GL_APICALL void (* GL_APIENTRY glVertexAttribI4iv)( GLuint index, const GLint* v );
|
||||
GL_APICALL void (* GL_APIENTRY glVertexAttribI4uiv)( GLuint index, const GLuint* v );
|
||||
GL_APICALL void (* GL_APIENTRY glGetUniformuiv)( GLuint program,
|
||||
GLint location,
|
||||
GLuint* params );
|
||||
GL_APICALL GLint (* GL_APIENTRY glGetFragDataLocation)( GLuint program,
|
||||
const GLchar *name );
|
||||
GL_APICALL void (* GL_APIENTRY glUniform1ui)( GLint location, GLuint v0 );
|
||||
GL_APICALL void (* GL_APIENTRY glUniform2ui)( GLint location, GLuint v0, GLuint v1 );
|
||||
GL_APICALL void (* GL_APIENTRY glUniform3ui)( GLint location,
|
||||
GLuint v0,
|
||||
GLuint v1,
|
||||
GLuint v2 );
|
||||
GL_APICALL void (* GL_APIENTRY glUniform4ui)( GLint location,
|
||||
GLuint v0,
|
||||
GLuint v1,
|
||||
GLuint v2,
|
||||
GLuint v3 );
|
||||
GL_APICALL void (* GL_APIENTRY glUniform1uiv)( GLint location,
|
||||
GLsizei count,
|
||||
const GLuint* value );
|
||||
GL_APICALL void (* GL_APIENTRY glUniform2uiv)( GLint location,
|
||||
GLsizei count,
|
||||
const GLuint* value );
|
||||
GL_APICALL void (* GL_APIENTRY glUniform3uiv)( GLint location,
|
||||
GLsizei count,
|
||||
const GLuint* value );
|
||||
GL_APICALL void (* GL_APIENTRY glUniform4uiv)( GLint location,
|
||||
GLsizei count,
|
||||
const GLuint* value );
|
||||
GL_APICALL void (* GL_APIENTRY glClearBufferiv)( GLenum buffer,
|
||||
GLint drawbuffer,
|
||||
const GLint* value );
|
||||
GL_APICALL void (* GL_APIENTRY glClearBufferuiv)( GLenum buffer,
|
||||
GLint drawbuffer,
|
||||
const GLuint* value );
|
||||
GL_APICALL void (* GL_APIENTRY glClearBufferfv)( GLenum buffer,
|
||||
GLint drawbuffer,
|
||||
const GLfloat* value );
|
||||
GL_APICALL void (* GL_APIENTRY glClearBufferfi)( GLenum buffer,
|
||||
GLint drawbuffer,
|
||||
GLfloat depth,
|
||||
GLint stencil );
|
||||
GL_APICALL const GLubyte* (* GL_APIENTRY glGetStringi)( GLenum name, GLuint index );
|
||||
GL_APICALL void (* GL_APIENTRY glCopyBufferSubData)( GLenum readTarget,
|
||||
GLenum writeTarget,
|
||||
GLintptr readOffset,
|
||||
GLintptr writeOffset,
|
||||
GLsizeiptr size );
|
||||
GL_APICALL void (* GL_APIENTRY glGetUniformIndices)( GLuint program,
|
||||
GLsizei uniformCount,
|
||||
const GLchar* const * uniformNames,
|
||||
GLuint* uniformIndices );
|
||||
GL_APICALL void (* GL_APIENTRY glGetActiveUniformsiv)( GLuint program,
|
||||
GLsizei uniformCount,
|
||||
const GLuint* uniformIndices,
|
||||
GLenum pname,
|
||||
GLint* params );
|
||||
GL_APICALL GLuint (* GL_APIENTRY glGetUniformBlockIndex)( GLuint program,
|
||||
const GLchar* uniformBlockName );
|
||||
GL_APICALL void (* GL_APIENTRY glGetActiveUniformBlockiv)( GLuint program,
|
||||
GLuint uniformBlockIndex,
|
||||
GLenum pname,
|
||||
GLint* params );
|
||||
GL_APICALL void (* GL_APIENTRY glGetActiveUniformBlockName)( GLuint program,
|
||||
GLuint uniformBlockIndex,
|
||||
GLsizei bufSize,
|
||||
GLsizei* length,
|
||||
GLchar* uniformBlockName );
|
||||
GL_APICALL void (* GL_APIENTRY glUniformBlockBinding)( GLuint program,
|
||||
GLuint uniformBlockIndex,
|
||||
GLuint uniformBlockBinding );
|
||||
GL_APICALL void (* GL_APIENTRY glDrawArraysInstanced)( GLenum mode,
|
||||
GLint first,
|
||||
GLsizei count,
|
||||
GLsizei instanceCount );
|
||||
GL_APICALL void (* GL_APIENTRY glDrawElementsInstanced)( GLenum mode,
|
||||
GLsizei count,
|
||||
GLenum type,
|
||||
const GLvoid* indices,
|
||||
GLsizei instanceCount );
|
||||
GL_APICALL GLsync (* GL_APIENTRY glFenceSync)( GLenum condition, GLbitfield flags );
|
||||
GL_APICALL GLboolean (* GL_APIENTRY glIsSync)( GLsync sync );
|
||||
GL_APICALL void (* GL_APIENTRY glDeleteSync)( GLsync sync );
|
||||
GL_APICALL GLenum (* GL_APIENTRY glClientWaitSync)( GLsync sync,
|
||||
GLbitfield flags,
|
||||
GLuint64 timeout );
|
||||
GL_APICALL void (* GL_APIENTRY glWaitSync)( GLsync sync,
|
||||
GLbitfield flags,
|
||||
GLuint64 timeout );
|
||||
GL_APICALL void (* GL_APIENTRY glGetInteger64v)( GLenum pname, GLint64* params );
|
||||
GL_APICALL void (* GL_APIENTRY glGetSynciv)( GLsync sync,
|
||||
GLenum pname,
|
||||
GLsizei bufSize,
|
||||
GLsizei* length,
|
||||
GLint* values );
|
||||
GL_APICALL void (* GL_APIENTRY glGetInteger64i_v)( GLenum target,
|
||||
GLuint index,
|
||||
GLint64* data );
|
||||
GL_APICALL void (* GL_APIENTRY glGetBufferParameteri64v)( GLenum target,
|
||||
GLenum pname,
|
||||
GLint64* params );
|
||||
GL_APICALL void (* GL_APIENTRY glGenSamplers)( GLsizei count, GLuint* samplers );
|
||||
GL_APICALL void (* GL_APIENTRY glDeleteSamplers)( GLsizei count, const GLuint* samplers );
|
||||
GL_APICALL GLboolean (* GL_APIENTRY glIsSampler)( GLuint sampler );
|
||||
GL_APICALL void (* GL_APIENTRY glBindSampler)( GLuint unit, GLuint sampler );
|
||||
GL_APICALL void (* GL_APIENTRY glSamplerParameteri)( GLuint sampler,
|
||||
GLenum pname,
|
||||
GLint param );
|
||||
GL_APICALL void (* GL_APIENTRY glSamplerParameteriv)( GLuint sampler,
|
||||
GLenum pname,
|
||||
const GLint* param );
|
||||
GL_APICALL void (* GL_APIENTRY glSamplerParameterf)( GLuint sampler,
|
||||
GLenum pname,
|
||||
GLfloat param );
|
||||
GL_APICALL void (* GL_APIENTRY glSamplerParameterfv)( GLuint sampler,
|
||||
GLenum pname,
|
||||
const GLfloat* param );
|
||||
GL_APICALL void (* GL_APIENTRY glGetSamplerParameteriv)( GLuint sampler,
|
||||
GLenum pname,
|
||||
GLint* params );
|
||||
GL_APICALL void (* GL_APIENTRY glGetSamplerParameterfv)( GLuint sampler,
|
||||
GLenum pname,
|
||||
GLfloat* params );
|
||||
GL_APICALL void (* GL_APIENTRY glVertexAttribDivisor)( GLuint index, GLuint divisor );
|
||||
GL_APICALL void (* GL_APIENTRY glBindTransformFeedback)( GLenum target, GLuint id );
|
||||
GL_APICALL void (* GL_APIENTRY glDeleteTransformFeedbacks)( GLsizei n, const GLuint* ids );
|
||||
GL_APICALL void (* GL_APIENTRY glGenTransformFeedbacks)( GLsizei n, GLuint* ids );
|
||||
GL_APICALL GLboolean (* GL_APIENTRY glIsTransformFeedback)( GLuint id );
|
||||
GL_APICALL void (* GL_APIENTRY glPauseTransformFeedback)( void );
|
||||
GL_APICALL void (* GL_APIENTRY glResumeTransformFeedback)( void );
|
||||
GL_APICALL void (* GL_APIENTRY glGetProgramBinary)( GLuint program,
|
||||
GLsizei bufSize,
|
||||
GLsizei* length,
|
||||
GLenum* binaryFormat,
|
||||
GLvoid* binary );
|
||||
GL_APICALL void (* GL_APIENTRY glProgramBinary)( GLuint program,
|
||||
GLenum binaryFormat,
|
||||
const GLvoid* binary,
|
||||
GLsizei length );
|
||||
GL_APICALL void (* GL_APIENTRY glProgramParameteri)( GLuint program,
|
||||
GLenum pname,
|
||||
GLint value );
|
||||
GL_APICALL void (* GL_APIENTRY glInvalidateFramebuffer)( GLenum target,
|
||||
GLsizei numAttachments,
|
||||
const GLenum* attachments );
|
||||
GL_APICALL void (* GL_APIENTRY glInvalidateSubFramebuffer)( GLenum target,
|
||||
GLsizei numAttachments,
|
||||
const GLenum* attachments,
|
||||
GLint x,
|
||||
GLint y,
|
||||
GLsizei width,
|
||||
GLsizei height );
|
||||
GL_APICALL void (* GL_APIENTRY glTexStorage2D)( GLenum target,
|
||||
GLsizei levels,
|
||||
GLenum internalformat,
|
||||
GLsizei width,
|
||||
GLsizei height );
|
||||
GL_APICALL void (* GL_APIENTRY glTexStorage3D)( GLenum target,
|
||||
GLsizei levels,
|
||||
GLenum internalformat,
|
||||
GLsizei width,
|
||||
GLsizei height,
|
||||
GLsizei depth );
|
||||
GL_APICALL void (* GL_APIENTRY glGetInternalformativ)( GLenum target,
|
||||
GLenum internalformat,
|
||||
GLenum pname,
|
||||
GLsizei bufSize,
|
||||
GLint* params );
|
||||
663
Teapot/app/src/main/cpp/ndk_helper/gl3stub.h
Normal file
@@ -0,0 +1,663 @@
|
||||
#ifndef __gl3_h_
|
||||
#define __gl3_h_
|
||||
|
||||
/*
|
||||
* stub gl3.h for dynamic loading, based on:
|
||||
* gl3.h last updated on $Date: 2013-02-12 14:37:24 -0800 (Tue, 12 Feb 2013) $
|
||||
*
|
||||
* Changes:
|
||||
* - Added #include <GLES2/gl2.h>
|
||||
* - Removed duplicate OpenGL ES 2.0 declarations
|
||||
* - Converted OpenGL ES 3.0 function prototypes to function pointer
|
||||
* declarations
|
||||
* - Added gl3stubInit() declaration
|
||||
*/
|
||||
|
||||
#include <GLES2/gl2.h>
|
||||
#include <android/api-level.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
/*
|
||||
** Copyright (c) 2007-2013 The Khronos Group Inc.
|
||||
**
|
||||
** Permission is hereby granted, free of charge, to any person obtaining a
|
||||
** copy of this software and/or associated documentation files (the
|
||||
** "Materials"), to deal in the Materials without restriction, including
|
||||
** without limitation the rights to use, copy, modify, merge, publish,
|
||||
** distribute, sublicense, and/or sell copies of the Materials, and to
|
||||
** permit persons to whom the Materials are furnished to do so, subject to
|
||||
** the following conditions:
|
||||
**
|
||||
** The above copyright notice and this permission notice shall be included
|
||||
** in all copies or substantial portions of the Materials.
|
||||
**
|
||||
** THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||
** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||
** MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
||||
** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
||||
** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
||||
** TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||
** MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.
|
||||
*/
|
||||
|
||||
/*
|
||||
* This files is for apps that want to use ES3 if present,
|
||||
* but continue to work on pre-API-18 devices. They can't just link to -lGLESv3
|
||||
*since
|
||||
* that library doesn't exist on pre-API-18 devices.
|
||||
* The function dynamically check if OpenGLES3.0 APIs are present and fill in if
|
||||
*there are.
|
||||
* Also the header defines some extra variables for OpenGLES3.0.
|
||||
*
|
||||
*/
|
||||
|
||||
/* Call this function before calling any OpenGL ES 3.0 functions. It will
|
||||
* return GL_TRUE if the OpenGL ES 3.0 was successfully initialized, GL_FALSE
|
||||
* otherwise. */
|
||||
GLboolean gl3stubInit();
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Data type definitions
|
||||
*-----------------------------------------------------------------------*/
|
||||
|
||||
/* OpenGL ES 3.0 */
|
||||
|
||||
typedef unsigned short GLhalf;
|
||||
#if __ANDROID_API__ <= 19
|
||||
typedef khronos_int64_t GLint64;
|
||||
typedef khronos_uint64_t GLuint64;
|
||||
typedef struct __GLsync* GLsync;
|
||||
#endif
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Token definitions
|
||||
*-----------------------------------------------------------------------*/
|
||||
|
||||
/* OpenGL ES core versions */
|
||||
#define GL_ES_VERSION_3_0 1
|
||||
|
||||
/* OpenGL ES 3.0 */
|
||||
|
||||
#define GL_READ_BUFFER 0x0C02
|
||||
#define GL_UNPACK_ROW_LENGTH 0x0CF2
|
||||
#define GL_UNPACK_SKIP_ROWS 0x0CF3
|
||||
#define GL_UNPACK_SKIP_PIXELS 0x0CF4
|
||||
#define GL_PACK_ROW_LENGTH 0x0D02
|
||||
#define GL_PACK_SKIP_ROWS 0x0D03
|
||||
#define GL_PACK_SKIP_PIXELS 0x0D04
|
||||
#define GL_COLOR 0x1800
|
||||
#define GL_DEPTH 0x1801
|
||||
#define GL_STENCIL 0x1802
|
||||
#define GL_RED 0x1903
|
||||
#define GL_RGB8 0x8051
|
||||
#define GL_RGBA8 0x8058
|
||||
#define GL_RGB10_A2 0x8059
|
||||
#define GL_TEXTURE_BINDING_3D 0x806A
|
||||
#define GL_UNPACK_SKIP_IMAGES 0x806D
|
||||
#define GL_UNPACK_IMAGE_HEIGHT 0x806E
|
||||
#define GL_TEXTURE_3D 0x806F
|
||||
#define GL_TEXTURE_WRAP_R 0x8072
|
||||
#define GL_MAX_3D_TEXTURE_SIZE 0x8073
|
||||
#define GL_UNSIGNED_INT_2_10_10_10_REV 0x8368
|
||||
#define GL_MAX_ELEMENTS_VERTICES 0x80E8
|
||||
#define GL_MAX_ELEMENTS_INDICES 0x80E9
|
||||
#define GL_TEXTURE_MIN_LOD 0x813A
|
||||
#define GL_TEXTURE_MAX_LOD 0x813B
|
||||
#define GL_TEXTURE_BASE_LEVEL 0x813C
|
||||
#define GL_TEXTURE_MAX_LEVEL 0x813D
|
||||
#define GL_MIN 0x8007
|
||||
#define GL_MAX 0x8008
|
||||
#define GL_DEPTH_COMPONENT24 0x81A6
|
||||
#define GL_MAX_TEXTURE_LOD_BIAS 0x84FD
|
||||
#define GL_TEXTURE_COMPARE_MODE 0x884C
|
||||
#define GL_TEXTURE_COMPARE_FUNC 0x884D
|
||||
#define GL_CURRENT_QUERY 0x8865
|
||||
#define GL_QUERY_RESULT 0x8866
|
||||
#define GL_QUERY_RESULT_AVAILABLE 0x8867
|
||||
#define GL_BUFFER_MAPPED 0x88BC
|
||||
#define GL_BUFFER_MAP_POINTER 0x88BD
|
||||
#define GL_STREAM_READ 0x88E1
|
||||
#define GL_STREAM_COPY 0x88E2
|
||||
#define GL_STATIC_READ 0x88E5
|
||||
#define GL_STATIC_COPY 0x88E6
|
||||
#define GL_DYNAMIC_READ 0x88E9
|
||||
#define GL_DYNAMIC_COPY 0x88EA
|
||||
#define GL_MAX_DRAW_BUFFERS 0x8824
|
||||
#define GL_DRAW_BUFFER0 0x8825
|
||||
#define GL_DRAW_BUFFER1 0x8826
|
||||
#define GL_DRAW_BUFFER2 0x8827
|
||||
#define GL_DRAW_BUFFER3 0x8828
|
||||
#define GL_DRAW_BUFFER4 0x8829
|
||||
#define GL_DRAW_BUFFER5 0x882A
|
||||
#define GL_DRAW_BUFFER6 0x882B
|
||||
#define GL_DRAW_BUFFER7 0x882C
|
||||
#define GL_DRAW_BUFFER8 0x882D
|
||||
#define GL_DRAW_BUFFER9 0x882E
|
||||
#define GL_DRAW_BUFFER10 0x882F
|
||||
#define GL_DRAW_BUFFER11 0x8830
|
||||
#define GL_DRAW_BUFFER12 0x8831
|
||||
#define GL_DRAW_BUFFER13 0x8832
|
||||
#define GL_DRAW_BUFFER14 0x8833
|
||||
#define GL_DRAW_BUFFER15 0x8834
|
||||
#define GL_MAX_FRAGMENT_UNIFORM_COMPONENTS 0x8B49
|
||||
#define GL_MAX_VERTEX_UNIFORM_COMPONENTS 0x8B4A
|
||||
#define GL_SAMPLER_3D 0x8B5F
|
||||
#define GL_SAMPLER_2D_SHADOW 0x8B62
|
||||
#define GL_FRAGMENT_SHADER_DERIVATIVE_HINT 0x8B8B
|
||||
#define GL_PIXEL_PACK_BUFFER 0x88EB
|
||||
#define GL_PIXEL_UNPACK_BUFFER 0x88EC
|
||||
#define GL_PIXEL_PACK_BUFFER_BINDING 0x88ED
|
||||
#define GL_PIXEL_UNPACK_BUFFER_BINDING 0x88EF
|
||||
#define GL_FLOAT_MAT2x3 0x8B65
|
||||
#define GL_FLOAT_MAT2x4 0x8B66
|
||||
#define GL_FLOAT_MAT3x2 0x8B67
|
||||
#define GL_FLOAT_MAT3x4 0x8B68
|
||||
#define GL_FLOAT_MAT4x2 0x8B69
|
||||
#define GL_FLOAT_MAT4x3 0x8B6A
|
||||
#define GL_SRGB 0x8C40
|
||||
#define GL_SRGB8 0x8C41
|
||||
#define GL_SRGB8_ALPHA8 0x8C43
|
||||
#define GL_COMPARE_REF_TO_TEXTURE 0x884E
|
||||
#define GL_MAJOR_VERSION 0x821B
|
||||
#define GL_MINOR_VERSION 0x821C
|
||||
#define GL_NUM_EXTENSIONS 0x821D
|
||||
#define GL_RGBA32F 0x8814
|
||||
#define GL_RGB32F 0x8815
|
||||
#define GL_RGBA16F 0x881A
|
||||
#define GL_RGB16F 0x881B
|
||||
#define GL_VERTEX_ATTRIB_ARRAY_INTEGER 0x88FD
|
||||
#define GL_MAX_ARRAY_TEXTURE_LAYERS 0x88FF
|
||||
#define GL_MIN_PROGRAM_TEXEL_OFFSET 0x8904
|
||||
#define GL_MAX_PROGRAM_TEXEL_OFFSET 0x8905
|
||||
#define GL_MAX_VARYING_COMPONENTS 0x8B4B
|
||||
#define GL_TEXTURE_2D_ARRAY 0x8C1A
|
||||
#define GL_TEXTURE_BINDING_2D_ARRAY 0x8C1D
|
||||
#define GL_R11F_G11F_B10F 0x8C3A
|
||||
#define GL_UNSIGNED_INT_10F_11F_11F_REV 0x8C3B
|
||||
#define GL_RGB9_E5 0x8C3D
|
||||
#define GL_UNSIGNED_INT_5_9_9_9_REV 0x8C3E
|
||||
#define GL_TRANSFORM_FEEDBACK_VARYING_MAX_LENGTH 0x8C76
|
||||
#define GL_TRANSFORM_FEEDBACK_BUFFER_MODE 0x8C7F
|
||||
#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_COMPONENTS 0x8C80
|
||||
#define GL_TRANSFORM_FEEDBACK_VARYINGS 0x8C83
|
||||
#define GL_TRANSFORM_FEEDBACK_BUFFER_START 0x8C84
|
||||
#define GL_TRANSFORM_FEEDBACK_BUFFER_SIZE 0x8C85
|
||||
#define GL_TRANSFORM_FEEDBACK_PRIMITIVES_WRITTEN 0x8C88
|
||||
#define GL_RASTERIZER_DISCARD 0x8C89
|
||||
#define GL_MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS 0x8C8A
|
||||
#define GL_MAX_TRANSFORM_FEEDBACK_SEPARATE_ATTRIBS 0x8C8B
|
||||
#define GL_INTERLEAVED_ATTRIBS 0x8C8C
|
||||
#define GL_SEPARATE_ATTRIBS 0x8C8D
|
||||
#define GL_TRANSFORM_FEEDBACK_BUFFER 0x8C8E
|
||||
#define GL_TRANSFORM_FEEDBACK_BUFFER_BINDING 0x8C8F
|
||||
#define GL_RGBA32UI 0x8D70
|
||||
#define GL_RGB32UI 0x8D71
|
||||
#define GL_RGBA16UI 0x8D76
|
||||
#define GL_RGB16UI 0x8D77
|
||||
#define GL_RGBA8UI 0x8D7C
|
||||
#define GL_RGB8UI 0x8D7D
|
||||
#define GL_RGBA32I 0x8D82
|
||||
#define GL_RGB32I 0x8D83
|
||||
#define GL_RGBA16I 0x8D88
|
||||
#define GL_RGB16I 0x8D89
|
||||
#define GL_RGBA8I 0x8D8E
|
||||
#define GL_RGB8I 0x8D8F
|
||||
#define GL_RED_INTEGER 0x8D94
|
||||
#define GL_RGB_INTEGER 0x8D98
|
||||
#define GL_RGBA_INTEGER 0x8D99
|
||||
#define GL_SAMPLER_2D_ARRAY 0x8DC1
|
||||
#define GL_SAMPLER_2D_ARRAY_SHADOW 0x8DC4
|
||||
#define GL_SAMPLER_CUBE_SHADOW 0x8DC5
|
||||
#define GL_UNSIGNED_INT_VEC2 0x8DC6
|
||||
#define GL_UNSIGNED_INT_VEC3 0x8DC7
|
||||
#define GL_UNSIGNED_INT_VEC4 0x8DC8
|
||||
#define GL_INT_SAMPLER_2D 0x8DCA
|
||||
#define GL_INT_SAMPLER_3D 0x8DCB
|
||||
#define GL_INT_SAMPLER_CUBE 0x8DCC
|
||||
#define GL_INT_SAMPLER_2D_ARRAY 0x8DCF
|
||||
#define GL_UNSIGNED_INT_SAMPLER_2D 0x8DD2
|
||||
#define GL_UNSIGNED_INT_SAMPLER_3D 0x8DD3
|
||||
#define GL_UNSIGNED_INT_SAMPLER_CUBE 0x8DD4
|
||||
#define GL_UNSIGNED_INT_SAMPLER_2D_ARRAY 0x8DD7
|
||||
#define GL_BUFFER_ACCESS_FLAGS 0x911F
|
||||
#define GL_BUFFER_MAP_LENGTH 0x9120
|
||||
#define GL_BUFFER_MAP_OFFSET 0x9121
|
||||
#define GL_DEPTH_COMPONENT32F 0x8CAC
|
||||
#define GL_DEPTH32F_STENCIL8 0x8CAD
|
||||
#define GL_FLOAT_32_UNSIGNED_INT_24_8_REV 0x8DAD
|
||||
#define GL_FRAMEBUFFER_ATTACHMENT_COLOR_ENCODING 0x8210
|
||||
#define GL_FRAMEBUFFER_ATTACHMENT_COMPONENT_TYPE 0x8211
|
||||
#define GL_FRAMEBUFFER_ATTACHMENT_RED_SIZE 0x8212
|
||||
#define GL_FRAMEBUFFER_ATTACHMENT_GREEN_SIZE 0x8213
|
||||
#define GL_FRAMEBUFFER_ATTACHMENT_BLUE_SIZE 0x8214
|
||||
#define GL_FRAMEBUFFER_ATTACHMENT_ALPHA_SIZE 0x8215
|
||||
#define GL_FRAMEBUFFER_ATTACHMENT_DEPTH_SIZE 0x8216
|
||||
#define GL_FRAMEBUFFER_ATTACHMENT_STENCIL_SIZE 0x8217
|
||||
#define GL_FRAMEBUFFER_DEFAULT 0x8218
|
||||
#define GL_FRAMEBUFFER_UNDEFINED 0x8219
|
||||
#define GL_DEPTH_STENCIL_ATTACHMENT 0x821A
|
||||
#define GL_DEPTH_STENCIL 0x84F9
|
||||
#define GL_UNSIGNED_INT_24_8 0x84FA
|
||||
#define GL_DEPTH24_STENCIL8 0x88F0
|
||||
#define GL_UNSIGNED_NORMALIZED 0x8C17
|
||||
#define GL_DRAW_FRAMEBUFFER_BINDING GL_FRAMEBUFFER_BINDING
|
||||
#define GL_READ_FRAMEBUFFER 0x8CA8
|
||||
#define GL_DRAW_FRAMEBUFFER 0x8CA9
|
||||
#define GL_READ_FRAMEBUFFER_BINDING 0x8CAA
|
||||
#define GL_RENDERBUFFER_SAMPLES 0x8CAB
|
||||
#define GL_FRAMEBUFFER_ATTACHMENT_TEXTURE_LAYER 0x8CD4
|
||||
#define GL_MAX_COLOR_ATTACHMENTS 0x8CDF
|
||||
#define GL_COLOR_ATTACHMENT1 0x8CE1
|
||||
#define GL_COLOR_ATTACHMENT2 0x8CE2
|
||||
#define GL_COLOR_ATTACHMENT3 0x8CE3
|
||||
#define GL_COLOR_ATTACHMENT4 0x8CE4
|
||||
#define GL_COLOR_ATTACHMENT5 0x8CE5
|
||||
#define GL_COLOR_ATTACHMENT6 0x8CE6
|
||||
#define GL_COLOR_ATTACHMENT7 0x8CE7
|
||||
#define GL_COLOR_ATTACHMENT8 0x8CE8
|
||||
#define GL_COLOR_ATTACHMENT9 0x8CE9
|
||||
#define GL_COLOR_ATTACHMENT10 0x8CEA
|
||||
#define GL_COLOR_ATTACHMENT11 0x8CEB
|
||||
#define GL_COLOR_ATTACHMENT12 0x8CEC
|
||||
#define GL_COLOR_ATTACHMENT13 0x8CED
|
||||
#define GL_COLOR_ATTACHMENT14 0x8CEE
|
||||
#define GL_COLOR_ATTACHMENT15 0x8CEF
|
||||
#define GL_FRAMEBUFFER_INCOMPLETE_MULTISAMPLE 0x8D56
|
||||
#define GL_MAX_SAMPLES 0x8D57
|
||||
#define GL_HALF_FLOAT 0x140B
|
||||
#define GL_MAP_READ_BIT 0x0001
|
||||
#define GL_MAP_WRITE_BIT 0x0002
|
||||
#define GL_MAP_INVALIDATE_RANGE_BIT 0x0004
|
||||
#define GL_MAP_INVALIDATE_BUFFER_BIT 0x0008
|
||||
#define GL_MAP_FLUSH_EXPLICIT_BIT 0x0010
|
||||
#define GL_MAP_UNSYNCHRONIZED_BIT 0x0020
|
||||
#define GL_RG 0x8227
|
||||
#define GL_RG_INTEGER 0x8228
|
||||
#define GL_R8 0x8229
|
||||
#define GL_RG8 0x822B
|
||||
#define GL_R16F 0x822D
|
||||
#define GL_R32F 0x822E
|
||||
#define GL_RG16F 0x822F
|
||||
#define GL_RG32F 0x8230
|
||||
#define GL_R8I 0x8231
|
||||
#define GL_R8UI 0x8232
|
||||
#define GL_R16I 0x8233
|
||||
#define GL_R16UI 0x8234
|
||||
#define GL_R32I 0x8235
|
||||
#define GL_R32UI 0x8236
|
||||
#define GL_RG8I 0x8237
|
||||
#define GL_RG8UI 0x8238
|
||||
#define GL_RG16I 0x8239
|
||||
#define GL_RG16UI 0x823A
|
||||
#define GL_RG32I 0x823B
|
||||
#define GL_RG32UI 0x823C
|
||||
#define GL_VERTEX_ARRAY_BINDING 0x85B5
|
||||
#define GL_R8_SNORM 0x8F94
|
||||
#define GL_RG8_SNORM 0x8F95
|
||||
#define GL_RGB8_SNORM 0x8F96
|
||||
#define GL_RGBA8_SNORM 0x8F97
|
||||
#define GL_SIGNED_NORMALIZED 0x8F9C
|
||||
#define GL_PRIMITIVE_RESTART_FIXED_INDEX 0x8D69
|
||||
#define GL_COPY_READ_BUFFER 0x8F36
|
||||
#define GL_COPY_WRITE_BUFFER 0x8F37
|
||||
#define GL_COPY_READ_BUFFER_BINDING GL_COPY_READ_BUFFER
|
||||
#define GL_COPY_WRITE_BUFFER_BINDING GL_COPY_WRITE_BUFFER
|
||||
#define GL_UNIFORM_BUFFER 0x8A11
|
||||
#define GL_UNIFORM_BUFFER_BINDING 0x8A28
|
||||
#define GL_UNIFORM_BUFFER_START 0x8A29
|
||||
#define GL_UNIFORM_BUFFER_SIZE 0x8A2A
|
||||
#define GL_MAX_VERTEX_UNIFORM_BLOCKS 0x8A2B
|
||||
#define GL_MAX_FRAGMENT_UNIFORM_BLOCKS 0x8A2D
|
||||
#define GL_MAX_COMBINED_UNIFORM_BLOCKS 0x8A2E
|
||||
#define GL_MAX_UNIFORM_BUFFER_BINDINGS 0x8A2F
|
||||
#define GL_MAX_UNIFORM_BLOCK_SIZE 0x8A30
|
||||
#define GL_MAX_COMBINED_VERTEX_UNIFORM_COMPONENTS 0x8A31
|
||||
#define GL_MAX_COMBINED_FRAGMENT_UNIFORM_COMPONENTS 0x8A33
|
||||
#define GL_UNIFORM_BUFFER_OFFSET_ALIGNMENT 0x8A34
|
||||
#define GL_ACTIVE_UNIFORM_BLOCK_MAX_NAME_LENGTH 0x8A35
|
||||
#define GL_ACTIVE_UNIFORM_BLOCKS 0x8A36
|
||||
#define GL_UNIFORM_TYPE 0x8A37
|
||||
#define GL_UNIFORM_SIZE 0x8A38
|
||||
#define GL_UNIFORM_NAME_LENGTH 0x8A39
|
||||
#define GL_UNIFORM_BLOCK_INDEX 0x8A3A
|
||||
#define GL_UNIFORM_OFFSET 0x8A3B
|
||||
#define GL_UNIFORM_ARRAY_STRIDE 0x8A3C
|
||||
#define GL_UNIFORM_MATRIX_STRIDE 0x8A3D
|
||||
#define GL_UNIFORM_IS_ROW_MAJOR 0x8A3E
|
||||
#define GL_UNIFORM_BLOCK_BINDING 0x8A3F
|
||||
#define GL_UNIFORM_BLOCK_DATA_SIZE 0x8A40
|
||||
#define GL_UNIFORM_BLOCK_NAME_LENGTH 0x8A41
|
||||
#define GL_UNIFORM_BLOCK_ACTIVE_UNIFORMS 0x8A42
|
||||
#define GL_UNIFORM_BLOCK_ACTIVE_UNIFORM_INDICES 0x8A43
|
||||
#define GL_UNIFORM_BLOCK_REFERENCED_BY_VERTEX_SHADER 0x8A44
|
||||
#define GL_UNIFORM_BLOCK_REFERENCED_BY_FRAGMENT_SHADER 0x8A46
|
||||
#define GL_INVALID_INDEX 0xFFFFFFFFu
|
||||
#define GL_MAX_VERTEX_OUTPUT_COMPONENTS 0x9122
|
||||
#define GL_MAX_FRAGMENT_INPUT_COMPONENTS 0x9125
|
||||
#define GL_MAX_SERVER_WAIT_TIMEOUT 0x9111
|
||||
#define GL_OBJECT_TYPE 0x9112
|
||||
#define GL_SYNC_CONDITION 0x9113
|
||||
#define GL_SYNC_STATUS 0x9114
|
||||
#define GL_SYNC_FLAGS 0x9115
|
||||
#define GL_SYNC_FENCE 0x9116
|
||||
#define GL_SYNC_GPU_COMMANDS_COMPLETE 0x9117
|
||||
#define GL_UNSIGNALED 0x9118
|
||||
#define GL_SIGNALED 0x9119
|
||||
#define GL_ALREADY_SIGNALED 0x911A
|
||||
#define GL_TIMEOUT_EXPIRED 0x911B
|
||||
#define GL_CONDITION_SATISFIED 0x911C
|
||||
#define GL_WAIT_FAILED 0x911D
|
||||
#define GL_SYNC_FLUSH_COMMANDS_BIT 0x00000001
|
||||
#define GL_TIMEOUT_IGNORED 0xFFFFFFFFFFFFFFFFull
|
||||
#define GL_VERTEX_ATTRIB_ARRAY_DIVISOR 0x88FE
|
||||
#define GL_ANY_SAMPLES_PASSED 0x8C2F
|
||||
#define GL_ANY_SAMPLES_PASSED_CONSERVATIVE 0x8D6A
|
||||
#define GL_SAMPLER_BINDING 0x8919
|
||||
#define GL_RGB10_A2UI 0x906F
|
||||
#define GL_TEXTURE_SWIZZLE_R 0x8E42
|
||||
#define GL_TEXTURE_SWIZZLE_G 0x8E43
|
||||
#define GL_TEXTURE_SWIZZLE_B 0x8E44
|
||||
#define GL_TEXTURE_SWIZZLE_A 0x8E45
|
||||
#define GL_GREEN 0x1904
|
||||
#define GL_BLUE 0x1905
|
||||
#define GL_INT_2_10_10_10_REV 0x8D9F
|
||||
#define GL_TRANSFORM_FEEDBACK 0x8E22
|
||||
#define GL_TRANSFORM_FEEDBACK_PAUSED 0x8E23
|
||||
#define GL_TRANSFORM_FEEDBACK_ACTIVE 0x8E24
|
||||
#define GL_TRANSFORM_FEEDBACK_BINDING 0x8E25
|
||||
#define GL_PROGRAM_BINARY_RETRIEVABLE_HINT 0x8257
|
||||
#define GL_PROGRAM_BINARY_LENGTH 0x8741
|
||||
#define GL_NUM_PROGRAM_BINARY_FORMATS 0x87FE
|
||||
#define GL_PROGRAM_BINARY_FORMATS 0x87FF
|
||||
#define GL_COMPRESSED_R11_EAC 0x9270
|
||||
#define GL_COMPRESSED_SIGNED_R11_EAC 0x9271
|
||||
#define GL_COMPRESSED_RG11_EAC 0x9272
|
||||
#define GL_COMPRESSED_SIGNED_RG11_EAC 0x9273
|
||||
#define GL_COMPRESSED_RGB8_ETC2 0x9274
|
||||
#define GL_COMPRESSED_SRGB8_ETC2 0x9275
|
||||
#define GL_COMPRESSED_RGB8_PUNCHTHROUGH_ALPHA1_ETC2 0x9276
|
||||
#define GL_COMPRESSED_SRGB8_PUNCHTHROUGH_ALPHA1_ETC2 0x9277
|
||||
#define GL_COMPRESSED_RGBA8_ETC2_EAC 0x9278
|
||||
#define GL_COMPRESSED_SRGB8_ALPHA8_ETC2_EAC 0x9279
|
||||
#define GL_TEXTURE_IMMUTABLE_FORMAT 0x912F
|
||||
#define GL_MAX_ELEMENT_INDEX 0x8D6B
|
||||
#define GL_NUM_SAMPLE_COUNTS 0x9380
|
||||
#define GL_TEXTURE_IMMUTABLE_LEVELS 0x82DF
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Entrypoint definitions
|
||||
*-----------------------------------------------------------------------*/
|
||||
|
||||
/* OpenGL ES 3.0 */
|
||||
|
||||
extern GL_APICALL void (*GL_APIENTRY glReadBuffer)(GLenum mode);
|
||||
extern GL_APICALL void (*GL_APIENTRY glDrawRangeElements)(
|
||||
GLenum mode, GLuint start, GLuint end, GLsizei count, GLenum type,
|
||||
const GLvoid* indices);
|
||||
extern GL_APICALL void (*GL_APIENTRY glTexImage3D)(
|
||||
GLenum target, GLint level, GLint internalformat, GLsizei width,
|
||||
GLsizei height, GLsizei depth, GLint border, GLenum format, GLenum type,
|
||||
const GLvoid* pixels);
|
||||
extern GL_APICALL void (*GL_APIENTRY glTexSubImage3D)(
|
||||
GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset,
|
||||
GLsizei width, GLsizei height, GLsizei depth, GLenum format, GLenum type,
|
||||
const GLvoid* pixels);
|
||||
extern GL_APICALL void (*GL_APIENTRY glCopyTexSubImage3D)(
|
||||
GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset,
|
||||
GLint x, GLint y, GLsizei width, GLsizei height);
|
||||
extern GL_APICALL void (*GL_APIENTRY glCompressedTexImage3D)(
|
||||
GLenum target, GLint level, GLenum internalformat, GLsizei width,
|
||||
GLsizei height, GLsizei depth, GLint border, GLsizei imageSize,
|
||||
const GLvoid* data);
|
||||
extern GL_APICALL void (*GL_APIENTRY glCompressedTexSubImage3D)(
|
||||
GLenum target, GLint level, GLint xoffset, GLint yoffset, GLint zoffset,
|
||||
GLsizei width, GLsizei height, GLsizei depth, GLenum format,
|
||||
GLsizei imageSize, const GLvoid* data);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGenQueries)(GLsizei n, GLuint* ids);
|
||||
extern GL_APICALL void (*GL_APIENTRY glDeleteQueries)(GLsizei n,
|
||||
const GLuint* ids);
|
||||
extern GL_APICALL GLboolean (*GL_APIENTRY glIsQuery)(GLuint id);
|
||||
extern GL_APICALL void (*GL_APIENTRY glBeginQuery)(GLenum target, GLuint id);
|
||||
extern GL_APICALL void (*GL_APIENTRY glEndQuery)(GLenum target);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetQueryiv)(GLenum target, GLenum pname,
|
||||
GLint* params);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetQueryObjectuiv)(GLuint id,
|
||||
GLenum pname,
|
||||
GLuint* params);
|
||||
extern GL_APICALL GLboolean (*GL_APIENTRY glUnmapBuffer)(GLenum target);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetBufferPointerv)(GLenum target,
|
||||
GLenum pname,
|
||||
GLvoid** params);
|
||||
extern GL_APICALL void (*GL_APIENTRY glDrawBuffers)(GLsizei n,
|
||||
const GLenum* bufs);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniformMatrix2x3fv)(
|
||||
GLint location, GLsizei count, GLboolean transpose, const GLfloat* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniformMatrix3x2fv)(
|
||||
GLint location, GLsizei count, GLboolean transpose, const GLfloat* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniformMatrix2x4fv)(
|
||||
GLint location, GLsizei count, GLboolean transpose, const GLfloat* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniformMatrix4x2fv)(
|
||||
GLint location, GLsizei count, GLboolean transpose, const GLfloat* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniformMatrix3x4fv)(
|
||||
GLint location, GLsizei count, GLboolean transpose, const GLfloat* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniformMatrix4x3fv)(
|
||||
GLint location, GLsizei count, GLboolean transpose, const GLfloat* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glBlitFramebuffer)(
|
||||
GLint srcX0, GLint srcY0, GLint srcX1, GLint srcY1, GLint dstX0,
|
||||
GLint dstY0, GLint dstX1, GLint dstY1, GLbitfield mask, GLenum filter);
|
||||
extern GL_APICALL void (*GL_APIENTRY glRenderbufferStorageMultisample)(
|
||||
GLenum target, GLsizei samples, GLenum internalformat, GLsizei width,
|
||||
GLsizei height);
|
||||
extern GL_APICALL void (*GL_APIENTRY glFramebufferTextureLayer)(
|
||||
GLenum target, GLenum attachment, GLuint texture, GLint level, GLint layer);
|
||||
extern GL_APICALL GLvoid* (*GL_APIENTRY glMapBufferRange)(GLenum target,
|
||||
GLintptr offset,
|
||||
GLsizeiptr length,
|
||||
GLbitfield access);
|
||||
extern GL_APICALL void (*GL_APIENTRY glFlushMappedBufferRange)(
|
||||
GLenum target, GLintptr offset, GLsizeiptr length);
|
||||
extern GL_APICALL void (*GL_APIENTRY glBindVertexArray)(GLuint array);
|
||||
extern GL_APICALL void (*GL_APIENTRY
|
||||
glDeleteVertexArrays)(GLsizei n,
|
||||
const GLuint* arrays);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGenVertexArrays)(GLsizei n,
|
||||
GLuint* arrays);
|
||||
extern GL_APICALL GLboolean (*GL_APIENTRY glIsVertexArray)(GLuint array);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetIntegeri_v)(GLenum target,
|
||||
GLuint index,
|
||||
GLint* data);
|
||||
extern GL_APICALL void (*GL_APIENTRY
|
||||
glBeginTransformFeedback)(GLenum primitiveMode);
|
||||
extern GL_APICALL void (*GL_APIENTRY glEndTransformFeedback)(void);
|
||||
extern GL_APICALL void (*GL_APIENTRY
|
||||
glBindBufferRange)(GLenum target, GLuint index,
|
||||
GLuint buffer, GLintptr offset,
|
||||
GLsizeiptr size);
|
||||
extern GL_APICALL void (*GL_APIENTRY glBindBufferBase)(GLenum target,
|
||||
GLuint index,
|
||||
GLuint buffer);
|
||||
extern GL_APICALL void (*GL_APIENTRY glTransformFeedbackVaryings)(
|
||||
GLuint program, GLsizei count, const GLchar* const* varyings,
|
||||
GLenum bufferMode);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetTransformFeedbackVarying)(
|
||||
GLuint program, GLuint index, GLsizei bufSize, GLsizei* length,
|
||||
GLsizei* size, GLenum* type, GLchar* name);
|
||||
extern GL_APICALL void (*GL_APIENTRY
|
||||
glVertexAttribIPointer)(GLuint index, GLint size,
|
||||
GLenum type, GLsizei stride,
|
||||
const GLvoid* pointer);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetVertexAttribIiv)(GLuint index,
|
||||
GLenum pname,
|
||||
GLint* params);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetVertexAttribIuiv)(GLuint index,
|
||||
GLenum pname,
|
||||
GLuint* params);
|
||||
extern GL_APICALL void (*GL_APIENTRY glVertexAttribI4i)(GLuint index, GLint x,
|
||||
GLint y, GLint z,
|
||||
GLint w);
|
||||
extern GL_APICALL void (*GL_APIENTRY glVertexAttribI4ui)(GLuint index, GLuint x,
|
||||
GLuint y, GLuint z,
|
||||
GLuint w);
|
||||
extern GL_APICALL void (*GL_APIENTRY glVertexAttribI4iv)(GLuint index,
|
||||
const GLint* v);
|
||||
extern GL_APICALL void (*GL_APIENTRY glVertexAttribI4uiv)(GLuint index,
|
||||
const GLuint* v);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetUniformuiv)(GLuint program,
|
||||
GLint location,
|
||||
GLuint* params);
|
||||
extern GL_APICALL GLint (*GL_APIENTRY
|
||||
glGetFragDataLocation)(GLuint program,
|
||||
const GLchar* name);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniform1ui)(GLint location, GLuint v0);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniform2ui)(GLint location, GLuint v0,
|
||||
GLuint v1);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniform3ui)(GLint location, GLuint v0,
|
||||
GLuint v1, GLuint v2);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniform4ui)(GLint location, GLuint v0,
|
||||
GLuint v1, GLuint v2,
|
||||
GLuint v3);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniform1uiv)(GLint location,
|
||||
GLsizei count,
|
||||
const GLuint* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniform2uiv)(GLint location,
|
||||
GLsizei count,
|
||||
const GLuint* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniform3uiv)(GLint location,
|
||||
GLsizei count,
|
||||
const GLuint* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniform4uiv)(GLint location,
|
||||
GLsizei count,
|
||||
const GLuint* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glClearBufferiv)(GLenum buffer,
|
||||
GLint drawbuffer,
|
||||
const GLint* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glClearBufferuiv)(GLenum buffer,
|
||||
GLint drawbuffer,
|
||||
const GLuint* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glClearBufferfv)(GLenum buffer,
|
||||
GLint drawbuffer,
|
||||
const GLfloat* value);
|
||||
extern GL_APICALL void (*GL_APIENTRY
|
||||
glClearBufferfi)(GLenum buffer, GLint drawbuffer,
|
||||
GLfloat depth, GLint stencil);
|
||||
extern GL_APICALL const GLubyte* (*GL_APIENTRY glGetStringi)(GLenum name,
|
||||
GLuint index);
|
||||
extern GL_APICALL void (*GL_APIENTRY glCopyBufferSubData)(GLenum readTarget,
|
||||
GLenum writeTarget,
|
||||
GLintptr readOffset,
|
||||
GLintptr writeOffset,
|
||||
GLsizeiptr size);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetUniformIndices)(
|
||||
GLuint program, GLsizei uniformCount, const GLchar* const* uniformNames,
|
||||
GLuint* uniformIndices);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetActiveUniformsiv)(
|
||||
GLuint program, GLsizei uniformCount, const GLuint* uniformIndices,
|
||||
GLenum pname, GLint* params);
|
||||
extern GL_APICALL GLuint (*GL_APIENTRY glGetUniformBlockIndex)(
|
||||
GLuint program, const GLchar* uniformBlockName);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetActiveUniformBlockiv)(
|
||||
GLuint program, GLuint uniformBlockIndex, GLenum pname, GLint* params);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetActiveUniformBlockName)(
|
||||
GLuint program, GLuint uniformBlockIndex, GLsizei bufSize, GLsizei* length,
|
||||
GLchar* uniformBlockName);
|
||||
extern GL_APICALL void (*GL_APIENTRY glUniformBlockBinding)(
|
||||
GLuint program, GLuint uniformBlockIndex, GLuint uniformBlockBinding);
|
||||
extern GL_APICALL void (*GL_APIENTRY glDrawArraysInstanced)(
|
||||
GLenum mode, GLint first, GLsizei count, GLsizei instanceCount);
|
||||
extern GL_APICALL void (*GL_APIENTRY glDrawElementsInstanced)(
|
||||
GLenum mode, GLsizei count, GLenum type, const GLvoid* indices,
|
||||
GLsizei instanceCount);
|
||||
extern GL_APICALL GLsync (*GL_APIENTRY glFenceSync)(GLenum condition,
|
||||
GLbitfield flags);
|
||||
extern GL_APICALL GLboolean (*GL_APIENTRY glIsSync)(GLsync sync);
|
||||
extern GL_APICALL void (*GL_APIENTRY glDeleteSync)(GLsync sync);
|
||||
extern GL_APICALL GLenum (*GL_APIENTRY glClientWaitSync)(GLsync sync,
|
||||
GLbitfield flags,
|
||||
GLuint64 timeout);
|
||||
extern GL_APICALL void (*GL_APIENTRY glWaitSync)(GLsync sync, GLbitfield flags,
|
||||
GLuint64 timeout);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetInteger64v)(GLenum pname,
|
||||
GLint64* params);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetSynciv)(GLsync sync, GLenum pname,
|
||||
GLsizei bufSize,
|
||||
GLsizei* length,
|
||||
GLint* values);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetInteger64i_v)(GLenum target,
|
||||
GLuint index,
|
||||
GLint64* data);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetBufferParameteri64v)(GLenum target,
|
||||
GLenum pname,
|
||||
GLint64* params);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGenSamplers)(GLsizei count,
|
||||
GLuint* samplers);
|
||||
extern GL_APICALL void (*GL_APIENTRY glDeleteSamplers)(GLsizei count,
|
||||
const GLuint* samplers);
|
||||
extern GL_APICALL GLboolean (*GL_APIENTRY glIsSampler)(GLuint sampler);
|
||||
extern GL_APICALL void (*GL_APIENTRY glBindSampler)(GLuint unit,
|
||||
GLuint sampler);
|
||||
extern GL_APICALL void (*GL_APIENTRY glSamplerParameteri)(GLuint sampler,
|
||||
GLenum pname,
|
||||
GLint param);
|
||||
extern GL_APICALL void (*GL_APIENTRY glSamplerParameteriv)(GLuint sampler,
|
||||
GLenum pname,
|
||||
const GLint* param);
|
||||
extern GL_APICALL void (*GL_APIENTRY glSamplerParameterf)(GLuint sampler,
|
||||
GLenum pname,
|
||||
GLfloat param);
|
||||
extern GL_APICALL void (*GL_APIENTRY
|
||||
glSamplerParameterfv)(GLuint sampler, GLenum pname,
|
||||
const GLfloat* param);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetSamplerParameteriv)(GLuint sampler,
|
||||
GLenum pname,
|
||||
GLint* params);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetSamplerParameterfv)(GLuint sampler,
|
||||
GLenum pname,
|
||||
GLfloat* params);
|
||||
extern GL_APICALL void (*GL_APIENTRY glVertexAttribDivisor)(GLuint index,
|
||||
GLuint divisor);
|
||||
extern GL_APICALL void (*GL_APIENTRY glBindTransformFeedback)(GLenum target,
|
||||
GLuint id);
|
||||
extern GL_APICALL void (*GL_APIENTRY
|
||||
glDeleteTransformFeedbacks)(GLsizei n,
|
||||
const GLuint* ids);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGenTransformFeedbacks)(GLsizei n,
|
||||
GLuint* ids);
|
||||
extern GL_APICALL GLboolean (*GL_APIENTRY glIsTransformFeedback)(GLuint id);
|
||||
extern GL_APICALL void (*GL_APIENTRY glPauseTransformFeedback)(void);
|
||||
extern GL_APICALL void (*GL_APIENTRY glResumeTransformFeedback)(void);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetProgramBinary)(GLuint program,
|
||||
GLsizei bufSize,
|
||||
GLsizei* length,
|
||||
GLenum* binaryFormat,
|
||||
GLvoid* binary);
|
||||
extern GL_APICALL void (*GL_APIENTRY glProgramBinary)(GLuint program,
|
||||
GLenum binaryFormat,
|
||||
const GLvoid* binary,
|
||||
GLsizei length);
|
||||
extern GL_APICALL void (*GL_APIENTRY glProgramParameteri)(GLuint program,
|
||||
GLenum pname,
|
||||
GLint value);
|
||||
extern GL_APICALL void (*GL_APIENTRY glInvalidateFramebuffer)(
|
||||
GLenum target, GLsizei numAttachments, const GLenum* attachments);
|
||||
extern GL_APICALL void (*GL_APIENTRY glInvalidateSubFramebuffer)(
|
||||
GLenum target, GLsizei numAttachments, const GLenum* attachments, GLint x,
|
||||
GLint y, GLsizei width, GLsizei height);
|
||||
extern GL_APICALL void (*GL_APIENTRY
|
||||
glTexStorage2D)(GLenum target, GLsizei levels,
|
||||
GLenum internalformat,
|
||||
GLsizei width, GLsizei height);
|
||||
extern GL_APICALL void (*GL_APIENTRY glTexStorage3D)(
|
||||
GLenum target, GLsizei levels, GLenum internalformat, GLsizei width,
|
||||
GLsizei height, GLsizei depth);
|
||||
extern GL_APICALL void (*GL_APIENTRY glGetInternalformativ)(
|
||||
GLenum target, GLenum internalformat, GLenum pname, GLsizei bufSize,
|
||||
GLint* params);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
153
Teapot/app/src/main/cpp/ndk_helper/interpolator.cpp
Normal file
@@ -0,0 +1,153 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include "interpolator.h"
|
||||
#include <math.h>
|
||||
#include "interpolator.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
//-------------------------------------------------
|
||||
// Ctor
|
||||
//-------------------------------------------------
|
||||
Interpolator::Interpolator() { list_params_.clear(); }
|
||||
|
||||
//-------------------------------------------------
|
||||
// Dtor
|
||||
//-------------------------------------------------
|
||||
Interpolator::~Interpolator() { list_params_.clear(); }
|
||||
|
||||
void Interpolator::Clear() { list_params_.clear(); }
|
||||
|
||||
Interpolator& Interpolator::Set(const float start, const float dest,
|
||||
const INTERPOLATOR_TYPE type,
|
||||
const double duration) {
|
||||
// init the parameters for the interpolation process
|
||||
start_time_ = PerfMonitor::GetCurrentTime();
|
||||
dest_time_ = start_time_ + duration;
|
||||
type_ = type;
|
||||
|
||||
start_value_ = start;
|
||||
dest_value_ = dest;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Interpolator& Interpolator::Add(const float dest, const INTERPOLATOR_TYPE type,
|
||||
const double duration) {
|
||||
InterpolatorParams param;
|
||||
param.dest_value_ = dest;
|
||||
param.type_ = type;
|
||||
param.duration_ = duration;
|
||||
list_params_.push_back(param);
|
||||
return *this;
|
||||
}
|
||||
|
||||
bool Interpolator::Update(const double current_time, float& p) {
|
||||
bool bContinue;
|
||||
if (current_time >= dest_time_) {
|
||||
p = dest_value_;
|
||||
if (list_params_.size()) {
|
||||
InterpolatorParams& item = list_params_.front();
|
||||
Set(dest_value_, item.dest_value_, item.type_, item.duration_);
|
||||
list_params_.pop_front();
|
||||
|
||||
bContinue = true;
|
||||
} else {
|
||||
bContinue = false;
|
||||
}
|
||||
} else {
|
||||
float t = (float)(current_time - start_time_);
|
||||
float d = (float)(dest_time_ - start_time_);
|
||||
float b = start_value_;
|
||||
float c = dest_value_ - start_value_;
|
||||
p = GetFormula(type_, t, b, d, c);
|
||||
|
||||
bContinue = true;
|
||||
}
|
||||
return bContinue;
|
||||
}
|
||||
|
||||
float Interpolator::GetFormula(const INTERPOLATOR_TYPE type, const float t,
|
||||
const float b, const float d, const float c) {
|
||||
float t1;
|
||||
switch (type) {
|
||||
case INTERPOLATOR_TYPE_LINEAR:
|
||||
// simple linear interpolation - no easing
|
||||
return (c * t / d + b);
|
||||
|
||||
case INTERPOLATOR_TYPE_EASEINQUAD:
|
||||
// quadratic (t^2) easing in - accelerating from zero velocity
|
||||
t1 = t / d;
|
||||
return (c * t1 * t1 + b);
|
||||
|
||||
case INTERPOLATOR_TYPE_EASEOUTQUAD:
|
||||
// quadratic (t^2) easing out - decelerating to zero velocity
|
||||
t1 = t / d;
|
||||
return (-c * t1 * (t1 - 2) + b);
|
||||
|
||||
case INTERPOLATOR_TYPE_EASEINOUTQUAD:
|
||||
// quadratic easing in/out - acceleration until halfway, then deceleration
|
||||
t1 = t / d / 2;
|
||||
if (t1 < 1)
|
||||
return (c / 2 * t1 * t1 + b);
|
||||
else {
|
||||
t1 = t1 - 1;
|
||||
return (-c / 2 * (t1 * (t1 - 2) - 1) + b);
|
||||
}
|
||||
case INTERPOLATOR_TYPE_EASEINCUBIC:
|
||||
// cubic easing in - accelerating from zero velocity
|
||||
t1 = t / d;
|
||||
return (c * t1 * t1 * t1 + b);
|
||||
|
||||
case INTERPOLATOR_TYPE_EASEOUTCUBIC:
|
||||
// cubic easing in - accelerating from zero velocity
|
||||
t1 = t / d - 1;
|
||||
return (c * (t1 * t1 * t1 + 1) + b);
|
||||
|
||||
case INTERPOLATOR_TYPE_EASEINOUTCUBIC:
|
||||
// cubic easing in - accelerating from zero velocity
|
||||
t1 = t / d / 2;
|
||||
|
||||
if (t1 < 1)
|
||||
return (c / 2 * t1 * t1 * t1 + b);
|
||||
else {
|
||||
t1 -= 2;
|
||||
return (c / 2 * (t1 * t1 * t1 + 2) + b);
|
||||
}
|
||||
case INTERPOLATOR_TYPE_EASEINQUART:
|
||||
// quartic easing in - accelerating from zero velocity
|
||||
t1 = t / d;
|
||||
return (c * t1 * t1 * t1 * t1 + b);
|
||||
|
||||
case INTERPOLATOR_TYPE_EASEINEXPO:
|
||||
// exponential (2^t) easing in - accelerating from zero velocity
|
||||
if (t == 0)
|
||||
return b;
|
||||
else
|
||||
return (c * powf(2, (10 * (t / d - 1))) + b);
|
||||
|
||||
case INTERPOLATOR_TYPE_EASEOUTEXPO:
|
||||
// exponential (2^t) easing out - decelerating to zero velocity
|
||||
if (t == d)
|
||||
return (b + c);
|
||||
else
|
||||
return (c * (-powf(2, -10 * t / d) + 1) + b);
|
||||
default:
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
} // namespace ndkHelper
|
||||
80
Teapot/app/src/main/cpp/ndk_helper/interpolator.h
Normal file
@@ -0,0 +1,80 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#ifndef INTERPOLATOR_H_
|
||||
#define INTERPOLATOR_H_
|
||||
|
||||
#include <jni.h>
|
||||
#include <errno.h>
|
||||
#include <time.h>
|
||||
#include "JNIHelper.h"
|
||||
#include "perfMonitor.h"
|
||||
#include <list>
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
enum INTERPOLATOR_TYPE {
|
||||
INTERPOLATOR_TYPE_LINEAR,
|
||||
INTERPOLATOR_TYPE_EASEINQUAD,
|
||||
INTERPOLATOR_TYPE_EASEOUTQUAD,
|
||||
INTERPOLATOR_TYPE_EASEINOUTQUAD,
|
||||
INTERPOLATOR_TYPE_EASEINCUBIC,
|
||||
INTERPOLATOR_TYPE_EASEOUTCUBIC,
|
||||
INTERPOLATOR_TYPE_EASEINOUTCUBIC,
|
||||
INTERPOLATOR_TYPE_EASEINQUART,
|
||||
INTERPOLATOR_TYPE_EASEINEXPO,
|
||||
INTERPOLATOR_TYPE_EASEOUTEXPO,
|
||||
};
|
||||
|
||||
struct InterpolatorParams {
|
||||
float dest_value_;
|
||||
INTERPOLATOR_TYPE type_;
|
||||
double duration_;
|
||||
};
|
||||
|
||||
/******************************************************************
|
||||
* Interpolates values with several interpolation methods
|
||||
*/
|
||||
class Interpolator {
|
||||
private:
|
||||
double start_time_;
|
||||
double dest_time_;
|
||||
INTERPOLATOR_TYPE type_;
|
||||
|
||||
float start_value_;
|
||||
float dest_value_;
|
||||
std::list<InterpolatorParams> list_params_;
|
||||
|
||||
float GetFormula(const INTERPOLATOR_TYPE type, const float t, const float b,
|
||||
const float d, const float c);
|
||||
|
||||
public:
|
||||
Interpolator();
|
||||
~Interpolator();
|
||||
|
||||
Interpolator& Set(const float start, const float dest,
|
||||
const INTERPOLATOR_TYPE type, double duration);
|
||||
|
||||
Interpolator& Add(const float dest, const INTERPOLATOR_TYPE type,
|
||||
const double duration);
|
||||
|
||||
bool Update(const double currentTime, float& p);
|
||||
|
||||
void Clear();
|
||||
};
|
||||
|
||||
} // namespace ndkHelper
|
||||
#endif /* INTERPOLATOR_H_ */
|
||||
57
Teapot/app/src/main/cpp/ndk_helper/perfMonitor.cpp
Normal file
@@ -0,0 +1,57 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include "perfMonitor.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
PerfMonitor::PerfMonitor()
|
||||
: tv_last_sec_(0), last_tick_(0.f), tickindex_(0), ticksum_(0) {
|
||||
for (int32_t i = 0; i < NUM_SAMPLES; ++i) ticklist_[i] = 0;
|
||||
}
|
||||
|
||||
PerfMonitor::~PerfMonitor() {}
|
||||
|
||||
double PerfMonitor::UpdateTick(double currentTick) {
|
||||
ticksum_ -= ticklist_[tickindex_];
|
||||
ticksum_ += currentTick;
|
||||
ticklist_[tickindex_] = currentTick;
|
||||
tickindex_ = (tickindex_ + 1) % NUM_SAMPLES;
|
||||
|
||||
return ((double)ticksum_ / NUM_SAMPLES);
|
||||
}
|
||||
|
||||
bool PerfMonitor::Update(float &fFPS) {
|
||||
struct timeval Time;
|
||||
gettimeofday(&Time, NULL);
|
||||
|
||||
double time = Time.tv_sec + Time.tv_usec * 1.0 / 1000000.0;
|
||||
double tick = time - last_tick_;
|
||||
double d = UpdateTick(tick);
|
||||
last_tick_ = time;
|
||||
|
||||
if (Time.tv_sec - tv_last_sec_ >= 1) {
|
||||
current_FPS_ = 1.f / d;
|
||||
tv_last_sec_ = Time.tv_sec;
|
||||
fFPS = current_FPS_;
|
||||
return true;
|
||||
} else {
|
||||
fFPS = current_FPS_;
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
} // namespace ndkHelper
|
||||
59
Teapot/app/src/main/cpp/ndk_helper/perfMonitor.h
Normal file
@@ -0,0 +1,59 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#ifndef PERFMONITOR_H_
|
||||
#define PERFMONITOR_H_
|
||||
|
||||
#include <jni.h>
|
||||
#include <errno.h>
|
||||
#include <time.h>
|
||||
#include "JNIHelper.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
const int32_t NUM_SAMPLES = 100;
|
||||
|
||||
/******************************************************************
|
||||
* Helper class for a performance monitoring and get current tick time
|
||||
*/
|
||||
class PerfMonitor {
|
||||
private:
|
||||
float current_FPS_;
|
||||
time_t tv_last_sec_;
|
||||
|
||||
double last_tick_;
|
||||
int32_t tickindex_;
|
||||
double ticksum_;
|
||||
double ticklist_[NUM_SAMPLES];
|
||||
|
||||
double UpdateTick(double current_tick);
|
||||
|
||||
public:
|
||||
PerfMonitor();
|
||||
virtual ~PerfMonitor();
|
||||
|
||||
bool Update(float &fFPS);
|
||||
|
||||
static double GetCurrentTime() {
|
||||
struct timeval time;
|
||||
gettimeofday(&time, NULL);
|
||||
double ret = time.tv_sec + time.tv_usec * 1.0 / 1000000.0;
|
||||
return ret;
|
||||
}
|
||||
};
|
||||
|
||||
} // namespace ndkHelper
|
||||
#endif /* PERFMONITOR_H_ */
|
||||
167
Teapot/app/src/main/cpp/ndk_helper/shader.cpp
Normal file
@@ -0,0 +1,167 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include <EGL/egl.h>
|
||||
#include <GLES2/gl2.h>
|
||||
|
||||
#include "shader.h"
|
||||
#include "JNIHelper.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
#define DEBUG (1)
|
||||
|
||||
bool shader::CompileShader(
|
||||
GLuint *shader, const GLenum type, const char *str_file_name,
|
||||
const std::map<std::string, std::string> &map_parameters) {
|
||||
std::vector<uint8_t> data;
|
||||
if (!JNIHelper::GetInstance()->ReadFile(str_file_name, &data)) {
|
||||
LOGI("Can not open a file:%s", str_file_name);
|
||||
return false;
|
||||
}
|
||||
|
||||
const char REPLACEMENT_TAG = '*';
|
||||
// Fill-in parameters
|
||||
std::string str(data.begin(), data.end());
|
||||
std::string str_replacement_map(data.size(), ' ');
|
||||
|
||||
std::map<std::string, std::string>::const_iterator it =
|
||||
map_parameters.begin();
|
||||
std::map<std::string, std::string>::const_iterator itEnd =
|
||||
map_parameters.end();
|
||||
while (it != itEnd) {
|
||||
size_t pos = 0;
|
||||
while ((pos = str.find(it->first, pos)) != std::string::npos) {
|
||||
// Check if the sub string is already touched
|
||||
|
||||
size_t replaced_pos = str_replacement_map.find(REPLACEMENT_TAG, pos);
|
||||
if (replaced_pos == std::string::npos || replaced_pos > pos) {
|
||||
|
||||
str.replace(pos, it->first.length(), it->second);
|
||||
str_replacement_map.replace(pos, it->first.length(), it->first.length(),
|
||||
REPLACEMENT_TAG);
|
||||
pos += it->second.length();
|
||||
} else {
|
||||
// The replacement target has been touched by other tag, skipping them
|
||||
pos += it->second.length();
|
||||
}
|
||||
}
|
||||
it++;
|
||||
}
|
||||
|
||||
LOGI("Patched Shdader:\n%s", str.c_str());
|
||||
|
||||
std::vector<uint8_t> v(str.begin(), str.end());
|
||||
str.clear();
|
||||
return shader::CompileShader(shader, type, v);
|
||||
}
|
||||
|
||||
bool shader::CompileShader(GLuint *shader, const GLenum type,
|
||||
const GLchar *source, const int32_t iSize) {
|
||||
if (source == NULL || iSize <= 0) return false;
|
||||
|
||||
*shader = glCreateShader(type);
|
||||
glShaderSource(*shader, 1, &source, &iSize); // Not specifying 3rd parameter
|
||||
// (size) could be troublesome..
|
||||
|
||||
glCompileShader(*shader);
|
||||
|
||||
#if defined(DEBUG)
|
||||
GLint logLength;
|
||||
glGetShaderiv(*shader, GL_INFO_LOG_LENGTH, &logLength);
|
||||
if (logLength > 0) {
|
||||
GLchar *log = (GLchar *)malloc(logLength);
|
||||
glGetShaderInfoLog(*shader, logLength, &logLength, log);
|
||||
LOGI("Shader compile log:\n%s", log);
|
||||
free(log);
|
||||
}
|
||||
#endif
|
||||
|
||||
GLint status;
|
||||
glGetShaderiv(*shader, GL_COMPILE_STATUS, &status);
|
||||
if (status == 0) {
|
||||
glDeleteShader(*shader);
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool shader::CompileShader(GLuint *shader, const GLenum type,
|
||||
std::vector<uint8_t> &data) {
|
||||
if (!data.size()) return false;
|
||||
|
||||
const GLchar *source = (GLchar *)&data[0];
|
||||
int32_t iSize = data.size();
|
||||
return shader::CompileShader(shader, type, source, iSize);
|
||||
}
|
||||
|
||||
bool shader::CompileShader(GLuint *shader, const GLenum type,
|
||||
const char *strFileName) {
|
||||
std::vector<uint8_t> data;
|
||||
bool b = JNIHelper::GetInstance()->ReadFile(strFileName, &data);
|
||||
if (!b) {
|
||||
LOGI("Can not open a file:%s", strFileName);
|
||||
return false;
|
||||
}
|
||||
|
||||
return shader::CompileShader(shader, type, data);
|
||||
}
|
||||
|
||||
bool shader::LinkProgram(const GLuint prog) {
|
||||
GLint status;
|
||||
|
||||
glLinkProgram(prog);
|
||||
|
||||
#if defined(DEBUG)
|
||||
GLint logLength;
|
||||
glGetProgramiv(prog, GL_INFO_LOG_LENGTH, &logLength);
|
||||
if (logLength > 0) {
|
||||
GLchar *log = (GLchar *)malloc(logLength);
|
||||
glGetProgramInfoLog(prog, logLength, &logLength, log);
|
||||
LOGI("Program link log:\n%s", log);
|
||||
free(log);
|
||||
}
|
||||
#endif
|
||||
|
||||
glGetProgramiv(prog, GL_LINK_STATUS, &status);
|
||||
if (status == 0) {
|
||||
LOGI("Program link failed\n");
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool shader::ValidateProgram(const GLuint prog) {
|
||||
GLint logLength, status;
|
||||
|
||||
glValidateProgram(prog);
|
||||
glGetProgramiv(prog, GL_INFO_LOG_LENGTH, &logLength);
|
||||
if (logLength > 0) {
|
||||
GLchar *log = (GLchar *)malloc(logLength);
|
||||
glGetProgramInfoLog(prog, logLength, &logLength, log);
|
||||
LOGI("Program validate log:\n%s", log);
|
||||
free(log);
|
||||
}
|
||||
|
||||
glGetProgramiv(prog, GL_VALIDATE_STATUS, &status);
|
||||
if (status == 0) return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
} // namespace ndkHelper
|
||||
120
Teapot/app/src/main/cpp/ndk_helper/shader.h
Normal file
@@ -0,0 +1,120 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#ifndef SHADER_H_
|
||||
#define SHADER_H_
|
||||
|
||||
#include <jni.h>
|
||||
|
||||
#include <vector>
|
||||
#include <map>
|
||||
#include <string>
|
||||
|
||||
#include <EGL/egl.h>
|
||||
#include <GLES/gl.h>
|
||||
|
||||
#include <android/log.h>
|
||||
|
||||
#include "JNIHelper.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
namespace shader {
|
||||
|
||||
/******************************************************************
|
||||
* Shader compiler helper
|
||||
* namespace: ndkHelper::shader
|
||||
*
|
||||
*/
|
||||
|
||||
/******************************************************************
|
||||
* CompileShader() with vector
|
||||
*
|
||||
* arguments:
|
||||
* out: shader, shader variable
|
||||
* in: type, shader type (i.e. GL_VERTEX_SHADER/GL_FRAGMENT_SHADER)
|
||||
* in: data, source vector
|
||||
* return: true if a shader compilation succeeded, false if it failed
|
||||
*
|
||||
*/
|
||||
bool CompileShader(GLuint *shader, const GLenum type,
|
||||
std::vector<uint8_t> &data);
|
||||
|
||||
/******************************************************************
|
||||
* CompileShader() with buffer
|
||||
*
|
||||
* arguments:
|
||||
* out: shader, shader variable
|
||||
* in: type, shader type (i.e. GL_VERTEX_SHADER/GL_FRAGMENT_SHADER)
|
||||
* in: source, source buffer
|
||||
* in: iSize, buffer size
|
||||
* return: true if a shader compilation succeeded, false if it failed
|
||||
*
|
||||
*/
|
||||
bool CompileShader(GLuint *shader, const GLenum type, const GLchar *source,
|
||||
const int32_t iSize);
|
||||
|
||||
/******************************************************************
|
||||
* CompileShader() with filename
|
||||
*
|
||||
* arguments:
|
||||
* out: shader, shader variable
|
||||
* in: type, shader type (i.e. GL_VERTEX_SHADER/GL_FRAGMENT_SHADER)
|
||||
* in: strFilename, filename
|
||||
* return: true if a shader compilation succeeded, false if it failed
|
||||
*
|
||||
*/
|
||||
bool CompileShader(GLuint *shader, const GLenum type, const char *strFileName);
|
||||
|
||||
/******************************************************************
|
||||
* CompileShader() with std::map helps patching on a shader on the fly.
|
||||
*
|
||||
* arguments:
|
||||
* out: shader, shader variable
|
||||
* in: type, shader type (i.e. GL_VERTEX_SHADER/GL_FRAGMENT_SHADER)
|
||||
* in: mapParameters
|
||||
* For a example,
|
||||
* map : %KEY% -> %VALUE% replaces all %KEY% entries in the given shader
|
||||
*code to %VALUE"
|
||||
* return: true if a shader compilation succeeded, false if it failed
|
||||
*
|
||||
*/
|
||||
bool CompileShader(GLuint *shader, const GLenum type, const char *str_file_name,
|
||||
const std::map<std::string, std::string> &map_parameters);
|
||||
|
||||
/******************************************************************
|
||||
* LinkProgram()
|
||||
*
|
||||
* arguments:
|
||||
* in: program, program
|
||||
* return: true if a shader linkage succeeded, false if it failed
|
||||
*
|
||||
*/
|
||||
bool LinkProgram(const GLuint prog);
|
||||
|
||||
/******************************************************************
|
||||
* validateProgram()
|
||||
*
|
||||
* arguments:
|
||||
* in: program, program
|
||||
* return: true if a shader validation succeeded, false if it failed
|
||||
*
|
||||
*/
|
||||
bool ValidateProgram(const GLuint prog);
|
||||
} // namespace shader
|
||||
|
||||
} // namespace ndkHelper
|
||||
#endif /* SHADER_H_ */
|
||||
281
Teapot/app/src/main/cpp/ndk_helper/tapCamera.cpp
Normal file
@@ -0,0 +1,281 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
//----------------------------------------------------------
|
||||
// tapCamera.cpp
|
||||
// Camera control with tap
|
||||
//
|
||||
//----------------------------------------------------------
|
||||
#include <fstream>
|
||||
#include "tapCamera.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
const float TRANSFORM_FACTOR = 15.f;
|
||||
const float TRANSFORM_FACTORZ = 10.f;
|
||||
|
||||
const float MOMENTUM_FACTOR_DECREASE = 0.85f;
|
||||
const float MOMENTUM_FACTOR_DECREASE_SHIFT = 0.9f;
|
||||
const float MOMENTUM_FACTOR = 0.8f;
|
||||
const float MOMENTUM_FACTOR_THRESHOLD = 0.001f;
|
||||
|
||||
//----------------------------------------------------------
|
||||
// Ctor
|
||||
//----------------------------------------------------------
|
||||
TapCamera::TapCamera()
|
||||
: ball_radius_(0.75f),
|
||||
dragging_(false),
|
||||
pinching_(false),
|
||||
pinch_start_distance_SQ_(0.f),
|
||||
camera_rotation_(0.f),
|
||||
camera_rotation_start_(0.f),
|
||||
camera_rotation_now_(0.f),
|
||||
momentum_(false),
|
||||
momemtum_steps_(0.f),
|
||||
flip_z_(0.f) {
|
||||
// Init offset
|
||||
InitParameters();
|
||||
|
||||
vec_flip_ = Vec2(1.f, -1.f);
|
||||
flip_z_ = -1.f;
|
||||
vec_pinch_transform_factor_ = Vec3(1.f, 1.f, 1.f);
|
||||
|
||||
vec_ball_center_ = Vec2(0, 0);
|
||||
vec_ball_now_ = Vec2(0, 0);
|
||||
vec_ball_down_ = Vec2(0, 0);
|
||||
|
||||
vec_pinch_start_ = Vec2(0, 0);
|
||||
vec_pinch_start_center_ = Vec2(0, 0);
|
||||
|
||||
vec_flip_ = Vec2(0, 0);
|
||||
}
|
||||
|
||||
void TapCamera::InitParameters() {
|
||||
// Init parameters
|
||||
vec_offset_ = Vec3();
|
||||
vec_offset_now_ = Vec3();
|
||||
|
||||
quat_ball_rot_ = Quaternion();
|
||||
quat_ball_now_ = Quaternion();
|
||||
quat_ball_now_.ToMatrix(mat_rotation_);
|
||||
camera_rotation_ = 0.f;
|
||||
|
||||
vec_drag_delta_ = Vec2();
|
||||
vec_offset_delta_ = Vec3();
|
||||
|
||||
momentum_ = false;
|
||||
}
|
||||
|
||||
//----------------------------------------------------------
|
||||
// Dtor
|
||||
//----------------------------------------------------------
|
||||
TapCamera::~TapCamera() {}
|
||||
|
||||
void TapCamera::Update() {
|
||||
if (momentum_) {
|
||||
float momenttum_steps = momemtum_steps_;
|
||||
|
||||
// Momentum rotation
|
||||
Vec2 v = vec_drag_delta_;
|
||||
BeginDrag(Vec2()); // NOTE:This call reset _VDragDelta
|
||||
Drag(v * vec_flip_);
|
||||
|
||||
// Momentum shift
|
||||
vec_offset_ += vec_offset_delta_;
|
||||
|
||||
BallUpdate();
|
||||
EndDrag();
|
||||
|
||||
// Decrease deltas
|
||||
vec_drag_delta_ = v * MOMENTUM_FACTOR_DECREASE;
|
||||
vec_offset_delta_ = vec_offset_delta_ * MOMENTUM_FACTOR_DECREASE_SHIFT;
|
||||
|
||||
// Count steps
|
||||
momemtum_steps_ = momenttum_steps * MOMENTUM_FACTOR_DECREASE;
|
||||
if (momemtum_steps_ < MOMENTUM_FACTOR_THRESHOLD) {
|
||||
momentum_ = false;
|
||||
}
|
||||
} else {
|
||||
vec_drag_delta_ *= MOMENTUM_FACTOR;
|
||||
vec_offset_delta_ = vec_offset_delta_ * MOMENTUM_FACTOR;
|
||||
BallUpdate();
|
||||
}
|
||||
|
||||
Vec3 vec = vec_offset_ + vec_offset_now_;
|
||||
Vec3 vec_tmp(TRANSFORM_FACTOR, -TRANSFORM_FACTOR, TRANSFORM_FACTORZ);
|
||||
|
||||
vec *= vec_tmp * vec_pinch_transform_factor_;
|
||||
|
||||
mat_transform_ = Mat4::Translation(vec);
|
||||
}
|
||||
|
||||
Mat4& TapCamera::GetRotationMatrix() { return mat_rotation_; }
|
||||
|
||||
Mat4& TapCamera::GetTransformMatrix() { return mat_transform_; }
|
||||
|
||||
void TapCamera::Reset(const bool bAnimate) {
|
||||
InitParameters();
|
||||
Update();
|
||||
}
|
||||
|
||||
//----------------------------------------------------------
|
||||
// Drag control
|
||||
//----------------------------------------------------------
|
||||
void TapCamera::BeginDrag(const Vec2& v) {
|
||||
if (dragging_) EndDrag();
|
||||
|
||||
if (pinching_) EndPinch();
|
||||
|
||||
Vec2 vec = v * vec_flip_;
|
||||
vec_ball_now_ = vec;
|
||||
vec_ball_down_ = vec_ball_now_;
|
||||
|
||||
dragging_ = true;
|
||||
momentum_ = false;
|
||||
vec_last_input_ = vec;
|
||||
vec_drag_delta_ = Vec2();
|
||||
}
|
||||
|
||||
void TapCamera::EndDrag() {
|
||||
quat_ball_down_ = quat_ball_now_;
|
||||
quat_ball_rot_ = Quaternion();
|
||||
|
||||
dragging_ = false;
|
||||
momentum_ = true;
|
||||
momemtum_steps_ = 1.0f;
|
||||
}
|
||||
|
||||
void TapCamera::Drag(const Vec2& v) {
|
||||
if (!dragging_) return;
|
||||
|
||||
Vec2 vec = v * vec_flip_;
|
||||
vec_ball_now_ = vec;
|
||||
|
||||
vec_drag_delta_ = vec_drag_delta_ * MOMENTUM_FACTOR + (vec - vec_last_input_);
|
||||
vec_last_input_ = vec;
|
||||
}
|
||||
|
||||
//----------------------------------------------------------
|
||||
// Pinch controll
|
||||
//----------------------------------------------------------
|
||||
void TapCamera::BeginPinch(const Vec2& v1, const Vec2& v2) {
|
||||
if (dragging_) EndDrag();
|
||||
|
||||
if (pinching_) EndPinch();
|
||||
|
||||
BeginDrag(Vec2());
|
||||
|
||||
vec_pinch_start_center_ = (v1 + v2) / 2.f;
|
||||
|
||||
Vec2 vec = v1 - v2;
|
||||
float x_diff;
|
||||
float y_diff;
|
||||
vec.Value(x_diff, y_diff);
|
||||
|
||||
pinch_start_distance_SQ_ = x_diff * x_diff + y_diff * y_diff;
|
||||
camera_rotation_start_ = atan2f(y_diff, x_diff);
|
||||
camera_rotation_now_ = 0;
|
||||
|
||||
pinching_ = true;
|
||||
momentum_ = false;
|
||||
|
||||
// Init momentum factors
|
||||
vec_offset_delta_ = Vec3();
|
||||
}
|
||||
|
||||
void TapCamera::EndPinch() {
|
||||
pinching_ = false;
|
||||
momentum_ = true;
|
||||
momemtum_steps_ = 1.f;
|
||||
vec_offset_ += vec_offset_now_;
|
||||
camera_rotation_ += camera_rotation_now_;
|
||||
vec_offset_now_ = Vec3();
|
||||
|
||||
camera_rotation_now_ = 0;
|
||||
|
||||
EndDrag();
|
||||
}
|
||||
|
||||
void TapCamera::Pinch(const Vec2& v1, const Vec2& v2) {
|
||||
if (!pinching_) return;
|
||||
|
||||
// Update momentum factor
|
||||
vec_offset_last_ = vec_offset_now_;
|
||||
|
||||
float x_diff, y_diff;
|
||||
Vec2 vec = v1 - v2;
|
||||
vec.Value(x_diff, y_diff);
|
||||
|
||||
float fDistanceSQ = x_diff * x_diff + y_diff * y_diff;
|
||||
|
||||
float f = pinch_start_distance_SQ_ / fDistanceSQ;
|
||||
if (f < 1.f)
|
||||
f = -1.f / f + 1.0f;
|
||||
else
|
||||
f = f - 1.f;
|
||||
if (isnan(f)) f = 0.f;
|
||||
|
||||
vec = (v1 + v2) / 2.f - vec_pinch_start_center_;
|
||||
vec_offset_now_ = Vec3(vec, flip_z_ * f);
|
||||
|
||||
// Update momentum factor
|
||||
vec_offset_delta_ = vec_offset_delta_ * MOMENTUM_FACTOR +
|
||||
(vec_offset_now_ - vec_offset_last_);
|
||||
|
||||
//
|
||||
// Update ration quaternion
|
||||
float fRotation = atan2f(y_diff, x_diff);
|
||||
camera_rotation_now_ = fRotation - camera_rotation_start_;
|
||||
|
||||
// Trackball rotation
|
||||
quat_ball_rot_ = Quaternion(0.f, 0.f, sinf(-camera_rotation_now_ * 0.5f),
|
||||
cosf(-camera_rotation_now_ * 0.5f));
|
||||
}
|
||||
|
||||
//----------------------------------------------------------
|
||||
// Trackball controll
|
||||
//----------------------------------------------------------
|
||||
void TapCamera::BallUpdate() {
|
||||
if (dragging_) {
|
||||
Vec3 vec_from = PointOnSphere(vec_ball_down_);
|
||||
Vec3 vec_to = PointOnSphere(vec_ball_now_);
|
||||
|
||||
Vec3 vec = vec_from.Cross(vec_to);
|
||||
float w = vec_from.Dot(vec_to);
|
||||
|
||||
Quaternion qDrag = Quaternion(vec, w);
|
||||
qDrag = qDrag * quat_ball_down_;
|
||||
quat_ball_now_ = quat_ball_rot_ * qDrag;
|
||||
}
|
||||
quat_ball_now_.ToMatrix(mat_rotation_);
|
||||
}
|
||||
|
||||
Vec3 TapCamera::PointOnSphere(Vec2& point) {
|
||||
Vec3 ball_mouse;
|
||||
float mag;
|
||||
Vec2 vec = (point - vec_ball_center_) / ball_radius_;
|
||||
mag = vec.Dot(vec);
|
||||
if (mag > 1.f) {
|
||||
float scale = 1.f / sqrtf(mag);
|
||||
vec *= scale;
|
||||
ball_mouse = Vec3(vec, 0.f);
|
||||
} else {
|
||||
ball_mouse = Vec3(vec, sqrtf(1.f - mag));
|
||||
}
|
||||
return ball_mouse;
|
||||
}
|
||||
|
||||
} // namespace ndkHelper
|
||||
108
Teapot/app/src/main/cpp/ndk_helper/tapCamera.h
Normal file
@@ -0,0 +1,108 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
#include <vector>
|
||||
#include <string>
|
||||
#include <GLES2/gl2.h>
|
||||
|
||||
#include "JNIHelper.h"
|
||||
#include "vecmath.h"
|
||||
#include "interpolator.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
/******************************************************************
|
||||
* Camera control helper class with a tap gesture
|
||||
* This class is mainly used for 3D space camera control in samples.
|
||||
*
|
||||
*/
|
||||
class TapCamera {
|
||||
private:
|
||||
// Trackball
|
||||
Vec2 vec_ball_center_;
|
||||
float ball_radius_;
|
||||
Quaternion quat_ball_now_;
|
||||
Quaternion quat_ball_down_;
|
||||
Vec2 vec_ball_now_;
|
||||
Vec2 vec_ball_down_;
|
||||
Quaternion quat_ball_rot_;
|
||||
|
||||
bool dragging_;
|
||||
bool pinching_;
|
||||
|
||||
// Pinch related info
|
||||
Vec2 vec_pinch_start_;
|
||||
Vec2 vec_pinch_start_center_;
|
||||
float pinch_start_distance_SQ_;
|
||||
|
||||
// Camera shift
|
||||
Vec3 vec_offset_;
|
||||
Vec3 vec_offset_now_;
|
||||
|
||||
// Camera Rotation
|
||||
float camera_rotation_;
|
||||
float camera_rotation_start_;
|
||||
float camera_rotation_now_;
|
||||
|
||||
// Momentum support
|
||||
bool momentum_;
|
||||
Vec2 vec_drag_delta_;
|
||||
Vec2 vec_last_input_;
|
||||
Vec3 vec_offset_last_;
|
||||
Vec3 vec_offset_delta_;
|
||||
float momemtum_steps_;
|
||||
|
||||
Vec2 vec_flip_;
|
||||
float flip_z_;
|
||||
|
||||
Mat4 mat_rotation_;
|
||||
Mat4 mat_transform_;
|
||||
|
||||
Vec3 vec_pinch_transform_factor_;
|
||||
|
||||
Vec3 PointOnSphere(Vec2& point);
|
||||
void BallUpdate();
|
||||
void InitParameters();
|
||||
|
||||
public:
|
||||
TapCamera();
|
||||
virtual ~TapCamera();
|
||||
void BeginDrag(const Vec2& vec);
|
||||
void EndDrag();
|
||||
void Drag(const Vec2& vec);
|
||||
void Update();
|
||||
|
||||
Mat4& GetRotationMatrix();
|
||||
Mat4& GetTransformMatrix();
|
||||
|
||||
void BeginPinch(const Vec2& v1, const Vec2& v2);
|
||||
void EndPinch();
|
||||
void Pinch(const Vec2& v1, const Vec2& v2);
|
||||
|
||||
void SetFlip(const float x, const float y, const float z) {
|
||||
vec_flip_ = Vec2(x, y);
|
||||
flip_z_ = z;
|
||||
}
|
||||
|
||||
void SetPinchTransformFactor(const float x, const float y, const float z) {
|
||||
vec_pinch_transform_factor_ = Vec3(x, y, z);
|
||||
}
|
||||
|
||||
void Reset(const bool bAnimate);
|
||||
};
|
||||
|
||||
} // namespace ndkHelper
|
||||
362
Teapot/app/src/main/cpp/ndk_helper/vecmath.cpp
Normal file
@@ -0,0 +1,362 @@
|
||||
/*
|
||||
* Copy_right 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* y_ou may_ not use this file ex_cept in compliance with the License.
|
||||
* You may_ obtain a copy_ of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by_ applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either ex_press or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// vecmath.cpp
|
||||
//--------------------------------------------------------------------------------
|
||||
#include "vecmath.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// vec3
|
||||
//--------------------------------------------------------------------------------
|
||||
Vec3::Vec3(const Vec4& vec) {
|
||||
x_ = vec.x_;
|
||||
y_ = vec.y_;
|
||||
z_ = vec.z_;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// vec4
|
||||
//--------------------------------------------------------------------------------
|
||||
Vec4 Vec4::operator*(const Mat4& rhs) const {
|
||||
Vec4 out;
|
||||
out.x_ = x_ * rhs.f_[0] + y_ * rhs.f_[1] + z_ * rhs.f_[2] + w_ * rhs.f_[3];
|
||||
out.y_ = x_ * rhs.f_[4] + y_ * rhs.f_[5] + z_ * rhs.f_[6] + w_ * rhs.f_[7];
|
||||
out.z_ = x_ * rhs.f_[8] + y_ * rhs.f_[9] + z_ * rhs.f_[10] + w_ * rhs.f_[11];
|
||||
out.w_ =
|
||||
x_ * rhs.f_[12] + y_ * rhs.f_[13] + z_ * rhs.f_[14] + w_ * rhs.f_[15];
|
||||
return out;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// mat4
|
||||
//--------------------------------------------------------------------------------
|
||||
Mat4::Mat4() {
|
||||
for (int32_t i = 0; i < 16; ++i) f_[i] = 0.f;
|
||||
}
|
||||
|
||||
Mat4::Mat4(const float* mIn) {
|
||||
for (int32_t i = 0; i < 16; ++i) f_[i] = mIn[i];
|
||||
}
|
||||
|
||||
Mat4 Mat4::operator*(const Mat4& rhs) const {
|
||||
Mat4 ret;
|
||||
ret.f_[0] = f_[0] * rhs.f_[0] + f_[4] * rhs.f_[1] + f_[8] * rhs.f_[2] +
|
||||
f_[12] * rhs.f_[3];
|
||||
ret.f_[1] = f_[1] * rhs.f_[0] + f_[5] * rhs.f_[1] + f_[9] * rhs.f_[2] +
|
||||
f_[13] * rhs.f_[3];
|
||||
ret.f_[2] = f_[2] * rhs.f_[0] + f_[6] * rhs.f_[1] + f_[10] * rhs.f_[2] +
|
||||
f_[14] * rhs.f_[3];
|
||||
ret.f_[3] = f_[3] * rhs.f_[0] + f_[7] * rhs.f_[1] + f_[11] * rhs.f_[2] +
|
||||
f_[15] * rhs.f_[3];
|
||||
|
||||
ret.f_[4] = f_[0] * rhs.f_[4] + f_[4] * rhs.f_[5] + f_[8] * rhs.f_[6] +
|
||||
f_[12] * rhs.f_[7];
|
||||
ret.f_[5] = f_[1] * rhs.f_[4] + f_[5] * rhs.f_[5] + f_[9] * rhs.f_[6] +
|
||||
f_[13] * rhs.f_[7];
|
||||
ret.f_[6] = f_[2] * rhs.f_[4] + f_[6] * rhs.f_[5] + f_[10] * rhs.f_[6] +
|
||||
f_[14] * rhs.f_[7];
|
||||
ret.f_[7] = f_[3] * rhs.f_[4] + f_[7] * rhs.f_[5] + f_[11] * rhs.f_[6] +
|
||||
f_[15] * rhs.f_[7];
|
||||
|
||||
ret.f_[8] = f_[0] * rhs.f_[8] + f_[4] * rhs.f_[9] + f_[8] * rhs.f_[10] +
|
||||
f_[12] * rhs.f_[11];
|
||||
ret.f_[9] = f_[1] * rhs.f_[8] + f_[5] * rhs.f_[9] + f_[9] * rhs.f_[10] +
|
||||
f_[13] * rhs.f_[11];
|
||||
ret.f_[10] = f_[2] * rhs.f_[8] + f_[6] * rhs.f_[9] + f_[10] * rhs.f_[10] +
|
||||
f_[14] * rhs.f_[11];
|
||||
ret.f_[11] = f_[3] * rhs.f_[8] + f_[7] * rhs.f_[9] + f_[11] * rhs.f_[10] +
|
||||
f_[15] * rhs.f_[11];
|
||||
|
||||
ret.f_[12] = f_[0] * rhs.f_[12] + f_[4] * rhs.f_[13] + f_[8] * rhs.f_[14] +
|
||||
f_[12] * rhs.f_[15];
|
||||
ret.f_[13] = f_[1] * rhs.f_[12] + f_[5] * rhs.f_[13] + f_[9] * rhs.f_[14] +
|
||||
f_[13] * rhs.f_[15];
|
||||
ret.f_[14] = f_[2] * rhs.f_[12] + f_[6] * rhs.f_[13] + f_[10] * rhs.f_[14] +
|
||||
f_[14] * rhs.f_[15];
|
||||
ret.f_[15] = f_[3] * rhs.f_[12] + f_[7] * rhs.f_[13] + f_[11] * rhs.f_[14] +
|
||||
f_[15] * rhs.f_[15];
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec4 Mat4::operator*(const Vec4& rhs) const {
|
||||
Vec4 ret;
|
||||
ret.x_ = rhs.x_ * f_[0] + rhs.y_ * f_[4] + rhs.z_ * f_[8] + rhs.w_ * f_[12];
|
||||
ret.y_ = rhs.x_ * f_[1] + rhs.y_ * f_[5] + rhs.z_ * f_[9] + rhs.w_ * f_[13];
|
||||
ret.z_ = rhs.x_ * f_[2] + rhs.y_ * f_[6] + rhs.z_ * f_[10] + rhs.w_ * f_[14];
|
||||
ret.w_ = rhs.x_ * f_[3] + rhs.y_ * f_[7] + rhs.z_ * f_[11] + rhs.w_ * f_[15];
|
||||
return ret;
|
||||
}
|
||||
|
||||
Mat4 Mat4::Inverse() {
|
||||
Mat4 ret;
|
||||
float det_1;
|
||||
float pos = 0;
|
||||
float neg = 0;
|
||||
float temp;
|
||||
|
||||
temp = f_[0] * f_[5] * f_[10];
|
||||
if (temp >= 0)
|
||||
pos += temp;
|
||||
else
|
||||
neg += temp;
|
||||
temp = f_[4] * f_[9] * f_[2];
|
||||
if (temp >= 0)
|
||||
pos += temp;
|
||||
else
|
||||
neg += temp;
|
||||
temp = f_[8] * f_[1] * f_[6];
|
||||
if (temp >= 0)
|
||||
pos += temp;
|
||||
else
|
||||
neg += temp;
|
||||
temp = -f_[8] * f_[5] * f_[2];
|
||||
if (temp >= 0)
|
||||
pos += temp;
|
||||
else
|
||||
neg += temp;
|
||||
temp = -f_[4] * f_[1] * f_[10];
|
||||
if (temp >= 0)
|
||||
pos += temp;
|
||||
else
|
||||
neg += temp;
|
||||
temp = -f_[0] * f_[9] * f_[6];
|
||||
if (temp >= 0)
|
||||
pos += temp;
|
||||
else
|
||||
neg += temp;
|
||||
det_1 = pos + neg;
|
||||
|
||||
if (det_1 == 0.0) {
|
||||
// Error
|
||||
} else {
|
||||
det_1 = 1.0f / det_1;
|
||||
ret.f_[0] = (f_[5] * f_[10] - f_[9] * f_[6]) * det_1;
|
||||
ret.f_[1] = -(f_[1] * f_[10] - f_[9] * f_[2]) * det_1;
|
||||
ret.f_[2] = (f_[1] * f_[6] - f_[5] * f_[2]) * det_1;
|
||||
ret.f_[4] = -(f_[4] * f_[10] - f_[8] * f_[6]) * det_1;
|
||||
ret.f_[5] = (f_[0] * f_[10] - f_[8] * f_[2]) * det_1;
|
||||
ret.f_[6] = -(f_[0] * f_[6] - f_[4] * f_[2]) * det_1;
|
||||
ret.f_[8] = (f_[4] * f_[9] - f_[8] * f_[5]) * det_1;
|
||||
ret.f_[9] = -(f_[0] * f_[9] - f_[8] * f_[1]) * det_1;
|
||||
ret.f_[10] = (f_[0] * f_[5] - f_[4] * f_[1]) * det_1;
|
||||
|
||||
/* Calculate -C * inverse(A) */
|
||||
ret.f_[12] =
|
||||
-(f_[12] * ret.f_[0] + f_[13] * ret.f_[4] + f_[14] * ret.f_[8]);
|
||||
ret.f_[13] =
|
||||
-(f_[12] * ret.f_[1] + f_[13] * ret.f_[5] + f_[14] * ret.f_[9]);
|
||||
ret.f_[14] =
|
||||
-(f_[12] * ret.f_[2] + f_[13] * ret.f_[6] + f_[14] * ret.f_[10]);
|
||||
|
||||
ret.f_[3] = 0.0f;
|
||||
ret.f_[7] = 0.0f;
|
||||
ret.f_[11] = 0.0f;
|
||||
ret.f_[15] = 1.0f;
|
||||
}
|
||||
|
||||
*this = ret;
|
||||
return *this;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// Misc
|
||||
//--------------------------------------------------------------------------------
|
||||
Mat4 Mat4::RotationX(const float fAngle) {
|
||||
Mat4 ret;
|
||||
float fCosine, fSine;
|
||||
|
||||
fCosine = cosf(fAngle);
|
||||
fSine = sinf(fAngle);
|
||||
|
||||
ret.f_[0] = 1.0f;
|
||||
ret.f_[4] = 0.0f;
|
||||
ret.f_[8] = 0.0f;
|
||||
ret.f_[12] = 0.0f;
|
||||
ret.f_[1] = 0.0f;
|
||||
ret.f_[5] = fCosine;
|
||||
ret.f_[9] = fSine;
|
||||
ret.f_[13] = 0.0f;
|
||||
ret.f_[2] = 0.0f;
|
||||
ret.f_[6] = -fSine;
|
||||
ret.f_[10] = fCosine;
|
||||
ret.f_[14] = 0.0f;
|
||||
ret.f_[3] = 0.0f;
|
||||
ret.f_[7] = 0.0f;
|
||||
ret.f_[11] = 0.0f;
|
||||
ret.f_[15] = 1.0f;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Mat4 Mat4::RotationY(const float fAngle) {
|
||||
Mat4 ret;
|
||||
float fCosine, fSine;
|
||||
|
||||
fCosine = cosf(fAngle);
|
||||
fSine = sinf(fAngle);
|
||||
|
||||
ret.f_[0] = fCosine;
|
||||
ret.f_[4] = 0.0f;
|
||||
ret.f_[8] = -fSine;
|
||||
ret.f_[12] = 0.0f;
|
||||
ret.f_[1] = 0.0f;
|
||||
ret.f_[5] = 1.0f;
|
||||
ret.f_[9] = 0.0f;
|
||||
ret.f_[13] = 0.0f;
|
||||
ret.f_[2] = fSine;
|
||||
ret.f_[6] = 0.0f;
|
||||
ret.f_[10] = fCosine;
|
||||
ret.f_[14] = 0.0f;
|
||||
ret.f_[3] = 0.0f;
|
||||
ret.f_[7] = 0.0f;
|
||||
ret.f_[11] = 0.0f;
|
||||
ret.f_[15] = 1.0f;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Mat4 Mat4::RotationZ(const float fAngle) {
|
||||
Mat4 ret;
|
||||
float fCosine, fSine;
|
||||
|
||||
fCosine = cosf(fAngle);
|
||||
fSine = sinf(fAngle);
|
||||
|
||||
ret.f_[0] = fCosine;
|
||||
ret.f_[4] = fSine;
|
||||
ret.f_[8] = 0.0f;
|
||||
ret.f_[12] = 0.0f;
|
||||
ret.f_[1] = -fSine;
|
||||
ret.f_[5] = fCosine;
|
||||
ret.f_[9] = 0.0f;
|
||||
ret.f_[13] = 0.0f;
|
||||
ret.f_[2] = 0.0f;
|
||||
ret.f_[6] = 0.0f;
|
||||
ret.f_[10] = 1.0f;
|
||||
ret.f_[14] = 0.0f;
|
||||
ret.f_[3] = 0.0f;
|
||||
ret.f_[7] = 0.0f;
|
||||
ret.f_[11] = 0.0f;
|
||||
ret.f_[15] = 1.0f;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Mat4 Mat4::Translation(const float fX, const float fY, const float fZ) {
|
||||
Mat4 ret;
|
||||
ret.f_[0] = 1.0f;
|
||||
ret.f_[4] = 0.0f;
|
||||
ret.f_[8] = 0.0f;
|
||||
ret.f_[12] = fX;
|
||||
ret.f_[1] = 0.0f;
|
||||
ret.f_[5] = 1.0f;
|
||||
ret.f_[9] = 0.0f;
|
||||
ret.f_[13] = fY;
|
||||
ret.f_[2] = 0.0f;
|
||||
ret.f_[6] = 0.0f;
|
||||
ret.f_[10] = 1.0f;
|
||||
ret.f_[14] = fZ;
|
||||
ret.f_[3] = 0.0f;
|
||||
ret.f_[7] = 0.0f;
|
||||
ret.f_[11] = 0.0f;
|
||||
ret.f_[15] = 1.0f;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Mat4 Mat4::Translation(const Vec3 vec) {
|
||||
Mat4 ret;
|
||||
ret.f_[0] = 1.0f;
|
||||
ret.f_[4] = 0.0f;
|
||||
ret.f_[8] = 0.0f;
|
||||
ret.f_[12] = vec.x_;
|
||||
ret.f_[1] = 0.0f;
|
||||
ret.f_[5] = 1.0f;
|
||||
ret.f_[9] = 0.0f;
|
||||
ret.f_[13] = vec.y_;
|
||||
ret.f_[2] = 0.0f;
|
||||
ret.f_[6] = 0.0f;
|
||||
ret.f_[10] = 1.0f;
|
||||
ret.f_[14] = vec.z_;
|
||||
ret.f_[3] = 0.0f;
|
||||
ret.f_[7] = 0.0f;
|
||||
ret.f_[11] = 0.0f;
|
||||
ret.f_[15] = 1.0f;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Mat4 Mat4::Perspective(float width, float height, float nearPlane,
|
||||
float farPlane) {
|
||||
float n2 = 2.0f * nearPlane;
|
||||
float rcpnmf = 1.f / (nearPlane - farPlane);
|
||||
|
||||
Mat4 result;
|
||||
result.f_[0] = n2 / width;
|
||||
result.f_[4] = 0;
|
||||
result.f_[8] = 0;
|
||||
result.f_[12] = 0;
|
||||
result.f_[1] = 0;
|
||||
result.f_[5] = n2 / height;
|
||||
result.f_[9] = 0;
|
||||
result.f_[13] = 0;
|
||||
result.f_[2] = 0;
|
||||
result.f_[6] = 0;
|
||||
result.f_[10] = (farPlane + nearPlane) * rcpnmf;
|
||||
result.f_[14] = farPlane * rcpnmf * n2;
|
||||
result.f_[3] = 0;
|
||||
result.f_[7] = 0;
|
||||
result.f_[11] = -1.0;
|
||||
result.f_[15] = 0;
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
Mat4 Mat4::LookAt(const Vec3& vec_eye, const Vec3& vec_at, const Vec3& vec_up) {
|
||||
Vec3 vec_forward, vec_up_norm, vec_side;
|
||||
Mat4 result;
|
||||
|
||||
vec_forward.x_ = vec_eye.x_ - vec_at.x_;
|
||||
vec_forward.y_ = vec_eye.y_ - vec_at.y_;
|
||||
vec_forward.z_ = vec_eye.z_ - vec_at.z_;
|
||||
|
||||
vec_forward.Normalize();
|
||||
vec_up_norm = vec_up;
|
||||
vec_up_norm.Normalize();
|
||||
vec_side = vec_up_norm.Cross(vec_forward);
|
||||
vec_up_norm = vec_forward.Cross(vec_side);
|
||||
|
||||
result.f_[0] = vec_side.x_;
|
||||
result.f_[4] = vec_side.y_;
|
||||
result.f_[8] = vec_side.z_;
|
||||
result.f_[12] = 0;
|
||||
result.f_[1] = vec_up_norm.x_;
|
||||
result.f_[5] = vec_up_norm.y_;
|
||||
result.f_[9] = vec_up_norm.z_;
|
||||
result.f_[13] = 0;
|
||||
result.f_[2] = vec_forward.x_;
|
||||
result.f_[6] = vec_forward.y_;
|
||||
result.f_[10] = vec_forward.z_;
|
||||
result.f_[14] = 0;
|
||||
result.f_[3] = 0;
|
||||
result.f_[7] = 0;
|
||||
result.f_[11] = 0;
|
||||
result.f_[15] = 1.0;
|
||||
|
||||
result.PostTranslate(-vec_eye.x_, -vec_eye.y_, -vec_eye.z_);
|
||||
return result;
|
||||
}
|
||||
|
||||
} // namespace ndkHelper
|
||||
959
Teapot/app/src/main/cpp/ndk_helper/vecmath.h
Normal file
@@ -0,0 +1,959 @@
|
||||
/*
|
||||
* Copyright 2013 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#ifndef VECMATH_H_
|
||||
#define VECMATH_H_
|
||||
|
||||
#include <math.h>
|
||||
#include "JNIHelper.h"
|
||||
|
||||
namespace ndk_helper {
|
||||
|
||||
/******************************************************************
|
||||
* Helper class for vector math operations
|
||||
* Currently all implementations are in pure C++.
|
||||
* Each class is an opaque class so caller does not have a direct access
|
||||
* to each element. This is for an ease of future optimization to use vector
|
||||
*operations.
|
||||
*
|
||||
*/
|
||||
|
||||
class Vec2;
|
||||
class Vec3;
|
||||
class Vec4;
|
||||
class Mat4;
|
||||
|
||||
/******************************************************************
|
||||
* 2 elements vector class
|
||||
*
|
||||
*/
|
||||
class Vec2 {
|
||||
private:
|
||||
float x_;
|
||||
float y_;
|
||||
|
||||
public:
|
||||
friend class Vec3;
|
||||
friend class Vec4;
|
||||
friend class Mat4;
|
||||
friend class Quaternion;
|
||||
|
||||
Vec2() { x_ = y_ = 0.f; }
|
||||
|
||||
Vec2(const float fX, const float fY) {
|
||||
x_ = fX;
|
||||
y_ = fY;
|
||||
}
|
||||
|
||||
Vec2(const Vec2& vec) {
|
||||
x_ = vec.x_;
|
||||
y_ = vec.y_;
|
||||
}
|
||||
|
||||
Vec2(const float* pVec) {
|
||||
x_ = (*pVec++);
|
||||
y_ = (*pVec++);
|
||||
}
|
||||
|
||||
// Operators
|
||||
Vec2 operator*(const Vec2& rhs) const {
|
||||
Vec2 ret;
|
||||
ret.x_ = x_ * rhs.x_;
|
||||
ret.y_ = y_ * rhs.y_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec2 operator/(const Vec2& rhs) const {
|
||||
Vec2 ret;
|
||||
ret.x_ = x_ / rhs.x_;
|
||||
ret.y_ = y_ / rhs.y_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec2 operator+(const Vec2& rhs) const {
|
||||
Vec2 ret;
|
||||
ret.x_ = x_ + rhs.x_;
|
||||
ret.y_ = y_ + rhs.y_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec2 operator-(const Vec2& rhs) const {
|
||||
Vec2 ret;
|
||||
ret.x_ = x_ - rhs.x_;
|
||||
ret.y_ = y_ - rhs.y_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec2& operator+=(const Vec2& rhs) {
|
||||
x_ += rhs.x_;
|
||||
y_ += rhs.y_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec2& operator-=(const Vec2& rhs) {
|
||||
x_ -= rhs.x_;
|
||||
y_ -= rhs.y_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec2& operator*=(const Vec2& rhs) {
|
||||
x_ *= rhs.x_;
|
||||
y_ *= rhs.y_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec2& operator/=(const Vec2& rhs) {
|
||||
x_ /= rhs.x_;
|
||||
y_ /= rhs.y_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
// External operators
|
||||
friend Vec2 operator-(const Vec2& rhs) { return Vec2(rhs) *= -1; }
|
||||
|
||||
friend Vec2 operator*(const float lhs, const Vec2& rhs) {
|
||||
Vec2 ret;
|
||||
ret.x_ = lhs * rhs.x_;
|
||||
ret.y_ = lhs * rhs.y_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
friend Vec2 operator/(const float lhs, const Vec2& rhs) {
|
||||
Vec2 ret;
|
||||
ret.x_ = lhs / rhs.x_;
|
||||
ret.y_ = lhs / rhs.y_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
// Operators with float
|
||||
Vec2 operator*(const float& rhs) const {
|
||||
Vec2 ret;
|
||||
ret.x_ = x_ * rhs;
|
||||
ret.y_ = y_ * rhs;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec2& operator*=(const float& rhs) {
|
||||
x_ = x_ * rhs;
|
||||
y_ = y_ * rhs;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec2 operator/(const float& rhs) const {
|
||||
Vec2 ret;
|
||||
ret.x_ = x_ / rhs;
|
||||
ret.y_ = y_ / rhs;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec2& operator/=(const float& rhs) {
|
||||
x_ = x_ / rhs;
|
||||
y_ = y_ / rhs;
|
||||
return *this;
|
||||
}
|
||||
|
||||
// Compare
|
||||
bool operator==(const Vec2& rhs) const {
|
||||
if (x_ != rhs.x_ || y_ != rhs.y_) return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
bool operator!=(const Vec2& rhs) const {
|
||||
if (x_ == rhs.x_) return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
float Length() const { return sqrtf(x_ * x_ + y_ * y_); }
|
||||
|
||||
Vec2 Normalize() {
|
||||
float len = Length();
|
||||
x_ = x_ / len;
|
||||
y_ = y_ / len;
|
||||
return *this;
|
||||
}
|
||||
|
||||
float Dot(const Vec2& rhs) { return x_ * rhs.x_ + y_ * rhs.y_; }
|
||||
|
||||
bool Validate() {
|
||||
if (isnan(x_) || isnan(y_)) return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
void Value(float& fX, float& fY) {
|
||||
fX = x_;
|
||||
fY = y_;
|
||||
}
|
||||
|
||||
void Dump() { LOGI("Vec2 %f %f", x_, y_); }
|
||||
};
|
||||
|
||||
/******************************************************************
|
||||
* 3 elements vector class
|
||||
*
|
||||
*/
|
||||
class Vec3 {
|
||||
private:
|
||||
float x_, y_, z_;
|
||||
|
||||
public:
|
||||
friend class Vec4;
|
||||
friend class Mat4;
|
||||
friend class Quaternion;
|
||||
|
||||
Vec3() { x_ = y_ = z_ = 0.f; }
|
||||
|
||||
Vec3(const float fX, const float fY, const float fZ) {
|
||||
x_ = fX;
|
||||
y_ = fY;
|
||||
z_ = fZ;
|
||||
}
|
||||
|
||||
Vec3(const Vec3& vec) {
|
||||
x_ = vec.x_;
|
||||
y_ = vec.y_;
|
||||
z_ = vec.z_;
|
||||
}
|
||||
|
||||
Vec3(const float* pVec) {
|
||||
x_ = (*pVec++);
|
||||
y_ = (*pVec++);
|
||||
z_ = *pVec;
|
||||
}
|
||||
|
||||
Vec3(const Vec2& vec, float f) {
|
||||
x_ = vec.x_;
|
||||
y_ = vec.y_;
|
||||
z_ = f;
|
||||
}
|
||||
|
||||
Vec3(const Vec4& vec);
|
||||
|
||||
// Operators
|
||||
Vec3 operator*(const Vec3& rhs) const {
|
||||
Vec3 ret;
|
||||
ret.x_ = x_ * rhs.x_;
|
||||
ret.y_ = y_ * rhs.y_;
|
||||
ret.z_ = z_ * rhs.z_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec3 operator/(const Vec3& rhs) const {
|
||||
Vec3 ret;
|
||||
ret.x_ = x_ / rhs.x_;
|
||||
ret.y_ = y_ / rhs.y_;
|
||||
ret.z_ = z_ / rhs.z_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec3 operator+(const Vec3& rhs) const {
|
||||
Vec3 ret;
|
||||
ret.x_ = x_ + rhs.x_;
|
||||
ret.y_ = y_ + rhs.y_;
|
||||
ret.z_ = z_ + rhs.z_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec3 operator-(const Vec3& rhs) const {
|
||||
Vec3 ret;
|
||||
ret.x_ = x_ - rhs.x_;
|
||||
ret.y_ = y_ - rhs.y_;
|
||||
ret.z_ = z_ - rhs.z_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec3& operator+=(const Vec3& rhs) {
|
||||
x_ += rhs.x_;
|
||||
y_ += rhs.y_;
|
||||
z_ += rhs.z_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec3& operator-=(const Vec3& rhs) {
|
||||
x_ -= rhs.x_;
|
||||
y_ -= rhs.y_;
|
||||
z_ -= rhs.z_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec3& operator*=(const Vec3& rhs) {
|
||||
x_ *= rhs.x_;
|
||||
y_ *= rhs.y_;
|
||||
z_ *= rhs.z_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec3& operator/=(const Vec3& rhs) {
|
||||
x_ /= rhs.x_;
|
||||
y_ /= rhs.y_;
|
||||
z_ /= rhs.z_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
// External operators
|
||||
friend Vec3 operator-(const Vec3& rhs) { return Vec3(rhs) *= -1; }
|
||||
|
||||
friend Vec3 operator*(const float lhs, const Vec3& rhs) {
|
||||
Vec3 ret;
|
||||
ret.x_ = lhs * rhs.x_;
|
||||
ret.y_ = lhs * rhs.y_;
|
||||
ret.z_ = lhs * rhs.z_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
friend Vec3 operator/(const float lhs, const Vec3& rhs) {
|
||||
Vec3 ret;
|
||||
ret.x_ = lhs / rhs.x_;
|
||||
ret.y_ = lhs / rhs.y_;
|
||||
ret.z_ = lhs / rhs.z_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
// Operators with float
|
||||
Vec3 operator*(const float& rhs) const {
|
||||
Vec3 ret;
|
||||
ret.x_ = x_ * rhs;
|
||||
ret.y_ = y_ * rhs;
|
||||
ret.z_ = z_ * rhs;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec3& operator*=(const float& rhs) {
|
||||
x_ = x_ * rhs;
|
||||
y_ = y_ * rhs;
|
||||
z_ = z_ * rhs;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec3 operator/(const float& rhs) const {
|
||||
Vec3 ret;
|
||||
ret.x_ = x_ / rhs;
|
||||
ret.y_ = y_ / rhs;
|
||||
ret.z_ = z_ / rhs;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec3& operator/=(const float& rhs) {
|
||||
x_ = x_ / rhs;
|
||||
y_ = y_ / rhs;
|
||||
z_ = z_ / rhs;
|
||||
return *this;
|
||||
}
|
||||
|
||||
// Compare
|
||||
bool operator==(const Vec3& rhs) const {
|
||||
if (x_ != rhs.x_ || y_ != rhs.y_ || z_ != rhs.z_) return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
bool operator!=(const Vec3& rhs) const {
|
||||
if (x_ == rhs.x_) return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
float Length() const { return sqrtf(x_ * x_ + y_ * y_ + z_ * z_); }
|
||||
|
||||
Vec3 Normalize() {
|
||||
float len = Length();
|
||||
x_ = x_ / len;
|
||||
y_ = y_ / len;
|
||||
z_ = z_ / len;
|
||||
return *this;
|
||||
}
|
||||
|
||||
float Dot(const Vec3& rhs) { return x_ * rhs.x_ + y_ * rhs.y_ + z_ * rhs.z_; }
|
||||
|
||||
Vec3 Cross(const Vec3& rhs) {
|
||||
Vec3 ret;
|
||||
ret.x_ = y_ * rhs.z_ - z_ * rhs.y_;
|
||||
ret.y_ = z_ * rhs.x_ - x_ * rhs.z_;
|
||||
ret.z_ = x_ * rhs.y_ - y_ * rhs.x_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
bool Validate() {
|
||||
if (isnan(x_) || isnan(y_) || isnan(z_)) return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
void Value(float& fX, float& fY, float& fZ) {
|
||||
fX = x_;
|
||||
fY = y_;
|
||||
fZ = z_;
|
||||
}
|
||||
|
||||
void Dump() { LOGI("Vec3 %f %f %f", x_, y_, z_); }
|
||||
};
|
||||
|
||||
/******************************************************************
|
||||
* 4 elements vector class
|
||||
*
|
||||
*/
|
||||
class Vec4 {
|
||||
private:
|
||||
float x_, y_, z_, w_;
|
||||
|
||||
public:
|
||||
friend class Vec3;
|
||||
friend class Mat4;
|
||||
friend class Quaternion;
|
||||
|
||||
Vec4() { x_ = y_ = z_ = w_ = 0.f; }
|
||||
|
||||
Vec4(const float fX, const float fY, const float fZ, const float fW) {
|
||||
x_ = fX;
|
||||
y_ = fY;
|
||||
z_ = fZ;
|
||||
w_ = fW;
|
||||
}
|
||||
|
||||
Vec4(const Vec4& vec) {
|
||||
x_ = vec.x_;
|
||||
y_ = vec.y_;
|
||||
z_ = vec.z_;
|
||||
w_ = vec.w_;
|
||||
}
|
||||
|
||||
Vec4(const Vec3& vec, const float fW) {
|
||||
x_ = vec.x_;
|
||||
y_ = vec.y_;
|
||||
z_ = vec.z_;
|
||||
w_ = fW;
|
||||
}
|
||||
|
||||
Vec4(const float* pVec) {
|
||||
x_ = (*pVec++);
|
||||
y_ = (*pVec++);
|
||||
z_ = *pVec;
|
||||
w_ = *pVec;
|
||||
}
|
||||
|
||||
// Operators
|
||||
Vec4 operator*(const Vec4& rhs) const {
|
||||
Vec4 ret;
|
||||
ret.x_ = x_ * rhs.x_;
|
||||
ret.y_ = y_ * rhs.y_;
|
||||
ret.z_ = z_ * rhs.z_;
|
||||
ret.w_ = z_ * rhs.w_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec4 operator/(const Vec4& rhs) const {
|
||||
Vec4 ret;
|
||||
ret.x_ = x_ / rhs.x_;
|
||||
ret.y_ = y_ / rhs.y_;
|
||||
ret.z_ = z_ / rhs.z_;
|
||||
ret.w_ = z_ / rhs.w_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec4 operator+(const Vec4& rhs) const {
|
||||
Vec4 ret;
|
||||
ret.x_ = x_ + rhs.x_;
|
||||
ret.y_ = y_ + rhs.y_;
|
||||
ret.z_ = z_ + rhs.z_;
|
||||
ret.w_ = z_ + rhs.w_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec4 operator-(const Vec4& rhs) const {
|
||||
Vec4 ret;
|
||||
ret.x_ = x_ - rhs.x_;
|
||||
ret.y_ = y_ - rhs.y_;
|
||||
ret.z_ = z_ - rhs.z_;
|
||||
ret.w_ = z_ - rhs.w_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec4& operator+=(const Vec4& rhs) {
|
||||
x_ += rhs.x_;
|
||||
y_ += rhs.y_;
|
||||
z_ += rhs.z_;
|
||||
w_ += rhs.w_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec4& operator-=(const Vec4& rhs) {
|
||||
x_ -= rhs.x_;
|
||||
y_ -= rhs.y_;
|
||||
z_ -= rhs.z_;
|
||||
w_ -= rhs.w_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec4& operator*=(const Vec4& rhs) {
|
||||
x_ *= rhs.x_;
|
||||
y_ *= rhs.y_;
|
||||
z_ *= rhs.z_;
|
||||
w_ *= rhs.w_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec4& operator/=(const Vec4& rhs) {
|
||||
x_ /= rhs.x_;
|
||||
y_ /= rhs.y_;
|
||||
z_ /= rhs.z_;
|
||||
w_ /= rhs.w_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
// External operators
|
||||
friend Vec4 operator-(const Vec4& rhs) { return Vec4(rhs) *= -1; }
|
||||
|
||||
friend Vec4 operator*(const float lhs, const Vec4& rhs) {
|
||||
Vec4 ret;
|
||||
ret.x_ = lhs * rhs.x_;
|
||||
ret.y_ = lhs * rhs.y_;
|
||||
ret.z_ = lhs * rhs.z_;
|
||||
ret.w_ = lhs * rhs.w_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
friend Vec4 operator/(const float lhs, const Vec4& rhs) {
|
||||
Vec4 ret;
|
||||
ret.x_ = lhs / rhs.x_;
|
||||
ret.y_ = lhs / rhs.y_;
|
||||
ret.z_ = lhs / rhs.z_;
|
||||
ret.w_ = lhs / rhs.w_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
// Operators with float
|
||||
Vec4 operator*(const float& rhs) const {
|
||||
Vec4 ret;
|
||||
ret.x_ = x_ * rhs;
|
||||
ret.y_ = y_ * rhs;
|
||||
ret.z_ = z_ * rhs;
|
||||
ret.w_ = w_ * rhs;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec4& operator*=(const float& rhs) {
|
||||
x_ = x_ * rhs;
|
||||
y_ = y_ * rhs;
|
||||
z_ = z_ * rhs;
|
||||
w_ = w_ * rhs;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Vec4 operator/(const float& rhs) const {
|
||||
Vec4 ret;
|
||||
ret.x_ = x_ / rhs;
|
||||
ret.y_ = y_ / rhs;
|
||||
ret.z_ = z_ / rhs;
|
||||
ret.w_ = w_ / rhs;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Vec4& operator/=(const float& rhs) {
|
||||
x_ = x_ / rhs;
|
||||
y_ = y_ / rhs;
|
||||
z_ = z_ / rhs;
|
||||
w_ = w_ / rhs;
|
||||
return *this;
|
||||
}
|
||||
|
||||
// Compare
|
||||
bool operator==(const Vec4& rhs) const {
|
||||
if (x_ != rhs.x_ || y_ != rhs.y_ || z_ != rhs.z_ || w_ != rhs.w_)
|
||||
return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
bool operator!=(const Vec4& rhs) const {
|
||||
if (x_ == rhs.x_) return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
Vec4 operator*(const Mat4& rhs) const;
|
||||
|
||||
float Length() const { return sqrtf(x_ * x_ + y_ * y_ + z_ * z_ + w_ * w_); }
|
||||
|
||||
Vec4 Normalize() {
|
||||
float len = Length();
|
||||
x_ = x_ / len;
|
||||
y_ = y_ / len;
|
||||
z_ = z_ / len;
|
||||
w_ = w_ / len;
|
||||
return *this;
|
||||
}
|
||||
|
||||
float Dot(const Vec3& rhs) { return x_ * rhs.x_ + y_ * rhs.y_ + z_ * rhs.z_; }
|
||||
|
||||
Vec3 Cross(const Vec3& rhs) {
|
||||
Vec3 ret;
|
||||
ret.x_ = y_ * rhs.z_ - z_ * rhs.y_;
|
||||
ret.y_ = z_ * rhs.x_ - x_ * rhs.z_;
|
||||
ret.z_ = x_ * rhs.y_ - y_ * rhs.x_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
bool Validate() {
|
||||
if (isnan(x_) || isnan(y_) || isnan(z_) || isnan(w_)) return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
void Value(float& fX, float& fY, float& fZ, float& fW) {
|
||||
fX = x_;
|
||||
fY = y_;
|
||||
fZ = z_;
|
||||
fW = w_;
|
||||
}
|
||||
};
|
||||
|
||||
/******************************************************************
|
||||
* 4x4 matrix
|
||||
*
|
||||
*/
|
||||
class Mat4 {
|
||||
private:
|
||||
float f_[16];
|
||||
|
||||
public:
|
||||
friend class Vec3;
|
||||
friend class Vec4;
|
||||
friend class Quaternion;
|
||||
|
||||
Mat4();
|
||||
Mat4(const float*);
|
||||
|
||||
Mat4 operator*(const Mat4& rhs) const;
|
||||
Vec4 operator*(const Vec4& rhs) const;
|
||||
|
||||
Mat4 operator+(const Mat4& rhs) const {
|
||||
Mat4 ret;
|
||||
for (int32_t i = 0; i < 16; ++i) {
|
||||
ret.f_[i] = f_[i] + rhs.f_[i];
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
||||
Mat4 operator-(const Mat4& rhs) const {
|
||||
Mat4 ret;
|
||||
for (int32_t i = 0; i < 16; ++i) {
|
||||
ret.f_[i] = f_[i] - rhs.f_[i];
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
||||
Mat4& operator+=(const Mat4& rhs) {
|
||||
for (int32_t i = 0; i < 16; ++i) {
|
||||
f_[i] += rhs.f_[i];
|
||||
}
|
||||
return *this;
|
||||
}
|
||||
|
||||
Mat4& operator-=(const Mat4& rhs) {
|
||||
for (int32_t i = 0; i < 16; ++i) {
|
||||
f_[i] -= rhs.f_[i];
|
||||
}
|
||||
return *this;
|
||||
}
|
||||
|
||||
Mat4& operator*=(const Mat4& rhs) {
|
||||
Mat4 ret;
|
||||
ret.f_[0] = f_[0] * rhs.f_[0] + f_[4] * rhs.f_[1] + f_[8] * rhs.f_[2] +
|
||||
f_[12] * rhs.f_[3];
|
||||
ret.f_[1] = f_[1] * rhs.f_[0] + f_[5] * rhs.f_[1] + f_[9] * rhs.f_[2] +
|
||||
f_[13] * rhs.f_[3];
|
||||
ret.f_[2] = f_[2] * rhs.f_[0] + f_[6] * rhs.f_[1] + f_[10] * rhs.f_[2] +
|
||||
f_[14] * rhs.f_[3];
|
||||
ret.f_[3] = f_[3] * rhs.f_[0] + f_[7] * rhs.f_[1] + f_[11] * rhs.f_[2] +
|
||||
f_[15] * rhs.f_[3];
|
||||
|
||||
ret.f_[4] = f_[0] * rhs.f_[4] + f_[4] * rhs.f_[5] + f_[8] * rhs.f_[6] +
|
||||
f_[12] * rhs.f_[7];
|
||||
ret.f_[5] = f_[1] * rhs.f_[4] + f_[5] * rhs.f_[5] + f_[9] * rhs.f_[6] +
|
||||
f_[13] * rhs.f_[7];
|
||||
ret.f_[6] = f_[2] * rhs.f_[4] + f_[6] * rhs.f_[5] + f_[10] * rhs.f_[6] +
|
||||
f_[14] * rhs.f_[7];
|
||||
ret.f_[7] = f_[3] * rhs.f_[4] + f_[7] * rhs.f_[5] + f_[11] * rhs.f_[6] +
|
||||
f_[15] * rhs.f_[7];
|
||||
|
||||
ret.f_[8] = f_[0] * rhs.f_[8] + f_[4] * rhs.f_[9] + f_[8] * rhs.f_[10] +
|
||||
f_[12] * rhs.f_[11];
|
||||
ret.f_[9] = f_[1] * rhs.f_[8] + f_[5] * rhs.f_[9] + f_[9] * rhs.f_[10] +
|
||||
f_[13] * rhs.f_[11];
|
||||
ret.f_[10] = f_[2] * rhs.f_[8] + f_[6] * rhs.f_[9] + f_[10] * rhs.f_[10] +
|
||||
f_[14] * rhs.f_[11];
|
||||
ret.f_[11] = f_[3] * rhs.f_[8] + f_[7] * rhs.f_[9] + f_[11] * rhs.f_[10] +
|
||||
f_[15] * rhs.f_[11];
|
||||
|
||||
ret.f_[12] = f_[0] * rhs.f_[12] + f_[4] * rhs.f_[13] + f_[8] * rhs.f_[14] +
|
||||
f_[12] * rhs.f_[15];
|
||||
ret.f_[13] = f_[1] * rhs.f_[12] + f_[5] * rhs.f_[13] + f_[9] * rhs.f_[14] +
|
||||
f_[13] * rhs.f_[15];
|
||||
ret.f_[14] = f_[2] * rhs.f_[12] + f_[6] * rhs.f_[13] + f_[10] * rhs.f_[14] +
|
||||
f_[14] * rhs.f_[15];
|
||||
ret.f_[15] = f_[3] * rhs.f_[12] + f_[7] * rhs.f_[13] + f_[11] * rhs.f_[14] +
|
||||
f_[15] * rhs.f_[15];
|
||||
|
||||
*this = ret;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Mat4 operator*(const float rhs) {
|
||||
Mat4 ret;
|
||||
for (int32_t i = 0; i < 16; ++i) {
|
||||
ret.f_[i] = f_[i] * rhs;
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
||||
Mat4& operator*=(const float rhs) {
|
||||
for (int32_t i = 0; i < 16; ++i) {
|
||||
f_[i] *= rhs;
|
||||
}
|
||||
return *this;
|
||||
}
|
||||
|
||||
Mat4& operator=(const Mat4& rhs) {
|
||||
for (int32_t i = 0; i < 16; ++i) {
|
||||
f_[i] = rhs.f_[i];
|
||||
}
|
||||
return *this;
|
||||
}
|
||||
|
||||
Mat4 Inverse();
|
||||
|
||||
Mat4 Transpose() {
|
||||
Mat4 ret;
|
||||
ret.f_[0] = f_[0];
|
||||
ret.f_[1] = f_[4];
|
||||
ret.f_[2] = f_[8];
|
||||
ret.f_[3] = f_[12];
|
||||
ret.f_[4] = f_[1];
|
||||
ret.f_[5] = f_[5];
|
||||
ret.f_[6] = f_[9];
|
||||
ret.f_[7] = f_[13];
|
||||
ret.f_[8] = f_[2];
|
||||
ret.f_[9] = f_[6];
|
||||
ret.f_[10] = f_[10];
|
||||
ret.f_[11] = f_[14];
|
||||
ret.f_[12] = f_[3];
|
||||
ret.f_[13] = f_[7];
|
||||
ret.f_[14] = f_[11];
|
||||
ret.f_[15] = f_[15];
|
||||
*this = ret;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Mat4& PostTranslate(float tx, float ty, float tz) {
|
||||
f_[12] += (tx * f_[0]) + (ty * f_[4]) + (tz * f_[8]);
|
||||
f_[13] += (tx * f_[1]) + (ty * f_[5]) + (tz * f_[9]);
|
||||
f_[14] += (tx * f_[2]) + (ty * f_[6]) + (tz * f_[10]);
|
||||
f_[15] += (tx * f_[3]) + (ty * f_[7]) + (tz * f_[11]);
|
||||
return *this;
|
||||
}
|
||||
|
||||
float* Ptr() { return f_; }
|
||||
|
||||
//--------------------------------------------------------------------------------
|
||||
// Misc
|
||||
//--------------------------------------------------------------------------------
|
||||
static Mat4 Perspective(float width, float height, float nearPlane,
|
||||
float farPlane);
|
||||
|
||||
static Mat4 LookAt(const Vec3& vEye, const Vec3& vAt, const Vec3& vUp);
|
||||
|
||||
static Mat4 Translation(const float fX, const float fY, const float fZ);
|
||||
static Mat4 Translation(const Vec3 vec);
|
||||
|
||||
static Mat4 RotationX(const float angle);
|
||||
|
||||
static Mat4 RotationY(const float angle);
|
||||
|
||||
static Mat4 RotationZ(const float angle);
|
||||
|
||||
static Mat4 Identity() {
|
||||
Mat4 ret;
|
||||
ret.f_[0] = 1.f;
|
||||
ret.f_[1] = 0;
|
||||
ret.f_[2] = 0;
|
||||
ret.f_[3] = 0;
|
||||
ret.f_[4] = 0;
|
||||
ret.f_[5] = 1.f;
|
||||
ret.f_[6] = 0;
|
||||
ret.f_[7] = 0;
|
||||
ret.f_[8] = 0;
|
||||
ret.f_[9] = 0;
|
||||
ret.f_[10] = 1.f;
|
||||
ret.f_[11] = 0;
|
||||
ret.f_[12] = 0;
|
||||
ret.f_[13] = 0;
|
||||
ret.f_[14] = 0;
|
||||
ret.f_[15] = 1.f;
|
||||
return ret;
|
||||
}
|
||||
|
||||
void Dump() {
|
||||
LOGI("%f %f %f %f", f_[0], f_[1], f_[2], f_[3]);
|
||||
LOGI("%f %f %f %f", f_[4], f_[5], f_[6], f_[7]);
|
||||
LOGI("%f %f %f %f", f_[8], f_[9], f_[10], f_[11]);
|
||||
LOGI("%f %f %f %f", f_[12], f_[13], f_[14], f_[15]);
|
||||
}
|
||||
};
|
||||
|
||||
/******************************************************************
|
||||
* Quaternion class
|
||||
*
|
||||
*/
|
||||
class Quaternion {
|
||||
private:
|
||||
float x_, y_, z_, w_;
|
||||
|
||||
public:
|
||||
friend class Vec3;
|
||||
friend class Vec4;
|
||||
friend class Mat4;
|
||||
|
||||
Quaternion() {
|
||||
x_ = 0.f;
|
||||
y_ = 0.f;
|
||||
z_ = 0.f;
|
||||
w_ = 1.f;
|
||||
}
|
||||
|
||||
Quaternion(const float fX, const float fY, const float fZ, const float fW) {
|
||||
x_ = fX;
|
||||
y_ = fY;
|
||||
z_ = fZ;
|
||||
w_ = fW;
|
||||
}
|
||||
|
||||
Quaternion(const Vec3 vec, const float fW) {
|
||||
x_ = vec.x_;
|
||||
y_ = vec.y_;
|
||||
z_ = vec.z_;
|
||||
w_ = fW;
|
||||
}
|
||||
|
||||
Quaternion(const float* p) {
|
||||
x_ = *p++;
|
||||
y_ = *p++;
|
||||
z_ = *p++;
|
||||
w_ = *p++;
|
||||
}
|
||||
|
||||
Quaternion operator*(const Quaternion rhs) {
|
||||
Quaternion ret;
|
||||
ret.x_ = x_ * rhs.w_ + y_ * rhs.z_ - z_ * rhs.y_ + w_ * rhs.x_;
|
||||
ret.y_ = -x_ * rhs.z_ + y_ * rhs.w_ + z_ * rhs.x_ + w_ * rhs.y_;
|
||||
ret.z_ = x_ * rhs.y_ - y_ * rhs.x_ + z_ * rhs.w_ + w_ * rhs.z_;
|
||||
ret.w_ = -x_ * rhs.x_ - y_ * rhs.y_ - z_ * rhs.z_ + w_ * rhs.w_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
Quaternion& operator*=(const Quaternion rhs) {
|
||||
Quaternion ret;
|
||||
ret.x_ = x_ * rhs.w_ + y_ * rhs.z_ - z_ * rhs.y_ + w_ * rhs.x_;
|
||||
ret.y_ = -x_ * rhs.z_ + y_ * rhs.w_ + z_ * rhs.x_ + w_ * rhs.y_;
|
||||
ret.z_ = x_ * rhs.y_ - y_ * rhs.x_ + z_ * rhs.w_ + w_ * rhs.z_;
|
||||
ret.w_ = -x_ * rhs.x_ - y_ * rhs.y_ - z_ * rhs.z_ + w_ * rhs.w_;
|
||||
*this = ret;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Quaternion Conjugate() {
|
||||
x_ = -x_;
|
||||
y_ = -y_;
|
||||
z_ = -z_;
|
||||
return *this;
|
||||
}
|
||||
|
||||
// Non destuctive version
|
||||
Quaternion Conjugated() {
|
||||
Quaternion ret;
|
||||
ret.x_ = -x_;
|
||||
ret.y_ = -y_;
|
||||
ret.z_ = -z_;
|
||||
ret.w_ = w_;
|
||||
return ret;
|
||||
}
|
||||
|
||||
void ToMatrix(Mat4& mat) {
|
||||
float x2 = x_ * x_ * 2.0f;
|
||||
float y2 = y_ * y_ * 2.0f;
|
||||
float z2 = z_ * z_ * 2.0f;
|
||||
float xy = x_ * y_ * 2.0f;
|
||||
float yz = y_ * z_ * 2.0f;
|
||||
float zx = z_ * x_ * 2.0f;
|
||||
float xw = x_ * w_ * 2.0f;
|
||||
float yw = y_ * w_ * 2.0f;
|
||||
float zw = z_ * w_ * 2.0f;
|
||||
|
||||
mat.f_[0] = 1.0f - y2 - z2;
|
||||
mat.f_[1] = xy + zw;
|
||||
mat.f_[2] = zx - yw;
|
||||
mat.f_[4] = xy - zw;
|
||||
mat.f_[5] = 1.0f - z2 - x2;
|
||||
mat.f_[6] = yz + xw;
|
||||
mat.f_[8] = zx + yw;
|
||||
mat.f_[9] = yz - xw;
|
||||
mat.f_[10] = 1.0f - x2 - y2;
|
||||
|
||||
mat.f_[3] = mat.f_[7] = mat.f_[11] = mat.f_[12] = mat.f_[13] = mat.f_[14] =
|
||||
0.0f;
|
||||
mat.f_[15] = 1.0f;
|
||||
}
|
||||
|
||||
void ToMatrixPreserveTranslate(Mat4& mat) {
|
||||
float x2 = x_ * x_ * 2.0f;
|
||||
float y2 = y_ * y_ * 2.0f;
|
||||
float z2 = z_ * z_ * 2.0f;
|
||||
float xy = x_ * y_ * 2.0f;
|
||||
float yz = y_ * z_ * 2.0f;
|
||||
float zx = z_ * x_ * 2.0f;
|
||||
float xw = x_ * w_ * 2.0f;
|
||||
float yw = y_ * w_ * 2.0f;
|
||||
float zw = z_ * w_ * 2.0f;
|
||||
|
||||
mat.f_[0] = 1.0f - y2 - z2;
|
||||
mat.f_[1] = xy + zw;
|
||||
mat.f_[2] = zx - yw;
|
||||
mat.f_[4] = xy - zw;
|
||||
mat.f_[5] = 1.0f - z2 - x2;
|
||||
mat.f_[6] = yz + xw;
|
||||
mat.f_[8] = zx + yw;
|
||||
mat.f_[9] = yz - xw;
|
||||
mat.f_[10] = 1.0f - x2 - y2;
|
||||
|
||||
mat.f_[3] = mat.f_[7] = mat.f_[11] = 0.0f;
|
||||
mat.f_[15] = 1.0f;
|
||||
}
|
||||
|
||||
static Quaternion RotationAxis(const Vec3 axis, const float angle) {
|
||||
Quaternion ret;
|
||||
float s = sinf(angle / 2);
|
||||
ret.x_ = s * axis.x_;
|
||||
ret.y_ = s * axis.y_;
|
||||
ret.z_ = s * axis.z_;
|
||||
ret.w_ = cosf(angle / 2);
|
||||
return ret;
|
||||
}
|
||||
|
||||
void Value(float& fX, float& fY, float& fZ, float& fW) {
|
||||
fX = x_;
|
||||
fY = y_;
|
||||
fZ = z_;
|
||||
fW = w_;
|
||||
}
|
||||
};
|
||||
|
||||
} // namespace ndk_helper
|
||||
#endif /* VECMATH_H_ */
|
||||
|
Before Width: | Height: | Size: 8.0 KiB After Width: | Height: | Size: 8.0 KiB |
|
Before Width: | Height: | Size: 2.5 KiB After Width: | Height: | Size: 2.5 KiB |
|
Before Width: | Height: | Size: 4.0 KiB After Width: | Height: | Size: 4.0 KiB |
|
Before Width: | Height: | Size: 13 KiB After Width: | Height: | Size: 13 KiB |