Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone




VPS  250 ҷ͹

WebView - Android Widgets Example

WebView - Android Widgets สำหรับ WebView เป็น Widget ที่ใช้สำหรับการแสดงผลข้อมูลของเว็บไซต์ที่อยู่ในรูปแบบ URL ต่าง ๆ โดยจะใช้มุมมองของ Web Browser ที่อยู่ใน OS รุ่นนั้น ๆ

WebView - Android Widgets

XML Syntax
    <WebView
        android:id="@+id/webView1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" >
    </WebView>

Example 1 ตัวอย่างการแสดงผลจาก URL แบบง่าย ๆ

WebView - Android Widgets

ออกแบบหน้าจอ GraphicalLayout ด้วย Widget ตามรูป

activity_main.xml (XML Layout)
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

    <WebView
        android:id="@+id/webView1"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true" />

</RelativeLayout>


MainActivity.java (Java Code)
package com.myapp;

import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.webkit.WebView;


public class MainActivity extends Activity{

	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);

		WebView WebViw = (WebView) findViewById(R.id.webView1);
		WebViw.getSettings().setJavaScriptEnabled(true);
		WebViw.loadUrl("http://m.thaicreate.com");
		
	}

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.activity_main, menu);
        return true;
    }
    
}


คำอธิบาย
WebViw.getSettings().setJavaScriptEnabled(true);

สำหรับคำสั่งนี้เป็นการเปิดใช้งาน JavaScript

AndroidManifrst.xml
.
.
<uses-permission android:name="android.permission.INTERNET" />
.
.


WebView - Android Widgets

แก้ไขไฟล์ AndroidManifrst.xml ดังรูป

Screenshot

WebView - Android Widgets

แสดงข้อมูลใน WebView ซึ่งจะแสดงจาก URL ของ http://m.thaicreate.com





Example 2 ตัวอย่างการรับค่า URL ของเว็บไซต์ ผ่าน EditText จาก User

WebView - Android Widgets

ออกแบบหน้าจอ GraphicalLayout ด้วย Widget ตามรูป

activity_main.xml (XML Layout)
	<ViewSwitcher xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/viewSwitcher1"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent">
    	
	<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
	    xmlns:tools="http://schemas.android.com/tools"
	    android:id="@+id/tableLayout1"
	    android:layout_width="match_parent"
	    android:layout_height="match_parent"
	    android:layout_marginTop="50dp" >
	    
	    <TextView
		    android:id="@+id/textView1"
		    android:layout_width="wrap_content"
		    android:layout_height="wrap_content"
		   	android:gravity="center"
		    android:text="Enter Your Site" />

		<EditText
		    android:id="@+id/editText1"
		    android:layout_width="wrap_content"
		    android:layout_height="wrap_content"
		    android:ems="10" >

		</EditText>
		
			<RelativeLayout 
		        android:layout_width="fill_parent"
		        android:layout_height="wrap_content">
				<Button
				    android:id="@+id/button1"
				    android:layout_width="wrap_content"
				    android:layout_height="wrap_content"
				    android:layout_centerHorizontal="true"
			    android:text="Go" />
			</RelativeLayout>

     </TableLayout>
     
	<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
		    xmlns:tools="http://schemas.android.com/tools"
		    android:id="@+id/tableLayout2"
		    android:layout_width="match_parent"
		    android:layout_height="match_parent"
		    android:layout_marginTop="0dp" >
	    <WebView
	        android:id="@+id/webView1"
	        android:layout_width="match_parent"
	        android:layout_height="match_parent"/>  
	        
	</TableLayout>	

</ViewSwitcher>


MainActivity.java (Java Code)
package com.myapp;

import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.View;
import android.webkit.WebView;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ViewSwitcher;


public class MainActivity extends Activity{
	
