使用WebView加载网页

本文介绍了在Android应用中使用WebView加载指定URL的方法,并对比了使用Intent启动浏览器的方式。详细展示了WebView配置步骤及如何监听加载过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

有时在app中需要显示一个url指定的网页,可以使用两种方式,一种是通过intent打开浏览器app,另一种是采用WebView加载url。

1、通过intent打开浏览器app

Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse("http://www.kuaiya.cn"));
startActivity(intent);

2、采用WebView加载url

1)、在xml中添加一个WebView控件

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

2)、在Activity中定义这个控件并且设置基本参数

private WebView mWebView;
mWebView = (WebView) findViewById(R.id.webview);

3)、下方是WebView的基本设置

mWebView.setVerticalScrollBarEnabled(false);
mWebView.setHorizontalScrollBarEnabled(false);

WebSettings webSettings = mWebView.getSettings();
webSettings.setSupportZoom(true);
webSettings.setBuiltInZoomControls(true);
webSettings.setJavaScriptEnabled(true);
webSettings.setDomStorageEnabled(true);
mWebView.requestFocus();
if (Build.VERSION.SDK_INT > 8) {
    webSettings.setPluginState(PluginState.ON);
}
webSettings.setAllowFileAccess(true);
webSettings.setUseWideViewPort(true);
webSettings.setLoadWithOverviewMode(true);
webSettings.setCacheMode(WebSettings.LOAD_NO_CACHE);

mWebView.setWebViewClient(new WebViewClient() {
    @Override
    public void onPageStarted(WebView view, String url, Bitmap favicon) {
        super.onPageStarted(view, url, favicon);
        // 开始加载网页
    }

    @Override
    public void onPageFinished(WebView view, String url) {
        super.onPageFinished(view, url);
        // 网页正常加载结束
    }

    @Override
    public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) {
        super.onReceivedError(view, errorCode, description, failingUrl);
        // 网页加载出现问题
    }

    @Override
    public boolean shouldOverrideUrlLoading(WebView view, String url) {
        // 如果用户点击网页中的某个链接,会执行此方法
        // 比如点击类似“打开某个应用”的链接,你可以根据url判断出并且打开手机上的这个app
        // 而不是执行下述代码
        return super.shouldOverrideUrlLoading(view, url);
    }
});
mWebView.setWebChromeClient(new WebChromeClient() {
    @Override
    public void onShowCustomView(View view, CustomViewCallback callback) {
        super.onShowCustomView(view, callback);
    }

    @Override
    public void onHideCustomView() {
        super.onHideCustomView();
    }

    @Override
    public void onProgressChanged(WebView view, int newProgress) {
        super.onProgressChanged(view, newProgress);
        // 网页加载的进度,当前进度为newProgress,其值从0到100
    }
});

4)、加载一个网页

mWebView.loadUrl("http://www.kuaiya.cn");

3、广告

  • 手机如何连电脑?
  • 如何与电脑互发文件?
  • 如何与电脑互发文字?
  • 如何推送通知到电脑?
  • 电脑如何远程控制手机的相机?

快牙网传——全部搞定!

不想试试吗?
在豌豆荚等应用商店搜索“快牙网传“,或立即下载 Apk,也可以扫码下载。
这里写图片描述

### 使用 Kivy 中的 WebView 组件加载网页 Kivy本身并不直接提供名为`WebView`的组件,但是可以通过Python代码调用平台特定的功能来实现相同的效果。对于Android设备而言,可以利用Pyjnius库与底层API交互从而嵌入WebView[^1]。 为了在基于Kivy的应用程序里显示Web页面,在安卓平台上通常会采用如下方式: #### 安卓上的解决方案 通过 `plyer` 或者更底层的方式即借助 Pyjnius 来访问 Android 的原生控件。下面是一个简单的例子展示怎样创建一个包含WebView的小部件并加载指定URL: ```python from kivy.uix.boxlayout import BoxLayout from kivy.base import runTouchApp from jnius import autoclass, cast # 加载必要的 Java 类 Intent = autoclass('android.content.Intent') Uri = autoclass('android.net.Uri') # 创建布局容器 class MyBrowser(BoxLayout): def __init__(self, **kwargs): super(MyBrowser, self).__init__(**kwargs) PythonActivity = autoclass('org.kivy.android.PythonActivity').mActivity # 初始化 WebView 设置 WebView = autoclass('android.webkit.WebView') webView = WebView(PythonActivity) settings = webView.getSettings() settings.setJavaScriptEnabled(True) # 启用 JavaScript 支持 [^2] # 将 WebView 添加到当前活动窗口中 activity = PythonActivity mainLayout = activity.findViewById( autoclass('android.R$id').content) mainLayout.addView(webView) # 载入目标网址 urlToLoad = 'http://www.example.com' webView.loadUrl(urlToLoad) if __name__ == '__main__': runTouchApp(MyBrowser()) ``` 这段脚本展示了如何设置WebView以支持JavaScript,并将其添加至应用程序界面内,同时指定了要打开的具体网站地址。 需要注意的是上述方法适用于构建针对Android系统的应用;如果考虑跨平台开发,则可能需要寻找其他适合iOS或其他操作系统的替代方案,比如使用CEF(Chromium Embedded Framework)作为备选技术之一[^3]。 当涉及到全屏模式的支持时,如播放视频等内容,还需要额外处理一些事件监听器以及视图管理逻辑,确保用户体验良好[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值