哪位大神能帮忙看看?jni

我在做手机联系人的时候,在开始的场景中通过jni可以成功调用这个函数和回调函数,
然后在跳转到另外一个界面的时候就不能正常的回调函数了,并且在eclipse中,跳转到联系人界面的时候,就报了一个错误:
call to OpenGL ES API with no current context (logged once per thread) ,这是为什么呢?就算报错的话,第一个场景中
也应该报错呀,可是第一个场景中又没有问题,而且第二个场景中区别不大(问题应该不是这个上面)!醉了!
public void ShowContact(){
startActivityForResult(new Intent(Intent.ACTION_PICK,ContactsContract.Contacts.CONTENT_URI), 1);
}

protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);
    if (resultCode == Activity.RESULT_OK) {
    //ContentProvider展示数据类似一个单个数据库表
    //ContentResolver实例带的方法可实现找到指定的ContentProvider并获取到ContentProvider的数据
    ContentResolver reContentResolverol = getContentResolver();  
    //URI,每个ContentProvider定义一个唯一的公开的URI,用于指定到它的数据集
    Uri contactData = data.getData();
    //查询就是输入URI等参数,其中URI是必须的,其他是可选的,如果系统能找到URI对应的ContentProvider将返回一个Cursor对象.
    Cursor cursor = managedQuery(contactData, null, null, null, null);  
    cursor.moveToFirst(); 
    //获得DATA表中的名字
    username = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME));  
    //条件为联系人ID
    String contactId = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts._ID));  
    // 获得DATA表中的电话号码,条件为联系人ID,因为手机号码可能会有多个
    Cursor phone = reContentResolverol.query(ContactsContract.CommonDataKinds.Phone.CONTENT_URI,   
             null,   
             ContactsContract.CommonDataKinds.Phone.CONTACT_ID + " = " + contactId,   
             null,   
             null);  
     while (phone.moveToNext()) {  
         usernumber = phone.getString(phone.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER));  
        // et_mobile.setText(usernumber+" ("+username+")");  
         Log.i(username, "ss");  
      // 通过JNI调用Cocos2d-x的C++函数  
         JniCallCocos.helloCocos(username); 
                      
         }
    } 
}

c++代码呢,写的不清楚,没办法解释