mirror of https://github.com/axmolengine/axmol.git
updates to JniHelper, refactoring of existing JNI calls
This commit is contained in:
parent
d86d32fb09
commit
c4b995fe59
|
@ -26,31 +26,22 @@ THE SOFTWARE.
|
||||||
#include "cddandroidAndroidJavaEngine.h"
|
#include "cddandroidAndroidJavaEngine.h"
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <android/log.h>
|
#include <android/log.h>
|
||||||
#include <jni.h>
|
|
||||||
#include <sys/system_properties.h>
|
#include <sys/system_properties.h>
|
||||||
#include "platform/android/jni/JniHelper.h"
|
|
||||||
#include "ccdandroidUtils.h"
|
#include "ccdandroidUtils.h"
|
||||||
#include "audio/include/AudioEngine.h"
|
#include "audio/include/AudioEngine.h"
|
||||||
|
#include "platform/android/jni/JniHelper.h"
|
||||||
|
|
||||||
// logging
|
// logging
|
||||||
#define LOG_TAG "cocosdenshion::android::AndroidJavaEngine"
|
#define LOG_TAG "cocosdenshion::android::AndroidJavaEngine"
|
||||||
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,LOG_TAG,__VA_ARGS__)
|
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,LOG_TAG,__VA_ARGS__)
|
||||||
|
|
||||||
// Java class
|
// Java class
|
||||||
#define CLASS_NAME "org/cocos2dx/lib/Cocos2dxHelper"
|
static const std::string helperClassName = "org/cocos2dx/lib/Cocos2dxHelper";
|
||||||
|
|
||||||
|
using namespace cocos2d;
|
||||||
using namespace cocos2d::experimental;
|
using namespace cocos2d::experimental;
|
||||||
using namespace CocosDenshion::android;
|
using namespace CocosDenshion::android;
|
||||||
|
|
||||||
static inline bool getJNIStaticMethodInfo(cocos2d::JniMethodInfo &methodinfo,
|
|
||||||
const char *methodName,
|
|
||||||
const char *paramCode) {
|
|
||||||
return cocos2d::JniHelper::getStaticMethodInfo(methodinfo,
|
|
||||||
CLASS_NAME,
|
|
||||||
methodName,
|
|
||||||
paramCode);
|
|
||||||
}
|
|
||||||
|
|
||||||
AndroidJavaEngine::AndroidJavaEngine()
|
AndroidJavaEngine::AndroidJavaEngine()
|
||||||
: _implementBaseOnAudioEngine(false)
|
: _implementBaseOnAudioEngine(false)
|
||||||
, _effectVolume(1.f)
|
, _effectVolume(1.f)
|
||||||
|
@ -78,89 +69,35 @@ AndroidJavaEngine::~AndroidJavaEngine()
|
||||||
{
|
{
|
||||||
stopAllEffects();
|
stopAllEffects();
|
||||||
}
|
}
|
||||||
cocos2d::JniMethodInfo methodInfo;
|
|
||||||
|
|
||||||
if (!getJNIStaticMethodInfo(methodInfo, "end", "()V")) {
|
JniHelper::callStaticVoidMethod(helperClassName, "end");
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
methodInfo.env->CallStaticVoidMethod(methodInfo.classID, methodInfo.methodID);
|
|
||||||
methodInfo.env->DeleteLocalRef(methodInfo.classID);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AndroidJavaEngine::preloadBackgroundMusic(const char* filePath) {
|
void AndroidJavaEngine::preloadBackgroundMusic(const char* filePath) {
|
||||||
std::string fullPath = CocosDenshion::android::getFullPathWithoutAssetsPrefix(filePath);
|
std::string fullPath = CocosDenshion::android::getFullPathWithoutAssetsPrefix(filePath);
|
||||||
|
JniHelper::callStaticVoidMethod(helperClassName, "preloadBackgroundMusic", filePath);
|
||||||
// void playBackgroundMusic(String,boolean)
|
|
||||||
cocos2d::JniMethodInfo methodInfo;
|
|
||||||
|
|
||||||
if (!getJNIStaticMethodInfo(methodInfo, "preloadBackgroundMusic", "(Ljava/lang/String;)V")) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
jstring stringArg = methodInfo.env->NewStringUTF(fullPath.c_str());
|
|
||||||
methodInfo.env->CallStaticVoidMethod(methodInfo.classID, methodInfo.methodID, stringArg);
|
|
||||||
methodInfo.env->DeleteLocalRef(stringArg);
|
|
||||||
methodInfo.env->DeleteLocalRef(methodInfo.classID);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AndroidJavaEngine::playBackgroundMusic(const char* filePath, bool loop) {
|
void AndroidJavaEngine::playBackgroundMusic(const char* filePath, bool loop) {
|
||||||
std::string fullPath = CocosDenshion::android::getFullPathWithoutAssetsPrefix(filePath);
|
std::string fullPath = CocosDenshion::android::getFullPathWithoutAssetsPrefix(filePath);
|
||||||
|
JniHelper::callStaticVoidMethod(helperClassName, "playBackgroundMusic", filePath, loop);
|
||||||
cocos2d::JniMethodInfo methodInfo;
|
|
||||||
|
|
||||||
if (!getJNIStaticMethodInfo(methodInfo, "playBackgroundMusic", "(Ljava/lang/String;Z)V")) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
jstring stringArg = methodInfo.env->NewStringUTF(fullPath.c_str());
|
|
||||||
methodInfo.env->CallStaticVoidMethod(methodInfo.classID, methodInfo.methodID, stringArg, loop);
|
|
||||||
methodInfo.env->DeleteLocalRef(stringArg);
|
|
||||||
methodInfo.env->DeleteLocalRef(methodInfo.classID);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AndroidJavaEngine::stopBackgroundMusic(bool releaseData) {
|
void AndroidJavaEngine::stopBackgroundMusic(bool releaseData) {
|
||||||
cocos2d::JniMethodInfo methodInfo;
|
JniHelper::callStaticVoidMethod(helperClassName, "stopBackgroundMusic");
|
||||||
|
|
||||||
if (!getJNIStaticMethodInfo(methodInfo, "stopBackgroundMusic", "()V")) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
methodInfo.env->CallStaticVoidMethod(methodInfo.classID, methodInfo.methodID);
|
|
||||||
methodInfo.env->DeleteLocalRef(methodInfo.classID);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AndroidJavaEngine::pauseBackgroundMusic() {
|
void AndroidJavaEngine::pauseBackgroundMusic() {
|
||||||
cocos2d::JniMethodInfo methodInfo;
|
JniHelper::callStaticVoidMethod(helperClassName, "pauseBackgroundMusic");
|
||||||
|
|
||||||
if (!getJNIStaticMethodInfo(methodInfo, "pauseBackgroundMusic", "()V")) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
methodInfo.env->CallStaticVoidMethod(methodInfo.classID, methodInfo.methodID);
|
|
||||||
methodInfo.env->DeleteLocalRef(methodInfo.classID);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AndroidJavaEngine::resumeBackgroundMusic() {
|
void AndroidJavaEngine::resumeBackgroundMusic() {
|
||||||
cocos2d::JniMethodInfo methodInfo;
|
JniHelper::callStaticVoidMethod(helperClassName, "resumeBackgroundMusic");
|
||||||
|
|
||||||
if (!getJNIStaticMethodInfo(methodInfo, "resumeBackgroundMusic", "()V")) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
methodInfo.env->CallStaticVoidMethod(methodInfo.classID, methodInfo.methodID);
|
|
||||||
methodInfo.env->DeleteLocalRef(methodInfo.classID);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AndroidJavaEngine::rewindBackgroundMusic() {
|
void AndroidJavaEngine::rewindBackgroundMusic() {
|
||||||
cocos2d::JniMethodInfo methodInfo;
|
JniHelper::callStaticVoidMethod(helperClassName, "rewindBackgroundMusic");
|
||||||
|
|
||||||
if (!getJNIStaticMethodInfo(methodInfo, "rewindBackgroundMusic", "()V")) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
methodInfo.env->CallStaticVoidMethod(methodInfo.classID, methodInfo.methodID);
|
|
||||||
methodInfo.env->DeleteLocalRef(methodInfo.classID);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool AndroidJavaEngine::willPlayBackgroundMusic() {
|
bool AndroidJavaEngine::willPlayBackgroundMusic() {
|
||||||
|
@ -168,181 +105,17 @@ bool AndroidJavaEngine::willPlayBackgroundMusic() {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool AndroidJavaEngine::isBackgroundMusicPlaying() {
|
bool AndroidJavaEngine::isBackgroundMusicPlaying() {
|
||||||
cocos2d::JniMethodInfo methodInfo;
|
return JniHelper::callStaticBooleanMethod(helperClassName, "isBackgroundMusicPlaying");
|
||||||
jboolean ret = false;
|
|
||||||
|
|
||||||
if (!getJNIStaticMethodInfo(methodInfo, "isBackgroundMusicPlaying", "()Z")) {
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
ret = methodInfo.env->CallStaticBooleanMethod(methodInfo.classID, methodInfo.methodID);
|
|
||||||
methodInfo.env->DeleteLocalRef(methodInfo.classID);
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
float AndroidJavaEngine::getBackgroundMusicVolume() {
|
float AndroidJavaEngine::getBackgroundMusicVolume() {
|
||||||
cocos2d::JniMethodInfo methodInfo;
|
return JniHelper::callStaticFloatMethod(helperClassName, "getBackgroundMusicVolume");
|
||||||
jfloat ret = -1.0;
|
|
||||||
|
|
||||||
if (!getJNIStaticMethodInfo(methodInfo, "getBackgroundMusicVolume", "()F")) {
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
ret = methodInfo.env->CallStaticFloatMethod(methodInfo.classID, methodInfo.methodID);
|
|
||||||
methodInfo.env->DeleteLocalRef(methodInfo.classID);
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AndroidJavaEngine::setBackgroundMusicVolume(float volume) {
|
void AndroidJavaEngine::setBackgroundMusicVolume(float volume) {
|
||||||
cocos2d::JniMethodInfo methodInfo;
|
JniHelper::callStaticVoidMethod(helperClassName, "setBackgroundMusicVolume", volume);
|
||||||
|
|
||||||
if (!getJNIStaticMethodInfo(methodInfo, "setBackgroundMusicVolume", "(F)V")) {
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
methodInfo.env->CallStaticVoidMethod(methodInfo.classID, methodInfo.methodID, volume);
|
|
||||||
methodInfo.env->DeleteLocalRef(methodInfo.classID);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static float _jni_getEffectsVolume() {
|
|
||||||
cocos2d::JniMethodInfo methodInfo;
|
|
||||||
jfloat ret = -1.0;
|
|
||||||
|
|
||||||
if (!getJNIStaticMethodInfo(methodInfo, "getEffectsVolume", "()F")) {
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
ret = methodInfo.env->CallStaticFloatMethod(methodInfo.classID, methodInfo.methodID);
|
|
||||||
methodInfo.env->DeleteLocalRef(methodInfo.classID);
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void _jni_setEffectsVolume(float volume) {
|
|
||||||
cocos2d::JniMethodInfo methodInfo;
|
|
||||||
|
|
||||||
if (!getJNIStaticMethodInfo(methodInfo, "setEffectsVolume", "(F)V")) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
methodInfo.env->CallStaticVoidMethod(methodInfo.classID, methodInfo.methodID, volume);
|
|
||||||
methodInfo.env->DeleteLocalRef(methodInfo.classID);
|
|
||||||
}
|
|
||||||
|
|
||||||
static unsigned int _jni_playEffect(const char* filePath, bool loop, float pitch, float pan, float gain)
|
|
||||||
{
|
|
||||||
cocos2d::JniMethodInfo methodInfo;
|
|
||||||
int ret = 0;
|
|
||||||
std::string fullPath = CocosDenshion::android::getFullPathWithoutAssetsPrefix(filePath);
|
|
||||||
|
|
||||||
if (!getJNIStaticMethodInfo(methodInfo, "playEffect", "(Ljava/lang/String;ZFFF)I")) {
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
jstring stringArg = methodInfo.env->NewStringUTF(fullPath.c_str());
|
|
||||||
ret = methodInfo.env->CallStaticIntMethod(methodInfo.classID,
|
|
||||||
methodInfo.methodID,
|
|
||||||
stringArg,
|
|
||||||
loop,
|
|
||||||
pitch, pan, gain);
|
|
||||||
methodInfo.env->DeleteLocalRef(stringArg);
|
|
||||||
methodInfo.env->DeleteLocalRef(methodInfo.classID);
|
|
||||||
|
|
||||||
return (unsigned int)ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void _jni_pauseEffect(unsigned int soundId) {
|
|
||||||
cocos2d::JniMethodInfo methodInfo;
|
|
||||||
|
|
||||||
if (!getJNIStaticMethodInfo(methodInfo, "pauseEffect", "(I)V")) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
methodInfo.env->CallStaticVoidMethod(methodInfo.classID, methodInfo.methodID, (int)soundId);
|
|
||||||
methodInfo.env->DeleteLocalRef(methodInfo.classID);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void _jni_pauseAllEffects() {
|
|
||||||
cocos2d::JniMethodInfo methodInfo;
|
|
||||||
|
|
||||||
if (!getJNIStaticMethodInfo(methodInfo, "pauseAllEffects", "()V")) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
methodInfo.env->CallStaticVoidMethod(methodInfo.classID, methodInfo.methodID);
|
|
||||||
methodInfo.env->DeleteLocalRef(methodInfo.classID);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void _jni_resumeEffect(unsigned int soundId) {
|
|
||||||
cocos2d::JniMethodInfo methodInfo;
|
|
||||||
|
|
||||||
if (!getJNIStaticMethodInfo(methodInfo, "resumeEffect", "(I)V")) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
methodInfo.env->CallStaticVoidMethod(methodInfo.classID, methodInfo.methodID, (int)soundId);
|
|
||||||
methodInfo.env->DeleteLocalRef(methodInfo.classID);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void _jni_resumeAllEffects() {
|
|
||||||
cocos2d::JniMethodInfo methodInfo;
|
|
||||||
|
|
||||||
if (!getJNIStaticMethodInfo(methodInfo, "resumeAllEffects", "()V")) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
methodInfo.env->CallStaticVoidMethod(methodInfo.classID, methodInfo.methodID);
|
|
||||||
methodInfo.env->DeleteLocalRef(methodInfo.classID);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void _jni_stopEffect(unsigned int soundId) {
|
|
||||||
cocos2d::JniMethodInfo methodInfo;
|
|
||||||
|
|
||||||
if (!getJNIStaticMethodInfo(methodInfo, "stopEffect", "(I)V")) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
methodInfo.env->CallStaticVoidMethod(methodInfo.classID, methodInfo.methodID, (int)soundId);
|
|
||||||
methodInfo.env->DeleteLocalRef(methodInfo.classID);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void _jni_stopAllEffects() {
|
|
||||||
cocos2d::JniMethodInfo methodInfo;
|
|
||||||
|
|
||||||
if (!getJNIStaticMethodInfo(methodInfo, "stopAllEffects", "()V")) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
methodInfo.env->CallStaticVoidMethod(methodInfo.classID, methodInfo.methodID);
|
|
||||||
methodInfo.env->DeleteLocalRef(methodInfo.classID);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void loadEffect(const char* filePath, char* loadEffectName) {
|
|
||||||
cocos2d::JniMethodInfo methodInfo;
|
|
||||||
std::string fullPath = CocosDenshion::android::getFullPathWithoutAssetsPrefix(filePath);
|
|
||||||
|
|
||||||
if (!cocos2d::JniHelper::getStaticMethodInfo(methodInfo, CLASS_NAME, loadEffectName, "(Ljava/lang/String;)V")) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
jstring stringArg = methodInfo.env->NewStringUTF(fullPath.c_str());
|
|
||||||
methodInfo.env->CallStaticVoidMethod(methodInfo.classID, methodInfo.methodID, stringArg);
|
|
||||||
methodInfo.env->DeleteLocalRef(stringArg);
|
|
||||||
methodInfo.env->DeleteLocalRef(methodInfo.classID);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void _jni_preloadEffect(const char* filePath) {
|
|
||||||
loadEffect(filePath, "preloadEffect");
|
|
||||||
}
|
|
||||||
|
|
||||||
static void _jni_unloadEffect(const char* filePath) {
|
|
||||||
loadEffect(filePath, "unloadEffect");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
float AndroidJavaEngine::getEffectsVolume()
|
float AndroidJavaEngine::getEffectsVolume()
|
||||||
{
|
{
|
||||||
if (_implementBaseOnAudioEngine)
|
if (_implementBaseOnAudioEngine)
|
||||||
|
@ -351,7 +124,7 @@ float AndroidJavaEngine::getEffectsVolume()
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
return _jni_getEffectsVolume();
|
return JniHelper::callStaticFloatMethod(helperClassName, "getEffectsVolume");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -379,7 +152,7 @@ void AndroidJavaEngine::setEffectsVolume(float volume)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
_jni_setEffectsVolume(volume);
|
JniHelper::callStaticVoidMethod(helperClassName, "setEffectsVolume", volume);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -402,7 +175,9 @@ unsigned int AndroidJavaEngine::playEffect(const char* filePath, bool loop,
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
return _jni_playEffect(filePath, loop, pitch, pan, gain);
|
std::string fullPath = CocosDenshion::android::getFullPathWithoutAssetsPrefix(filePath);
|
||||||
|
int ret = JniHelper::callStaticIntMethod(helperClassName, "playEffect", fullPath, loop, pitch, pan, gain);
|
||||||
|
return (unsigned int)ret;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -414,7 +189,7 @@ void AndroidJavaEngine::pauseEffect(unsigned int soundID)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
_jni_pauseEffect(soundID);
|
JniHelper::callStaticVoidMethod(helperClassName, "pauseEffect", (int)soundID);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -426,7 +201,7 @@ void AndroidJavaEngine::resumeEffect(unsigned int soundID)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
_jni_resumeEffect(soundID);
|
JniHelper::callStaticVoidMethod(helperClassName, "resumeEffect", (int)soundID);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -439,7 +214,7 @@ void AndroidJavaEngine::stopEffect(unsigned int soundID)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
_jni_stopEffect(soundID);
|
JniHelper::callStaticVoidMethod(helperClassName, "stopEffect", (int)soundID);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -454,7 +229,7 @@ void AndroidJavaEngine::pauseAllEffects()
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
_jni_pauseAllEffects();
|
JniHelper::callStaticVoidMethod(helperClassName, "pauseAllEffects");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -469,7 +244,7 @@ void AndroidJavaEngine::resumeAllEffects()
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
_jni_resumeAllEffects();
|
JniHelper::callStaticVoidMethod(helperClassName, "resumeAllEffects");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -485,7 +260,7 @@ void AndroidJavaEngine::stopAllEffects()
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
_jni_stopAllEffects();
|
JniHelper::callStaticVoidMethod(helperClassName, "stopAllEffects");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -493,7 +268,8 @@ void AndroidJavaEngine::preloadEffect(const char* filePath)
|
||||||
{
|
{
|
||||||
if (!_implementBaseOnAudioEngine)
|
if (!_implementBaseOnAudioEngine)
|
||||||
{
|
{
|
||||||
_jni_preloadEffect(filePath);
|
std::string fullPath = CocosDenshion::android::getFullPathWithoutAssetsPrefix(filePath);
|
||||||
|
JniHelper::callStaticVoidMethod(helperClassName, "preloadEffect", fullPath);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -501,6 +277,7 @@ void AndroidJavaEngine::unloadEffect(const char* filePath)
|
||||||
{
|
{
|
||||||
if (!_implementBaseOnAudioEngine)
|
if (!_implementBaseOnAudioEngine)
|
||||||
{
|
{
|
||||||
_jni_unloadEffect(filePath);
|
std::string fullPath = CocosDenshion::android::getFullPathWithoutAssetsPrefix(filePath);
|
||||||
|
JniHelper::callStaticVoidMethod(helperClassName, "unloadEffect", fullPath);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -155,14 +155,8 @@ Controller::Controller()
|
||||||
init();
|
init();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Controller::receiveExternalKeyEvent(int externalKeyCode,bool receive)
|
void Controller::receiveExternalKeyEvent(int externalKeyCode,bool receive) {
|
||||||
{
|
JniHelper::callStaticVoidMethod("org/cocos2dx/lib/GameControllerHelper", "receiveExternalKeyEvent", _deviceId, externalKeyCode, receive);
|
||||||
JniMethodInfo t;
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, "org/cocos2dx/lib/GameControllerHelper", "receiveExternalKeyEvent", "(IIZ)V")) {
|
|
||||||
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, _deviceId, externalKeyCode, receive);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
NS_CC_END
|
NS_CC_END
|
||||||
|
|
|
@ -29,7 +29,7 @@ THE SOFTWARE.
|
||||||
#include "base/base64.h"
|
#include "base/base64.h"
|
||||||
|
|
||||||
#if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)
|
#if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)
|
||||||
#include "platform/android/jni/Java_org_cocos2dx_lib_Cocos2dxHelper.h"
|
#include "platform/android/jni/JniHelper.h"
|
||||||
|
|
||||||
// root name of xml
|
// root name of xml
|
||||||
#define USERDEFAULT_ROOT_NAME "userDefaultRoot"
|
#define USERDEFAULT_ROOT_NAME "userDefaultRoot"
|
||||||
|
@ -43,8 +43,9 @@ THE SOFTWARE.
|
||||||
#include "tinyxml2.h"
|
#include "tinyxml2.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
using namespace std;
|
static const std::string helperClassName = "org/cocos2dx/lib/Cocos2dxHelper";
|
||||||
|
|
||||||
|
using namespace std;
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -191,7 +192,7 @@ bool UserDefault::getBoolForKey(const char* pKey, bool defaultValue)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return getBoolForKeyJNI(pKey, defaultValue);
|
return JniHelper::callStaticBooleanMethod(helperClassName, "getBoolForKey", pKey, defaultValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
int UserDefault::getIntegerForKey(const char* pKey)
|
int UserDefault::getIntegerForKey(const char* pKey)
|
||||||
|
@ -227,7 +228,7 @@ int UserDefault::getIntegerForKey(const char* pKey, int defaultValue)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return getIntegerForKeyJNI(pKey, defaultValue);
|
return JniHelper::callStaticIntMethod(helperClassName, "getIntegerForKey", pKey, defaultValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
float UserDefault::getFloatForKey(const char* pKey)
|
float UserDefault::getFloatForKey(const char* pKey)
|
||||||
|
@ -263,7 +264,7 @@ float UserDefault::getFloatForKey(const char* pKey, float defaultValue)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return getFloatForKeyJNI(pKey, defaultValue);
|
return JniHelper::callStaticFloatMethod(helperClassName, "getFloatForKey", pKey, defaultValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
double UserDefault::getDoubleForKey(const char* pKey)
|
double UserDefault::getDoubleForKey(const char* pKey)
|
||||||
|
@ -299,7 +300,7 @@ double UserDefault::getDoubleForKey(const char* pKey, double defaultValue)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return getDoubleForKeyJNI(pKey, defaultValue);
|
return JniHelper::callStaticDoubleMethod(helperClassName, "getDoubleForKey", pKey, defaultValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string UserDefault::getStringForKey(const char* pKey)
|
std::string UserDefault::getStringForKey(const char* pKey)
|
||||||
|
@ -335,7 +336,7 @@ string UserDefault::getStringForKey(const char* pKey, const std::string & defaul
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return getStringForKeyJNI(pKey, defaultValue.c_str());
|
return JniHelper::callStaticStringMethod(helperClassName, "getStringForKey", pKey, defaultValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
Data UserDefault::getDataForKey(const char* pKey)
|
Data UserDefault::getDataForKey(const char* pKey)
|
||||||
|
@ -383,7 +384,7 @@ Data UserDefault::getDataForKey(const char* pKey, const Data& defaultValue)
|
||||||
char * encodedDefaultData = NULL;
|
char * encodedDefaultData = NULL;
|
||||||
unsigned int encodedDefaultDataLen = !defaultValue.isNull() ? base64Encode(defaultValue.getBytes(), defaultValue.getSize(), &encodedDefaultData) : 0;
|
unsigned int encodedDefaultDataLen = !defaultValue.isNull() ? base64Encode(defaultValue.getBytes(), defaultValue.getSize(), &encodedDefaultData) : 0;
|
||||||
|
|
||||||
string encodedStr = getStringForKeyJNI(pKey, encodedDefaultData);
|
string encodedStr = JniHelper::callStaticStringMethod(helperClassName, "getStringForKey", pKey, (const char*)encodedDefaultData);
|
||||||
|
|
||||||
if (encodedDefaultData)
|
if (encodedDefaultData)
|
||||||
free(encodedDefaultData);
|
free(encodedDefaultData);
|
||||||
|
@ -411,7 +412,7 @@ void UserDefault::setBoolForKey(const char* pKey, bool value)
|
||||||
deleteNodeByKey(pKey);
|
deleteNodeByKey(pKey);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return setBoolForKeyJNI(pKey, value);
|
JniHelper::callStaticVoidMethod(helperClassName, "setBoolForKey", pKey, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
void UserDefault::setIntegerForKey(const char* pKey, int value)
|
void UserDefault::setIntegerForKey(const char* pKey, int value)
|
||||||
|
@ -420,7 +421,7 @@ void UserDefault::setIntegerForKey(const char* pKey, int value)
|
||||||
deleteNodeByKey(pKey);
|
deleteNodeByKey(pKey);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return setIntegerForKeyJNI(pKey, value);
|
JniHelper::callStaticVoidMethod(helperClassName, "setIntegerForKey", pKey, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
void UserDefault::setFloatForKey(const char* pKey, float value)
|
void UserDefault::setFloatForKey(const char* pKey, float value)
|
||||||
|
@ -429,7 +430,7 @@ void UserDefault::setFloatForKey(const char* pKey, float value)
|
||||||
deleteNodeByKey(pKey);
|
deleteNodeByKey(pKey);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return setFloatForKeyJNI(pKey, value);
|
JniHelper::callStaticVoidMethod(helperClassName, "setFloatForKey", pKey, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
void UserDefault::setDoubleForKey(const char* pKey, double value)
|
void UserDefault::setDoubleForKey(const char* pKey, double value)
|
||||||
|
@ -438,7 +439,7 @@ void UserDefault::setDoubleForKey(const char* pKey, double value)
|
||||||
deleteNodeByKey(pKey);
|
deleteNodeByKey(pKey);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return setDoubleForKeyJNI(pKey, value);
|
JniHelper::callStaticVoidMethod(helperClassName, "setDoubleForKey", pKey, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
void UserDefault::setStringForKey(const char* pKey, const std::string& value)
|
void UserDefault::setStringForKey(const char* pKey, const std::string& value)
|
||||||
|
@ -447,7 +448,7 @@ void UserDefault::setStringForKey(const char* pKey, const std::string & value)
|
||||||
deleteNodeByKey(pKey);
|
deleteNodeByKey(pKey);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return setStringForKeyJNI(pKey, value.c_str());
|
JniHelper::callStaticVoidMethod(helperClassName, "setStringForKey", pKey, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
void UserDefault::setDataForKey(const char* pKey, const Data& value)
|
void UserDefault::setDataForKey(const char* pKey, const Data& value)
|
||||||
|
@ -462,7 +463,7 @@ void UserDefault::setDataForKey(const char* pKey, const Data& value)
|
||||||
|
|
||||||
CCLOG("SET DATA ENCODED: --%s", encodedData);
|
CCLOG("SET DATA ENCODED: --%s", encodedData);
|
||||||
|
|
||||||
setStringForKeyJNI(pKey, encodedData);
|
JniHelper::callStaticVoidMethod(helperClassName, "setStringForKey", pKey, (const char*)encodedData);
|
||||||
|
|
||||||
if (encodedData)
|
if (encodedData)
|
||||||
free(encodedData);
|
free(encodedData);
|
||||||
|
@ -498,7 +499,8 @@ void UserDefault::initXMLFilePath()
|
||||||
if (! _isFilePathInitialized)
|
if (! _isFilePathInitialized)
|
||||||
{
|
{
|
||||||
// UserDefault.xml is stored in /data/data/<package-path>/ before v2.1.2
|
// UserDefault.xml is stored in /data/data/<package-path>/ before v2.1.2
|
||||||
_filePath += "/data/data/" + getPackageNameJNI() + "/" + XML_FILE_NAME;
|
std::string packageName = JniHelper::callStaticStringMethod(helperClassName, "getCocos2dxPackageName");
|
||||||
|
_filePath += "/data/data/" + packageName + "/" + XML_FILE_NAME;
|
||||||
_isFilePathInitialized = true;
|
_isFilePathInitialized = true;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -527,7 +529,7 @@ void UserDefault::deleteValueForKey(const char* key)
|
||||||
CCLOG("the key is invalid");
|
CCLOG("the key is invalid");
|
||||||
}
|
}
|
||||||
|
|
||||||
deleteValueForKeyJNI(key);
|
JniHelper::callStaticVoidMethod(helperClassName, "deleteValueForKey", key);
|
||||||
|
|
||||||
flush();
|
flush();
|
||||||
}
|
}
|
||||||
|
|
|
@ -49,8 +49,6 @@ set(COCOS_PLATFORM_SPECIFIC_SRC
|
||||||
platform/android/CCGLViewImpl-android.cpp
|
platform/android/CCGLViewImpl-android.cpp
|
||||||
platform/android/CCFileUtils-android.cpp
|
platform/android/CCFileUtils-android.cpp
|
||||||
platform/android/javaactivity-android.cpp
|
platform/android/javaactivity-android.cpp
|
||||||
platform/android/jni/DPIJni.cpp
|
|
||||||
platform/android/jni/IMEJni.cpp
|
|
||||||
platform/android/jni/Java_org_cocos2dx_lib_Cocos2dxAccelerometer.cpp
|
platform/android/jni/Java_org_cocos2dx_lib_Cocos2dxAccelerometer.cpp
|
||||||
platform/android/jni/Java_org_cocos2dx_lib_Cocos2dxBitmap.cpp
|
platform/android/jni/Java_org_cocos2dx_lib_Cocos2dxBitmap.cpp
|
||||||
platform/android/jni/Java_org_cocos2dx_lib_Cocos2dxHelper.cpp
|
platform/android/jni/Java_org_cocos2dx_lib_Cocos2dxHelper.cpp
|
||||||
|
|
|
@ -14,8 +14,6 @@ CCGLViewImpl-android.cpp \
|
||||||
CCFileUtils-android.cpp \
|
CCFileUtils-android.cpp \
|
||||||
javaactivity-android.cpp \
|
javaactivity-android.cpp \
|
||||||
CCEnhanceAPI-android.cpp \
|
CCEnhanceAPI-android.cpp \
|
||||||
jni/DPIJni.cpp \
|
|
||||||
jni/IMEJni.cpp \
|
|
||||||
jni/Java_org_cocos2dx_lib_Cocos2dxAccelerometer.cpp \
|
jni/Java_org_cocos2dx_lib_Cocos2dxAccelerometer.cpp \
|
||||||
jni/Java_org_cocos2dx_lib_Cocos2dxBitmap.cpp \
|
jni/Java_org_cocos2dx_lib_Cocos2dxBitmap.cpp \
|
||||||
jni/Java_org_cocos2dx_lib_Cocos2dxHelper.cpp \
|
jni/Java_org_cocos2dx_lib_Cocos2dxHelper.cpp \
|
||||||
|
|
|
@ -26,8 +26,7 @@ THE SOFTWARE.
|
||||||
#include "platform/CCPlatformConfig.h"
|
#include "platform/CCPlatformConfig.h"
|
||||||
#if CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID
|
#if CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID
|
||||||
|
|
||||||
#include "jni/JniHelper.h"
|
#include "platform/android/jni/JniHelper.h"
|
||||||
#include "jni/Java_org_cocos2dx_lib_Cocos2dxHelper.h"
|
|
||||||
#include "CCApplication.h"
|
#include "CCApplication.h"
|
||||||
#include "base/CCDirector.h"
|
#include "base/CCDirector.h"
|
||||||
#include <android/log.h>
|
#include <android/log.h>
|
||||||
|
@ -45,6 +44,8 @@ extern "C" size_t __ctype_get_mb_cur_max(void) {
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
static const std::string helperClassName = "org/cocos2dx/lib/Cocos2dxHelper";
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
// sharedApplication pointer
|
// sharedApplication pointer
|
||||||
|
@ -73,18 +74,8 @@ int Application::run()
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Application::setAnimationInterval(float interval)
|
void Application::setAnimationInterval(float interval) {
|
||||||
{
|
JniHelper::callStaticVoidMethod("org/cocos2dx/lib/Cocos2dxRenderer", "setAnimationInterval", interval);
|
||||||
JniMethodInfo methodInfo;
|
|
||||||
if (! JniHelper::getStaticMethodInfo(methodInfo, "org/cocos2dx/lib/Cocos2dxRenderer", "setAnimationInterval",
|
|
||||||
"(F)V"))
|
|
||||||
{
|
|
||||||
CCLOG("%s %d: error to get methodInfo", __FILE__, __LINE__);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
methodInfo.env->CallStaticVoidMethod(methodInfo.classID, methodInfo.methodID, interval);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////
|
||||||
|
@ -105,14 +96,15 @@ Application* Application::sharedApplication()
|
||||||
const char * Application::getCurrentLanguageCode()
|
const char * Application::getCurrentLanguageCode()
|
||||||
{
|
{
|
||||||
static char code[3]={0};
|
static char code[3]={0};
|
||||||
strncpy(code,getCurrentLanguageJNI().c_str(),2);
|
std::string language = JniHelper::callStaticStringMethod(helperClassName, "getCurrentLanguage");
|
||||||
|
strncpy(code, language.c_str(), 2);
|
||||||
code[2]='\0';
|
code[2]='\0';
|
||||||
return code;
|
return code;
|
||||||
}
|
}
|
||||||
|
|
||||||
LanguageType Application::getCurrentLanguage()
|
LanguageType Application::getCurrentLanguage()
|
||||||
{
|
{
|
||||||
std::string languageName = getCurrentLanguageJNI();
|
std::string languageName = JniHelper::callStaticStringMethod(helperClassName, "getCurrentLanguage");
|
||||||
const char* pLanguageName = languageName.c_str();
|
const char* pLanguageName = languageName.c_str();
|
||||||
LanguageType ret = LanguageType::ENGLISH;
|
LanguageType ret = LanguageType::ENGLISH;
|
||||||
|
|
||||||
|
@ -202,7 +194,7 @@ Application::Platform Application::getTargetPlatform()
|
||||||
|
|
||||||
bool Application::openURL(const std::string &url)
|
bool Application::openURL(const std::string &url)
|
||||||
{
|
{
|
||||||
return openURLJNI(url.c_str());
|
return JniHelper::callStaticBooleanMethod(helperClassName, "openURL", url);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Application::applicationScreenSizeChanged(int newWidth, int newHeight) {
|
void Application::applicationScreenSizeChanged(int newWidth, int newHeight) {
|
||||||
|
|
|
@ -27,7 +27,7 @@ THE SOFTWARE.
|
||||||
#if CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID
|
#if CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID
|
||||||
|
|
||||||
#include "platform/CCCommon.h"
|
#include "platform/CCCommon.h"
|
||||||
#include "jni/Java_org_cocos2dx_lib_Cocos2dxHelper.h"
|
#include "platform/android/jni/JniHelper.h"
|
||||||
#include <android/log.h>
|
#include <android/log.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <jni.h>
|
#include <jni.h>
|
||||||
|
@ -38,7 +38,7 @@ NS_CC_BEGIN
|
||||||
|
|
||||||
void MessageBox(const char * pszMsg, const char * pszTitle)
|
void MessageBox(const char * pszMsg, const char * pszTitle)
|
||||||
{
|
{
|
||||||
showDialogJNI(pszMsg, pszTitle);
|
JniHelper::callStaticVoidMethod("org/cocos2dx/lib/Cocos2dxHelper", "showDialog", pszMsg, pszTitle);
|
||||||
}
|
}
|
||||||
|
|
||||||
void LuaLog(const char * pszFormat)
|
void LuaLog(const char * pszFormat)
|
||||||
|
|
|
@ -31,11 +31,11 @@ THE SOFTWARE.
|
||||||
#include <android/log.h>
|
#include <android/log.h>
|
||||||
#include <jni.h>
|
#include <jni.h>
|
||||||
#include "base/ccTypes.h"
|
#include "base/ccTypes.h"
|
||||||
#include "jni/DPIJni.h"
|
#include "platform/android/jni/JniHelper.h"
|
||||||
#include "jni/Java_org_cocos2dx_lib_Cocos2dxHelper.h"
|
|
||||||
#include "jni/JniHelper.h"
|
|
||||||
#include "platform/CCFileUtils.h"
|
#include "platform/CCFileUtils.h"
|
||||||
|
|
||||||
|
static const std::string helperClassName = "org/cocos2dx/lib/Cocos2dxHelper";
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
int Device::getDPI()
|
int Device::getDPI()
|
||||||
|
@ -43,7 +43,7 @@ int Device::getDPI()
|
||||||
static int dpi = -1;
|
static int dpi = -1;
|
||||||
if (dpi == -1)
|
if (dpi == -1)
|
||||||
{
|
{
|
||||||
dpi = (int)getDPIJNI();
|
dpi = JniHelper::callStaticIntMethod(helperClassName, "getDPI");
|
||||||
}
|
}
|
||||||
return dpi;
|
return dpi;
|
||||||
}
|
}
|
||||||
|
@ -52,17 +52,17 @@ void Device::setAccelerometerEnabled(bool isEnabled)
|
||||||
{
|
{
|
||||||
if (isEnabled)
|
if (isEnabled)
|
||||||
{
|
{
|
||||||
enableAccelerometerJni();
|
JniHelper::callStaticVoidMethod(helperClassName, "enableAccelerometer");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
disableAccelerometerJni();
|
JniHelper::callStaticVoidMethod(helperClassName, "disableAccelerometer");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Device::setAccelerometerInterval(float interval)
|
void Device::setAccelerometerInterval(float interval)
|
||||||
{
|
{
|
||||||
setAccelerometerIntervalJni(interval);
|
JniHelper::callStaticVoidMethod(helperClassName, "setAccelerometerInterval", interval);
|
||||||
}
|
}
|
||||||
|
|
||||||
class BitmapDC
|
class BitmapDC
|
||||||
|
@ -170,12 +170,12 @@ Data Device::getTextureDataForText(const char * text, const FontDefinition& text
|
||||||
|
|
||||||
void Device::setKeepScreenOn(bool value)
|
void Device::setKeepScreenOn(bool value)
|
||||||
{
|
{
|
||||||
setKeepScreenOnJni(value);
|
JniHelper::callStaticVoidMethod(helperClassName, "setKeepScreenOn", value);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Device::vibrate(float duration)
|
void Device::vibrate(float duration)
|
||||||
{
|
{
|
||||||
vibrateJni(duration);
|
JniHelper::callStaticVoidMethod(helperClassName, "vibrate", duration);
|
||||||
}
|
}
|
||||||
|
|
||||||
NS_CC_END
|
NS_CC_END
|
||||||
|
|
|
@ -28,10 +28,10 @@ THE SOFTWARE.
|
||||||
|
|
||||||
#include "CCFileUtils-android.h"
|
#include "CCFileUtils-android.h"
|
||||||
#include "platform/CCCommon.h"
|
#include "platform/CCCommon.h"
|
||||||
#include "jni/Java_org_cocos2dx_lib_Cocos2dxHelper.h"
|
#include "platform/android/jni/JniHelper.h"
|
||||||
|
#include "platform/android/jni/CocosPlayClient.h"
|
||||||
#include "android/asset_manager.h"
|
#include "android/asset_manager.h"
|
||||||
#include "android/asset_manager_jni.h"
|
#include "android/asset_manager_jni.h"
|
||||||
#include "jni/CocosPlayClient.h"
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
|
||||||
|
@ -471,7 +471,7 @@ string FileUtilsAndroid::getWritablePath() const
|
||||||
// Fix for Nexus 10 (Android 4.2 multi-user environment)
|
// Fix for Nexus 10 (Android 4.2 multi-user environment)
|
||||||
// the path is retrieved through Java Context.getCacheDir() method
|
// the path is retrieved through Java Context.getCacheDir() method
|
||||||
string dir("");
|
string dir("");
|
||||||
string tmp = getFileDirectoryJNI();
|
string tmp = JniHelper::callStaticStringMethod("org/cocos2dx/lib/Cocos2dxHelper", "getCocos2dxWritablePath");
|
||||||
|
|
||||||
if (tmp.length() > 0)
|
if (tmp.length() > 0)
|
||||||
{
|
{
|
||||||
|
|
|
@ -29,9 +29,7 @@ THE SOFTWARE.
|
||||||
#include "CCGLViewImpl-android.h"
|
#include "CCGLViewImpl-android.h"
|
||||||
#include "base/CCDirector.h"
|
#include "base/CCDirector.h"
|
||||||
#include "base/ccMacros.h"
|
#include "base/ccMacros.h"
|
||||||
#include "jni/IMEJni.h"
|
|
||||||
#include "jni/JniHelper.h"
|
#include "jni/JniHelper.h"
|
||||||
#include "jni/Java_org_cocos2dx_lib_Cocos2dxHelper.h"
|
|
||||||
#include "CCGL.h"
|
#include "CCGL.h"
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
@ -112,7 +110,7 @@ bool GLViewImpl::isOpenGLReady()
|
||||||
|
|
||||||
void GLViewImpl::end()
|
void GLViewImpl::end()
|
||||||
{
|
{
|
||||||
terminateProcessJNI();
|
JniHelper::callStaticVoidMethod("org/cocos2dx/lib/Cocos2dxHelper", "terminateProcess");
|
||||||
}
|
}
|
||||||
|
|
||||||
void GLViewImpl::swapBuffers()
|
void GLViewImpl::swapBuffers()
|
||||||
|
@ -121,7 +119,11 @@ void GLViewImpl::swapBuffers()
|
||||||
|
|
||||||
void GLViewImpl::setIMEKeyboardState(bool bOpen)
|
void GLViewImpl::setIMEKeyboardState(bool bOpen)
|
||||||
{
|
{
|
||||||
setKeyboardStateJNI((int)bOpen);
|
if (bOpen) {
|
||||||
|
JniHelper::callStaticVoidMethod("org/cocos2dx/lib/Cocos2dxGLSurfaceView", "openIMEKeyboard");
|
||||||
|
} else {
|
||||||
|
JniHelper::callStaticVoidMethod("org/cocos2dx/lib/Cocos2dxGLSurfaceView", "closeIMEKeyboard");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
NS_CC_END
|
NS_CC_END
|
||||||
|
|
|
@ -1,19 +0,0 @@
|
||||||
#include "DPIJni.h"
|
|
||||||
#include "jni/JniHelper.h"
|
|
||||||
|
|
||||||
USING_NS_CC;
|
|
||||||
|
|
||||||
extern "C" {
|
|
||||||
|
|
||||||
int getDPIJNI()
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
jint ret = -1;
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, "org/cocos2dx/lib/Cocos2dxHelper", "getDPI", "()I")) {
|
|
||||||
ret = t.env->CallStaticIntMethod(t.classID, t.methodID);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
} // extern "C"
|
|
|
@ -1,10 +0,0 @@
|
||||||
#ifndef __DPIJNI_H__
|
|
||||||
#define __DPIJNI_H__
|
|
||||||
|
|
||||||
extern "C" {
|
|
||||||
|
|
||||||
int getDPIJNI();
|
|
||||||
|
|
||||||
} // extern "C"
|
|
||||||
|
|
||||||
#endif /* __DPIJNI_H__ */
|
|
|
@ -1,61 +0,0 @@
|
||||||
/****************************************************************************
|
|
||||||
Copyright (c) 2011-2012 cocos2d-x.org
|
|
||||||
Copyright (c) 2013-2014 Chukong Technologies Inc.
|
|
||||||
|
|
||||||
http://www.cocos2d-x.org
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
|
||||||
in the Software without restriction, including without limitation the rights
|
|
||||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
||||||
copies of the Software, and to permit persons to whom the Software is
|
|
||||||
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 Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
AUTHORS 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 SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
||||||
THE SOFTWARE.
|
|
||||||
****************************************************************************/
|
|
||||||
#include "IMEJni.h"
|
|
||||||
#include "base/CCIMEDispatcher.h"
|
|
||||||
#include "JniHelper.h"
|
|
||||||
|
|
||||||
#include <android/log.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <jni.h>
|
|
||||||
|
|
||||||
using namespace cocos2d;
|
|
||||||
|
|
||||||
extern "C" {
|
|
||||||
void setKeyboardStateJNI(int bOpen) {
|
|
||||||
if (bOpen) {
|
|
||||||
openKeyboardJNI();
|
|
||||||
} else {
|
|
||||||
closeKeyboardJNI();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void openKeyboardJNI() {
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, "org/cocos2dx/lib/Cocos2dxGLSurfaceView", "openIMEKeyboard", "()V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void closeKeyboardJNI() {
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, "org/cocos2dx/lib/Cocos2dxGLSurfaceView", "closeIMEKeyboard", "()V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,34 +0,0 @@
|
||||||
/****************************************************************************
|
|
||||||
Copyright (c) 2011-2012 cocos2d-x.org
|
|
||||||
Copyright (c) 2013-2014 Chukong Technologies Inc.
|
|
||||||
|
|
||||||
http://www.cocos2d-x.org
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
|
||||||
in the Software without restriction, including without limitation the rights
|
|
||||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
||||||
copies of the Software, and to permit persons to whom the Software is
|
|
||||||
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 Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
AUTHORS 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 SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
||||||
THE SOFTWARE.
|
|
||||||
****************************************************************************/
|
|
||||||
#ifndef __ANDROID_IME_JNI_H__
|
|
||||||
#define __ANDROID_IME_JNI_H__
|
|
||||||
|
|
||||||
extern "C" {
|
|
||||||
extern void setKeyboardStateJNI(int open);
|
|
||||||
extern void openKeyboardJNI();
|
|
||||||
extern void closeKeyboardJNI();
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif // __ANDROID_IME_JNI_H__
|
|
|
@ -23,48 +23,22 @@ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||||
THE SOFTWARE.
|
THE SOFTWARE.
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#include "JniHelper.h"
|
#include "platform/android/jni/JniHelper.h"
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "base/CCDirector.h"
|
#include "base/CCDirector.h"
|
||||||
#include "../CCApplication.h"
|
#include "../CCApplication.h"
|
||||||
#include "platform/CCFileUtils.h"
|
#include "platform/CCFileUtils.h"
|
||||||
#include <jni.h>
|
|
||||||
#include "base/ccUTF8.h"
|
#include "base/ccUTF8.h"
|
||||||
|
|
||||||
|
static const std::string className = "org/cocos2dx/lib/Cocos2dxBitmap";
|
||||||
|
|
||||||
using namespace cocos2d;
|
using namespace cocos2d;
|
||||||
|
|
||||||
|
|
||||||
int getFontSizeAccordingHeightJni(int height) {
|
int getFontSizeAccordingHeightJni(int height) {
|
||||||
int ret = 0;
|
return JniHelper::callStaticIntMethod(className, "getFontSizeAccordingHeight", height);
|
||||||
|
|
||||||
JniMethodInfo t;
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, "org/cocos2dx/lib/Cocos2dxBitmap", "getFontSizeAccordingHeight", "(I)I")) {
|
|
||||||
ret = t.env->CallStaticIntMethod(t.classID, t.methodID, height);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string getStringWithEllipsisJni(const char* text, float width, float fontSize) {
|
std::string getStringWithEllipsisJni(const char* text, float width, float fontSize) {
|
||||||
std::string ret;
|
return JniHelper::callStaticStringMethod(className, "getStringWithEllipsis", text, width, fontSize);
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, "org/cocos2dx/lib/Cocos2dxBitmap", "getStringWithEllipsis", "(Ljava/lang/String;FF)Ljava/lang/String;")) {
|
|
||||||
jstring stringArg1;
|
|
||||||
|
|
||||||
if (!text) {
|
|
||||||
stringArg1 = t.env->NewStringUTF("");
|
|
||||||
} else {
|
|
||||||
stringArg1 = t.env->NewStringUTF(text);
|
|
||||||
}
|
|
||||||
|
|
||||||
jstring retFromJava = (jstring)t.env->CallStaticObjectMethod(t.classID, t.methodID, stringArg1, width, fontSize);
|
|
||||||
ret = cocos2d::StringUtils::getStringUTFCharsJNI(t.env, retFromJava);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(stringArg1);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -37,8 +37,7 @@ THE SOFTWARE.
|
||||||
#define LOG_TAG "Java_org_cocos2dx_lib_Cocos2dxHelper.cpp"
|
#define LOG_TAG "Java_org_cocos2dx_lib_Cocos2dxHelper.cpp"
|
||||||
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,LOG_TAG,__VA_ARGS__)
|
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,LOG_TAG,__VA_ARGS__)
|
||||||
|
|
||||||
#define CLASS_NAME "org/cocos2dx/lib/Cocos2dxHelper"
|
static const std::string className = "org/cocos2dx/lib/Cocos2dxHelper";
|
||||||
#define EDITBOX_CLASS_NAME "org/cocos2dx/lib/Cocos2dxEditBoxHelper"
|
|
||||||
|
|
||||||
static EditTextCallback s_editTextCallback = nullptr;
|
static EditTextCallback s_editTextCallback = nullptr;
|
||||||
static void* s_ctx = nullptr;
|
static void* s_ctx = nullptr;
|
||||||
|
@ -84,479 +83,11 @@ const char * getApkPath() {
|
||||||
return g_apkPath.c_str();
|
return g_apkPath.c_str();
|
||||||
}
|
}
|
||||||
|
|
||||||
void showDialogJNI(const char * message, const char * title) {
|
|
||||||
if (!message) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
JniMethodInfo t;
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "showDialog", "(Ljava/lang/String;Ljava/lang/String;)V")) {
|
|
||||||
jstring stringArg1;
|
|
||||||
|
|
||||||
if (!title) {
|
|
||||||
stringArg1 = t.env->NewStringUTF("");
|
|
||||||
} else {
|
|
||||||
stringArg1 = t.env->NewStringUTF(title);
|
|
||||||
}
|
|
||||||
|
|
||||||
jstring stringArg2 = t.env->NewStringUTF(message);
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, stringArg1, stringArg2);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(stringArg1);
|
|
||||||
t.env->DeleteLocalRef(stringArg2);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void terminateProcessJNI() {
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "terminateProcess", "()V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string getPackageNameJNI() {
|
|
||||||
JniMethodInfo t;
|
|
||||||
std::string ret("");
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "getCocos2dxPackageName", "()Ljava/lang/String;")) {
|
|
||||||
jstring str = (jstring)t.env->CallStaticObjectMethod(t.classID, t.methodID);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
ret = JniHelper::jstring2string(str);
|
|
||||||
t.env->DeleteLocalRef(str);
|
|
||||||
}
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string getFileDirectoryJNI() {
|
|
||||||
JniMethodInfo t;
|
|
||||||
std::string ret("");
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "getCocos2dxWritablePath", "()Ljava/lang/String;")) {
|
|
||||||
jstring str = (jstring)t.env->CallStaticObjectMethod(t.classID, t.methodID);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
ret = JniHelper::jstring2string(str);
|
|
||||||
t.env->DeleteLocalRef(str);
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string getCurrentLanguageJNI() {
|
|
||||||
JniMethodInfo t;
|
|
||||||
std::string ret("");
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "getCurrentLanguage", "()Ljava/lang/String;")) {
|
|
||||||
jstring str = (jstring)t.env->CallStaticObjectMethod(t.classID, t.methodID);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
ret = JniHelper::jstring2string(str);
|
|
||||||
t.env->DeleteLocalRef(str);
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
void enableAccelerometerJni() {
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "enableAccelerometer", "()V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setAccelerometerIntervalJni(float interval) {
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "setAccelerometerInterval", "(F)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, interval);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void disableAccelerometerJni() {
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "disableAccelerometer", "()V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setKeepScreenOnJni(bool value) {
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "setKeepScreenOn", "(Z)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, value);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void vibrateJni(float duration) {
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "vibrate", "(F)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, duration);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
extern bool openURLJNI(const char* url) {
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
bool ret = false;
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "openURL", "(Ljava/lang/String;)Z")) {
|
|
||||||
jstring stringArg = t.env->NewStringUTF(url);
|
|
||||||
ret = t.env->CallStaticBooleanMethod(t.classID, t.methodID, stringArg);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
t.env->DeleteLocalRef(stringArg);
|
|
||||||
}
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
// functions for UserDefault
|
|
||||||
bool getBoolForKeyJNI(const char* key, bool defaultValue)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "getBoolForKey", "(Ljava/lang/String;Z)Z")) {
|
|
||||||
jstring stringArg = t.env->NewStringUTF(key);
|
|
||||||
jboolean ret = t.env->CallStaticBooleanMethod(t.classID, t.methodID, stringArg, defaultValue);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
t.env->DeleteLocalRef(stringArg);
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
return defaultValue;
|
|
||||||
}
|
|
||||||
|
|
||||||
int getIntegerForKeyJNI(const char* key, int defaultValue)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "getIntegerForKey", "(Ljava/lang/String;I)I")) {
|
|
||||||
jstring stringArg = t.env->NewStringUTF(key);
|
|
||||||
jint ret = t.env->CallStaticIntMethod(t.classID, t.methodID, stringArg, defaultValue);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
t.env->DeleteLocalRef(stringArg);
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
return defaultValue;
|
|
||||||
}
|
|
||||||
|
|
||||||
float getFloatForKeyJNI(const char* key, float defaultValue)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "getFloatForKey", "(Ljava/lang/String;F)F")) {
|
|
||||||
jstring stringArg = t.env->NewStringUTF(key);
|
|
||||||
jfloat ret = t.env->CallStaticFloatMethod(t.classID, t.methodID, stringArg, defaultValue);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
t.env->DeleteLocalRef(stringArg);
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
return defaultValue;
|
|
||||||
}
|
|
||||||
|
|
||||||
double getDoubleForKeyJNI(const char* key, double defaultValue)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "getDoubleForKey", "(Ljava/lang/String;D)D")) {
|
|
||||||
jstring stringArg = t.env->NewStringUTF(key);
|
|
||||||
jdouble ret = t.env->CallStaticDoubleMethod(t.classID, t.methodID, stringArg, defaultValue);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
t.env->DeleteLocalRef(stringArg);
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
return defaultValue;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string getStringForKeyJNI(const char* key, const char* defaultValue)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
std::string ret("");
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "getStringForKey", "(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;")) {
|
|
||||||
jstring stringArg1 = t.env->NewStringUTF(key);
|
|
||||||
jstring stringArg2 = t.env->NewStringUTF(defaultValue);
|
|
||||||
jstring str = (jstring)t.env->CallStaticObjectMethod(t.classID, t.methodID, stringArg1, stringArg2);
|
|
||||||
ret = JniHelper::jstring2string(str);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
t.env->DeleteLocalRef(stringArg1);
|
|
||||||
t.env->DeleteLocalRef(stringArg2);
|
|
||||||
t.env->DeleteLocalRef(str);
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
return defaultValue;
|
|
||||||
}
|
|
||||||
|
|
||||||
void setBoolForKeyJNI(const char* key, bool value)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "setBoolForKey", "(Ljava/lang/String;Z)V")) {
|
|
||||||
jstring stringArg = t.env->NewStringUTF(key);
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, stringArg, value);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
t.env->DeleteLocalRef(stringArg);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setIntegerForKeyJNI(const char* key, int value)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "setIntegerForKey", "(Ljava/lang/String;I)V")) {
|
|
||||||
jstring stringArg = t.env->NewStringUTF(key);
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, stringArg, value);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
t.env->DeleteLocalRef(stringArg);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setFloatForKeyJNI(const char* key, float value)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "setFloatForKey", "(Ljava/lang/String;F)V")) {
|
|
||||||
jstring stringArg = t.env->NewStringUTF(key);
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, stringArg, value);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
t.env->DeleteLocalRef(stringArg);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setDoubleForKeyJNI(const char* key, double value)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "setDoubleForKey", "(Ljava/lang/String;D)V")) {
|
|
||||||
jstring stringArg = t.env->NewStringUTF(key);
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, stringArg, value);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
t.env->DeleteLocalRef(stringArg);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setStringForKeyJNI(const char* key, const char* value)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "setStringForKey", "(Ljava/lang/String;Ljava/lang/String;)V")) {
|
|
||||||
jstring stringArg1 = t.env->NewStringUTF(key);
|
|
||||||
jstring stringArg2 = t.env->NewStringUTF(value);
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, stringArg1, stringArg2);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
t.env->DeleteLocalRef(stringArg1);
|
|
||||||
t.env->DeleteLocalRef(stringArg2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void deleteValueForKeyJNI(const char* key)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "deleteValueForKey", "(Ljava/lang/String;)V")) {
|
|
||||||
jstring stringArg1 = t.env->NewStringUTF(key);
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, stringArg1);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
t.env->DeleteLocalRef(stringArg1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int addEditBoxJNI(int left, int top, int width, int height, float scaleX){
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
int ret = -1;
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, EDITBOX_CLASS_NAME, "createEditBox", "(IIIIF)I")) {
|
|
||||||
ret = t.env->CallStaticIntMethod(t.classID, t.methodID, left, top, width, height, scaleX);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
void removeEditBoxJNI(int index)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, EDITBOX_CLASS_NAME, "removeEditBox", "(I)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setEditBoxViewRectJNI(int index, int left, int top, int width, int height)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, EDITBOX_CLASS_NAME, "setEditBoxViewRect", "(IIIII)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, left, top, width, height);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setMaxLengthJNI(int index, int maxLength)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, EDITBOX_CLASS_NAME, "setMaxLength", "(II)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, maxLength);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void openEditBoxKeyboardJNI(int index)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, EDITBOX_CLASS_NAME, "openKeyboard", "(I)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void closeEditBoxKeyboardJNI(int index)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, EDITBOX_CLASS_NAME, "closeKeyboard", "(I)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setVisibleEditBoxJNI(int index, bool visibility)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, EDITBOX_CLASS_NAME, "setVisible", "(IZ)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, visibility);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setReturnTypeEditBoxJNI(int index, int returnType)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, EDITBOX_CLASS_NAME, "setReturnType", "(II)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, returnType);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setInputFlagEditBoxJNI(int index, int returnType)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, EDITBOX_CLASS_NAME, "setInputFlag", "(II)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, returnType);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setInputModeEditBoxJNI(int index, int inputMode)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, EDITBOX_CLASS_NAME, "setInputMode", "(II)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, inputMode);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setTextEditBoxJNI(int index, const char* text)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, EDITBOX_CLASS_NAME, "setText", "(ILjava/lang/String;)V")) {
|
|
||||||
jstring stringText = StringUtils::newStringUTFJNI(t.env,text);
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID,index, stringText);
|
|
||||||
t.env->DeleteLocalRef(stringText);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setFontEditBoxJNI(int index, const char* fontName, float fontSize)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, EDITBOX_CLASS_NAME, "setFont", "(ILjava/lang/String;F)V")) {
|
|
||||||
jstring stringText = StringUtils::newStringUTFJNI(t.env,fontName);
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID,index, stringText, fontSize);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
t.env->DeleteLocalRef(stringText);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setFontColorEditBoxJNI(int index, int red, int green, int blue, int alpha)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, EDITBOX_CLASS_NAME, "setFontColor", "(IIIII)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID,index, red, green, blue, alpha);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setPlaceHolderTextEditBoxJNI(int index, const char* text)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, EDITBOX_CLASS_NAME, "setPlaceHolderText", "(ILjava/lang/String;)V")) {
|
|
||||||
jstring stringText = StringUtils::newStringUTFJNI(t.env,text);
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID,index, stringText);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
t.env->DeleteLocalRef(stringText);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void setPlaceHolderTextColorEditBoxJNI(int index, int red, int green, int blue, int alpha)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, EDITBOX_CLASS_NAME, "setPlaceHolderTextColor", "(IIIII)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID,index, red, green, blue, alpha);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void conversionEncodingJNI(const char* src, int byteSize, const char* fromCharset, char* dst, const char* newCharset)
|
void conversionEncodingJNI(const char* src, int byteSize, const char* fromCharset, char* dst, const char* newCharset)
|
||||||
{
|
{
|
||||||
JniMethodInfo methodInfo;
|
JniMethodInfo methodInfo;
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(methodInfo, CLASS_NAME, "conversionEncoding", "([BLjava/lang/String;Ljava/lang/String;)[B")) {
|
if (JniHelper::getStaticMethodInfo(methodInfo, className.c_str(), "conversionEncoding", "([BLjava/lang/String;Ljava/lang/String;)[B")) {
|
||||||
jbyteArray strArray = methodInfo.env->NewByteArray(byteSize);
|
jbyteArray strArray = methodInfo.env->NewByteArray(byteSize);
|
||||||
methodInfo.env->SetByteArrayRegion(strArray, 0, byteSize, reinterpret_cast<const jbyte*>(src));
|
methodInfo.env->SetByteArrayRegion(strArray, 0, byteSize, reinterpret_cast<const jbyte*>(src));
|
||||||
|
|
||||||
|
|
|
@ -31,28 +31,22 @@ typedef void (*EditTextCallback)(const char* text, void* ctx);
|
||||||
|
|
||||||
extern const char * getApkPath();
|
extern const char * getApkPath();
|
||||||
extern void showDialogJNI(const char * message, const char * title);
|
extern void showDialogJNI(const char * message, const char * title);
|
||||||
extern void terminateProcessJNI();
|
// extern void terminateProcessJNI();
|
||||||
extern std::string getCurrentLanguageJNI();
|
// extern std::string getCurrentLanguageJNI();
|
||||||
extern std::string getPackageNameJNI();
|
// extern std::string getPackageNameJNI();
|
||||||
extern std::string getFileDirectoryJNI();
|
extern std::string getFileDirectoryJNI();
|
||||||
extern void enableAccelerometerJni();
|
|
||||||
extern void disableAccelerometerJni();
|
|
||||||
extern void setAccelerometerIntervalJni(float interval);
|
|
||||||
extern void setKeepScreenOnJni(bool value);
|
|
||||||
extern void vibrateJni(float duration);
|
|
||||||
extern bool openURLJNI(const char* url);
|
|
||||||
// functions for UserDefault
|
// functions for UserDefault
|
||||||
extern bool getBoolForKeyJNI(const char* key, bool defaultValue);
|
// extern bool getBoolForKeyJNI(const char* key, bool defaultValue);
|
||||||
extern int getIntegerForKeyJNI(const char* key, int defaultValue);
|
// extern int getIntegerForKeyJNI(const char* key, int defaultValue);
|
||||||
extern float getFloatForKeyJNI(const char* key, float defaultValue);
|
// extern float getFloatForKeyJNI(const char* key, float defaultValue);
|
||||||
extern double getDoubleForKeyJNI(const char* key, double defaultValue);
|
// extern double getDoubleForKeyJNI(const char* key, double defaultValue);
|
||||||
extern std::string getStringForKeyJNI(const char* key, const char* defaultValue);
|
// extern std::string getStringForKeyJNI(const char* key, const char* defaultValue);
|
||||||
extern void setBoolForKeyJNI(const char* key, bool value);
|
// extern void setBoolForKeyJNI(const char* key, bool value);
|
||||||
extern void setIntegerForKeyJNI(const char* key, int value);
|
// extern void setIntegerForKeyJNI(const char* key, int value);
|
||||||
extern void setFloatForKeyJNI(const char* key, float value);
|
// extern void setFloatForKeyJNI(const char* key, float value);
|
||||||
extern void setDoubleForKeyJNI(const char* key, double value);
|
// extern void setDoubleForKeyJNI(const char* key, double value);
|
||||||
extern void setStringForKeyJNI(const char* key, const char* value);
|
// extern void setStringForKeyJNI(const char* key, const char* value);
|
||||||
extern void deleteValueForKeyJNI(const char* key);
|
// extern void deleteValueForKeyJNI(const char* key);
|
||||||
extern void conversionEncodingJNI(const char* src, int byteSize, const char* fromCharset, char* dst, const char* newCharset);
|
extern void conversionEncodingJNI(const char* src, int byteSize, const char* fromCharset, char* dst, const char* newCharset);
|
||||||
//Added for new Android EditBox
|
//Added for new Android EditBox
|
||||||
extern int addEditBoxJNI(int left, int top, int width, int height, float scaleX);
|
extern int addEditBoxJNI(int left, int top, int width, int height, float scaleX);
|
||||||
|
|
|
@ -277,7 +277,7 @@ namespace cocos2d {
|
||||||
}
|
}
|
||||||
|
|
||||||
jstring JniHelper::convert(cocos2d::JniMethodInfo& t, const char* x) {
|
jstring JniHelper::convert(cocos2d::JniMethodInfo& t, const char* x) {
|
||||||
jstring ret = t.env->NewStringUTF(x ? x : "");
|
jstring ret = cocos2d::StringUtils::newStringUTFJNI(t.env, x ? x : "");
|
||||||
localRefs[t.env].push_back(ret);
|
localRefs[t.env].push_back(ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -297,5 +297,8 @@ namespace cocos2d {
|
||||||
localRefs[env].clear();
|
localRefs[env].clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void JniHelper::reportError(const std::string& className, const std::string& methodName, const std::string& signature) {
|
||||||
|
LOGE("Failed to find static java method. Class name: %s, method name: %s, signature: %s ", className.c_str(), methodName.c_str(), signature.c_str());
|
||||||
|
}
|
||||||
|
|
||||||
} //namespace cocos2d
|
} //namespace cocos2d
|
||||||
|
|
|
@ -72,6 +72,8 @@ public:
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, convert(t, xs)...);
|
t.env->CallStaticVoidMethod(t.classID, t.methodID, convert(t, xs)...);
|
||||||
t.env->DeleteLocalRef(t.classID);
|
t.env->DeleteLocalRef(t.classID);
|
||||||
deleteLocalRefs(t.env);
|
deleteLocalRefs(t.env);
|
||||||
|
} else {
|
||||||
|
reportError(className, methodName, signature);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -86,6 +88,8 @@ public:
|
||||||
jret = t.env->CallStaticBooleanMethod(t.classID, t.methodID, convert(t, xs)...);
|
jret = t.env->CallStaticBooleanMethod(t.classID, t.methodID, convert(t, xs)...);
|
||||||
t.env->DeleteLocalRef(t.classID);
|
t.env->DeleteLocalRef(t.classID);
|
||||||
deleteLocalRefs(t.env);
|
deleteLocalRefs(t.env);
|
||||||
|
} else {
|
||||||
|
reportError(className, methodName, signature);
|
||||||
}
|
}
|
||||||
return (jret == JNI_TRUE);
|
return (jret == JNI_TRUE);
|
||||||
}
|
}
|
||||||
|
@ -101,6 +105,8 @@ public:
|
||||||
ret = t.env->CallStaticIntMethod(t.classID, t.methodID, convert(t, xs)...);
|
ret = t.env->CallStaticIntMethod(t.classID, t.methodID, convert(t, xs)...);
|
||||||
t.env->DeleteLocalRef(t.classID);
|
t.env->DeleteLocalRef(t.classID);
|
||||||
deleteLocalRefs(t.env);
|
deleteLocalRefs(t.env);
|
||||||
|
} else {
|
||||||
|
reportError(className, methodName, signature);
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -116,6 +122,8 @@ public:
|
||||||
ret = t.env->CallStaticFloatMethod(t.classID, t.methodID, convert(t, xs)...);
|
ret = t.env->CallStaticFloatMethod(t.classID, t.methodID, convert(t, xs)...);
|
||||||
t.env->DeleteLocalRef(t.classID);
|
t.env->DeleteLocalRef(t.classID);
|
||||||
deleteLocalRefs(t.env);
|
deleteLocalRefs(t.env);
|
||||||
|
} else {
|
||||||
|
reportError(className, methodName, signature);
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -131,6 +139,8 @@ public:
|
||||||
ret = t.env->CallStaticDoubleMethod(t.classID, t.methodID, convert(t, xs)...);
|
ret = t.env->CallStaticDoubleMethod(t.classID, t.methodID, convert(t, xs)...);
|
||||||
t.env->DeleteLocalRef(t.classID);
|
t.env->DeleteLocalRef(t.classID);
|
||||||
deleteLocalRefs(t.env);
|
deleteLocalRefs(t.env);
|
||||||
|
} else {
|
||||||
|
reportError(className, methodName, signature);
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -149,6 +159,8 @@ public:
|
||||||
t.env->DeleteLocalRef(t.classID);
|
t.env->DeleteLocalRef(t.classID);
|
||||||
t.env->DeleteLocalRef(jret);
|
t.env->DeleteLocalRef(jret);
|
||||||
deleteLocalRefs(t.env);
|
deleteLocalRefs(t.env);
|
||||||
|
} else {
|
||||||
|
reportError(className, methodName, signature);
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -167,66 +179,68 @@ private:
|
||||||
|
|
||||||
static jstring convert(cocos2d::JniMethodInfo& t, const std::string& x);
|
static jstring convert(cocos2d::JniMethodInfo& t, const std::string& x);
|
||||||
|
|
||||||
static std::unordered_map<JNIEnv*, std::vector<jobject>> localRefs;
|
|
||||||
|
|
||||||
static void deleteLocalRefs(JNIEnv* env);
|
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
static T convert(cocos2d::JniMethodInfo&, T x) {
|
static T convert(cocos2d::JniMethodInfo&, T x) {
|
||||||
return x;
|
return x;
|
||||||
}
|
}
|
||||||
|
|
||||||
static constexpr const char* getJNISignature() {
|
static std::unordered_map<JNIEnv*, std::vector<jobject>> localRefs;
|
||||||
|
|
||||||
|
static void deleteLocalRefs(JNIEnv* env);
|
||||||
|
|
||||||
|
static std::string getJNISignature() {
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
static constexpr const char* getJNISignature(bool) {
|
static std::string getJNISignature(bool) {
|
||||||
return "Z";
|
return "Z";
|
||||||
}
|
}
|
||||||
|
|
||||||
static constexpr const char* getJNISignature(char) {
|
static std::string getJNISignature(char) {
|
||||||
return "C";
|
return "C";
|
||||||
}
|
}
|
||||||
|
|
||||||
static constexpr const char* getJNISignature(short) {
|
static std::string getJNISignature(short) {
|
||||||
return "S";
|
return "S";
|
||||||
}
|
}
|
||||||
|
|
||||||
static constexpr const char* getJNISignature(int) {
|
static std::string getJNISignature(int) {
|
||||||
return "I";
|
return "I";
|
||||||
}
|
}
|
||||||
|
|
||||||
static constexpr const char* getJNISignature(long) {
|
static std::string getJNISignature(long) {
|
||||||
return "J";
|
return "J";
|
||||||
}
|
}
|
||||||
|
|
||||||
static constexpr const char* getJNISignature(float) {
|
static std::string getJNISignature(float) {
|
||||||
return "F";
|
return "F";
|
||||||
}
|
}
|
||||||
|
|
||||||
static constexpr const char* getJNISignature(double) {
|
static std::string getJNISignature(double) {
|
||||||
return "D";
|
return "D";
|
||||||
}
|
}
|
||||||
|
|
||||||
static constexpr const char* getJNISignature(const char*) {
|
static std::string getJNISignature(const char*) {
|
||||||
return "Ljava/lang/String;";
|
return "Ljava/lang/String;";
|
||||||
}
|
}
|
||||||
|
|
||||||
static constexpr const char* getJNISignature(const std::string&) {
|
static std::string getJNISignature(const std::string&) {
|
||||||
return "Ljava/lang/String;";
|
return "Ljava/lang/String;";
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
static constexpr const char* getJNISignature(T x) {
|
static std::string getJNISignature(T x) {
|
||||||
// This template should never be instantiated
|
// This template should never be instantiated
|
||||||
static_assert(sizeof(x) == 0, "Unsupported argument type");
|
static_assert(sizeof(x) == 0, "Unsupported argument type");
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T, typename... Ts>
|
template <typename T, typename... Ts>
|
||||||
static constexpr const char* getJNISignature(T x, Ts... xs) {
|
static std::string getJNISignature(T x, Ts... xs) {
|
||||||
return (std::string(getJNISignature(x)) + std::string(getJNISignature(xs...))).c_str();
|
return getJNISignature(x) + getJNISignature(xs...);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void reportError(const std::string& className, const std::string& methodName, const std::string& signature);
|
||||||
};
|
};
|
||||||
|
|
||||||
NS_CC_END
|
NS_CC_END
|
||||||
|
|
|
@ -42,6 +42,8 @@
|
||||||
USING_NS_CC;
|
USING_NS_CC;
|
||||||
static int _initialized = 0;
|
static int _initialized = 0;
|
||||||
|
|
||||||
|
static className = "org/cocos2dx/lib/Cocos2dxLocalStorage";
|
||||||
|
|
||||||
static void splitFilename (std::string& str)
|
static void splitFilename (std::string& str)
|
||||||
{
|
{
|
||||||
size_t found = 0;
|
size_t found = 0;
|
||||||
|
@ -59,36 +61,18 @@ void localStorageInit( const std::string& fullpath)
|
||||||
|
|
||||||
if( ! _initialized )
|
if( ! _initialized )
|
||||||
{
|
{
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, "org/cocos2dx/lib/Cocos2dxLocalStorage", "init", "(Ljava/lang/String;Ljava/lang/String;)Z")) {
|
|
||||||
std::string strDBFilename = fullpath;
|
std::string strDBFilename = fullpath;
|
||||||
splitFilename(strDBFilename);
|
splitFilename(strDBFilename);
|
||||||
jstring jdbName = t.env->NewStringUTF(strDBFilename.c_str());
|
if (JniHelper::CallStaticBooleanMethod(className, "init", strDBFilename, "data")) {
|
||||||
jstring jtableName = t.env->NewStringUTF("data");
|
|
||||||
jboolean ret = t.env->CallStaticBooleanMethod(t.classID, t.methodID, jdbName, jtableName);
|
|
||||||
t.env->DeleteLocalRef(jdbName);
|
|
||||||
t.env->DeleteLocalRef(jtableName);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
if (ret) {
|
|
||||||
_initialized = 1;
|
_initialized = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
void localStorageFree()
|
void localStorageFree()
|
||||||
{
|
{
|
||||||
if( _initialized ) {
|
if( _initialized ) {
|
||||||
|
JniHelper::CallStaticVoidMethod(className, "destory");
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, "org/cocos2dx/lib/Cocos2dxLocalStorage", "destory", "()V"))
|
|
||||||
{
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
|
|
||||||
_initialized = 0;
|
_initialized = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -97,17 +81,7 @@ void localStorageFree()
|
||||||
void localStorageSetItem( const std::string& key, const std::string& value)
|
void localStorageSetItem( const std::string& key, const std::string& value)
|
||||||
{
|
{
|
||||||
assert( _initialized );
|
assert( _initialized );
|
||||||
|
JniHelper::CallStaticVoidMethod(className, "setItem", key, value);
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, "org/cocos2dx/lib/Cocos2dxLocalStorage", "setItem", "(Ljava/lang/String;Ljava/lang/String;)V")) {
|
|
||||||
jstring jkey = t.env->NewStringUTF(key.c_str());
|
|
||||||
jstring jvalue = t.env->NewStringUTF(value.c_str());
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, jkey, jvalue);
|
|
||||||
t.env->DeleteLocalRef(jkey);
|
|
||||||
t.env->DeleteLocalRef(jvalue);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/** gets an item from the LS */
|
/** gets an item from the LS */
|
||||||
|
@ -136,14 +110,7 @@ bool localStorageGetItem( const std::string& key, std::string *outItem )
|
||||||
void localStorageRemoveItem( const std::string& key )
|
void localStorageRemoveItem( const std::string& key )
|
||||||
{
|
{
|
||||||
assert( _initialized );
|
assert( _initialized );
|
||||||
JniMethodInfo t;
|
JniHelper::CallStaticVoidMethod(className, "removeItem", key);
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, "org/cocos2dx/lib/Cocos2dxLocalStorage", "removeItem", "(Ljava/lang/String;)V")) {
|
|
||||||
jstring jkey = t.env->NewStringUTF(key.c_str());
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, jkey);
|
|
||||||
t.env->DeleteLocalRef(jkey);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -151,12 +118,7 @@ void localStorageRemoveItem( const std::string& key )
|
||||||
void localStorageClear()
|
void localStorageClear()
|
||||||
{
|
{
|
||||||
assert( _initialized );
|
assert( _initialized );
|
||||||
JniMethodInfo t;
|
JniHelper::CallStaticVoidMethod(className, "clear");
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, "org/cocos2dx/lib/Cocos2dxLocalStorage", "clear", "()V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // #if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)
|
#endif // #if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)
|
||||||
|
|
|
@ -30,7 +30,7 @@
|
||||||
|
|
||||||
#include "UIEditBox.h"
|
#include "UIEditBox.h"
|
||||||
#include <jni.h>
|
#include <jni.h>
|
||||||
#include "jni/Java_org_cocos2dx_lib_Cocos2dxHelper.h"
|
#include "platform/android/jni/JniHelper.h"
|
||||||
#include "2d/CCLabel.h"
|
#include "2d/CCLabel.h"
|
||||||
#include "base/ccUTF8.h"
|
#include "base/ccUTF8.h"
|
||||||
#include "math/Vec2.h"
|
#include "math/Vec2.h"
|
||||||
|
@ -39,6 +39,7 @@
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
|
static const std::string editBoxClassName = "org/cocos2dx/lib/Cocos2dxEditBoxHelper";
|
||||||
|
|
||||||
namespace ui {
|
namespace ui {
|
||||||
|
|
||||||
|
@ -80,7 +81,8 @@ EditBoxImplAndroid::EditBoxImplAndroid(EditBox* pEditText)
|
||||||
EditBoxImplAndroid::~EditBoxImplAndroid()
|
EditBoxImplAndroid::~EditBoxImplAndroid()
|
||||||
{
|
{
|
||||||
s_allEditBoxes.erase(_editBoxIndex);
|
s_allEditBoxes.erase(_editBoxIndex);
|
||||||
removeEditBoxJNI(_editBoxIndex);
|
JniHelper::callStaticVoidMethod(editBoxClassName, "removeEditBox", _editBoxIndex);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void EditBoxImplAndroid::createNativeControl(const Rect& frame)
|
void EditBoxImplAndroid::createNativeControl(const Rect& frame)
|
||||||
|
@ -100,7 +102,9 @@ void EditBoxImplAndroid::createNativeControl(const Rect& frame)
|
||||||
auto uiWidth = (rightTop.x - leftBottom.x) * glView->getScaleX();
|
auto uiWidth = (rightTop.x - leftBottom.x) * glView->getScaleX();
|
||||||
auto uiHeight = (rightTop.y - leftBottom.y) * glView->getScaleY();
|
auto uiHeight = (rightTop.y - leftBottom.y) * glView->getScaleY();
|
||||||
LOGD("scaleX = %f", glView->getScaleX());
|
LOGD("scaleX = %f", glView->getScaleX());
|
||||||
_editBoxIndex = addEditBoxJNI(uiLeft, uiTop, uiWidth, uiHeight, glView->getScaleX());
|
_editBoxIndex = JniHelper::callStaticIntMethod(editBoxClassName, "createEditBox",
|
||||||
|
(int)uiLeft, (int)uiTop, (int)uiWidth, (int)uiHeight,
|
||||||
|
(float)glView->getScaleX());
|
||||||
s_allEditBoxes[_editBoxIndex] = this;
|
s_allEditBoxes[_editBoxIndex] = this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -108,12 +112,15 @@ void EditBoxImplAndroid::setNativeFont(const char* pFontName, int fontSize)
|
||||||
{
|
{
|
||||||
auto director = cocos2d::Director::getInstance();
|
auto director = cocos2d::Director::getInstance();
|
||||||
auto glView = director->getOpenGLView();
|
auto glView = director->getOpenGLView();
|
||||||
setFontEditBoxJNI(_editBoxIndex, pFontName, fontSize * glView->getScaleX());
|
JniHelper::callStaticVoidMethod(editBoxClassName, "setFont",
|
||||||
|
_editBoxIndex, pFontName,
|
||||||
|
(float)fontSize * glView->getScaleX());
|
||||||
}
|
}
|
||||||
|
|
||||||
void EditBoxImplAndroid::setNativeFontColor(const Color4B& color)
|
void EditBoxImplAndroid::setNativeFontColor(const Color4B& color)
|
||||||
{
|
{
|
||||||
setFontColorEditBoxJNI(_editBoxIndex, color.r, color.g, color.b, color.a);
|
JniHelper::callStaticVoidMethod(editBoxClassName, "setFontColor", _editBoxIndex,
|
||||||
|
(int)color.r, (int)color.g, (int)color.b, (int)color.a);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EditBoxImplAndroid::setNativePlaceholderFont(const char* pFontName, int fontSize)
|
void EditBoxImplAndroid::setNativePlaceholderFont(const char* pFontName, int fontSize)
|
||||||
|
@ -123,28 +130,31 @@ void EditBoxImplAndroid::setNativePlaceholderFont(const char* pFontName, int fon
|
||||||
|
|
||||||
void EditBoxImplAndroid::setNativePlaceholderFontColor(const Color4B& color)
|
void EditBoxImplAndroid::setNativePlaceholderFontColor(const Color4B& color)
|
||||||
{
|
{
|
||||||
setPlaceHolderTextColorEditBoxJNI(_editBoxIndex, color.r, color.g, color.b, color.a);
|
JniHelper::callStaticVoidMethod(editBoxClassName, "setPlaceHolderTextColor", _editBoxIndex,
|
||||||
|
(int)color.r, (int)color.g, (int)color.b, (int)color.a);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EditBoxImplAndroid::setNativeInputMode(EditBox::InputMode inputMode)
|
void EditBoxImplAndroid::setNativeInputMode(EditBox::InputMode inputMode)
|
||||||
{
|
{
|
||||||
setInputModeEditBoxJNI(_editBoxIndex, static_cast<int>(inputMode));
|
JniHelper::callStaticVoidMethod(editBoxClassName, "setInputMode",
|
||||||
|
_editBoxIndex, static_cast<int>(inputMode));
|
||||||
}
|
}
|
||||||
|
|
||||||
void EditBoxImplAndroid::setNativeMaxLength(int maxLength)
|
void EditBoxImplAndroid::setNativeMaxLength(int maxLength)
|
||||||
{
|
{
|
||||||
setMaxLengthJNI(_editBoxIndex, maxLength);
|
JniHelper::callStaticVoidMethod(editBoxClassName, "setMaxLength", _editBoxIndex, maxLength);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void EditBoxImplAndroid::setNativeInputFlag(EditBox::InputFlag inputFlag)
|
void EditBoxImplAndroid::setNativeInputFlag(EditBox::InputFlag inputFlag)
|
||||||
{
|
{
|
||||||
setInputFlagEditBoxJNI(_editBoxIndex, static_cast<int>(inputFlag));
|
JniHelper::callStaticVoidMethod(editBoxClassName, "setInputFlag",
|
||||||
|
_editBoxIndex, static_cast<int>(inputFlag));
|
||||||
}
|
}
|
||||||
|
|
||||||
void EditBoxImplAndroid::setNativeReturnType(EditBox::KeyboardReturnType returnType)
|
void EditBoxImplAndroid::setNativeReturnType(EditBox::KeyboardReturnType returnType)
|
||||||
{
|
{
|
||||||
setReturnTypeEditBoxJNI(_editBoxIndex, static_cast<int>(returnType));
|
JniHelper::callStaticVoidMethod(editBoxClassName, "setReturnType",
|
||||||
|
_editBoxIndex, static_cast<int>(returnType));
|
||||||
}
|
}
|
||||||
|
|
||||||
bool EditBoxImplAndroid::isEditing()
|
bool EditBoxImplAndroid::isEditing()
|
||||||
|
@ -154,36 +164,37 @@ bool EditBoxImplAndroid::isEditing()
|
||||||
|
|
||||||
void EditBoxImplAndroid::setNativeText(const char* pText)
|
void EditBoxImplAndroid::setNativeText(const char* pText)
|
||||||
{
|
{
|
||||||
setTextEditBoxJNI(_editBoxIndex, pText);
|
JniHelper::callStaticVoidMethod(editBoxClassName, "setText", _editBoxIndex, pText);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EditBoxImplAndroid::setNativePlaceHolder(const char* pText)
|
void EditBoxImplAndroid::setNativePlaceHolder(const char* pText)
|
||||||
{
|
{
|
||||||
setPlaceHolderTextEditBoxJNI(_editBoxIndex, pText);
|
JniHelper::callStaticVoidMethod(editBoxClassName, "setPlaceHolderText", _editBoxIndex, pText);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void EditBoxImplAndroid::setNativeVisible(bool visible)
|
void EditBoxImplAndroid::setNativeVisible(bool visible)
|
||||||
{ // don't need to be implemented on android platform.
|
{ // don't need to be implemented on android platform.
|
||||||
setVisibleEditBoxJNI(_editBoxIndex, visible);
|
JniHelper::callStaticVoidMethod(editBoxClassName, "setVisible", _editBoxIndex, visible);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EditBoxImplAndroid::updateNativeFrame(const Rect& rect)
|
void EditBoxImplAndroid::updateNativeFrame(const Rect& rect)
|
||||||
{
|
{
|
||||||
|
JniHelper::callStaticVoidMethod(editBoxClassName, "setEditBoxViewRect", _editBoxIndex,
|
||||||
setEditBoxViewRectJNI(_editBoxIndex, rect.origin.x, rect.origin.y, rect.size.width, rect.size.height);
|
(int)rect.origin.x, (int)rect.origin.y,
|
||||||
|
(int)rect.size.width, (int)rect.size.height);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EditBoxImplAndroid::nativeOpenKeyboard()
|
void EditBoxImplAndroid::nativeOpenKeyboard()
|
||||||
{
|
{
|
||||||
//it will also open up the soft keyboard
|
//it will also open up the soft keyboard
|
||||||
setVisibleEditBoxJNI(_editBoxIndex,true);
|
JniHelper::callStaticVoidMethod(editBoxClassName, "setVisible", _editBoxIndex, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void EditBoxImplAndroid::nativeCloseKeyboard()
|
void EditBoxImplAndroid::nativeCloseKeyboard()
|
||||||
{
|
{
|
||||||
closeEditBoxKeyboardJNI(_editBoxIndex);
|
JniHelper::callStaticVoidMethod(editBoxClassName, "closeKeyboard", _editBoxIndex);
|
||||||
}
|
}
|
||||||
|
|
||||||
void editBoxEditingDidBegin(int index)
|
void editBoxEditingDidBegin(int index)
|
||||||
|
|
|
@ -29,14 +29,15 @@
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <jni.h>
|
#include <jni.h>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include "jni/JniHelper.h"
|
#include "platform/android/jni/JniHelper.h"
|
||||||
#include "base/CCDirector.h"
|
#include "base/CCDirector.h"
|
||||||
#include "base/CCEventListenerKeyboard.h"
|
#include "base/CCEventListenerKeyboard.h"
|
||||||
#include "platform/CCFileUtils.h"
|
#include "platform/CCFileUtils.h"
|
||||||
#include "ui/UIHelper.h"
|
#include "ui/UIHelper.h"
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------------------------------------
|
||||||
#define CLASS_NAME "org/cocos2dx/lib/Cocos2dxVideoHelper"
|
|
||||||
|
static const std::string videoHelperClassName = "org/cocos2dx/lib/Cocos2dxVideoHelper";
|
||||||
|
|
||||||
USING_NS_CC;
|
USING_NS_CC;
|
||||||
|
|
||||||
|
@ -54,7 +55,7 @@ int createVideoWidgetJNI()
|
||||||
{
|
{
|
||||||
JniMethodInfo t;
|
JniMethodInfo t;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "createVideoWidget", "()I")) {
|
if (JniHelper::getStaticMethodInfo(t, videoHelperClassName.c_str(), "createVideoWidget", "()I")) {
|
||||||
ret = t.env->CallStaticIntMethod(t.classID, t.methodID);
|
ret = t.env->CallStaticIntMethod(t.classID, t.methodID);
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
t.env->DeleteLocalRef(t.classID);
|
||||||
|
@ -63,108 +64,6 @@ int createVideoWidgetJNI()
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
void callVideoNonParameterFun(int index,const char* funName)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, funName, "(I)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void removeVideoWidgetJNI(int index)
|
|
||||||
{
|
|
||||||
callVideoNonParameterFun(index,"removeVideoWidget");
|
|
||||||
}
|
|
||||||
|
|
||||||
void setVideoRectJNI(int index,int left,int top,int width,int height)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "setVideoRect", "(IIIII)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, left, top, width, height);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setFullScreenEnabledJni(int index,bool enabled, int width, int height)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "setFullScreenEnabled", "(IZII)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, enabled, width, height);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setVideoURLJNI(int index,int videoSource,const std::string& videoUrl)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "setVideoUrl", "(IILjava/lang/String;)V")) {
|
|
||||||
jstring stringArg = t.env->NewStringUTF(videoUrl.c_str());
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, videoSource,stringArg);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
t.env->DeleteLocalRef(stringArg);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void startVideoJNI(int index)
|
|
||||||
{
|
|
||||||
callVideoNonParameterFun(index,"startVideo");
|
|
||||||
}
|
|
||||||
|
|
||||||
void pauseVideoJNI(int index)
|
|
||||||
{
|
|
||||||
callVideoNonParameterFun(index,"pauseVideo");
|
|
||||||
}
|
|
||||||
|
|
||||||
void resumeVideoJNI(int index)
|
|
||||||
{
|
|
||||||
callVideoNonParameterFun(index,"resumeVideo");
|
|
||||||
}
|
|
||||||
|
|
||||||
void stopVideoJNI(int index)
|
|
||||||
{
|
|
||||||
callVideoNonParameterFun(index,"stopVideo");
|
|
||||||
}
|
|
||||||
|
|
||||||
void seekVideoToJNI(int index,int msec)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "seekVideoTo", "(II)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, msec);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setVideoVisible(int index,bool visible)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "setVideoVisible", "(IZ)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, visible);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setVideoKeepRatioEnabled(int index,bool enabled)
|
|
||||||
{
|
|
||||||
JniMethodInfo t;
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, CLASS_NAME, "setVideoKeepRatioEnabled", "(IZ)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, enabled);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
//-----------------------------------------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
using namespace cocos2d::experimental::ui;
|
using namespace cocos2d::experimental::ui;
|
||||||
|
@ -190,21 +89,23 @@ VideoPlayer::VideoPlayer()
|
||||||
VideoPlayer::~VideoPlayer()
|
VideoPlayer::~VideoPlayer()
|
||||||
{
|
{
|
||||||
s_allVideoPlayers.erase(_videoPlayerIndex);
|
s_allVideoPlayers.erase(_videoPlayerIndex);
|
||||||
removeVideoWidgetJNI(_videoPlayerIndex);
|
JniHelper::callStaticVoidMethod(videoHelperClassName, "removeVideoWidget", _videoPlayerIndex);
|
||||||
}
|
}
|
||||||
|
|
||||||
void VideoPlayer::setFileName(const std::string& fileName)
|
void VideoPlayer::setFileName(const std::string& fileName)
|
||||||
{
|
{
|
||||||
_videoURL = FileUtils::getInstance()->fullPathForFilename(fileName);
|
_videoURL = FileUtils::getInstance()->fullPathForFilename(fileName);
|
||||||
_videoSource = VideoPlayer::Source::FILENAME;
|
_videoSource = VideoPlayer::Source::FILENAME;
|
||||||
setVideoURLJNI(_videoPlayerIndex, (int)Source::FILENAME,_videoURL);
|
JniHelper::callStaticVoidMethod(videoHelperClassName, "setVideoUrl", _videoPlayerIndex,
|
||||||
|
(int)Source::FILENAME,_videoURL);
|
||||||
}
|
}
|
||||||
|
|
||||||
void VideoPlayer::setURL(const std::string& videoUrl)
|
void VideoPlayer::setURL(const std::string& videoUrl)
|
||||||
{
|
{
|
||||||
_videoURL = videoUrl;
|
_videoURL = videoUrl;
|
||||||
_videoSource = VideoPlayer::Source::URL;
|
_videoSource = VideoPlayer::Source::URL;
|
||||||
setVideoURLJNI(_videoPlayerIndex,(int)Source::URL,_videoURL);
|
JniHelper::callStaticVoidMethod(videoHelperClassName, "setVideoUrl", _videoPlayerIndex,
|
||||||
|
(int)Source::URL,_videoURL);
|
||||||
}
|
}
|
||||||
|
|
||||||
void VideoPlayer::draw(Renderer* renderer, const Mat4 &transform, uint32_t flags)
|
void VideoPlayer::draw(Renderer* renderer, const Mat4 &transform, uint32_t flags)
|
||||||
|
@ -214,9 +115,9 @@ void VideoPlayer::draw(Renderer* renderer, const Mat4 &transform, uint32_t flags
|
||||||
if (flags & FLAGS_TRANSFORM_DIRTY)
|
if (flags & FLAGS_TRANSFORM_DIRTY)
|
||||||
{
|
{
|
||||||
auto uiRect = cocos2d::ui::Helper::convertBoundingBoxToScreen(this);
|
auto uiRect = cocos2d::ui::Helper::convertBoundingBoxToScreen(this);
|
||||||
|
JniHelper::callStaticVoidMethod(videoHelperClassName, "setVideoRect", _videoPlayerIndex,
|
||||||
setVideoRectJNI(_videoPlayerIndex, uiRect.origin.x, uiRect.origin.y,
|
(int)uiRect.origin.x, (int)uiRect.origin.y,
|
||||||
uiRect.size.width, uiRect.size.height);
|
(int)uiRect.size.width, (int)uiRect.size.height);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if CC_VIDEOPLAYER_DEBUG_DRAW
|
#if CC_VIDEOPLAYER_DEBUG_DRAW
|
||||||
|
@ -240,7 +141,8 @@ void VideoPlayer::setFullScreenEnabled(bool enabled)
|
||||||
_fullScreenEnabled = enabled;
|
_fullScreenEnabled = enabled;
|
||||||
|
|
||||||
auto frameSize = Director::getInstance()->getOpenGLView()->getFrameSize();
|
auto frameSize = Director::getInstance()->getOpenGLView()->getFrameSize();
|
||||||
setFullScreenEnabledJni(_videoPlayerIndex, enabled, frameSize.width, frameSize.height);
|
JniHelper::callStaticVoidMethod(videoHelperClassName, "setFullScreenEnabled", _videoPlayerIndex,
|
||||||
|
enabled, (int)frameSize.width, (int)frameSize.height);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -254,7 +156,7 @@ void VideoPlayer::setKeepAspectRatioEnabled(bool enable)
|
||||||
if (_keepAspectRatioEnabled != enable)
|
if (_keepAspectRatioEnabled != enable)
|
||||||
{
|
{
|
||||||
_keepAspectRatioEnabled = enable;
|
_keepAspectRatioEnabled = enable;
|
||||||
setVideoKeepRatioEnabled(_videoPlayerIndex,enable);
|
JniHelper::callStaticVoidMethod(videoHelperClassName, "setVideoKeepRatioEnabled", _videoPlayerIndex, enable);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -287,7 +189,7 @@ void VideoPlayer::play()
|
||||||
{
|
{
|
||||||
if (! _videoURL.empty())
|
if (! _videoURL.empty())
|
||||||
{
|
{
|
||||||
startVideoJNI(_videoPlayerIndex);
|
JniHelper::callStaticVoidMethod(videoHelperClassName, "startVideo", _videoPlayerIndex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -295,7 +197,7 @@ void VideoPlayer::pause()
|
||||||
{
|
{
|
||||||
if (! _videoURL.empty())
|
if (! _videoURL.empty())
|
||||||
{
|
{
|
||||||
pauseVideoJNI(_videoPlayerIndex);
|
JniHelper::callStaticVoidMethod(videoHelperClassName, "pauseVideo", _videoPlayerIndex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -303,7 +205,7 @@ void VideoPlayer::resume()
|
||||||
{
|
{
|
||||||
if (! _videoURL.empty())
|
if (! _videoURL.empty())
|
||||||
{
|
{
|
||||||
resumeVideoJNI(_videoPlayerIndex);
|
JniHelper::callStaticVoidMethod(videoHelperClassName, "resumeVideo", _videoPlayerIndex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -311,7 +213,7 @@ void VideoPlayer::stop()
|
||||||
{
|
{
|
||||||
if (! _videoURL.empty())
|
if (! _videoURL.empty())
|
||||||
{
|
{
|
||||||
stopVideoJNI(_videoPlayerIndex);
|
JniHelper::callStaticVoidMethod(videoHelperClassName, "stopVideo", _videoPlayerIndex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -319,7 +221,7 @@ void VideoPlayer::seekTo(float sec)
|
||||||
{
|
{
|
||||||
if (! _videoURL.empty())
|
if (! _videoURL.empty())
|
||||||
{
|
{
|
||||||
seekVideoToJNI(_videoPlayerIndex,int(sec * 1000));
|
JniHelper::callStaticVoidMethod(videoHelperClassName, "seekVideoTo", _videoPlayerIndex, int(sec * 1000));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -334,7 +236,7 @@ void VideoPlayer::setVisible(bool visible)
|
||||||
|
|
||||||
if (! _videoURL.empty())
|
if (! _videoURL.empty())
|
||||||
{
|
{
|
||||||
setVideoVisible(_videoPlayerIndex,visible);
|
JniHelper::callStaticVoidMethod(videoHelperClassName, "setVideoVisible", _videoPlayerIndex, visible);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -29,8 +29,7 @@
|
||||||
#include <unordered_map>
|
#include <unordered_map>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include "jni/JniHelper.h"
|
#include "platform/android/jni/JniHelper.h"
|
||||||
#include <jni.h>
|
|
||||||
|
|
||||||
#include "UIWebView.h"
|
#include "UIWebView.h"
|
||||||
#include "platform/CCGLView.h"
|
#include "platform/CCGLView.h"
|
||||||
|
@ -38,7 +37,7 @@
|
||||||
#include "platform/CCFileUtils.h"
|
#include "platform/CCFileUtils.h"
|
||||||
#include "ui/UIHelper.h"
|
#include "ui/UIHelper.h"
|
||||||
|
|
||||||
#define CLASS_NAME "org/cocos2dx/lib/Cocos2dxWebViewHelper"
|
static const std::string className = "org/cocos2dx/lib/Cocos2dxWebViewHelper";
|
||||||
|
|
||||||
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,"",__VA_ARGS__)
|
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG,"",__VA_ARGS__)
|
||||||
|
|
||||||
|
@ -132,7 +131,7 @@ namespace {
|
||||||
|
|
||||||
int createWebViewJNI() {
|
int createWebViewJNI() {
|
||||||
cocos2d::JniMethodInfo t;
|
cocos2d::JniMethodInfo t;
|
||||||
if (cocos2d::JniHelper::getStaticMethodInfo(t, CLASS_NAME, "createWebView", "()I")) {
|
if (cocos2d::JniHelper::getStaticMethodInfo(t, className.c_str(), "createWebView", "()I")) {
|
||||||
// LOGD("error: %s,%d",__func__,__LINE__);
|
// LOGD("error: %s,%d",__func__,__LINE__);
|
||||||
jint viewTag = t.env->CallStaticIntMethod(t.classID, t.methodID);
|
jint viewTag = t.env->CallStaticIntMethod(t.classID, t.methodID);
|
||||||
t.env->DeleteLocalRef(t.classID);
|
t.env->DeleteLocalRef(t.classID);
|
||||||
|
@ -141,179 +140,6 @@ int createWebViewJNI() {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void removeWebViewJNI(const int index) {
|
|
||||||
// LOGD("error: %s,%d",__func__,__LINE__);
|
|
||||||
cocos2d::JniMethodInfo t;
|
|
||||||
if (cocos2d::JniHelper::getStaticMethodInfo(t, CLASS_NAME, "removeWebView", "(I)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setWebViewRectJNI(const int index, const int left, const int top, const int width, const int height) {
|
|
||||||
// LOGD("error: %s,%d",__func__,__LINE__);
|
|
||||||
cocos2d::JniMethodInfo t;
|
|
||||||
if (cocos2d::JniHelper::getStaticMethodInfo(t, CLASS_NAME, "setWebViewRect", "(IIIII)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, left, top, width, height);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setJavascriptInterfaceSchemeJNI(const int index, const std::string &scheme) {
|
|
||||||
// LOGD("error: %s,%d",__func__,__LINE__);
|
|
||||||
cocos2d::JniMethodInfo t;
|
|
||||||
if (cocos2d::JniHelper::getStaticMethodInfo(t, CLASS_NAME, "setJavascriptInterfaceScheme", "(ILjava/lang/String;)V")) {
|
|
||||||
jstring jScheme = t.env->NewStringUTF(scheme.c_str());
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, jScheme);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(jScheme);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void loadDataJNI(const int index, const std::string &data, const std::string &MIMEType, const std::string &encoding, const std::string &baseURL) {
|
|
||||||
// LOGD("error: %s,%d",__func__,__LINE__);
|
|
||||||
cocos2d::JniMethodInfo t;
|
|
||||||
if (cocos2d::JniHelper::getStaticMethodInfo(t, CLASS_NAME, "loadData", "(ILjava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V")) {
|
|
||||||
jstring jData = t.env->NewStringUTF(data.c_str());
|
|
||||||
jstring jMIMEType = t.env->NewStringUTF(MIMEType.c_str());
|
|
||||||
jstring jEncoding = t.env->NewStringUTF(encoding.c_str());
|
|
||||||
jstring jBaseURL = t.env->NewStringUTF(getFixedBaseUrl(baseURL).c_str());
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, jData, jMIMEType, jEncoding, jBaseURL);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(jData);
|
|
||||||
t.env->DeleteLocalRef(jMIMEType);
|
|
||||||
t.env->DeleteLocalRef(jEncoding);
|
|
||||||
t.env->DeleteLocalRef(jBaseURL);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void loadHTMLStringJNI(const int index, const std::string &string, const std::string &baseURL) {
|
|
||||||
// LOGD("error: %s,%d",__func__,__LINE__);
|
|
||||||
cocos2d::JniMethodInfo t;
|
|
||||||
if (cocos2d::JniHelper::getStaticMethodInfo(t, CLASS_NAME, "loadHTMLString", "(ILjava/lang/String;Ljava/lang/String;)V")) {
|
|
||||||
jstring jString = t.env->NewStringUTF(string.c_str());
|
|
||||||
jstring jBaseURL = t.env->NewStringUTF(getFixedBaseUrl(baseURL).c_str());
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, jString, jBaseURL);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(jString);
|
|
||||||
t.env->DeleteLocalRef(jBaseURL);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void loadUrlJNI(const int index, const std::string &url) {
|
|
||||||
cocos2d::JniMethodInfo t;
|
|
||||||
if (cocos2d::JniHelper::getStaticMethodInfo(t, CLASS_NAME, "loadUrl", "(ILjava/lang/String;)V")) {
|
|
||||||
jstring jUrl = t.env->NewStringUTF(url.c_str());
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, jUrl);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(jUrl);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void loadFileJNI(const int index, const std::string &filePath) {
|
|
||||||
// LOGD("error: %s,%d",__func__,__LINE__);
|
|
||||||
cocos2d::JniMethodInfo t;
|
|
||||||
if (cocos2d::JniHelper::getStaticMethodInfo(t, CLASS_NAME, "loadFile", "(ILjava/lang/String;)V")) {
|
|
||||||
jstring jFilePath = t.env->NewStringUTF(filePath.c_str());
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, jFilePath);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(jFilePath);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void stopLoadingJNI(const int index) {
|
|
||||||
// LOGD("error: %s,%d",__func__,__LINE__);
|
|
||||||
cocos2d::JniMethodInfo t;
|
|
||||||
if (cocos2d::JniHelper::getStaticMethodInfo(t, CLASS_NAME, "stopLoading", "(I)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void reloadJNI(const int index) {
|
|
||||||
// LOGD("error: %s,%d",__func__,__LINE__);
|
|
||||||
cocos2d::JniMethodInfo t;
|
|
||||||
if (cocos2d::JniHelper::getStaticMethodInfo(t, CLASS_NAME, "reload", "(I)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
bool canGoBackJNI(const int index) {
|
|
||||||
// LOGD("error: %s,%d",__func__,__LINE__);
|
|
||||||
cocos2d::JniMethodInfo t;
|
|
||||||
if (cocos2d::JniHelper::getStaticMethodInfo(t, CLASS_NAME, "canGoBack", "(I)Z")) {
|
|
||||||
jboolean ret = t.env->CallStaticBooleanMethod(t.classID, t.methodID, index);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool canGoForwardJNI(const int index) {
|
|
||||||
// LOGD("error: %s,%d",__func__,__LINE__);
|
|
||||||
cocos2d::JniMethodInfo t;
|
|
||||||
if (cocos2d::JniHelper::getStaticMethodInfo(t, CLASS_NAME, "canGoForward", "(I)Z")) {
|
|
||||||
jboolean ret = t.env->CallStaticBooleanMethod(t.classID, t.methodID, index);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
void goBackJNI(const int index) {
|
|
||||||
// LOGD("error: %s,%d",__func__,__LINE__);
|
|
||||||
cocos2d::JniMethodInfo t;
|
|
||||||
if (cocos2d::JniHelper::getStaticMethodInfo(t, CLASS_NAME, "goBack", "(I)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void goForwardJNI(const int index) {
|
|
||||||
// LOGD("error: %s,%d",__func__,__LINE__);
|
|
||||||
cocos2d::JniMethodInfo t;
|
|
||||||
if (cocos2d::JniHelper::getStaticMethodInfo(t, CLASS_NAME, "goForward", "(I)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void evaluateJSJNI(const int index, const std::string &js) {
|
|
||||||
// LOGD("error: %s,%d",__func__,__LINE__);
|
|
||||||
cocos2d::JniMethodInfo t;
|
|
||||||
if (cocos2d::JniHelper::getStaticMethodInfo(t, CLASS_NAME, "evaluateJS", "(ILjava/lang/String;)V")) {
|
|
||||||
jstring jjs = t.env->NewStringUTF(js.c_str());
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, jjs);
|
|
||||||
|
|
||||||
t.env->DeleteLocalRef(jjs);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setScalesPageToFitJNI(const int index, const bool scalesPageToFit) {
|
|
||||||
// LOGD("error: %s,%d",__func__,__LINE__);
|
|
||||||
cocos2d::JniMethodInfo t;
|
|
||||||
if (cocos2d::JniHelper::getStaticMethodInfo(t, CLASS_NAME, "setScalesPageToFit", "(IZ)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, scalesPageToFit);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void setWebViewVisibleJNI(const int index, const bool visible) {
|
|
||||||
// LOGD("error: %s,%d",__func__,__LINE__);
|
|
||||||
cocos2d::JniMethodInfo t;
|
|
||||||
if (cocos2d::JniHelper::getStaticMethodInfo(t, CLASS_NAME, "setVisible", "(IZ)V")) {
|
|
||||||
t.env->CallStaticVoidMethod(t.classID, t.methodID, index, visible);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string getUrlStringByFileName(const std::string &fileName) {
|
std::string getUrlStringByFileName(const std::string &fileName) {
|
||||||
// LOGD("error: %s,%d",__func__,__LINE__);
|
// LOGD("error: %s,%d",__func__,__LINE__);
|
||||||
const std::string basePath("file:///android_asset/");
|
const std::string basePath("file:///android_asset/");
|
||||||
|
@ -343,62 +169,62 @@ namespace cocos2d {
|
||||||
}
|
}
|
||||||
|
|
||||||
WebViewImpl::~WebViewImpl() {
|
WebViewImpl::~WebViewImpl() {
|
||||||
removeWebViewJNI(_viewTag);
|
JniHelper::callStaticVoidMethod(className, "removeWebView", _viewTag);
|
||||||
s_WebViewImpls.erase(_viewTag);
|
s_WebViewImpls.erase(_viewTag);
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebViewImpl::loadData(const Data &data, const std::string &MIMEType, const std::string &encoding, const std::string &baseURL) {
|
void WebViewImpl::loadData(const Data &data, const std::string &MIMEType, const std::string &encoding, const std::string &baseURL) {
|
||||||
std::string dataString(reinterpret_cast<char *>(data.getBytes()), static_cast<unsigned int>(data.getSize()));
|
std::string dataString(reinterpret_cast<char *>(data.getBytes()), static_cast<unsigned int>(data.getSize()));
|
||||||
loadDataJNI(_viewTag, dataString, MIMEType, encoding, baseURL);
|
JniHelper::callStaticVoidMethod(className, "setJavascriptInterfaceScheme", _viewTag, dataString, MIMEType, encoding, baseURL);
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebViewImpl::loadHTMLString(const std::string &string, const std::string &baseURL) {
|
void WebViewImpl::loadHTMLString(const std::string &string, const std::string &baseURL) {
|
||||||
loadHTMLStringJNI(_viewTag, string, baseURL);
|
JniHelper::callStaticVoidMethod(className, "loadHTMLString", _viewTag, string, baseURL);
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebViewImpl::loadURL(const std::string &url) {
|
void WebViewImpl::loadURL(const std::string &url) {
|
||||||
loadUrlJNI(_viewTag, url);
|
JniHelper::callStaticVoidMethod(className, "loadUrl", _viewTag, url);
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebViewImpl::loadFile(const std::string &fileName) {
|
void WebViewImpl::loadFile(const std::string &fileName) {
|
||||||
auto fullPath = getUrlStringByFileName(fileName);
|
auto fullPath = getUrlStringByFileName(fileName);
|
||||||
loadFileJNI(_viewTag, fullPath);
|
JniHelper::callStaticVoidMethod(className, "loadFile", _viewTag, fullPath);
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebViewImpl::stopLoading() {
|
void WebViewImpl::stopLoading() {
|
||||||
stopLoadingJNI(_viewTag);
|
JniHelper::callStaticVoidMethod(className, "stopLoading", _viewTag);
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebViewImpl::reload() {
|
void WebViewImpl::reload() {
|
||||||
reloadJNI(_viewTag);
|
JniHelper::callStaticVoidMethod(className, "reload", _viewTag);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool WebViewImpl::canGoBack() {
|
bool WebViewImpl::canGoBack() {
|
||||||
return canGoBackJNI(_viewTag);
|
return JniHelper::callStaticBooleanMethod(className, "canGoBack", _viewTag);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool WebViewImpl::canGoForward() {
|
bool WebViewImpl::canGoForward() {
|
||||||
return canGoForwardJNI(_viewTag);
|
return JniHelper::callStaticBooleanMethod(className, "canGoForward", _viewTag);
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebViewImpl::goBack() {
|
void WebViewImpl::goBack() {
|
||||||
goBackJNI(_viewTag);
|
JniHelper::callStaticVoidMethod(className, "goBack", _viewTag);
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebViewImpl::goForward() {
|
void WebViewImpl::goForward() {
|
||||||
goForwardJNI(_viewTag);
|
JniHelper::callStaticVoidMethod(className, "goForward", _viewTag);
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebViewImpl::setJavascriptInterfaceScheme(const std::string &scheme) {
|
void WebViewImpl::setJavascriptInterfaceScheme(const std::string &scheme) {
|
||||||
setJavascriptInterfaceSchemeJNI(_viewTag, scheme);
|
JniHelper::callStaticVoidMethod(className, "setJavascriptInterfaceScheme", _viewTag, scheme);
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebViewImpl::evaluateJS(const std::string &js) {
|
void WebViewImpl::evaluateJS(const std::string &js) {
|
||||||
evaluateJSJNI(_viewTag, js);
|
JniHelper::callStaticVoidMethod(className, "evaluateJS", _viewTag, js);
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebViewImpl::setScalesPageToFit(const bool scalesPageToFit) {
|
void WebViewImpl::setScalesPageToFit(const bool scalesPageToFit) {
|
||||||
setScalesPageToFitJNI(_viewTag, scalesPageToFit);
|
JniHelper::callStaticVoidMethod(className, "setScalesPageToFit", _viewTag, scalesPageToFit);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool WebViewImpl::shouldStartLoading(const int viewTag, const std::string &url) {
|
bool WebViewImpl::shouldStartLoading(const int viewTag, const std::string &url) {
|
||||||
|
@ -446,14 +272,14 @@ namespace cocos2d {
|
||||||
void WebViewImpl::draw(cocos2d::Renderer *renderer, cocos2d::Mat4 const &transform, uint32_t flags) {
|
void WebViewImpl::draw(cocos2d::Renderer *renderer, cocos2d::Mat4 const &transform, uint32_t flags) {
|
||||||
if (flags & cocos2d::Node::FLAGS_TRANSFORM_DIRTY) {
|
if (flags & cocos2d::Node::FLAGS_TRANSFORM_DIRTY) {
|
||||||
auto uiRect = cocos2d::ui::Helper::convertBoundingBoxToScreen(_webView);
|
auto uiRect = cocos2d::ui::Helper::convertBoundingBoxToScreen(_webView);
|
||||||
|
JniHelper::callStaticVoidMethod(className, "setWebViewRect", _viewTag,
|
||||||
setWebViewRectJNI(_viewTag, uiRect.origin.x, uiRect.origin.y,
|
(int)uiRect.origin.x, (int)uiRect.origin.y,
|
||||||
uiRect.size.width, uiRect.size.height);
|
(int)uiRect.size.width, (int)uiRect.size.height);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebViewImpl::setVisible(bool visible) {
|
void WebViewImpl::setVisible(bool visible) {
|
||||||
setWebViewVisibleJNI(_viewTag, visible);
|
JniHelper::callStaticVoidMethod(className, "setVisible", _viewTag, visible);
|
||||||
}
|
}
|
||||||
} // namespace ui
|
} // namespace ui
|
||||||
} // namespace experimental
|
} // namespace experimental
|
||||||
|
|
|
@ -6,23 +6,14 @@
|
||||||
using namespace std;
|
using namespace std;
|
||||||
using namespace cocos2d;
|
using namespace cocos2d;
|
||||||
|
|
||||||
static std::string ACTIVITY_PATH("org/cocos2dx/lua/AppActivity");
|
static std::string className = "org/cocos2dx/lua/AppActivity";
|
||||||
|
|
||||||
void setActivityPathForAndroid(const std::string& path)
|
void setActivityPathForAndroid(const std::string& path)
|
||||||
{
|
{
|
||||||
ACTIVITY_PATH = path;
|
className = path;
|
||||||
}
|
}
|
||||||
|
|
||||||
string getIPAddress()
|
string getIPAddress()
|
||||||
{
|
{
|
||||||
JniMethodInfo t;
|
return JniHelper::callStaticStringMethod(className, "getLocalIpAddress");
|
||||||
string IPAddress("");
|
|
||||||
|
|
||||||
if (JniHelper::getStaticMethodInfo(t, ACTIVITY_PATH.c_str(), "getLocalIpAddress", "()Ljava/lang/String;")) {
|
|
||||||
jstring str = (jstring)t.env->CallStaticObjectMethod(t.classID, t.methodID);
|
|
||||||
t.env->DeleteLocalRef(t.classID);
|
|
||||||
IPAddress = JniHelper::jstring2string(str);
|
|
||||||
t.env->DeleteLocalRef(str);
|
|
||||||
}
|
|
||||||
return IPAddress;
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue