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



Clound SSD Virtual Server

Android Google Map : Marker Location from PHP/MySQL (JSON)

Android Google Map : Marker Location from PHP/MySQL (JSON) ในบทความนี้จะเป็นตัวอย่างเขียน Android App กับ Google Map API ในการปักหมุด (Marker) ต่ำแหน่ง Location จาก MySQL Database จะใช้การอ่านข้อมูลจาก HTTP จากฝั่ง Web Server ซึ่งจะมี PHP ทำหน้าที่อ่านข้อมูลจาก MySQL Database ให้อยู่ในรูปแบบของ JSON โดยรูปแบบการทำงานคือ เมื่อมีการ Request ค่าจาก Android ผ่าน URL ของ Web Server ทาง Server จะมีการรับ-ส่งค่าในรูปแบบของ JSON มายัง Android App เมื่อ Android ได้ค่า JSON ก็จะนำค่าที่ประกอบด้วย Latitude, Longitude และ LocationName มาปักหมุดลงใน Google App



Android Google Map : Marker Location from PHP/MySQL (JSON)


สำหรับตัวอย่างและ Code นี้รองรับการเขียนทั้งบนโปรแกรม Eclipse และ Android Studio

ใน AndroidManifest.xml เพิ่ม Permission ดังนี้
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="com.google.android.providers.gsf.permission.READ_GSERVICES" />
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />


รูปแบบการ Marker Location บน Google Map ในหลายๆ ตำแหน่ง

การอ่านข้อมูลจาก JSON และจัดเก็บลงใน ArrayList
ArrayList<HashMap<String, String>> location = null;
String url = "https://www.thaicreate.com/android/getLatLon.php";

JSONArray data = new JSONArray(getHttpGet(url));

location = new ArrayList<HashMap<String, String>>();
HashMap<String, String> map;

for(int i = 0; i < data.length(); i++){
	JSONObject c = data.getJSONObject(i);

	map = new HashMap<String, String>();
	map.put("LocationID", c.getString("LocationID"));
	map.put("Latitude", c.getString("Latitude"));
	map.put("Longitude", c.getString("Longitude"));
	map.put("LocationName", c.getString("LocationName"));
	location.add(map);
}

การลูปข้อมูลและปักหมุด (Marker) ลงใน Google Map
for (int i = 0; i < location.size(); i++) {
	Latitude = Double.parseDouble(location.get(i).get("Latitude").toString());
	Longitude = Double.parseDouble(location.get(i).get("Longitude").toString());
	String name = location.get(i).get("LocationName").toString();
	MarkerOptions marker = new MarkerOptions().position(new LatLng(Latitude, Longitude)).title(name);
	googleMap.addMarker(marker);
}


ไฟล์ต่าง ๆ ที่เกี่ยวข้อง ประกอบด้วย MySQL Table และ PHP

Table : location
CREATE TABLE IF NOT EXISTS `location` (
  `LocationID` int(11) NOT NULL,
  `Latitude` varchar(50) NOT NULL,
  `Longitude` varchar(50) NOT NULL,
  `LocationName` varchar(255) NOT NULL
) ENGINE=MyISAM DEFAULT CHARSET=tis620;

--
-- Dumping data for table `location`
--

INSERT INTO `location` (`LocationID`, `Latitude`, `Longitude`, `LocationName`) VALUES
(1, '13.860633', '100.612155', 'Ladplakao 76'),
(2, '13.858747', '100.610996', 'Ladplakao 70'),
(3, '13.863903', '100.614343', 'Ladplakao 80'),
(4, '13.861122', '100.611988', 'Ladplakao 89');

โครสร้างของตาราง location

Android Google Map : Marker Location from PHP/MySQL (JSON)








getLatLon.php : ไฟล์ php สำหรับอ่านข้อมูลจากตารางเพื่อแปลงเป็น JSON
<?php
	$objConnect = mysql_connect("localhost","root","root");
	$objDB = mysql_select_db("mydatabase");

	$strSQL = "SELECT * FROM `location`  ORDER BY LocationID  ASC ";

	$objQuery = mysql_query($strSQL) or die(mysql_error());
	$arrRows = array();
	$arryItem = array();
	while($arr = mysql_fetch_array($objQuery)) {
		$arryItem["LocationID"] = $arr["LocationID"];
		$arryItem["Latitude"] = $arr["Latitude"];
		$arryItem["Longitude"] = $arr["Longitude"];
		$arryItem["LocationName"] = $arr["LocationName"];
		$arrRows[] = $arryItem;
	}
		
echo json_encode($arrRows);
?>

JSON Result
[ {"LocationID":"1","Latitude":"13.860633","Longitude":"100.612155","LocationName":"Ladplakao 76"}, {"LocationID":"2","Latitude":"13.858747","Longitude":"100.610996","LocationName":"Ladplakao 70"}, {"LocationID":"3","Latitude":"13.863903","Longitude":"100.614343","LocationName":"Ladplakao 80"}, {"LocationID":"4","Latitude":"13.861122","Longitude":"100.611988","LocationName":"Ladplakao 89"} ]


Example : ตัวอย่างการเขียน Android App เพื่ออ่านข้อมูลจาก JSON และปักหมุด Marker ลงบน Google Map

Android Google Map : Marker Location from PHP/MySQL (JSON)

activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<fragment xmlns:android="http://schemas.android.com/apk/res/android"
          android:id="@+id/googleMap"
          android:layout_width="fill_parent"
          android:layout_height="fill_parent"
          android:name="com.google.android.gms.maps.SupportMapFragment"/>


MainActivity.java
package com.myapp;

import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.SupportMapFragment;
import com.google.android.gms.maps.model.LatLng;
import com.google.android.gms.maps.model.MarkerOptions;

import android.os.Bundle;
import android.os.StrictMode;
import android.support.v4.app.FragmentActivity;
import android.util.Log;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.HashMap;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.StatusLine;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.DefaultHttpClient;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import com.google.android.gms.maps.CameraUpdateFactory;

public class MainActivity extends FragmentActivity {

	// Google Map
	private GoogleMap googleMap;

	// Latitude & Longitude
	private Double Latitude = 0.00;
	private Double Longitude = 0.00;

	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);

        //*** Permission StrictMode
        if (android.os.Build.VERSION.SDK_INT > 9) {
            StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();
            StrictMode.setThreadPolicy(policy);
        }
        
		ArrayList<HashMap<String, String>> location = null;
        String url = "https://www.thaicreate.com/android/getLatLon.php";
		try {
			
			JSONArray data = new JSONArray(getHttpGet(url));
			
			location = new ArrayList<HashMap<String, String>>();
			HashMap<String, String> map;
			
			for(int i = 0; i < data.length(); i++){
                JSONObject c = data.getJSONObject(i);
             			
    			map = new HashMap<String, String>();
    			map.put("LocationID", c.getString("LocationID"));
    			map.put("Latitude", c.getString("Latitude"));
    			map.put("Longitude", c.getString("Longitude"));
    			map.put("LocationName", c.getString("LocationName"));
    			location.add(map);
    			
			}	        
			
		} catch (JSONException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		

		// *** Display Google Map
		googleMap = ((SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.googleMap)).getMap();

		// *** Focus & Zoom
		Latitude = Double.parseDouble(location.get(0).get("Latitude").toString());
		Longitude = Double.parseDouble(location.get(0).get("Longitude").toString());
		LatLng coordinate = new LatLng(Latitude, Longitude);
		googleMap.setMapType(com.google.android.gms.maps.GoogleMap.MAP_TYPE_HYBRID);
		googleMap.animateCamera(CameraUpdateFactory.newLatLngZoom(coordinate, 17));

		// *** Marker (Loop)
		for (int i = 0; i < location.size(); i++) {
			Latitude = Double.parseDouble(location.get(i).get("Latitude").toString());
			Longitude = Double.parseDouble(location.get(i).get("Longitude").toString());
			String name = location.get(i).get("LocationName").toString();
			MarkerOptions marker = new MarkerOptions().position(new LatLng(Latitude, Longitude)).title(name);
			googleMap.addMarker(marker);
		}

	}

	public static String getHttpGet(String url) {
		StringBuilder str = new StringBuilder();
		HttpClient client = new DefaultHttpClient();
		HttpGet httpGet = new HttpGet(url);
		try {
			HttpResponse response = client.execute(httpGet);
			StatusLine statusLine = response.getStatusLine();
			int statusCode = statusLine.getStatusCode();
			if (statusCode == 200) { // Download OK
				HttpEntity entity = response.getEntity();
				InputStream content = entity.getContent();
				BufferedReader reader = new BufferedReader(new InputStreamReader(content));
				String line;
				while ((line = reader.readLine()) != null) {
					str.append(line);
				}
			} else {
				Log.e("Log", "Failed to download result..");
			}
		} catch (ClientProtocolException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}
		return str.toString();
	}
	
}









จาก Code นี้จะเป็นการอ่าน Location จาก JSON เก็บลงใน ArrayList จากนั้นค่อยมา Loop เพื่อปักหมุดลงใน Google Map

Screenshot

Android Google Map : Marker Location from PHP/MySQL (JSON)

การปักหมุดในหลาย ๆ ตำแหน่ง จาก Location ที่ได้จาก PHP/MySQL (JSON)

   
Share


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


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


   


Bookmark.   
       
  By : ThaiCreate.Com Team (บทความเป็นลิขสิทธิ์ของเว็บไทยครีเอทห้ามนำเผยแพร่ ณ เว็บไซต์อื่น ๆ)
  Score Rating :  
  Create/Update Date : 2015-11-21 22:52:22 / 2017-03-26 21:17:38
  Download : No files
 Sponsored Links / Related

 
Android Google Map (Step by Step)
Rating :

 
Android Google Map : Focus, Zoom Level , Map Type
Rating :

 
Android Google Map : Change Map Type (Normal, Satellite, Hybrid and Terrain)
Rating :

 
Android Google Map : Check Enabled Location Services
Rating :

 
Android Google Map : Get Current Location (Latitude, Longitude)
Rating :

 
Android Google Map : Marker Location (Latitude , Longitude)
Rating :

 
Android Google Map : Adding Multiple Marker (Latitude, Longitude)
Rating :

 
Android Google Map : Marker from Current Location (LocationChanged)
Rating :

 
Android Google Map : Get Address Name from Latitude,Longitude (Geocoder)
Rating :

 
Android Google Map : Search and Find Location
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
   







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