【问题标题】:Webview - How to stay on the current page on RotateWebview - 如何在 Rotate 上停留在当前页面
【发布时间】:2017-12-20 18:48:20
【问题描述】:

我为我的企业家开发了一个网站,我几乎只使用 PHP

所以 Java 语言(和 android studio)对我来说真的很新。尽管如此,我必须创建一个 APK 才能使用该网站(以阻止该网站上的 android 主页)

但是当我转动屏幕时,webview 显示的是主页而不是当前页面。

我做了一些研究,并整合了我在这里看到的内容:Android - Preventing WebView reload on Rotate

但这不起作用,我不明白为什么我总是回到“Google.com”

MainActivity.java

package eu.test.chrome;

import android.graphics.Bitmap;
import android.os.Bundle;
import android.support.v4.widget.SwipeRefreshLayout;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.webkit.WebChromeClient;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.ProgressBar;

public class MainActivity extends AppCompatActivity {

    WebView webView;

    SwipeRefreshLayout swipe;
    ProgressBar progressBar;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        progressBar = (ProgressBar) findViewById(R.id.awv_progressBar);
        swipe = (SwipeRefreshLayout) findViewById(R.id.swipe);
        LoadWeb();

        progressBar.setMax(100);
        progressBar.setProgress(1);


        swipe = (SwipeRefreshLayout) findViewById(R.id.swipe);
        swipe.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
            @Override
            public void onRefresh() {
                webView.reload();
            }
        });


        webView.setWebChromeClient(new WebChromeClient() {
            public void onProgressChanged(WebView view, int progress) {
                progressBar.setProgress(progress);
            }
        });


        webView.setWebViewClient(new WebViewClient() {

            @Override
            public void onPageStarted(WebView view, String url, Bitmap favicon) {
                super.onPageStarted(view, url, favicon);
                progressBar.setVisibility(View.VISIBLE);
            }


            public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) {
                webView.loadUrl("file:///android_asset/error.html");
            }


            public void onPageFinished(WebView view, String url) {
                //Don't show ProgressBar
                progressBar.setVisibility(View.GONE);
                //Hide the SwipeRefreshLayout
                swipe.setRefreshing(false);
            }

        });

    }


    /* I integrated what I saw here: https://stackoverflow.com/questions/12131025/android-preventing-webview-reload-on-rotate but that does not work
    @Override
    protected void onSaveInstanceState(Bundle outState )
    {
        super.onSaveInstanceState(outState);
        webView.saveState(outState);
    }

    @Override
    protected void onRestoreInstanceState(Bundle savedInstanceState)
    {
        super.onRestoreInstanceState(savedInstanceState);
        webView.restoreState(savedInstanceState);
    }*/


    public void LoadWeb() {

        webView = (WebView) findViewById(R.id.webView);
        webView.getSettings().setJavaScriptEnabled(true);
        webView.getSettings().setAppCacheEnabled(true);
        webView.loadUrl("https://www.google.com/");
        swipe.setRefreshing(true);
    }

    @Override
    public void onBackPressed() {

        if (webView.canGoBack()) {
            webView.goBack();
        } else {
            finish();
        }
    }

}

Activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/rel_parent"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity">

    <ProgressBar
        android:id="@+id/awv_progressBar"
        style="?android:attr/progressBarStyleHorizontal"
        android:layout_width="match_parent"
        android:layout_height="26dp"
        android:indeterminate="true" />


    <android.support.v4.widget.SwipeRefreshLayout
        android:id="@+id/swipe"
        android:layout_width="match_parent"
        android:layout_height="match_parent">

        <WebView
            android:id="@+id/webView"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />

    </android.support.v4.widget.SwipeRefreshLayout>


</LinearLayout>

清单

 <?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="eu.test.chrome">
    <uses-permission android:name="android.permission.INTERNET"/>

    <application
        android:hardwareAccelerated="false"
        android:configChanges="orientation|screenSize" 
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

