iOS/iPhone Map View (MKMapView) Longitude , Latitude Example (iPhone,iPad) |
iOS/iPhone Map View (MKMapView) Longitude , Latitude Example (iPhone,iPad) บทความนี้จะเป็นการสร้าง Map บน iOS แสดงผบน iPhone หรือ iPad ด้วยการใช้ Object ที่มีชื่อว่า Map View โดย Map View จะใการเรียกใช้ Class ของ MKMapView ซึ่งเป็น Framework ของ MapKit.Framework และก่อนที่เราจะเขียนโปรแกรมบน Xcode เพื่อแสดง Map จะต้องทำการเพิ่ม Framework ตัวนี้เข้ามาด้วย
iOS/iPhone Map View (MKMapView) Example
ในตัวอย่างจะมีอยู่ 2 ส่วนคือ จะได้เรียนรู้การแสดง Map บนหน้าจอ ด้วย Map View (MKMapView) และการปักหมุดลงใน Map ด้วยการอ้างอิงจากตำแหน่งของ Longitude และ Latitude ซึ่งวิธีการต่าง ๆ ไม่ยากซับซ้อนเท่าไหร่ และเขียน Code ไม่กี่บรรทัด
Example การสร้าง Map และปัดหมุดลงใน Map ด้วยการอ้างอิงจากตำแหน่งของ Longitude และ Latitude
data:image/s3,"s3://crabby-images/794c3/794c301713f61793c12131d5ed60ca6aa040d0a7" alt="iOS/iPhone Map View (MKMapView) Example iOS/iPhone Map View (MKMapView) Example"
เริ่มต้นด้วยการสร้าง Project บน Xcode แบบง่าย ๆ ด้วย Single View Application
data:image/s3,"s3://crabby-images/e81c4/e81c46b541fc1110441b6f84457838ac1cb5cb03" alt="iOS/iPhone Map View (MKMapView) Example iOS/iPhone Map View (MKMapView) Example"
เลือกและไม่เลือกรายการดังรูป
data:image/s3,"s3://crabby-images/d6260/d6260c0d135ff6b046314cb4e9048ccedc177611" alt="iOS/iPhone Map View (MKMapView) Example iOS/iPhone Map View (MKMapView) Example"
ในการเขียนเพื่อเรียกใช้ Map เราจะใช้ Framework ของ MapKit ขั้นแรกให้คลิกที่ Project หลัก
data:image/s3,"s3://crabby-images/444b0/444b0940920b78b548d4566947f352d3bb6d4822" alt="iOS/iPhone Map View (MKMapView) Example iOS/iPhone Map View (MKMapView) Example"
เลื่อนมาข้าล่าง ๆ จะเห็นว่าตอนนี้เรามี Framework อยู่ 3 ตัว ที่ถูกใช้งานบน Project
data:image/s3,"s3://crabby-images/0dbdd/0dbdd5ba10bc19e42a178efb52d1d176956f6e9e" alt="iOS/iPhone Map View (MKMapView) Example iOS/iPhone Map View (MKMapView) Example"
ให้คลิกที่เครื่องหมายบวก (+)
data:image/s3,"s3://crabby-images/d9615/d9615eeab1b242c95505496e0bcdce2f01ee8591" alt="iOS/iPhone Map View (MKMapView) Example iOS/iPhone Map View (MKMapView) Example"
ค้นหา Framework ที่ชื่อว่า Map จะปรากฏ MapKit.framework ให้เลือก Add จากนั้นก็เสร็จสิ้นขั้นตอนการเพิ่ม Framework
data:image/s3,"s3://crabby-images/5f5f4/5f5f4842c4a355d6c13bdda9bdcb1ce6e434fd71" alt="iOS/iPhone Map View (MKMapView) Example iOS/iPhone Map View (MKMapView) Example"
กลับมายัง View หลักตอนนี้ยังว่าง ๆ ไม่มี Object ใด ๆ ทั้งสิ้น
data:image/s3,"s3://crabby-images/1ff1d/1ff1de602f8b1888b6d732cd98ca876a7319760d" alt="iOS/iPhone Map View (MKMapView) Example iOS/iPhone Map View (MKMapView) Example"
ให้เราลาก Object ที่มีชื่อว่า Map View มาวางไว้ในหน้าจอ Interface ของ View
data:image/s3,"s3://crabby-images/140d0/140d0768af0d05809a635f46e60bda39490acdd8" alt="iOS/iPhone Map View (MKMapView) Example iOS/iPhone Map View (MKMapView) Example"
ทำการ import ไฟล์ ประกาศ และเชื่อม IBOutlet ดังรูป
data:image/s3,"s3://crabby-images/3e4a1/3e4a1da4484521765b9997f40cb7931ee791d408" alt="iOS/iPhone Map View (MKMapView) Example iOS/iPhone Map View (MKMapView) Example"
เนื่องจากเราจะทำปัดหมุดและจัดการตำแหน่งบนลงบน Map ให้เรา New File ของ Class ขึ้นมา 1 ตัว
data:image/s3,"s3://crabby-images/66fe5/66fe5a521b08f4b47f3a7c1387cfe0e759a76664" alt="iOS/iPhone Map View (MKMapView) Example iOS/iPhone Map View (MKMapView) Example"
เลือก Objective-C Class
data:image/s3,"s3://crabby-images/592e5/592e58f10bde87db40a5cb9d9a9ae2da8bf5c1a5" alt="iOS/iPhone Map View (MKMapView) Example iOS/iPhone Map View (MKMapView) Example"
เลือก Subclass เป็น NSObject
data:image/s3,"s3://crabby-images/3aff3/3aff344d28e0435147c7ef5bcc6ff634425e779c" alt="iOS/iPhone Map View (MKMapView) Example iOS/iPhone Map View (MKMapView) Example"
ได้ Class ขึ้นมาอีก 1 ชุด
ไฟล์ DisplayMap.h
data:image/s3,"s3://crabby-images/6437a/6437a0f5bbfb33070a7d37221fda3784ab7deef7" alt="iOS/iPhone Map View (MKMapView) Example iOS/iPhone Map View (MKMapView) Example"
ไฟล์ DisplayMap.m
data:image/s3,"s3://crabby-images/e29cf/e29cf5a278d40846204a0f37fc9aff982a400a2b" alt="iOS/iPhone Map View (MKMapView) Example iOS/iPhone Map View (MKMapView) Example"
Code ทั้งหมดของ .h และ .m ในภาษา Objective-C
DisplayMap.h
//
// DisplayMap.h
// mapViewApp
//
// Created by Weerachai on 11/10/55 BE.
// Copyright (c) 2555 Weerachai. All rights reserved.
//
#import <Foundation/Foundation.h>
#import <MapKit/MKAnnotation.h>
@interface DisplayMap : NSObject <MKAnnotation> {
CLLocationCoordinate2D coordinate;
NSString *title;
NSString *subtitle;
}
@property (nonatomic, assign) CLLocationCoordinate2D coordinate;
@property (nonatomic, copy) NSString *title;
@property (nonatomic, copy) NSString *subtitle;
@end
DisplayMap.m
//
// DisplayMap.m
// mapViewApp
//
// Created by Weerachai on 11/10/55 BE.
// Copyright (c) 2555 Weerachai. All rights reserved.
//
#import "DisplayMap.h"
@implementation DisplayMap
@synthesize coordinate,title,subtitle;
-(void)dealloc{
[title release];
[super dealloc];
}
@end
ViewController.h
//
// ViewController.h
// mapViewApp
//
// Created by Weerachai on 11/10/55 BE.
// Copyright (c) 2555 Weerachai. All rights reserved.
//
#import <UIKit/UIKit.h>
#import <MapKit/MapKit.h>
@interface ViewController : UIViewController <MKMapViewDelegate>
{
IBOutlet MKMapView *mapview;
}
@property (retain, nonatomic) IBOutlet MKMapView *mapview;
@end
ViewController.m
//
// ViewController.m
// mapViewApp
//
// Created by Weerachai on 11/10/55 BE.
// Copyright (c) 2555 Weerachai. All rights reserved.
//
#import "ViewController.h"
#import "DisplayMap.h"
@interface ViewController ()
@end
@implementation ViewController
@synthesize mapview;
- (void)viewDidLoad
{
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
[mapview setMapType:MKMapTypeStandard];
[mapview setZoomEnabled:YES];
[mapview setScrollEnabled:YES];
MKCoordinateRegion region = { {0.0, 0.0 }, { 0.0, 0.0 } };
region.center.latitude = 13.815941829272814;
region.center.longitude = 100.56098341941833;
region.span.longitudeDelta = 0.01f;
region.span.latitudeDelta = 0.01f;
[mapview setRegion:region animated:YES];
[mapview setDelegate:self];
DisplayMap *ann = [[DisplayMap alloc] init];
ann.title = @" เซ็นทรัล ลาดพร้าว";
ann.subtitle = @"เลขที่ 1693 ถนนพหลโยธิน เขตจตุจักร กรุงเทพมหานคร";
ann.coordinate = region.center;
[mapview addAnnotation:ann];
}
- (void)didReceiveMemoryWarning
{
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}
- (void)dealloc {
[mapview release];
[super dealloc];
}
@end
จาก Code ลองไล่ดูแล้วไม่ยากครับ เป็นเพียงการแสดงตำแหน่งปักหมุดจากค่า Longitude และ Latitude
Screenshot
data:image/s3,"s3://crabby-images/6ce68/6ce683d927c7b7660b26beba164d6bce28d0b37f" alt="iOS/iPhone Map View (MKMapView) Example iOS/iPhone Map View (MKMapView) Example"
แสดง Map และมีการปักหมุดลงบน Map โดยอ้างถึงจากตำแหน่งของ Longitude และ Latitude
.
|
ช่วยกันสนับสนุนรักษาเว็บไซต์ความรู้แห่งนี้ไว้ด้วยการสนับสนุน Source Code 2.0 ของทีมงานไทยครีเอท
|
|
|
By : |
ThaiCreate.Com Team (บทความเป็นลิขสิทธิ์ของเว็บไทยครีเอทห้ามนำเผยแพร่ ณ เว็บไซต์อื่น ๆ) |
|
Score Rating : |
data:image/s3,"s3://crabby-images/2d4e3/2d4e35bc4c7324f7288ea00d29262acd856e7488" alt="" data:image/s3,"s3://crabby-images/2d4e3/2d4e35bc4c7324f7288ea00d29262acd856e7488" alt="" |
|
|
Create/Update Date : |
2012-11-13 16:44:57 /
2017-03-26 00:01:35 |
|
Download : |
|
|
Sponsored Links / Related |
|
|
|
|
|
|
|