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 (Latitude , Longitude)

Android Google Map : Marker Location (Latitude, Longitude) ในหัวข้อนี้เราจะมารู้วิธีการ Marker (ปักหมุด) Location ลงใน Google Map ด้วย Android App จะเป็นวิธีการระบุตำแหน่งหรือพิกัด Location ที่เราต้องการะทำเป็นสัญลักษณ์ โดยตำแหน่งที่จะปักหมุด (Marker) นั้นเราจะอ้างจากค่า Latitude, Longitude นอกจากจะปักหมุดแล้วเรายังสามารถเพิ่ม Tooltip หรือคำอธิบายลงในแต่ล่ะหมุดได้ ส่วนจำนวนที่สามารถจะปักหมุดได้ลงนั้น ขึ้นอยู่กับ API ที่จะเรียกใช้งานว่าใน API Key นั้น ๆ รองรับได้กี่จุด



Android Google Map : Marker Location (Latitude, Longitude)


สำหรับตัวอย่างและ 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

Marker Syntax
MarkerOptions marker = new MarkerOptions().position(new LatLng(Latitude, Longitude)).title(toolTip);
googleMap.addMarker(marker);

ในการ Maker Location บน Google Map สามารถใช้คำสั่ง addMarker(marker) ซึ่งรองรับการปักหมุดได้ในหลาย ๆ ตำแหน่ง (จำกัดอยู่ที่ API ว่าได้กี่ตำแหน่ง) อีกทั้งยังสามารถใส่ Tooltip ลงใน Marker ได้อีกด้วย

Example 1 : ตัวอย่างการเขียน Android App ปักหมุดหรือ Mark Location จาก Latitude และ Longitude

Android Google Map : Marker Location (Latitude, Longitude)

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.support.v4.app.FragmentActivity;

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);	
		
		Latitude = 13.844205;
		Longitude = 100.598856;
		
		if(Latitude > 0 && Longitude > 0)
		{
            //*** Display Google Map
            googleMap = ((SupportMapFragment)getSupportFragmentManager()
                    .findFragmentById(R.id.googleMap)).getMap(); 
            
            //*** Focus & Zoom
            LatLng coordinate = new LatLng(Latitude, Longitude);
            googleMap.setMapType(com.google.android.gms.maps.GoogleMap.MAP_TYPE_HYBRID);
            googleMap.animateCamera(CameraUpdateFactory.newLatLngZoom(coordinate, 17));
            
            //*** Marker
            String toolTip = String.format("Your Location Lat=%s, Lon=%s", Latitude,Longitude);
            MarkerOptions marker = new MarkerOptions().position(new LatLng(Latitude, Longitude)).title(toolTip);
            googleMap.addMarker(marker);

		}

	}

}









Screenshot

Android Google Map : Marker Location (Latitude, Longitude)

แสดงตำแหน่งที่ Marker (ปักหมุด)

กรณีต้องการเปลี่ยนสีของหมุด
            String toolTip = String.format("Your Location Lat=%s, Lon=%s", Latitude,Longitude);
            MarkerOptions marker = new MarkerOptions().position(new LatLng(Latitude, Longitude)).title(toolTip);
            marker.icon(BitmapDescriptorFactory.defaultMarker(BitmapDescriptorFactory.HUE_BLUE));
            googleMap.addMarker(marker);

Android Google Map : Marker Location (Latitude, Longitude)

ตัวอย่างการเปลี่ยนสีของหมุดเป็นน้ำเงิน

Android Google Map : Marker Location (Latitude, Longitude)

นอกจากนี้ยังสามารถเปลี่ยนเป็นสีอื่น ๆ ได้อีกมากมาย



Example 2 : การเปลี่ยนรูปภาพ (Image) ของหมุด (Marker) ที่จะปักลงบน Map

Android Google Map : Marker Location (Latitude, Longitude)

รูปภาพของหมุดแนะนำให้เป็น .png

Android Google Map : Marker Location (Latitude, Longitude)

จัดเก็บลงใน drawable

Syntax
            //*** Marker
            String toolTip = String.format("Your Location Lat=%s, Lon=%s", Latitude,Longitude);
            MarkerOptions marker = new MarkerOptions().position(new LatLng(Latitude, Longitude)).title(toolTip);
            marker.icon(BitmapDescriptorFactory.fromResource(R.drawable.marker));
            googleMap.addMarker(marker);


Screenshot

Android Google Map : Marker Location (Latitude, Longitude)

หมุด (Marker) ใหม่ที่ได้







.

   
Share


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


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


   


Bookmark.   
       
  By : ThaiCreate.Com Team (บทความเป็นลิขสิทธิ์ของเว็บไทยครีเอทห้ามนำเผยแพร่ ณ เว็บไซต์อื่น ๆ)
  Score Rating :  
  Create/Update Date : 2015-11-21 22:50:44 / 2017-03-26 21:15:40
  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 : 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 :

 
Android Google Map : Marker Location from PHP/MySQL (JSON)
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
ปรับแต่งเว็บให้โหลดเร็ว


Hit Link
   







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