Issue
I have a bug in my code when working with multiple webviews from an Java class that receives a reference of the activity object.
This is my code:
try {
mActivity.runOnUiThread(new Runnable() {
@SuppressLint("NewApi")
public void run() {
if (webView == null)
return;
if (visibility) {
webView.setVisibility(View.VISIBLE);
webView.requestFocus();
if (dialog != null && !dialog.isShowing()) {
System.out.println("case1: " + dialog + " , activity: " + mActivity + ", mview " + webView);
} else {
dialog = WebViewUtils.showWebView(mActivity, webView);
System.out.println("case2 " + dialog + " , activity: " + mActivity + ", mview " + webView);
}
if (!mActivity.isFinishing()) {
dialog.show();
}
} else {
dialog.dismiss();
webView.setVisibility(View.GONE);
}
}
});
} catch (Exception e) {
System.out.println(System.out);
Log.d(Constants.TAG, e.getMessage());
}
This is the error stack:
09-22 14:12:21.682: E/WindowManager(1772): android.view.WindowLeaked: Activity com.example.test.MainActivity has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView{41fc30e8 V.E..... R.....ID 0,0-768,1184} that was originally added here
09-22 14:12:21.682: E/WindowManager(1772): at android.view.ViewRootImpl.<init>(ViewRootImpl.java:346)
09-22 14:12:21.682: E/WindowManager(1772): at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:248)
09-22 14:12:21.682: E/WindowManager(1772): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:69)
09-22 14:12:21.682: E/WindowManager(1772): at android.app.Dialog.show(Dialog.java:286)
09-22 14:12:21.682: E/WindowManager(1772): at com.itnt.JavaTest$3.run(JavaTest.java:199)
09-22 14:12:21.682: E/WindowManager(1772): at android.app.Activity.runOnUiThread(Activity.java:4713)
09-22 14:12:21.682: E/WindowManager(1772): at com.itnt.JavaTest.setVisibility(JavaTest.java:180)
09-22 14:12:21.682: E/WindowManager(1772): at com.itnt.JavaTest.showAd(JavaTest.java:122)
09-22 14:12:21.682: E/WindowManager(1772): at com.itnt.JavaTest.showAd(JavaTest.java:139)
09-22 14:12:21.682: E/WindowManager(1772): at com.example.test.MainActivity.onClick(MainActivity.java:53)
09-22 14:12:21.682: E/WindowManager(1772): at android.view.View.performClick(View.java:4438)
09-22 14:12:21.682: E/WindowManager(1772): at android.view.View$PerformClick.run(View.java:18422)
09-22 14:12:21.682: E/WindowManager(1772): at android.os.Handler.handleCallback(Handler.java:733)
09-22 14:12:21.682: E/WindowManager(1772): at android.os.Handler.dispatchMessage(Handler.java:95)
09-22 14:12:21.682: E/WindowManager(1772): at android.os.Looper.loop(Looper.java:136)
09-22 14:12:21.682: E/WindowManager(1772): at android.app.ActivityThread.main(ActivityThread.java:5001)
09-22 14:12:21.682: E/WindowManager(1772): at java.lang.reflect.Method.invokeNative(Native Method)
09-22 14:12:21.682: E/WindowManager(1772): at java.lang.reflect.Method.invoke(Method.java:515)
09-22 14:12:21.682: E/WindowManager(1772): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785)
09-22 14:12:21.682: E/WindowManager(1772): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601)
09-22 14:12:21.682: E/WindowManager(1772): at dalvik.system.NativeStart.main(Native Method)
The lines that are stated there are among the block of code i posted. If i check if the activity is null or if the dialog is null, shouldn't this be ok for the code not to break? I am lost. Any ideas are welcomed. Thank you.
Solution
just call dialog.dismiss()
and it will work fine .... :)
Answered By - Umair
0 comments:
Post a Comment
Note: Only a member of this blog may post a comment.