6

मैं अपने प्रोजेक्ट के लिए एक घटक के रूप Cordova WebvView एम्बेडेड है, सब कुछ एक बात को छोड़कर ठीक काम करता है; जब बैक बटन दबाया जाता है तो मुझे लॉगकैट पर एक त्रुटि मिलती है जो कहता है "रिसीवर पंजीकृत नहीं है!" मुझे नहीं लगता कि मैंने एक रिसीवर पंजीकृत किया है। गिटहब here पर नमूना प्रोजेक्ट भी है। जब मैं इस एप्लिकेशन को चलाता हूं तो मुझे भी वही त्रुटि मिलती है।एम्बेडिंग Cordova WebView, रिसीवर पंजीकृत नहीं है

मुझे क्या करना चाहते है, मेरे Android प्रोजेक्ट में Cordova WebView एम्बेड और कुछ जावास्क्रिप्ट कार्यों चलाते हैं।

यहाँ मेरी मुख्य गतिविधि है;

public class MainNativeViewController extends FragmentActivity implements CordovaInterface, 
    JavaScriptListener { 

FragmentTransaction transaction; 
RelativeLayout childBrowser; 
RelativeLayout dialogBox; 
RelativeLayout emailComposer; 

private ExecutorService threadPool; 

CordovaWebViewFragment cordovaWebViewFragment; 

public CordovaWebView cordovaWebView; 

public LayoutInflater inflater; 
CordovaPlugin mActivityResultCallback; 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    // TODO Auto-generated method stub 
    super.onCreate(savedInstanceState); 

    setContentView(R.layout.fragment_container); 

    overridePendingTransition(R.anim.fade_in, R.anim.fade_out); 

    threadPool = Executors.newCachedThreadPool(); 

    cordovaWebView = SingleTonCordovaWebView.getCordovaWebView(this); 
    cordovaWebView.loadUrl("file:///android_asset/www/invoke_native_view.html"); 

    FragmentManager manager = getSupportFragmentManager(); 

    ListFragment listFragment = new ListFragment(); 

    manager.beginTransaction().add(R.id.fragment_container, listFragment).commit(); 
} 

@Override 
public void showFragment(String fragmentName) { 

    /* 
    * This method is used to create and replace a fragment to the 
    * container. according to name passed through here. 
    */ 

    transaction = getSupportFragmentManager().beginTransaction(); 
    transaction.setCustomAnimations(R.anim.slide_in_right, R.anim.slide_out_left, 
      R.anim.slide_in_left, R.anim.slide_out_right); 

    if (fragmentName.equals("error")) { 
     DialogCreator dialog = new DialogCreator(this); 
     dialog.createDialog("Error !", "Fragment Name is wrong,", "Check fragment name", false); 
    } else { 
     // fragment name is ignored for different cases, it will be used for 
     // further proporties. 
     // Just checking out the error in the case its not right parameter. 

     NativeViewTestFragment testFragment = new NativeViewTestFragment(fragmentName); 

     transaction.replace(R.id.fragment_container, testFragment); 
     transaction.addToBackStack(null); 
     transaction.commit(); 
    } 
} 

@Override 
protected void onNewIntent(final Intent intent) { 
    super.onNewIntent(intent); 

    // Forward to plugins 
    if ((this.cordovaWebView != null) && (this.cordovaWebView.pluginManager != null)) { 
     this.cordovaWebView.pluginManager.onNewIntent(intent); 
    } 
} 

@Override 
public void cancelLoadUrl() { 

} 

@Override 
public ExecutorService getThreadPool() { 
    return threadPool; 
} 

@Override 
public Activity getActivity() { 
    return this; 
} 

@Override 
public Context getContext() { 
    return this; 
} 

@Override 
public Object onMessage(final String id, final Object data) { 
    // return getCordovaFragment().onMessage(id, data); 
    return null; 
} 

@Override 
public void setActivityResultCallback(CordovaPlugin arg0) { 
    // TODO Auto-generated method stub 

} 

@Override 
public void startActivityForResult(CordovaPlugin plugin, Intent intent, int requestCode) { 
    mActivityResultCallback = plugin; 
    startActivityForResult(intent, requestCode); 
} 

@Override 
/** 
* Called when the system is about to start resuming a previous activity. 
*/ 
protected void onPause() { 
    super.onPause(); 

    // Send pause event to JavaScript 
    this.cordovaWebView.loadUrl("javascript:try{cordova.fireDocumentEvent('pause');}catch(e){console.log('exception firing pause event from native');};"); 

    // Forward to plugins 
    if (this.cordovaWebView.pluginManager != null) { 
     this.cordovaWebView.pluginManager.onPause(true); 
    } 
    threadPool.shutdown(); 
    threadPool = null; 
} 

