CallStatic<type>Method Routines - CallStaticIntMethod
CallStatic<type>MethodA Routines
CallStatic<type>MethodV Routines
NativeType CallStatic<type>Method
(JNIEnv *env, jclass clazz,
jmethodID methodID, ...);
NativeType CallStatic<type>MethodA
(JNIEnv *env, jclass clazz,
jmethodID methodID, jvalue *args);
NativeType CallStatic<type>MethodV
(JNIEnv *env, jclass clazz,
jmethodID methodID, va_list args);
(CallStaticIntMethod)This family of operations invokes a static method on a Java object, according to the specified method ID. The
methodID
argument must be obtained by calling GetStaticMethodID
()
.
The method ID must be derived from
clazz
, not from one of its superclasses.
(CallStaticIntMethod)
CallStatic<type>Method Routines
Programmers should place all arguments that are to be passed to the method immediately following the
methodID
argument. TheCallStatic<type>Method routine accepts these arguments and passes them to the Java method that the programmer wishes to invoke. (CallStaticIntMethod)CallStatic<type>MethodA Routines
Programmers should place all arguments to the method in an
args
array of jvalues
that immediately follows the methodID
argument. The CallStaticMethodA routine accepts the arguments in this array, and, in turn, passes them to the Java method that the programmer wishes to invoke.CallStatic<type>MethodV Routines
Programmers should place all arguments to the method in an
args
argument of type va_list
that immediately follows the methodID
argument. The CallStaticMethodV routine accepts the arguments, and, in turn, passes them to the Java method that the programmer wishes to invoke.
The following table describes each of the method calling routines according to their result types. You should replace type inCallStatic<type>Method with the Java type of the method, or one of the actual method calling routine names from the table, and replace NativeType with the corresponding native type for that routine.
Table 4-7a CallStatic<type>Method Calling Routines
LINKAGE:
Indices in the JNIEnv interface function table.
Table 4-7b CallStatic<type>Method Calling Routines
PARAMETERS of CallStaticIntMethod
env
: the JNI interface pointer.clazz
: a Java class object.methodID
: a static method ID.Additional Parameter for CallStatic<type>Method Routines:
arguments to the static method.
Additional Parameter for CallStatic<type>MethodA Routines:
args
: an array of arguments.Additional Parameter for CallStatic<type>MethodV Routines:
args
: a va_list
of arguments.RETURNS:
Returns the result of calling the static Java method.
THROWS:
Exceptions raised during the execution of the Java method.
Example of
CallStaticIntMethodvoid Texture::construct(AssetLoader* aLoader, s32 aIdx)
{
const c8* fileName = aLoader->getFileName();
// load texture
SBC::System::Application* app = &Game::getGame().getApplication();
JNIEnv *env;
bool shouldDetach = false;
JavaVM* vm = gJavaVM;
jint rc = vm->GetEnv((void **)&env, JNI_VERSION_1_6);
if (rc != JNI_OK)
{
shouldDetach = true;
vm->AttachCurrentThread(&env, NULL);
}
jclass& activityClass = gJavaActivityClass;
jmethodID mid = env->GetStaticMethodID(activityClass, "loadTexture", "(Ljava/lang/String;I)I");
jstring mystr = env->NewStringUTF(fileName);
jint ret = env->CallStaticIntMethod(activityClass, mid, mystr, aIdx);
env->DeleteLocalRef(mystr);
// store information on ID, width and height of texture
mTextureID = ret;
LOGE("textureID = %i", mTextureID);
mid = env->GetStaticMethodID(activityClass, "getTextureWidth", "()I");
mWidth = env->CallStaticIntMethod(activityClass, mid);
mid = env->GetStaticMethodID(activityClass, "getTextureHeight", "()I");
mHeight = env->CallStaticIntMethod(activityClass, mid);
if (shouldDetach)
vm->DetachCurrentThread();
LOGI("texture ID %i, width %i, height %i", mTextureID, mWidth, mHeight);
}