【问题讨论】:

  • 你添加了这个android:configChanges="keyboard|keyboardHidden|orientation"
  • 在我的清单上我添加了这个:android:configChanges="orientation|screenSize"
  • 赞这个&lt;activity android:name=".MainActivity" android:configChanges="keyboard|keyboardHidden|orientation" &gt;
  • 您是否覆盖了 ONSAVEINSTANCE ?
  • 我刚刚像你一样修改了我的清单文件,它不起作用......

标签: java android webview


【解决方案1】:

为了在旋转之前加载 URL,您需要进行一些添加。

public class MainActivity extends AppCompatActivity {
WebView webView;

SwipeRefreshLayout swipe;
ProgressBar progressBar;

private final String CACHE_URL_KEY = "CACHE_URL";

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    progressBar = (ProgressBar) findViewById(R.id.awv_progressBar);
    swipe = (SwipeRefreshLayout) findViewById(R.id.swipe);
    LoadWeb(savedInstanceState);

    progressBar.setMax(100);
    progressBar.setProgress(1);


    swipe = (SwipeRefreshLayout) findViewById(R.id.swipe);
    swipe.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
        @Override
        public void onRefresh() {
            webView.reload();
        }
    });


    webView.setWebChromeClient(new WebChromeClient() {
        public void onProgressChanged(WebView view, int progress) {
            progressBar.setProgress(progress);
        }
    });


    webView.setWebViewClient(new WebViewClient() {

        @Override
        public void onPageStarted(WebView view, String url, Bitmap favicon) {
            super.onPageStarted(view, url, favicon);
            progressBar.setVisibility(View.VISIBLE);
        }


        public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) {
            webView.loadUrl("file:///android_asset/error.html");
        }


        public void onPageFinished(WebView view, String url) {
            //Don't show ProgressBar
            progressBar.setVisibility(View.GONE);
            //Hide the SwipeRefreshLayout
            swipe.setRefreshing(false);
        }

    });

}


@Override
protected void onSaveInstanceState(Bundle outState )
{
    outState.putString(CACHE_URL_KEY,webView.getUrl());
    super.onSaveInstanceState(outState);
}


public void LoadWeb(Bundle savedInstanceState) {

    webView = (WebView) findViewById(R.id.webView);
    webView.getSettings().setJavaScriptEnabled(true);
    webView.getSettings().setAppCacheEnabled(true);


    if (savedInstanceState != null) {
        String savedUrl = savedInstanceState.getString(CACHE_URL_KEY);
        webView.loadUrl(savedUrl);
    }else {
        webView.loadUrl("https://www.google.com/");
    }


    swipe.setRefreshing(true);
}

@Override
public void onBackPressed() {

    if (webView.canGoBack()) {
        webView.goBack();
    } else {
        finish();
    }
}

}

这些是已完成的步骤:

  1. 您需要创建一个密钥来识别保存的 URL

    private final String CACHE_URL_KEY = "CACHE_URL";

  2. 每次旋转时都需要保存 URL

    @Override protected void onSaveInstanceState(Bundle outState ) { outState.putString(CACHE_URL_KEY,webView.getUrl()); super.onSaveInstanceState(outState); }

  3. 您需要检查是否有轮换。如果是,则 savedInstanceState 不会为 null,因此检索 Url 并加载它。 其他加载默认页面

    if (savedInstanceState != null) { String savedUrl = savedInstanceState.getString(CACHE_URL_KEY); webView.loadUrl(savedUrl); }else { webView.loadUrl("https://www.google.com/"); }

  4. 另外,将保存的状态传递给 LoadWeb 方法