	ViewSwitcher Vs;
	
	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);

        // viewSwitcher1
        Vs = (ViewSwitcher) findViewById(R.id.viewSwitcher1);
		
        // button1 (Go)
        Button btn1 = (Button) findViewById(R.id.button1);
        btn1.setOnClickListener(new View.OnClickListener() {
            public void onClick(View v) {
            	Vs.showNext();
                // editText1
            	EditText txtUrl = (EditText) findViewById(R.id.editText1);
            	// webView1
        		WebView WebViw = (WebView) findViewById(R.id.webView1);
				WebViw.getSettings().setJavaScriptEnabled(true);
        		WebViw.loadUrl(txtUrl.getText().toString());
            }
        });
		
	}

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.activity_main, menu);
        return true;
    }
    
}


Screenshot

WebView - Android Widgets

กรอก URLลงใน EditText แล้งคลิกที่ Go

WebView - Android Widgets

แสดงผลตาม URL ที่ได้ Input ลงไป






Example 3 การใช้ WebView แสดงผล Custom HTML คือสร้าง Format ของ HTML ขึ้นมาเอง

WebView - Android Widgets

ออกแบบหน้าจอ GraphicalLayout ด้วย Widget ตามรูป

activity_main.xml (XML Layout)
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
	    xmlns:tools="http://schemas.android.com/tools"
	    android:id="@+id/tableLayout1"
	    android:layout_width="match_parent"
	    android:layout_height="match_parent"
	    android:layout_marginTop="0dp" >
    <WebView
        android:id="@+id/webView1"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>  
        
</TableLayout>	



MainActivity.java (Java Code)
package com.myapp;

import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.webkit.WebView;


public class MainActivity extends Activity{
	
	
	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);

    	// webView1
		WebView WebViw = (WebView) findViewById(R.id.webView1);
		WebViw.getSettings().setJavaScriptEnabled(true);
		
		StringBuilder html = new StringBuilder();
		html.append("<html><body><h2><font color=\"red\">Sawatdee ThaiCreate.Com</font></h2>");

	   	WebViw.loadData(html.toString(), "text/html", "UTF-8");

	}
	

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.activity_main, menu);
        return true;
    }
    
}


Screenshot

WebView - Android Widgets

แสดงผลข้อมูลที่มาจาก Custom HTML





Example 4 การใช้ WebView แสดงผล Custom HTML และการใช้งาน JavaScriptInterface

WebViw.addJavascriptInterface(new JavaScriptInterface(this), "Android");


ในการใช้งาน Custom HTML จะต้องเรียกใช้ Property ของ addJavascriptInterface

WebView - Android Widgets

ออกแบบหน้าจอ GraphicalLayout ด้วย Widget ตามรูป

activity_main.xml (XML Layout)
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
	    xmlns:tools="http://schemas.android.com/tools"
	    android:id="@+id/tableLayout1"
	    android:layout_width="match_parent"
	    android:layout_height="match_parent"
	    android:layout_marginTop="0dp" >
    <WebView
        android:id="@+id/webView1"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>  
        
</TableLayout>	


MainActivity.java (Java Code)
package com.myapp;

import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.Menu;
import android.webkit.WebView;
import android.widget.Toast;


public class MainActivity extends Activity{
	
	@Override
	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);

    	// webView1
		WebView WebViw = (WebView) findViewById(R.id.webView1);
		WebViw.getSettings().setJavaScriptEnabled(true);
		WebViw.addJavascriptInterface(new JavaScriptInterface(this), "Android");
		
		StringBuilder html = new StringBuilder();
		html.append("<html><body><h2>Test WebView</h2>");
		html.append("<input type=\"text\" id=\"txtName\" />");
		html.append("<input type=\"button\" value=\"Say hello\" onClick=\"showAndroidToast(document.getElementById('txtName').value)\" />");

		html.append("<script type=\"text/javascript\">");
		html.append("    function showAndroidToast(toast) {");
		html.append("        Android.showToast(toast);");
		html.append("    }");
		html.append("</script>");
		
	   	WebViw.loadData(html.toString(), "text/html", "UTF-8");

	}
	
	public class JavaScriptInterface {
	    Context mContext;

	    /** Instantiate the interface and set the context */
	    JavaScriptInterface(Context c) {
	        mContext = c;
	    }

	    /** Show a toast from the web page */
	    public void showToast(String toast) {
	        Toast.makeText(mContext, toast, Toast.LENGTH_SHORT).show();
	    }
	}

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.activity_main, menu);
        return true;
    }
    
}


