Android:轻松获取WebView的内容宽度(赠源代码)

移动开发 Android
Android开发时,从WebView,我不但想要知道ContentHeight,还想知道ContentWidth。不幸的是,从一个WebView获取contentWidth是相当困难,因为SDK中没有一个像这样的方法,所以本文为大家呈现了一种实用的解决此问题的方法。

The extensive Android SDK allows you to do many great things with particular views like the WebView for displaying webpages on Android powered devices.

Android SDK 的扩展,通过使用特定的view,允许你做许多事情。比如,WebView,用来在Android手机上展示网页。

 

As of lately while I was experimenting with the Android SDK I was using a WebView in one of my activities.

最近,我在体验Android SDK的时候,在一个Activity中用到了WebView。

From that particular WebView I needed to know the ContentHeight but also the ContentWidth.

从WebView,我不但想要知道ContentHeight,还想知道ContentWidth。

Now getting the contentHeight is easy like so:

现在的情况是:获取contentHeight很easy,如下:

  1. webview.getContentHeight(); 

Unfortunately getting the contentWidth from a WebView is rather more difficult, since there is not a simple method like:

不幸的是,从一个WebView获取contentWidth是相当困难,因为SDK中没有一个像这样的方法:

  1. // THIS METHOD DOES NOT EXIST! 
  2.     webview.getContentWidth(); 

There are ways to get the contentWidth of the rendered HTML page and that is through Javascript. If Javascript can get it for you, then you can also have them in your Java code within your Android App.

当然是有方法获取contentWidth的,就是通过Javascript来获取。如果你能够支持Javascript,那么你就可以在你的Android 程序中,使用java代码来获取宽度。

By using a JavascriptInterface with your WebView you can let Javascript communicate with your Android App Java code by invoking methods on a registered object that you can embed using the JavascriptInterface.

通过在你的WebView中使用JavascriptInterface,通过调用你注册的JavascriptInterface方法,可以让Javascript和你的Android程序的java代码相互连通。

So how does this work?

怎么做呢?

For a quick example I created a simple Activity displaying a webview that loads a webpage wich displays a log message and a Toast message with the contentWidth wich was determined using Javascript. Note that this happens AFTER the page was finished loading, because before the page is finished loading the width might not be fully rendered. Also keep in mind that if there is content loaded asynchronously that it doesn't affect widths (most likely only heights will be affected as the width is almost always fully declared in CSS files unless you have a 100% width webpage).

搭建一个快速的例子:创建一个简单的展示webView的Activity,一个LogCat消息,一个Toast消息,用来显示我们通过 Javascript获取的宽度。注意:这些会在网页完全加载之后显示,因为在网页加载完成之前,宽度可能不能够正确的获取到。同时也要注意到,如果是异 步加载,这并不影响宽度(最多高度会受影响,因为宽度总是在CSS文件中做了完全的定义,除非在网页中你用了100%宽度。)。

Below is the code of the Activity Main.java:

