zoukankan      html  css  js  c++  java
  • Android_WebView_全屏

    WebView(网络视图)能加载显示网页,能够将其视为一个浏览器。
    它使用了WebKit渲染引擎加载显示网页,实现WebView有下面两种不同的方法:
    第一种方法的步骤:
    1.在要Activity中实例化WebView组件:WebView webView = new WebView(this);
    2.调用WebView的loadUrl()方法。设置WevView要显示的网页:
      互联网用:webView.loadUrl("http://www.google.com"); 
      本地文件用:webView.loadUrl("file:///android_asset/XX.html"); 
      本地文件存放在:assets 文件里
    3.调用Activity的setContentView( )方法来显示网页视图
    4.用WebView点链接看了非常多页以后为了让WebView支持回退功能。
    须要覆盖覆盖Activity类的onKeyDown()方法,
    假设不做不论什么处理,点击系统回退剪键,整个浏览器会调用finish()而结束自身,而不是回退到上一页面
    5.须要在AndroidManifest.xml文件里加入权限。否则会出现Web page not available错误。

    <uses-permission android:name="android.permission.INTERNET" /> 另外一种方法的步骤: 1、在布局文件里声明WebView 2、在Activity中实例化WebView 3、调用WebView的loadUrl( )方法。设置WevView要显示的网页 4、为了让WebView能够响应超链接功能。调用setWebViewClient( )方法,设置 WebView视图 5、用WebView点链接看了非常多页以后为了让WebView支持回退功能, 须要覆盖覆盖Activity类的onKeyDown()方法,假设不做不论什么处理, 点击系统回退剪键,整个浏览器会调用finish()而结束自身,而不是回退到上一页面 6、须要在AndroidManifest.xml文件里加入权限,否则出现Web page not available错误。 <uses-permission android:name="android.permission.INTERNET"/> 浏览器控件是每一个开发环境都具备的。windows的有webBrowser, android和ios都有webView。

    仅仅是其引擎不同,相对于微软的webBrowser, android及ios的webview的引擎都是webkit。对Html5提供支持。

    本篇主要介绍android的webview之强大。 A. webview组件怎样使用 1) 加入权限:AndroidManifest.xml中必须使用许可"android.permission.INTERNET", 否则会出Web page not available错误。

    2) 在要Activity中生成一个WebView组件: WebView webView = new WebView(this); 或者能够在activity的layout文件里加入webview控件: <WebView android:id="@+id/wv" android:layout_width="fill_parent" android:layout_height="fill_parent" android:text="@string/hello" /> 3) 设置WebView基本信息: 假设訪问的页面中有Javascript,则webview必须设置支持Javascript。

    webview.getSettings().setJavaScriptEnabled(true); 触摸焦点起作用 requestFocus(); 取消滚动栏 this.setScrollBarStyle(SCROLLBARS_OUTSIDE_OVERLAY); 4) 设置WevView要显示的网页: 互联网用:webView.loadUrl("http://www.google.com"); 本地文件用:webView.loadUrl("file:///android_asset/XX.html"); 本地文件存放在:assets文件里 5) 假设希望点击链接由自己处理,而不是新开Android的系统browser中响应该链接。 给WebView加入一个事件监听对象(WebViewClient)并重写当中的一些方法: shouldOverrideUrlLoading:对网页中超链接button的响应。 当按下某个连接时WebViewClient会调用这种方法。 并传递參数:按下的url。比方当webview内嵌网页的某个数字被点击时, 它会自己主动觉得这是一个电话请求。会传递url:tel:123, 假设你不希望如此可通过重写shouldOverrideUrlLoading函数解决: 另外还有其它一些可重写的方法 1,接收到Http请求的事件 onReceivedHttpAuthRequest(WebView view, HttpAuthHandler handler, String host, String realm) 2,打开链接前的事件 public boolean shouldOverrideUrlLoading(WebView view, String url) { view.loadUrl(url); return true; } 这个函数我们能够做非常多操作,比方我们读取到某些特殊的URL。于是就能够不打开地址,取消这个操作。 进行预先定义的其它操作,这对一个程序是非常必要的。

    3,加载页面完毕的事件 public void onPageFinished(WebView view, String url){ } 相同道理。我们知道一个页面加载完毕。于是我们能够关闭loading条,切换程序动作。 4。加载页面開始的事件 public void onPageStarted(WebView view, String url, Bitmap favicon) { } 这个事件就是開始加载页面调用的,通常我们能够在这设定一个loading的页面。告诉用户程序在等待网络响应。

    通过这几个事件。我们能够非常轻松的控制程序操作,一边用着浏览器显示内容。 一边监控着用户操作实现我们须要的各种显示方式,同一时候能够防止用户产生误操作。 6) 假设用webview点链接看了非常多页以后,假设不做不论什么处理,点击系统“Back”键, 整个浏览器会调用finish()而结束自身。假设希望浏览的网页回退而不是退出浏览器, 须要在当前Activity中处理并消费掉该Back事件。 覆盖Activity类的onKeyDown(int keyCoder,KeyEvent event)方法。 B. Webview与js交互 Webview与js的双向交互才是android的webview强大所在 首先,webview能够定义一个在其内嵌页面中能够触发的事件 全屏代码 1、在AndroidManifest.xml的配置文件里面的<activity 里面加入: android:theme="@android:style/Theme.NoTitleBar.Fullscreen"//去掉状态栏及标题栏 2、在setContentView(R.layout.**)前面加入: this.requestWindowFeature(Window.FEATURE_NO_TITLE);//去掉标题栏 this.getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN);//去掉信息栏 //====================================================================== package com.example.webview; import android.os.Bundle; import android.app.Activity; import android.view.KeyEvent; import android.view.Menu; import android.view.Window; import android.view.WindowManager; import android.webkit.WebView; public class MainActivity extends Activity { private WebView webView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // 全屏代码 requestWindowFeature(Window.FEATURE_NO_TITLE); getWindow().setFlags(WindowManager.LayoutParams. FLAG_FULLSCREEN , WindowManager.LayoutParams. FLAG_FULLSCREEN); // setContentView(R.layout.activity_main); // 实例化一个webView webView = new WebView(this); // 设置WebView属性,能够运行Javascript脚本 webView.getSettings().setJavaScriptEnabled(true); // 全国重点城市空气质量排行榜, String url; //url = "http://tianqi.2345.com/air-rank.htm"; url="file:///android_asset/beauty4/beauty4.html"; // 加载目标url webView.loadUrl(url); // 设置webView为主视图 setContentView(webView); } @Override public boolean onKeyDown(int keyCode, KeyEvent event) { // 假设按下的是后退键。而且webview能够后退,则webview后退 if (keyCode==KeyEvent.KEYCODE_BACK && webView.canGoBack()) { webView.goBack(); return true; } //return super.onKeyDown(keyCode, event); // 退出程序 return true; } @Override public boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.main, menu); return true; } }


  • 相关阅读:
    [BFS]luogu P2536 [AHOI2005]病毒检测
    AtCoder Regular Contest 116 总结
    NOI online 2021 #1 总结
    博客半复活
    vue2 Bus兄弟组件间传值问题:重复触发和首次未触发
    ant design中table组件的filter,如何在外部控制
    ant design vue 日期排序
    什么是断点续传?前端如何实现文件的断点续传
    主vue前端面试题补充
    P4248 [AHOI2013]差异 题解
  • 原文地址:https://www.cnblogs.com/brucemengbm/p/6733515.html
Copyright © 2011-2022 走看看