본문 바로가기

ios 뽀개기/ios 강좌13

ios 코어 로케이션 프레임워크로 위치 정보 수집하기 ios 코어 로케이션 프레임워크로 위치 정보 수집하기 1. 코어로케이션 매니져코어 로케이션 프레임워크의 주요 클래스는 CLLocatoinManager 와 CLLocatoin 이다 CLLocatoinManager 클래스의 인스턴스는 아래처럼 생성가능하다. var locatoinManager : CLLocatoinManager = CLLocatoinManager() CLLocatoinManager 인스턴스로 두 메서드 중 하나를 호출 할 수 있다 포그라운드에 있을 때만 위치정보를 추척한다면locatoinManager.requestWhenInUseAuthorizatoin() 백그라운드에 있을 때도 위치추적을 하는 경우라면locatoinManager.requestAlwaysAuthorizatoin() 2.위치정.. 2018. 5. 17.
ios 코어 로케이션 프레임워크 예제 ios 코어 로케이션 프레임워크 예제 스토리보트 화면viewcontroller.swift import UIKitimport CoreLocation class ViewController: UIViewController, CLLocationManagerDelegate { @IBOutlet weak var latitude: UILabel! @IBOutlet weak var longitude: UILabel! @IBOutlet weak var horizontalAccuracy: UILabel! @IBOutlet weak var altitude: UILabel! @IBOutlet weak var verticalAccuracy: UILabel! @IBOutlet weak var distance: UILabel! /.. 2018. 5. 16.
mkMap을 이용해서 길찾기 기능 구현 mkMap을 이용해서 길찾기 기능 구현 스토리 보드로 뷰를 이런식으로 간단하게 만들고 import UIKit import Contacts import MapKit class ViewController: UIViewController { //1.스토리 보드에서 만든 객체들을 컨트롤러와 연결시켜주었다. @IBOutlet weak var address: UITextField! @IBOutlet weak var city: UITextField! @IBOutlet weak var state: UITextField! @IBOutlet weak var zip: UITextField! //2. 사용자가 주소를 입력하고 getDirections 버튼을 누르면 해당메서드는 필드들에 있는 주소 정보를 추출한다. /*이렇게 .. 2018. 5. 16.
ios 지도 mkmap 3 - 해당 주소 지도에 표시하기&현재위치 ios 지도 mkmap 3 이번에는 mkplacemark 와 mkmapitem을 이용해서 텍스트 주소에 해당하는 표시를 지도위에 해보겠다 1. mkplacemark 인스턴스 생성하기 mkmapitem 클래스를 이용해서 지도를 표시할 때 나타나는 각각의 위치는 mkplacemark 객체에 의해 표현되어야 한다. mkplacemark 객체를 생성할 때 그 객체는 주소 속성 정보를 포함하고 있는 nsdictionary 객체와 함께 위치의 지리적 좌표로 초기화 되어야 한다. //매게 변수로 위도,경도가 들어간다. let coords = CLLocationCoordinate2DMake(51.5083, -0.1384) let address = [CNPostalAddressStreetKey: "181 Piccadil.. 2018. 5. 16.
ios 지도 mkmap 2 ios 지도 mkmap 2 위도와 경로 좌표를 이용해서 해당 주소 데이터를 찾는 방법을 알아본다. 먼저 앞의 포스팅에는 주소를 이용해서 미국 캘리포니아에 있는 애플의 위도와 경도를 구했다. 그 데이터를 이용해서 이번엔 주소를 찾아본다. 코드는 아래와 같다. 간단하다. //역방향 지오코딩 let geoCoder = CLGeocoder() //cllocatoin객체는 위도와 경로 좌표로 초기화 let newLocation = CLLocation(latitude: 37.3316833, longitude: -122.0301031) //geoCoder에 reverseGeocodeLocation 메서드로 전달 된다. geoCoder.reverseGeocodeLocation(newLocation, completion.. 2018. 5. 16.
ios 지도 mkmap 1 ios 지도 mkmap 1 텍스트 기반의 주소를 그 주소에 해당하는 좌표를 가지는 CLLocation 객체로 변환하는 CLGeocoder 클래스를 이용해서 미국 캘리포니아의 애플사의 좌표를 가져오는 예제를 살펴본다. let addressString = "One Infinite Loop, Cupertino, CA 95014" CLGeocoder().geocodeAddressString(addressString) { (placemarks, error) in if error != nil{ print("에러발생 \(error!.localizedDescription)") }else if placemarks!.count > 0{ let placemark = placemarks![0] let location = pl.. 2018. 5. 16.
Ios AutoLayout 7 - AutoLayout Landscape 이슈 Ios AutoLayout 7 - AutoLayout Landscape 이슈● 들어가기 전이번 포스팅에서는 Landscape을 했을때 발생하는 AutoLayout 이슈에 대해서 살펴보자. 글로 쓰는 것보다 사진을 바로 보자.대충 이런 현상이다. 세로였을때 바로 나오다가 Landscape했을 때 위와 같이 두 페이지가 반반 씩 동시에 나오는 이슈가 발생한다. viewWillTransition 함수를 override 해서 해결해보자.● 실습순서1.viewWillTransition 함수 override2.소스코드 리팩토링● viewWillTransition 함수아래의 viewWillTransitoin 함수는 view가 바뀔때 작동되는 함수다. 아래의 코드를 SwipingController 제일 윗 부분에 작성.. 2018. 5. 8.
Ios AutoLayout 6 - UIButton 이벤트와 UIPageControl속성 Ios AutoLayout 6 - UIButton 이벤트와 UIPageControl속성 ● 들어가기 전이번 포스팅에서는 이전 포스팅에서 만들었던 UIButton에 이벤트를 걸어서 "이전버튼"을 누르면 이전페이지로 이동시키고, "다음버튼"을 누르면 다음 버튼으로 이동시키는 코드를 작성해보자. 그리고 페이지가 이동할때 UIPageControl의 현재페이지를 보여주는 색깔점 표시도 변경시켜보자.● 실습순서1. ViewController.swift에 있는 UIButton객체와 UIPageControl객체와 autolayout을 설정한 함수 가져오기2. 버튼에 이벤트 걸어주기3.pageControl 설정4.scrollViewWillEndDragging 함수 구현● ViewController에 있는 객체들과 aut.. 2018. 5. 7.
Ios AutoLayout 5 - MVC 패턴 Ios AutoLayout 4 - MVC 패턴 ● 들어가기 전이번 포스팅에서는 mvc 패턴에 대해서 살펴보겠다. mvc 패턴은 아주아주 간단하게 말해서 어플리케이션을 만들때, m 모델단, v 화면단, c 컨트롤단으로 구분지어서 소스코드를 제작하는 방법이다. 반드시는 아니지만 굳이 구분을 하자면 프론트 엔드 즉, 디자이너는 v 부분 소스코드를 짜고, 개발자는 c 부분 소스코드를 짜고, db모델러는 m 부분을 담당한다.(쉽게 설명해서) 이러는 이유는 앞에서도 설명했는데, 페이지 하나에 화면소스, 컨트롤소스, 모델 소스를 짜버리면 나중에 유지보수하기가 힘들고 개발할때도 복잡해서 효율성이 떨어지기 때문이다. 아주 간단하게 설명하면 이렇다. 그렇다면 ios에서 mvc가 어떻게 활용되는지 보자. ● 실습순서1.모델.. 2018. 5. 6.
Ios AutoLayout 4 -UICollectionViewController 활용 Ios AutoLayout 4 -UICollectionViewController 활용 ● 들어가기 전이번포스팅에서는 UICollectionViewController를 이용해서 페이지를 좌우로 넘겨주는 기능을 살펴보자.● 실습순서1.rootview를 UICollectionViewController를 상속받는 클래스로 지정해주기2. UICollectionViewController를 상속받는 클래스 지정3. UICollectionViewController의 Cell을 꾸며줄 Customcell 만들기4.ViewController에 있던 소스 UICollectionViewController를 상속받는 클래스로 옮기기 ● rootview 지정해주기AppDelegate파일로 들어와서 window 객체를 초기화 하는.. 2018. 5. 5.
Ios AutoLayout 3 - UIStackViews와 pageController Ios AutoLayout 3 - UIStackViews와 pageController● 들어가기 전이번 포스팅에서는 맨아래 부분에 네비게이션 바를 구현해보자. 왼쪽 버튼 하나, 오른쪽 버튼 하나 그리고 가운데에는 pageController객체를 이용해서 페이지의 위치를 표현해줄것이다. 즉, 총 3개의 객체필요한데 이 객체를 UIStackViews를 이용해서 위치를 시켜 줄것이다. ● 실습순서1.버튼 객체 만들기2.페이지 컨트롤 객체 만들기3.버튼, 페이지 컨트롤 객체 오토레이아웃 지정해주기4. stackview를 이용해서 레아이웃설정해주기● 버튼객체와 페이지 컨트롤 객체 만들기viewdidLoad() 함수위에 버튼객체와 pageController 객체를 만들어준다. 123456789101112131415.. 2018. 5. 4.
Ios AutoLayout 2 - ContainerView와 NSMutableAttributedString Ios AutoLayout 2 - ContainerView와 NSMutableAttributedString ● 들어가기 전지난번 포스팅에서는 오토레이아웃으로 만들 간단한 프로젝트에 대한 소개를 했다. 이번 포스팅에서는 간단한 이슈가 나오는데 ContainerView와 NSMutableAttributedString을 이용해서 해결하는 과정을 포스팅 해보겠다. 부모 View를 만들어서 그안에 image view를 넣어 오토레이아웃을 지정해 줄것이다. 그리고 그림 아래 text는 NSMutableAttributedString 속성을 통해 작성할것이다. 이슈는 아래와 같다. 아이폰을 옆으로 기울이면 그림만 보이고 글은 아래로 숨어 버린다. 이 이슈를 부모 containerview를 이용해서 해결해보자.● 실습순.. 2018. 5. 3.
Ios AutoLayout 1 - 소개 Ios AutoLayout 1 - 소개 ● 들어가기 전이번 포스팅에서는 ios의 autolayout에 대해서 한번 알아보겠다. storyboard를 사용하는 대신에 autolayout관련 함수만으로 간단한 ios 어플리케이션을 만들어보면서 autolayout에 대해 이해해보자. 참고로 이 포스팅은 유튜브 "Lets Build That App" 채널을 참고해서 정리한 포스팅이다.● 소개UICollectionViewController을 이용해서 이미지와 글이 담긴 페이지가 좌우로 넘어가는 간단한 어플을 만들어보려고 한다. ● 실습순서1.ios클로저로 imageView 객체 만들기 , textView 객체 만들기2.속성 정의3.view에서 1번에서 만든 객체를 삽입해준다.4.위에서 만든 객체 autolayou.. 2018. 5. 2.