下面的代码是Activity的代码:

  1. 01  package com.pimmos.android.samples.webviewcontentwidth;   
  2. 02  import android.app.Activity; 
  3. 03  import android.os.Bundle; 
  4. 04  import android.util.Log; 
  5. 05  import android.webkit.WebView; 
  6. 06  import android.webkit.WebViewClient; 
  7. 07  import android.widget.Toast;   
  8. 08  public class Main extends Activity {       
  9. 09      private final static String LOG_TAG = "WebViewContentWidth"
  10. 10      private final Activity activity = this;   
  11. 11      private static int webviewContentWidth = 0
  12. 12      private static WebView webview;       
  13. 13    
  14. 14  /** Called when the activity is first created. */ 
  15. 15      @Override 
  16. 16      public void onCreate(Bundle savedInstanceState) { 
  17. 17           super.onCreate(savedInstanceState); 
  18. 18           setContentView(R.layout.main);   
  19. 19           webview = (WebView) findViewById(R.id.webview); 
  20. 20           webview.getSettings().setJavaScriptEnabled(true); 
  21. 21           webview.setSaveEnabled(true); 
  22. 22           webview.addJavascriptInterface(new JavaScriptInterface(), "HTMLOUT"); 
  23. 23           webview.setWebViewClient(new WebViewClient() { 
  24. 24               @Override 
  25. 25              public void onPageFinished(WebView view, String url) { 
  26. 26                   webview.loadUrl("javascript:window.HTMLOUT.getContentWidth(document.getElementsByTagName('html')[0].scrollWidth);"); 
  27. 27               } 
  28. 28           }); 
  29. 29           webview.loadUrl("http://www.pimmos.com/"); 
  30. 30       } 
  31. 31    
  32. 32       class JavaScriptInterface { 
  33. 33           public void getContentWidth(String value) { 
  34. 34               if (value != null) { 
  35. 35                   webviewContentWidth = Integer.parseInt(value); 
  36. 36                   Log.d(LOG_TAG, "Result from javascript: " + webviewContentWidth); 
  37. 37                   Toast.makeText(                         activity, 
  38. 38                           "ContentWidth of webpage is: " + 
  39. 39  webviewContentWidth                                 + 
  40. 40  "px", Toast.LENGTH_SHORT).show(); 
  41. 41               } 
  42. 42           } 
  43. 43       } 
  44. 44  } 

Below is the XML layout used with the Activity wich only contains a simple WebView:

下面是Activity的Layout,主要就是一个简单的WebView:

  1. <?xml version="1.0" encoding="utf-8"?> 
  2.     <LinearLayout 
  3.        xmlns:android="http://schemas.android.com/apk/res/android"    
  4.        android:orientation="vertical" 
  5.        android:layout_width="fill_parent"    
  6.        android:layout_height="fill_parent"
  7.        <WebView android:id="@+id/webview" 
  8.             android:layout_width="fill_parent" 
  9.             android:layout_height="fill_parent" /> 
  10.      </LinearLayout> 

AndroidManifest.xml layout:

AndroidManifest.xml代码:

  1. <?xml version="1.0" encoding="utf-8"?> 
  2.     <manifest 
  3.      xmlns:android="http://schemas.android.com/apk/res/android" 
  4.         package="com.pimmos.android.samples.webviewcontentwidth" 
  5.         android:versionCode="1" android:versionName="1.0"
  6.          <application android:icon="@drawable/icon" 
  7.      android:label="@string/app_name"
  8.              <activity android:name=".Main" 
  9.      android:label="@string/app_name"
  10.                  <intent-filter> 
  11.                      <action android:name="android.intent.action.MAIN" /> 
  12.                      <category 
  13.     android:name="android.intent.category.LAUNCHER" /> 
  14.                  </intent-filter> 
  15.              </activity> 
  16.            </application> 
  17.          <uses-sdk android:minSdkVersion="7" /> 
  18.          <uses-permission android:name="android.permission.INTERNET" /> 
  19.        </manifest> 

You can also download the full source of Android Application - WebViewContentWidth!

你也可以到这里下载全部的源代码:  

http://down.51cto.com/data/795941

责任编辑:闫佳明 来源: oschina
相关推荐

2009-04-03 08:28:39

2020-11-12 11:50:20

OpenHarmony

2011-05-26 14:17:16

Android 源代码

2010-02-04 10:58:29

Android 源代码

2014-11-06 09:31:20

Android 5.0Google

2010-10-09 11:01:31

JS

2013-03-26 13:42:12

Android 监听网

2010-03-02 10:08:28

Android源代码

2011-11-15 10:16:41

Android 4.0Google

2010-02-05 18:00:18

Android源代码

2017-09-18 22:55:46

GoogleAndroidRTDB

2014-07-30 14:22:41

AndroidWebView内存泄漏

2017-04-25 12:07:51

AndroidWebViewjs

2015-01-12 10:06:02

在线客服

2010-03-08 15:57:27

2013-07-03 16:49:17

AndroidWebView

2010-03-05 14:38:46

Android智能手机

2009-05-30 09:19:44

AndroidGoogle移动OS

2015-03-03 15:53:31

Android控件

2011-10-21 09:24:13

谷歌Android 4.0源代码
点赞
收藏

51CTO技术栈公众号