WebView

使用WebView浏览图片

package com.example.photogallery;

import android.annotation.SuppressLint;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.TextureView;
import android.view.View;
import android.view.ViewGroup;
import android.webkit.WebChromeClient;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.ProgressBar;
import android.widget.TextView;

public class PhotoPageFragment extends VisibleFragment {
    private String mUrl;
    private WebView mWebView;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setRetainInstance(true);

        mUrl = getActivity().getIntent().getData().toString();
    }

    @SuppressLint("SetJavaScriptEnabled")
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.fragment_photo_page, container,
                false);

        final ProgressBar progressBar = (ProgressBar) view.findViewById(R.id.progressBar);
        progressBar.setMax(100);//WebChromeClient范围在0-100
        final TextView titleTextView = (TextView) view.findViewById(R.id.titleTextView);
        mWebView = (WebView) view.findViewById(R.id.webView);

        // 启用JavaScript
        mWebView.getSettings().setJavaScriptEnabled(true);
        /**
         * 配置WebViewClient.
         * WebViewClient是一个事件接口。通过提供自己实现的WebViewClient,可响应各种渲染事件。
         * 例如,可检查渲染器何时开始从特定URL加载图片,或决定是否需要向服务器重新提交POST请求。
         */
        mWebView.setWebViewClient(new WebViewClient() {

            /**
             * shouldOverrideUrlLoading方法表示当有新的URL加载到WebView(譬如说点击某个链接),该方法会决定下一步的行动。
             * 如返回true值,意即“不要处理这个URL,我自己来”。如返回false值,意即“WebView,去加载这个URL,我不会对他做任何处理。”
             */
            @Override
            public boolean shouldOverrideUrlLoading(WebView view, String url) {
                return false;
            }
        });

        /**
         * WebChromeClient是一个响应那些改变浏览器中装饰元素的事件接口。
         * 这包括JavaScript警告信息、网页图标、状态条加载,以及当前网页标题的刷新。
         */
        mWebView.setWebChromeClient(new WebChromeClient(){
            @Override
            public void onProgressChanged(WebView view, int newProgress) {
                if(newProgress == 100){
                    progressBar.setVisibility(View.INVISIBLE);
                }else {
                    progressBar.setVisibility(View.VISIBLE);
                    progressBar.setProgress(newProgress);
                }
            }

            @Override
            public void onReceivedTitle(WebView view, String title) {
                titleTextView.setText(title);
            }
        });

        // 加载URL网页必须等WebView配置完成后进行,因此这一步操作最后完成
        mWebView.loadUrl(mUrl);

        return view;
    }
}
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

    <WebView
        android:id="@+id/webView"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_above="@+id/titleTextView"
        android:layout_alignParentTop="true" />

    <TextView
        android:id="@id/titleTextView"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_above="@+id/progressBar"
        android:layout_margin="5dp" />

    <ProgressBar
        android:id="@id/progressBar"
        style="?android:attr/progressBarStyleHorizontal"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:visibility="invisible" />

</RelativeLayout>
mGridView.setOnItemClickListener(new OnItemClickListener() {

            @Override
            public void onItemClick(AdapterView<?> arg0, View arg1, int pos,
                    long arg3) {
                GalleryItem item = mItems.get(pos);

                Uri photoPageUri = Uri.parse(item.getPhotoPageUrl());
                //启动默认的浏览器
                //Intent intent = new Intent(Intent.ACTION_VIEW, photoPageUri);
                Intent intent = new Intent(getActivity(), PhotoPageActivity.class);
                intent.setData(photoPageUri);

                startActivity(intent);
            }
        });

处理WebView的设备选择问题

当设备选择时,WebView会重新加载网页。这是因为WebView包含了太多的数据,以至于无法在onSaveInstanceState(…)方法内保存所有数据。

对于一些类似的类(如VideoView),Android文档推荐让activity自己处理设备配置变更。也就是说,无需销毁重建activity可直接调整自己的视图以适应新的屏幕尺寸。这样,WebView也就不必重新加载全部数据。(但着这种方法并不适用于所有视图)。
在清单文件中配置如下:

<activity android:name="com.example.photogallery.PhotoPageActivity"           android:configChanges="keyboardHidden|orientation|screenSize">
</activity>

android:configChanges属性表明,如果因键盘开关、屏幕方向改变、屏幕大小改变而发生设备配置更改,那么activity应自己处理配置变更。

注入任意JavaScript对象到WebView本身包含的文档中

使用addJavascriptInterface(Object object, String name)方法可注入任意JavaScript对象到WebView本身包含的文档中。

mWebView.addJavascriptInterface(new Object(){
            public void send(String message){
                Log.i(TAG, message);
            }
        }, "androidObject");

然后按如下方式调用:

<input type="button" value="In WebView!"
    onClick="sendToAndroid('In Android land')"/>

<script type="text/javascript">
    function sendToAndroid(message){
        androidObject.send(message);
    }
</script>

这可能有风险,因为一些可能的问题网页能够与应用直接接触。安全起见,最好能掌控有问题的HTML,要么严格控制不要暴露自己的接口。

代码地址

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值