【讨论】:

    【解决方案2】:

    试试这个

    import android.graphics.Bitmap;
    import android.support.v4.widget.SwipeRefreshLayout;
    import android.support.v7.app.AppCompatActivity;
    import android.os.Bundle;
    import android.support.v7.widget.Toolbar;
    import android.view.View;
    
    import android.support.v4.widget.SwipeRefreshLayout;
    import android.webkit.WebChromeClient;
    import android.webkit.WebView;
    import android.webkit.WebViewClient;
    import android.widget.ProgressBar;
    
    public class Main2Activity extends AppCompatActivity {
    
        WebView webView;
    
        SwipeRefreshLayout swipe;
        ProgressBar progressBar;
        Toolbar toolbar;
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main2);
    
    
    
            LoadWeb();
            progressBar = (ProgressBar) findViewById(R.id.awv_progressBar);
            progressBar.setMax(100);
            progressBar.setProgress(1);
    
    
            swipe.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
                @Override
                public void onRefresh() {
                    webView.reload();
                }
            });
    
            webView.setWebChromeClient(new WebChromeClient() {
                public void onProgressChanged(WebView view, int progress) {
    
    
                    progressBar.setProgress(progress);
                }
            });
    
            webView.setWebViewClient(new WebViewClient() {
    
                @Override
                public void onPageStarted(WebView view, String url, Bitmap favicon) {
                    super.onPageStarted(view, url, favicon);
                    progressBar.setVisibility(View.VISIBLE);
                }
    
                public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) {
    
                    webView.loadUrl("https://stackoverflow.com/questions/47885592/how-to-add-a-progress-loading-bar-in-webview/47885692#47885692");
                }
    
                public void onLoadResource(WebView view, String url) { //Doesn't work
    //                swipe.setRefreshing(true);
                }
    
                public void onPageFinished(WebView view, String url) {
    
                    //Hide the SwipeReefreshLayout
                    progressBar.setVisibility(View.GONE);
                    swipe.setRefreshing(false);
                }
    
            });
    
    
        }
    
        public void LoadWeb() {
    
            swipe = (SwipeRefreshLayout) findViewById(R.id.swipe);
            webView = (WebView) findViewById(R.id.webView);
            webView.getSettings().setJavaScriptEnabled(true);
            webView.getSettings().setAppCacheEnabled(true);
            webView.loadUrl("http://dev.ncryptedprojects.com/bistrostays_v3/");
            swipe.setRefreshing(true);
        }
    
        @Override
        protected void onSaveInstanceState(Bundle outState )
        {
            super.onSaveInstanceState(outState);
            webView.saveState(outState);
        }
    
        @Override
        protected void onRestoreInstanceState(Bundle savedInstanceState)
        {
            super.onRestoreInstanceState(savedInstanceState);
            webView.restoreState(savedInstanceState);
        }
    
        @Override
        public void onBackPressed() {
    
            if (webView.canGoBack()) {
                webView.goBack();
            } else {
                finish();
            }
        }
    
    }
    

    在你的清单文件中

    <activity android:name=".MainActivity"
       android:configChanges="orientation|screenSize">
         <intent-filter>
           <action android:name="android.intent.action.MAIN" />
    
           <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
     </activity>
    

    【讨论】:

    • 我复制粘贴了您的代码,但出现此错误消息“不幸的是,.. 已停止”
    • @Rocstar 从日志猫窗口分享您的崩溃日志
    • 有效!错误来自我没有更改的主题,非常感谢您的帮助!
    • @Rocstar 很乐意为您提供帮助
    【解决方案3】:

    在 Android 中创建方法,例如:

     @JavascriptInterface
     public boolean CallByMobApp(){
     return true;
    }
    

    JavaScript 中创建调用函数:

    $(window).load(function () {
    
    IsCallByMobileApp = false;
    try {
          IsCallByMobileApp = app.CallByMobApp();/*Is call by android app*/
    
    } catch (e) {
        IsCallByMobileApp = false;
    }
    }
    

    根据这个方法你可以管理要打开哪个页面。

    【讨论】:

      【解决方案4】:

      您每次都调用方法 LoadWeb。您需要检查 savedInstanceState == null 然后调用 LoadWeb。如果 savedInstanceState != null 则不要调用 LoadWeb

      【讨论】:

      • 我添加了这个 if (savedInstanceState == null) { LoadWeb(); } 但它不起作用
      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多