से जावा क्लास सदस्य को कॉल करना मैं एक ओपनजीएल सी/सी ++ एप्लीकेशन लिख रहा हूं जिसे मैं एंड्रॉइड एनडीके, जेएनआई समर्थन के माध्यम से एंड्रॉइड पर पोर्ट कर रहा हूं। मुझे देशी से संकेतित जावा कॉलबैक से कोड निष्पादित करने में कठिनाइयों का सामना करना पड़ रहा है।नेटिव सी/सी ++ कोड
यहाँ कोड है:
class OpenGLSurfaceView extends GLSurfaceView
{
…
public OpenGLSurfaceView(Context context, int deviceWidth, int deviceHeight)
{
super(context);
nativeObj = new NativeLib();
mRenderer = new OpenGLRenderer(context, nativeObj, deviceWidth, deviceHeight);
setRenderer(mRenderer);
setRenderMode(RENDERMODE_WHEN_DIRTY);
}
…
private void CallBack()
{
// force redraw
requestRender();
}
}
class OpenGLRenderer implements GLSurfaceView.Renderer
{
…
public void onSurfaceCreated(GL10 gl, EGLConfig config)
{
nativeObj.init(…);
nativeObj.cachejavaobject(JNIEnv *env, jobject obj); // for caching obj on native side
}
public void onSurfaceChanged(GL10 gl, int w, int h)
{
}
public void onDrawFrame(GL10 gl)
{
nativeObj.draw(…);
}
}
और मूल कोड में मैं एक समारोह texturesLoaded (है) कि जब कुछ बनावट एक और धागा पर पूरी तरह से लोड किए गए हैं संकेत है और मैं nativeLib.draw से एक ताज़ा मजबूर करने के लिए की जरूरत है (...) जावा पक्ष पर। यहाँ है कैसे मैं यह कर:
मैं JavaVM, jClass, jMethodID JNI_OnLoad पर कैश, और texturesLoaded पर
JNIEXPORT jint JNICALL JNI_OnLoad(JavaVM *jvm, void *reserved)
{
gJVM = jvm; // cache the JavaVM pointer
LogNativeToAndroidExt("JNILOAD!!!!!!!!!!");
JNIEnv *env;
int status = gJVM->GetEnv((void **)&env, JNI_VERSION_1_6);
if(status < 0)
{
LogNativeToAndroidExt("Failed to get JNI environment, assuming native thread");
status = gJVM->AttachCurrentThread(&env, NULL);
if(status < 0)
{
LogNativeToAndroidExt("callback_handler: failed to attach current thread");
return JNI_ERR;
}
}
gJClass = env->FindClass("com/android/newlineactivity/NewLineGLSurfaceView");
if(gJClass == NULL)
{
LogNativeToAndroidExt("Can't find Java class.");
return JNI_ERR;
}
gJMethodID = env->GetMethodID(gJClass, "callback", "()V");
if(gJMethodID == NULL)
{
LogNativeToAndroidExt("Can't find Java method void callback()");
return JNI_ERR;
}
return JNI_VERSION_1_6;
}
JNIEXPORT void Java_com_android_OpenGL_NativeLib_cachejavaobject(JNIEnv* env, jobject obj)
{
// cache the java object
gJObjectCached = obj;
...
}
और फिर gJObjectCached() मुझे क्या:
void texturesLoaded()
{
// Cannot share a JNIEnv between threads. You should share the JavaVM, and use JavaVM->GetEnv to discover the thread's JNIEnv
JNIEnv *env = NULL;
int status = gJVM->GetEnv((void **)&env, JNI_VERSION_1_6);
if(status < 0)
{
LogNativeToAndroidExt("callback_handler: failed to get JNI environment, assuming native thread");
status = gJVM->AttachCurrentThread(&env, NULL);
if(status < 0)
{
LogNativeToAndroidExt("callback_handler: failed to attach current thread");
return;
}
}
LogNativeToAndroidExt("Calling JAVA method from NATIVE C/C++");
env->CallVoidMethod(gJObjectCached, gJMethodID);
LogNativeToAndroidExt("DONE!!!");
}
परिणाम ... मूल पक्ष से मुझे कक्षा मिलती है, मुझे विधि मिलती है, विधि कहा जाता है, लेकिन जब यह पहुंचता है/कैल ls requestRender() अंदर (या GLSurfaceView के किसी भी अन्य सदस्य विधि तक पहुंचने का प्रयास कर रहा है इसे क्रैश!)
मैं CallStaticVoidMethod (gJClass, gjMethodID) के साथ प्रयास नहीं कर सकता; क्योंकि तब मेरे पास अनुरोधकर्ता(); तक पहुंच नहीं है;
कोई विचार या राय, शायद मैं यहां कुछ गलत कर रहा हूं।
धन्यवाद
'requestRender()' जावा में है, तो दुर्घटनाओं आमतौर पर एक अपवाद के साथ कर रहे है। क्या आप उल्लेख कर सकते हैं कि अपवाद क्या है। एंड्रॉइड एडीबी लॉग ऐसी जानकारी प्रकट करना चाहिए। लॉग इन करें [यहां] (http://developer.android.com/guide/developing/debugging/debugging-log.html) लॉग के बारे में पता लगाने के लिए – Warpspace