自定义WebView
如题,本文将介绍如何自定义WebView来加载指定URL,主要实现以下两点
- 获取URL地址并启动隐式Intent的调用
- 自定义WebView来加载URL
接着解释一下web view的作用及方法:
WebView可以使得网页轻松的内嵌到app里,还可以直接跟js相互调用。
webview有两个方法:setWebChromeClient 和 setWebClient
setWebClient:主要处理解析,渲染网页等浏览器做的事情
setWebChromeClient:辅助WebView处理Javascript的对话框,网站图标,网站title,加载进度等
WebViewClient就是帮助WebView处理各种通知、请求事件的。
下面是具体代码:
activi_main.xml:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context="hua.com.webviewtest.MainActivity">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
>
<EditText
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textSize="20sp"
android:hint="输入网址"
android:layout_weight="1"
android:id="@+id/et_url"
/>
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="访问"
android:id="@+id/btn_go"
/>
</LinearLayout>
<WebView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/my_webView"
>
</WebView>
</LinearLayout>
MyWebView:
package hua.com.webviewtest;
import android.net.Uri;
import android.os.Bundle;
import android.os.PersistableBundle;
import android.support.annotation.Nullable;
import android.support.v7.app.AppCompatActivity;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
/**
* Created by qinghua on 2017/4/18.
*/
public class MyWebView extends AppCompatActivity {
private WebView webView;
private String url;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.myview_layout);
initView();
setWebView();
}
private void initView() {
webView= (WebView) findViewById(R.id.webView);
url=getIntent().getData().toString();
}
private void setWebView() {
WebSettings webSettings=webView.getSettings();
webSettings.setJavaScriptEnabled(true);
webSettings.setSupportZoom(true);
webView.loadUrl(url);
webView.setWebViewClient(new WebViewClient(){
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
webView.loadUrl(url);
return true;
}
});
}
}
MainActivity
package hua.com.webviewtest;
import android.content.Intent;
import android.net.Uri;
import android.support.v4.app.NotificationCompat;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.webkit.WebResourceRequest;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.Button;
import android.widget.EditText;
public class MainActivity extends AppCompatActivity implements View.OnClickListener{
private Button btn_go;
private EditText et_url;
private String urlHead="http://";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
}
private void initView() {
btn_go= (Button) findViewById(R.id.btn_go);
et_url= (EditText) findViewById(R.id.et_url);
btn_go.setOnClickListener(this);
}
@Override
public void onClick(View view) {
switch (view.getId()){
case R.id.btn_go:
Intent intent=new Intent(Intent.ACTION_VIEW);
intent.setData(Uri.parse(urlHead+et_url.getText().toString()));
Intent choose=Intent.createChooser(intent,"选择一个浏览器");
startActivity(choose);
break;
}
}
}
具体运行截图
- 输入网址
- 选择浏览器
- 成功访问该网站
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。