@Override 
/** 
* Called when the activity will start interacting with the user. 
*/ 
protected void onResume() { 
    super.onResume(); 

    threadPool = Executors.newCachedThreadPool(); 

    if (this.cordovaWebView == null) { 
     return; 
    } 

    // Send resume event to JavaScript 
    this.cordovaWebView 
      .loadUrl("javascript:try{cordova.fireDocumentEvent('resume');}catch(e){console.log('exception firing resume event from native');};"); 

    // Forward to plugins 
    if (this.cordovaWebView.pluginManager != null) { 
     this.cordovaWebView.pluginManager.onResume(true); 
    }  
} 

@Override 
/** 
* The final call you receive before your activity is destroyed. 
*/ 
public void onDestroy() { 
    super.onDestroy(); 
    if (cordovaWebView.pluginManager != null) { 
     cordovaWebView.pluginManager.onDestroy(); 
    } 

    if (this.cordovaWebView != null) { 

     // Send destroy event to JavaScript 
     this.cordovaWebView 
       .loadUrl("javascript:try{cordova.require('cordova/channel').onDestroy.fire();}catch(e){console.log('exception firing destroy event from native');};"); 

     // Load blank page so that JavaScript onunload is called 
     this.cordovaWebView.loadUrl("about:blank"); 

     // Forward to plugins 
     if (this.cordovaWebView.pluginManager != null) { 
      this.cordovaWebView.pluginManager.onDestroy(); 
     } 
    } else { 
     // this.endActivity(); 
    } 
} 
} 

संपादित करें: यहाँ LogCat उत्पादन है,

11-23 12:25:36.117: E/AndroidRuntime(9645): FATAL EXCEPTION: main 

11-23 12:25:36.117: E/AndroidRuntime(9645): java.lang.RuntimeException: Unable to  destroy activity  {org.apache.cordova.example/okan.apps.nativeview.MainNativeViewController}:  java.lang.IllegalArgumentException: Receiver not registered:  [email protected] 
11-23 12:25:36.117: E/AndroidRuntime(9645):  at android.app.ActivityThread.performDestroyActivity(ActivityThread.java:3655) 
11-23 12:25:36.117: E/AndroidRuntime(9645):  at android.app.ActivityThread.handleDestroyActivity(ActivityThread.java:3673) 
11-23 12:25:36.117: E/AndroidRuntime(9645):  at android.app.ActivityThread.access$2900(ActivityThread.java:125) 
11-23 12:25:36.117: E/AndroidRuntime(9645):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2066) 
11-23 12:25:36.117: E/AndroidRuntime(9645):  at android.os.Handler.dispatchMessage(Handler.java:99) 
11-23 12:25:36.117: E/AndroidRuntime(9645):  at android.os.Looper.loop(Looper.java:123) 
11-23 12:25:36.117: E/AndroidRuntime(9645):  at android.app.ActivityThread.main(ActivityThread.java:4627) 
11-23 12:25:36.117: E/AndroidRuntime(9645):  at java.lang.reflect.Method.invokeNative(Native Method) 
11-23 12:25:36.117: E/AndroidRuntime(9645):  at java.lang.reflect.Method.invoke(Method.java:521) 
11-23 12:25:36.117: E/AndroidRuntime(9645):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868) 
11-23 12:25:36.117: E/AndroidRuntime(9645):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626) 
11-23 12:25:36.117: E/AndroidRuntime(9645):  at dalvik.system.NativeStart.main(Native Method) 
11-23 12:25:36.117: E/AndroidRuntime(9645): Caused by: java.lang.IllegalArgumentException: Receiver not registered: [email protected] 
11-23 12:25:36.117: E/AndroidRuntime(9645):  at android.app.ActivityThread$PackageInfo.forgetReceiverDispatcher(ActivityThread.java:793) 
11-23 12:25:36.117: E/AndroidRuntime(9645):  at android.app.ContextImpl.unregisterReceiver(ContextImpl.java:814) 
11-23 12:25:36.117: E/AndroidRuntime(9645):  at android.content.ContextWrapper.unregisterReceiver(ContextWrapper.java:331) 
11-23 12:25:36.117: E/AndroidRuntime(9645):  at org.apache.cordova.Device.onDestroy(Device.java:98) 
11-23 12:25:36.117: E/AndroidRuntime(9645):  at org.apache.cordova.api.PluginManager.onDestroy(PluginManager.java:317) 
11-23 12:25:36.117: E/AndroidRuntime(9645):  at okan.apps.nativeview.MainNativeViewController.onDestroy(MainNativeViewController.java:204) 
11-23 12:25:36.117: E/AndroidRuntime(9645):  at android.app.ActivityThread.performDestroyActivity(ActivityThread.java:3642) 
11-23 12:25:36.117: E/AndroidRuntime(9645):  ... 11 more 

