用android webview加載現有的.html文件




android-webview android-assets (5)

調試編譯發行版不同,因此:

考慮一下你的Project文件結構[ 這種情況下,如果調試集合 ]:

src
  |
  main
  debug
      |
      assets
           |
           index.html

您應該將index.html調用到您的WebView中,如下所示:

WebView web=(WebView)findViewById(R.id.web);
web.loadUrl("file:///android_asset/index.html");

佈局:

<WebView
android:id="@+id/web"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="top"/>

對於發布彙編來說,它應該是這樣的:

src
  |
  main
  release
        |
        assets
             |
             index.html  

我曾嘗試使用WebView從Google代碼和其他資源中嘗試示例,演示,但是當我嘗試在自己的代碼中執行代碼時,它不適用於我。

我想加載myfile.html ,我把它放在資產文件夾,並使用:

private WebView myWebView;

myWebView.loadUrl("file:///android_assets/myfile.html");

在模擬器上顯示錯誤

file:///android_assets/myfile.html的網頁無法加載為:未找到請求的文件。 /android_assets/myfile.html

當我把這個文件放到res/raw/文件夾中並使用:

myWebView.loadUrl("file:///android_res/raw/myfile.html");

那麼只有模擬器的android 2.2 API級別8可能會加載該文件,其他舊版本顯示相同的錯誤。 我錯過了什麼嗎?

有什麼方法可以在適用於所有API版本的應用程序包中加載現有的.html文件?


另外請確保你不要忘記:

<uses-permission android:name="android.permission.INTERNET" />


如果你的結構應該是這樣的:

/assets/html/index.html

/assets/scripts/index.js

/assets/css/index.css

然後,只要( Android WebView:處理方向更改

    if(WebViewStateHolder.INSTANCE.getBundle() == null) { //this works only on single instance of webview, use a map with TAG if you need more
        webView.loadUrl("file:///android_asset/html/index.html");
    } else {
        webView.restoreState(WebViewStateHolder.INSTANCE.getBundle());
    }

確保你添加

    WebSettings webSettings = webView.getSettings();
    webSettings.setJavaScriptEnabled(true);
    webSettings.setJavaScriptCanOpenWindowsAutomatically(true);
    if(android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.JELLY_BEAN) {
        webSettings.setAllowFileAccessFromFileURLs(true);
        webSettings.setAllowUniversalAccessFromFileURLs(true);
    }

然後只需使用網址

<html>
<head>
    <meta charset="utf-8">
    <title>Zzzz</title>
    <script src="../scripts/index.js"></script>
    <link rel="stylesheet" type="text/css" href="../css/index.css">

將.html文件複製並粘貼到項目的assets文件夾中,並在onCreate()的Activity上添加下面的代碼。

        WebView view = new WebView(this);
        view.getSettings().setJavaScriptEnabled(true);
        view.loadUrl("file:///android_asset/**YOUR FILE NAME**.html");
        view.setBackgroundColor(Color.TRANSPARENT);
        setContentView(view);

您可以手動讀取html文件,然後使用WebView的loadDataloadDataWithBaseUrl方法來顯示它。





android-assets