Screenshot

WebView - Android Widgets

แสดงผล Custom HTML ตามที่ได้สร้างขึ้น

WebView - Android Widgets

การทำงานรวมกับ JavaScript กับ Interface ของ Android






   
Share

Property & Method (Others Related)

Android Composite Widgets
ListView - Android Widgets Example
GridView - Android Widgets Example
ScrollView - Android Widgets Example
HorizontalScrollView - Android Widgets Example
SearchView - Android Widgets Example
SlidingDrawer - Android Widgets Example
TabWidget - Android Widgets Example
TabHost - Android Widgets Example

ช่วยกันสนับสนุนรักษาเว็บไซต์ความรู้แห่งนี้ไว้ด้วยการสนับสนุน Source Code 2.0 ของทีมงานไทยครีเอท


ลองใช้ค้นหาข้อมูล


   


Bookmark.   
       
  By : ThaiCreate.Com Team (บทความเป็นลิขสิทธิ์ของเว็บไทยครีเอทห้ามนำเผยแพร่ ณ เว็บไซต์อื่น ๆ)
  Score Rating :  
  Create/Update Date : 2012-07-01 16:17:04 / 2012-07-14 07:07:25
  Download : No files
 Sponsored Links / Related

 
Android Custom Adapter
Rating :

 
Android People Contact List, Name, Phone No, Photo Picture, Email and Address
Rating :

 
Android Rating (Vote) and ListView Part 1
Rating :

 
Android Rating (Vote) and ListView Part 2 (Member Login and Average Rating)
Rating :

 
Android PhoneGap (jQuery Mobile) Create Convert App from Website(URL)
Rating :

 
Android Capture Image and Camera Capture Screenshot (android.view.SurfaceView)
Rating :

 
Android Pull Down to Refresh And Release to Refresh or Update (Part 1)
Rating :

 
Android Pull Down to Refresh And Release to Update (Part 2 , PHP & MySQL)
Rating :


ThaiCreate.Com Forum




Comunity Forum Free Web Script
Jobs Freelance Free Uploads
Free Web Hosting Free Tools

สอน PHP ผ่าน Youtube ฟรี
สอน Android การเขียนโปรแกรม Android
สอน Windows Phone การเขียนโปรแกรม Windows Phone 7 และ 8
สอน iOS การเขียนโปรแกรม iPhone, iPad
สอน Java การเขียนโปรแกรม ภาษา Java
สอน Java GUI การเขียนโปรแกรม ภาษา Java GUI
สอน JSP การเขียนโปรแกรม ภาษา Java
สอน jQuery การเขียนโปรแกรม ภาษา jQuery
สอน .Net การเขียนโปรแกรม ภาษา .Net
Free Tutorial
สอน Google Maps Api
สอน Windows Service
สอน Entity Framework
สอน Android
สอน Java เขียน Java
Java GUI Swing
สอน JSP (Web App)
iOS (iPhone,iPad)
Windows Phone
Windows Azure
Windows Store
Laravel Framework
Yii PHP Framework
สอน jQuery
สอน jQuery กับ Ajax
สอน PHP OOP (Vdo)
Ajax Tutorials
SQL Tutorials
สอน SQL (Part 2)
JavaScript Tutorial
Javascript Tips
VBScript Tutorial
VBScript Validation
Microsoft Access
MySQL Tutorials
-- Stored Procedure
MariaDB Database
SQL Server Tutorial
SQL Server 2005
SQL Server 2008
SQL Server 2012
-- Stored Procedure
Oracle Database
-- Stored Procedure
SVN (Subversion)
แนวทางการทำ SEO
ปรับแต่งเว็บให้โหลดเร็ว


สุดยอด Source Code V2.0
 

แจ้งชำระเงิน/โอนเงิน
 

Hit Link
   


Acc : thaicreate@hotmail.com










Load balance : Server 03
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2017 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
for Contact Us : [Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 , 08-9968-0655 อัตราราคา คลิกที่นี่