android 下 利用webview實現瀏覽器功能

android 下 利用webview實現瀏覽器功能(一):android

 

一、界面添加WEBVIEW控件。web

二、在界面.JAVA代碼頁面(protected void onCreate(Bundle savedInstanceState) 方法中)添加以下代碼:瀏覽器

//#region
WebView wb=(WebView)findViewById(R.id.Wb_Main);
//設置WebView屬性,可以執行Javascript腳本 
wb.getSettings().setJavaScriptEnabled(true);
//加載須要顯示的網頁 
wb.loadUrl("http://www.baidu.com");
//設置web視圖
//當用戶點擊了你的WebView中的一個連接,默認的行爲是Android啓動一個處理URL的應用,一般,默認的瀏覽器打開並下載目標URL。可是,你能夠在你的WebView中覆蓋這一行爲,使得鏈接仍在你的WebView中打開。
wb.setWebViewClient(new WebViewClient());
//#endregion

 

 

三、設置配置文件並添加代碼app

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.hi"
android:versionCode="1"
android:versionName="1.0" >

<uses-sdk
android:minSdkVersion="18"
android:targetSdkVersion="18" />

<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" 
>
<activity
android:name=".MainActivity"
android:label="@string/app_name" android:theme="@android:style/Theme.NoTitleBar.Fullscreen">
<intent-filter>
<action android:name="android.intent.action.MAIN" />

<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>

</application>
<uses-permission android:name="android.permission.INTERNET"/> 
</manifest>

 

 

 

------------------------------------------------ide

一般咱們在製做瀏覽器客戶端時候會遇到以下問題:佈局

一、如何讓WEBVIEW全屏?this

  找到佈局界面,找到主窗體對象,清除PADDING等間距值便可。url

二、如何取消頂部頭?spa

  找到配置文件,選擇APPLICATION選項卡,進入APPLIACATION NODE佈局部分,右側詳見theme節點,選擇「@android:style/Theme.NoTitleBar.Fullscreen」值便可。code

 

 

----------------------------------------------

完成如上操做及步驟便可實現ANDROID的瀏覽器客戶端。

/****************************************************************************************************************************/

android 下 利用webview實現瀏覽器功能(二):

以下爲總體代碼,並附帶實現加載網頁頁面時的事件。

 1 package com.example.hi;
 2 
 3 import android.app.Activity;
 4 import android.app.ProgressDialog;
 5 import android.os.Bundle;
 6 import android.view.Menu;
 7 import android.view.MenuItem;
 8 import android.view.View;
 9 import android.view.Window;
10 import android.webkit.WebView;
11 import android.webkit.WebViewClient;
12 import android.widget.TextView;
13 import android.widget.Toast;
14 
15 public class MainActivity extends Activity {
16 
17 ProgressDialog dialog = null; 
18 WebView wb = null; 
19 TextView txv=null;
20 
21 @Override
22 protected void onCreate(Bundle savedInstanceState) {
23 super.onCreate(savedInstanceState);
24 setContentView(R.layout.activity_main);
25 //Toast.makeText(this, "Will Loading!", Toast.LENGTH_LONG).show();
26 
27 //#region /20151007/WEB載入
28 wb=(WebView)findViewById(R.id.Wb_Main);
29 txv=(TextView)findViewById(R.id.Txv_States);
30 //設置WebView屬性,可以執行Javascript腳本 
31 wb.getSettings().setJavaScriptEnabled(true);
32 //設置web視圖
33 //當用戶點擊了你的WebView中的一個連接,默認的行爲是Android啓動一個處理URL的應用,一般,默認的瀏覽器打開並下載目標URL。可是,你能夠在你的WebView中覆蓋這一行爲,使得鏈接仍在你的WebView中打開。
34 wb.setWebViewClient(new WebViewClient()
35 {
36 @Override
37 public void onPageFinished(WebView view,String url)
38 {
39 txv.setVisibility(View.GONE);
40 
41 //#region /對話框式的顯示與消失
42 //dialog = ProgressDialog.show(this,null,"數據加載中,請稍後...");
43 //dialog.dismiss();
44 //#endregion
45 }
46 });
47 
48 loadUrl("http://www.baidu.com");
49 //#endregion
50 }
51 
52 //#region /20151007/URL載入方法並附帶載入狀態處理
53 public void loadUrl(String url)
54 {
55 if(wb != null)
56 {
57 txv.setVisibility(View.VISIBLE);
58 wb.reload();
59 wb.loadUrl(url);
60 }
61 }
62 //#endregion
63 
64 @Override
65 public boolean onCreateOptionsMenu(Menu menu) {
66 // Inflate the menu; this adds items to the action bar if it is present.
67 getMenuInflater().inflate(R.menu.main, menu);
68 return true;
69 }
70 
71 @Override
72 public boolean onOptionsItemSelected(MenuItem item) {
73 // Handle action bar item clicks here. The action bar will
74 // automatically handle clicks on the Home/Up button, so long
75 // as you specify a parent activity in AndroidManifest.xml.
76 int id = item.getItemId();
77 if (id == R.id.action_settings) {
78 return true;
79 }
80 return super.onOptionsItemSelected(item);
81 }
82 }
相關文章
相關標籤/搜索