संपादित करें:

मैं एक समाधान के साथ समाप्त हो गया। मैं एक टुकड़े में कॉर्डोवा वेब व्यू का उपयोग कर रहा था, मैंने इसे टुकड़े से बाहर ले जाया और इसे टुकड़े के कंटेनर के साथ एक ही एक्सएमएल में रखा। अब यह त्रुटि के बिना काम करता है। गिटहब में नमूना प्रोजेक्ट में यह वही है, कॉर्डोवा वेबव्यू फ़्रेमलाउट में है।

उत्तर

1

आप पूरी लागू करने के लिए की जरूरत नहीं है को नष्ट खुद के प्रवाह, आप निम्न का उपयोग कर सकते हैं:

public void onDestroy() { 
    LOG.d("Destroying the View", "onDestroy()"); 
    super.onDestroy(); 

    if (this.cwv != null) { 
    this.cwv.handleDestroy(); 
    } 
} 

आशा इस मदद करता है।

+0

अरे, मैं अपने समाधान करने की कोशिश की लेकिन मैं अभी भी एक ही त्रुटि मिलती है जोड़कर मेरी टुकड़ा में इस हल किया। यह कहते हैं, 'गतिविधि MainNativeViewController IntentReceiver [email protected] कि मूल रूप से यहाँ पंजीकृत किया गया लीक किया गया है। ? ' handleDestroy() से पहले, यह यह काम करता है लगता है, आप unregisterReceiver के लिए एक कॉल याद कर रहे हैं()' – osayilgan

+0

अरे मैं मैं रास्ता मिल गया लगता है, मैं 'this.cwv.removeAllViews() कहा जाता है। मुझे अब त्रुटि नहीं मिली है, लेकिन मुझे इसका सही तरीका पता नहीं है? – osayilgan

+0

** संपादित करें: ** इस तरह से यह त्रुटि के बिना लेकिन मामले में नष्ट हो जाता है मैं यह तो नष्ट मैं एक त्रुटि है, जो कहते हैं, '" java.lang.IllegalStateException पाने के बाद एप्लिकेशन को पुन: प्रारंभ करने का प्रयास में: इस नहीं जा सकता SaveInstanceState के बाद कार्रवाई "' – osayilgan

4

मैं onDestroyView के लिए निम्न()

@Override 
    public void onDestroyView() { 
     super.onDestroyView(); 
     mCordovaWebView.handleDestroy(); 

    } 
+0

सुनिश्चित नहीं है कि कॉर्डोवा का कौन सा संस्करण आप उपयोग कर रहे हैं लेकिन (शायद यह नए संस्करणों में हल हो गया है), उस समय, जब मैंने उस प्रश्न से पूछा, तो आपका समाधान काम नहीं कर पाया। – osayilgan

+0

मैं एंड्रॉइड पर 3.6.4 का उपयोग कर रहा हूं। क्योंकि वापस करने के लिए बटन का उपयोग कर org.apache.cordova.App''' बाहर निकलने पर ... मैं यहां समाप्त हुए: रिसीवर पंजीकृत नहीं: लेकिन, मेरा समाधान ऊपर 'शुरू की है करने के लिए' 'java.lang.IllegalArgumentException लगता है ऐप खत्म करना मुझे '' 'गतिविधि प्रदान कर रहा था, 'मुख्य गतिविधि ViewController ने IntentReceiver [email protected] को लीक कर दिया है जो मूल रूप से यहां पंजीकृत था। क्या आप unregisterReceiver() '' पर कॉल खो रहे हैं जो आप मूल रूप से देख रहे थे के विपरीत होने लगते हैं। – theSociableme

+0

यदि आप उस अपवाद को देखते हैं तो उपर्युक्त @Yoel समाधान जोड़ने के बाद यह वही समस्या है। तो अगर आप हैंड्रॉय को कॉल करने के बजाय ऑनस्ट्रोव्यू में हैंड्रॉयडॉय को कॉल करने की बजाय समस्या हल करती है? – osayilgan