Swift 2를 사용한 iOS 개발-퀵 가이드

iOS 응용 프로그램을 개발하려면 MacBook Pro, Mac Mini 또는 OS X 운영 체제가 설치된 모든 Apple 장치와 같은 Apple 장치가 있어야합니다.

  • Xcode − 다음에서 다운로드 할 수 있습니다. https://developer.apple.com/downloads/ 무료로 제공되는 Apple 개발자 계정이 필요합니다.

  • Simulator − 이것은 컴퓨터에 설치된 가상 iPhone / iPad (iOS 장치)이므로 별도로 설치할 필요가 없습니다.

Xcode 정보

XcodeiOS / OS X 애플리케이션 개발을 위해 Apple에서 제공하는 기본 IDE (통합 개발 환경)입니다. iOS, OS X, Watch OS, TV OS 애플리케이션 등을 개발하는 데 필요한 모든 것이 포함 된 IDE입니다.

Xcode를 실행하려면 다음이 있어야합니다.

  • OS X, 즉 Apple의 공식 운영 체제를 실행하는 Mac 장치.
  • Apple ID (무료) : IDE를 다운로드합니다.

설치

장치에 Xcode를 설치하려면 다음 단계를 따르십시오. 이미 설치 한 경우 건너 뛰십시오.

  • App Store로 이동하여 아직 로그인하지 않은 경우 Xcode를 검색하십시오. 다운로드 및 설치를 클릭하십시오.

  • 다운로드가 완료되면 애플리케이션 또는 런치 패드로 이동하여 애플리케이션을 실행하십시오.

  • 처음 실행할 때 추가 다운로드를 요청하고 모든 것을 다운로드하고 요청하면 비밀번호를 입력합니다.

  • 이 모든 작업이 완료되면 아래와 같이 시작 화면이 나타납니다.

이 튜토리얼에서는 다음과 같은 iOS 개발의 기본 개념 중 일부를 배우게됩니다.

  • 새로운 프로젝트 만들기
  • IDE의 기능
  • IDE를 통해 탐색
  • 보기에 레이블 추가
  • 응용 프로그램 실행
  • 편의에 따라 시뮬레이터 조정

초보자라면이 튜토리얼이 큰 도움이 될 것입니다.

새로운 Xcode 프로젝트 생성

새로운 Xcode 프로젝트를 생성하려면 아래 단계를 따라야합니다.

Step 1 − 런치 패드에서 Xcode 아이콘을 클릭 한 다음 Create a new Xcode project.

Step 2 − iOS를 선택한 후 Single View Application을 선택하고 다음을 클릭합니다.

Step 3− 나타나는 다음 화면에는 채울 몇 개의 필드가 있습니다. 다음 사항은 이러한 각 필드를 채우는 방법을 설명합니다.

  • 프로젝트 이름을 입력하십시오-프로젝트와 유사한 이름 일 수 있습니다.

  • 지금은 팀 필드를 비워 둘 수 있습니다. 팀에서 응용 프로그램을 만들 때 사용됩니다.

  • 조직 이름은 조직의 이름이거나 개인 프로젝트 인 경우 원하는 이름을 지정할 수 있습니다. 앱 스토어에 앱을 게시하기 전까지는 중요하지 않습니다.

  • 식별자는 일반적으로 애플리케이션의 고유 식별자이며 앱 스토어의 다른 앱과 일치해서는 안됩니다 (앱 스토어에 앱을 업로드하도록 선택한 경우에만 해당).

  • 언어는 Swift, 장치는 보편적이며 다른 모든 옵션은 현재 선택 취소됩니다.

모든 세부 정보가 입력되면 다음 버튼을 클릭합니다.

Step 4− 프로젝트를 저장할 위치를 선택하십시오. 지금은 필요하지 않으므로 "Create Git Repository"확인란을 선택 취소합니다. 생성을 클릭합니다.

축하합니다! 프로젝트가 생성되었습니다.

Xcode 환경을 통한 탐색

클릭 Main.storyboard네비게이터 패널 내의 옵션. 그러면 응용 프로그램이 실행될 때 나타나는 기본보기가 나타납니다.

라벨 추가

화면 오른쪽 하단에 검색 창이 있습니다. 검색 창에 라벨을 입력하고 Return을 누르세요.

  • 레이블을 검색 한 후 레이블을 기본보기로 끌어다 놓습니다. 레이블 텍스트를 두 번 클릭하고 "Hello World"를 입력합니다.

  • 레이블을 뷰의 중앙으로 드래그하면 레이블이 정확히 중앙에있을 때 중앙에서 교차하는 두 개의 선이 나타납니다.

이제보기는 다음 스크린 샷과 같아야합니다.

응용 프로그램 실행

장치를 선택하고 오른쪽 상단의 재생 버튼을 클릭합니다.

이것은 iPhone 7 시뮬레이터에서 실행되는 최종 애플리케이션입니다.

시뮬레이터 속성 조정

애플리케이션을 처음 실행할 때 시뮬레이터 화면이 데스크톱 또는 노트북 화면에 맞지 않을 수 있습니다. 따라서 시뮬레이터가 전경에서 실행되는 동안 Window → Scale을 클릭하고 디스플레이에 맞는 시뮬레이터 화면 크기 비율을 선택합니다.

이 튜토리얼에서 시뮬레이터 기능을 언제 사용하는지 계속해서 논의 할 것입니다.

성공적으로 완료 한 첫 번째 신청서입니다. 건배!

이 장에서는 iOS가 사용자와의 상호 작용을 위해 제공하는 몇 가지 새로운 기능과 UI 기능을 소개합니다. 우리는 추가 할 것입니다-

  • 텍스트 필드
  • Labels
  • 버튼과 그 동작

또한 사용자가 입력 한 입력의 계산 결과를 표시하는 Dynamic Label에 대한 코드를 신속하게 작성합니다.

"앱 상호 작용 만들기"라는 제목은 애플리케이션이 사용자와 상호 작용하도록 만드는 것을 의미합니다. 따라서 여기서는 사용자에게 애플리케이션을 상호 작용하고 제어 할 수있는 권한을 부여합니다.

텍스트 필드 추가

여기에서 다시 새 프로젝트를 만들 것입니다. Xcode에서 새 프로젝트를 만드는 방법에 대해 이미 논의 했으므로 쉽게 관리 할 수 ​​있어야합니다.

좋습니다. 이제 "My Dog 's Age"라는 새 프로젝트를 만들겠습니다. 이 프로젝트를 만든 후 "Main.storyboard"파일을 클릭하고 아래 단계를 따릅니다.

  • 유틸리티 창의 검색 표시 줄 (Xcode의 오른쪽 하단에 있음)에서 Label을 검색합니다. 해당 레이블을 클릭하여 main.storyboard / (보기)로 끕니다. 그런 다음 레이블을 두 번 클릭하고 이름을 "My Dog 's Age"로 바꿉니다.

  • "텍스트 필드"를 검색하고 해당 텍스트 필드를 클릭하여보기로 끕니다. 이 텍스트 필드를 선택한 상태에서 속성 관리자로 이동하여 키보드 유형을 숫자 패드로 변경하여 아래 스크린 샷과 같이 숫자 만 입력 할 수 있도록합니다.

뷰에 버튼 추가

이제 검색 창에서 Button을 검색하십시오. 뷰로 드래그하고 두 번 클릭 한 다음 "계산"으로 이름을 바꿉니다.

보기에 레이블 추가

라벨을 검색하고 버튼 아래에 추가하여 연령 출력을 표시합니다. 두 번 클릭하고 레이블을 비우고 약간 늘려서 전체 출력이 표시되도록합니다.

Tip − 더블 클릭하여 이름을 변경할 수없는 경우 항목을 선택하고 유틸리티 창에서 − Attribute inspector, 해당 항목의 제목이 있습니다. 여기에서 수정하고 다음 스크린 샷과 같이 Return 키를 누릅니다.

이제 Main.storyboard는 다음 스크린 샷과 같아야합니다.

여기서 멈추지 않고 이제 main.storyboard에 이미지를 추가하는 방법에 대해 논의 할 것입니다.

뷰에 이미지 추가

우선 프로젝트에 추가 할 이미지를 먼저 검색해야합니다. 아래 주어진 이미지를 다운로드 할 수 있습니다-

이 이미지를 프로젝트에 복사하거나이 이미지를 프로젝트로 드래그하면 다음 창이 표시됩니다.

필요한 경우 항목을 선택하고 복사하고 그룹을 생성했는지 확인하십시오. 마침 버튼을 클릭합니다.

이제 유틸리티 창 → 개체 라이브러리로 이동하여 이미지보기를 검색합니다. 이미지보기를보기로 끕니다. 이제보기는 아래에 주어진 스크린 샷처럼 보일 것입니다.

이제이 이미지보기를 클릭하고보기에 끌어 놓은 다음 유틸리티 영역에 이미지를 선택하는 "이미지"라는 옵션이 있음을 알 수 있습니다. 해당 화살표를 클릭하면 사용 가능한 모든 이미지가 표시됩니다. 새로 추가 된 이미지보기를 선택했는지 확인하십시오.

이제 이미지보기 용 이미지를 선택 했으므로 최종보기는 다음 스크린 샷과 같아야합니다. 이 응용 프로그램을 위해 main.storyboard로 수행 할 유일한 작업입니다.

이것은 모든 UI 요소를 추가 한 후의보기입니다.

그 후,이 단계까지 완료 한 경우 계속할 코드의 논리적 구현이 있습니다.

이제 뷰 컨트롤러를 선택하고 오른쪽 상단 모서리에있는 보조 편집기 버튼을 클릭하여 보조 편집기를 엽니 다 (아래 스크린 샷 참조).

이제 뷰는 다음 스크린 샷과 같아야합니다.

애플리케이션에 기능 추가

지금까지 우리의 응용 프로그램은 어떤 것에 응답하지 않고 사용자 상호 작용에서 변경되지 않는 정적 응용 프로그램 일뿐입니다.

이제 UI 요소를 코드에 연결하는 주요 부분이 나왔고 UI는 사용자 입력에 따라 변경됩니다. 그만큼“ViewController.swift” 파일은 현재 뷰에 대한 코드를 작성할 기본 파일입니다.

Note− 현재 단일보기로 작업하고 있으며 나중에 여러보기에 대해 논의 할 때입니다. 서로 다른 파일이 서로 다른 뷰를 제어하는 ​​방법에 대해 설명합니다.

텍스트 필드를 클릭하고 control을 누른 다음 커서를 화면의 두 번째 부분 (예 : viewcontroller.swift 파일)으로 드래그합니다. 뷰와 빠른 파일을 연결하는 파란색 선이 표시됩니다. 마우스를 놓으면 입력을 요청하는 팝업이 표시됩니다.

TIP− 입력 필드와 유사한 이름으로 이름 필드를 채우십시오. 한 가지 중요한 점은 이름에 공백이 있어서는 안되므로 앞의 이미지와 같이 쓸 수 있다는 것입니다. 즉, 이름에 여러 단어가있는 경우 첫 번째 단어는 소문자로 작성하고 다음의 첫 번째 알파벳을 입력해야합니다. 단어는 자본이 될 것입니다.

동일한 절차를 따르고 나머지 요소를 연결합니다. 텍스트 필드와 레이블의 경우 유형은 Outlet입니다. 그러나 버튼을 추가하는 동안 유형은 아래 스크린 샷에 표시된 것과 같은 작업이어야합니다.

이 단계에서 viewcontroller.swift는 다음과 같습니다.

이제 버튼 동작 안에 다음 줄을 추가하십시오.

var age = Int(enteredAge.text!)! * 8 
yearsLabel.text = String(age);

Tipswift에서 라인을 끝내기 위해 세미콜론을 추가 할 필요는 없지만 세미콜론을 넣어도 컴파일러는 오류를보고하지 않습니다 .

위의 코드에서 첫 번째 줄은 변수 'age'를 선언하며 다음 장에서 설명합니다. 그런 다음 사용자가 입력 한 값을 Integer로 변환하고 8을 곱하여 할당합니다.

두 번째 줄에서는 출력 레이블에 'age'값을 할당합니다. 이 단계에서 뷰 컨트롤러는 다음과 같이 보일 것입니다.

이제 우리는 응용 프로그램을 실행하고 이것이 어떻게 나타날 것입니다.

Tip처음 실행할 때 키보드가 나타나지 않으면 시뮬레이터를 열고 하드웨어를 클릭 한 다음 키보드로 이동하여 소프트웨어 키보드 토글을 클릭하십시오.

다음 장에서는 새로운 도구에 대해 설명합니다. Playground. 또한 변수, 사전, 배열 루프, 클래스 및 객체와 같은 좀 더 빠른 개념을 배우게됩니다.

이 장에서는 신속한 코드를 작성하고 실행할 수있는 새로운 환경을 소개합니다. 우리는 또한 신속한 놀이터의 다음 측면을 다룰 것입니다.

  • Variables
  • Dictionaries
  • Arrays
  • Loops
  • 클래스 및 개체

Note−이 튜토리얼에서 사용할 기본 개념 만 살펴볼 것입니다. 신속하게 배우고 싶다면 Swift Tutorial을 확인하십시오 .

Playground는 신속한 코드 실행을 위해 Xcode와 함께 제공되는 도구입니다. 새로운 놀이터를 만드는 것부터 시작하겠습니다.

Swift Playground 시작

빠른 플레이 그라운드를 만들려면 Xcode 아이콘을 클릭하고 첫 번째 옵션을 선택하고 빠른 플레이 그라운드를 시작하세요.

플레이 그라운드에 이름을 지정하고 플랫폼을 iOS로 선택합니다. 놀이터 이름을 Demo Playground로 지정하겠습니다. 다음을 클릭하십시오.

놀이터를 만들기 위해 따라야 할 유일한 단계입니다. 다음 스크린 샷은 플레이 그라운드를 보여줍니다.

Sr. 아니요 기본 개념 및 설명
1 변수

변수는 우리 프로그램이 데이터를 저장하고 조작하는 데 사용할 수있는 메모리 / 저장소입니다. 각 변수에는 변수가 메모리에서 차지할 크기를 결정하는 특정 데이터 유형이 있습니다.

2 사전

사전은 키 값 쌍에 값을 저장하는 모음입니다. 즉, 사전에 저장된 데이터는 각 값이 키와 관련된 메서드에 저장됩니다. 여기에서 모든 키는 고유하며 동일한 사전에 두 번 나타날 수 없습니다.

배열

배열은 정렬 된 목록에 동일한 유형의 데이터를 저장하는 데이터 유형입니다. 동일한 값이 배열의 여러 인덱스 / 장소에 나타날 수 있습니다.

4 루프 (제어 흐름)

Swift는 다양한 제어 흐름 문을 제공합니다. 루프는 일반적으로 해당 루프에서 조건 / 프로그래머의 요구가 충족 될 때까지 조건 또는 문을 여러 번 반복하는 데 사용됩니다.

5 클래스와 객체

클래스는 프로그램 코드의 빌딩 블록 인 범용의 유연한 구조입니다.

객체는 일반적으로 클래스의 인스턴스를 참조하는 데 사용되는 용어이므로 객체 대신 인스턴스라고 부를 수 있습니다.

이 장에서는 Swift를 사용하여 두 개의 새로운 애플리케이션을 생성합니다.

첫 번째 응용 프로그램 – "숫자 추측"

이 섹션에서는 "번호 추측"이라는 애플리케이션을 생성합니다. 이 응용 프로그램을 만들려면 새 iOS 단일보기 응용 프로그램을 만들고 원하는 이름을 지정합니다.

클릭 main.storyboard 기본보기를 선택합니다.

  • 텍스트 레이블 추가 → 텍스트를 "숫자 추측"으로 변경합니다. 색상, 크기 속성을 변경하고 요구 사항에 따라 만드십시오.

  • 입력 필드를 추가하고 전체보기로 늘립니다.

  • 버튼을 추가하고 이름을 "Guess.

  • 레이블을 하나 더 추가하고 늘리고 텍스트 상자를 지 웁니다.

이것은 당신의 방법입니다 view 모든 요소를 ​​추가하면 다음과 같이 보일 것입니다.

이제 어시스턴트 편집기로 전환하고 UI 요소에서 드래그를 클릭하여 컨트롤러 파일을 본 다음 텍스트 필드를 콘센트로 연결하고 이름을 userInput으로 지정하십시오. 비슷하게,

  • 빈 라벨을 콘센트로 연결하고 이름을 resultLabel로 지정합니다.
  • Guess 버튼을 액션으로 연결하고 이름을 guessButtonPressed로 지정합니다.

논리는 무엇입니까?

논리는 간단합니다. 0-9 사이의 난수를 생성하고 사용자가 입력 한 숫자와 같은지 여부를 확인합니다. 같으면 "당신이 옳다"를 보여주고, 그렇지 않으면 "당신이 틀렸다!"를 보여줄 것입니다.

논리 적용

0-9 사이의 난수를 생성하려면 다음 명령을 사용합니다.

let rollIt = String(arc4random_uniform(10))

그런 다음 다음 로직을 사용하여 사용자 입력과 동일한 지 여부를 확인합니다.

if userInput.text == rollIt { 
   resultLabel.text = "You're right!" 
} else { 
   resultLabel.text = "Wrong! It was a " + rollIt + "." 
}

이것이 버튼 액션 함수의 최종 로직이 어떻게 보이는지입니다.

@IBAction func guessButtonPressed(_ sender: Any) { 
   let rollIt = String(arc4random_uniform(10))  
   if userInput.text == rollIt { 
      resultLabel.text = "You're right!" 
   } else { 
      resultLabel.text = "Wrong! It was a " + rollIt + "." 
   } 
}

이제 최종 애플리케이션이 다음과 같이 보일 것입니다.

이제 응용 프로그램을 실행하고 output. 시작 화면은 다음과 같습니다.

다음으로, input 지역.

다른 숫자를 입력하고 출력을 확인합시다.

하나 더 신청을 완료했습니다. 이 응용 프로그램을 실행하고 다른 입력을 입력하십시오.

두 번째 응용 프로그램 – "Is It Prime"

이 응용 프로그램에서 우리는 사용자로부터 입력을 받고 그 숫자가 소수인지 아닌지 확인할 것입니다.

  • Layout − 이전 애플리케이션과 유사하게 입력, 버튼 및 출력 레이블이 필요합니다.

  • Challenges− UI를 생성하고 요소를 코드에 연결합니다. 또한 전체 프로젝트를 직접 만들 수 있는지 시도하십시오. 혼자서 만들 수 있다면 훌륭하고 iOS 개발로 훌륭하게 수행하고 있습니다.

관리 할 수 ​​없더라도 걱정하지 마십시오. 다음 이미지를보고 똑같이 해보세요.

이와 같은 뷰를 만들어보십시오. 아직 할 수 없다면 추측 게임을 개발 한 이전 섹션을 읽어보십시오.

논리는 무엇입니까?

소수는 1과 숫자 자체를 제외한 다른 숫자로 나눌 수없는 숫자입니다.

Example − 7은 소수이며 1과 7을 제외한 다른 숫자는 나눌 수 없습니다.

구현하는 방법?

소수를 확인하는 코드를 작성하십시오. 그런 다음 사용자 입력을 받아 그것이 소수인지 아닌지 확인하십시오. 그렇다면 소수를 표시하십시오. 그렇지 않으면 결과 레이블에 소수가 아닌 것으로 표시됩니다.

다음은 제공된 번호가 "프라임"인지 여부를 확인하는 코드입니다.

@IBAction func isItPrimeButtonPressed(_ sender: Any) { 
   if let userEnteredString = userInput.text { 
      let userEnteredInteger = Int(userEnteredString) 
      if let number = userEnteredInteger { 
         var isPrime = true 
         if number == 1 { 
            isPrime = false 
         } 
         var i = 2 
         while i < number { 
            if number % i == 0 { 
               isPrime = false 
            } 
            i += 1 
         } 
         
         if isPrime { 
            resultLabel.text = "yes. \(number) is prime!" 
         } else { 
            resultLabel.text = "No. \(number) is not prime" 
         } 
      } else { 
         resultLabel.text = "Please enter a positive whole number"                 
      } 
   } 
}

이것이 버튼 동작의 모습입니다. 다음은 최종 코드 및보기 이미지입니다.

절차를 따랐을 때 실행중인 응용 프로그램의 모습은 다음과 같습니다.

이제 입력 값을 제공하여 애플리케이션을 테스트 해 보겠습니다.

이 장에서는 응용 프로그램에서 다중보기 만들기, 탐색 모음 추가, 테이블보기 추가, 응용 프로그램에 데이터 저장, 웹 응용 프로그램 만들기 등과 같은 몇 가지 고급 기능에 대해 설명합니다.

이 장에는 응용 프로그램을 개발하는 동안 필요한 대부분의 내용이 포함되어 있으므로 모든 섹션을주의 깊게 살펴보십시오.

다중 뷰 컨트롤러

이전 애플리케이션에서는 단일 뷰 / 뷰 컨트롤러 만 제공했습니다. 그러나 응용 프로그램에서 여러 뷰를 가질 수 있으며 이러한 뷰를 독립적으로 수행 할 수 있습니다.

따라서 새 프로젝트를 만드는 것으로 시작합니다. 이 프로젝트의 이름에는 여러보기가 있습니다. 다른 모든 프로젝트와 마찬가지로이 프로젝트에는 View Controller와 해당 컨트롤러에 대한 Swift File도 있습니다. (ID Inspector에서보기를 선택하고 속성을 확인하면 볼 수 있습니다.)

다음 스크린 샷은 현재 뷰가 어떻게 보이는지 보여줍니다.

오른쪽 (Identity inspector)에서 뷰 컨트롤러와 관련된 클래스를 볼 수 있습니다. 왼쪽에있는이 화살표가 진입 점입니다. 이것은 애플리케이션 실행이 시작된 후 표시되는 애플리케이션의 첫 번째보기입니다.

두 번째 다중 뷰 컨트롤러 추가

응용 프로그램에 다른 뷰 컨트롤러를 추가하기 위해 객체 라이브러리에서 뷰 컨트롤러를 검색합니다. 일단 그것을 찾으면 뷰 컨트롤러를 다른 뷰 바로 바깥쪽에있는 main.stroryboard로 드래그합니다.

이것이 애플리케이션의 모습입니다. 이제 뷰 컨트롤러를 추가했지만 이제 새로 추가 된 뷰에 대한 뷰 컨트롤러 클래스도 만들어야합니다.

Right click on your project → new File → cocoa Touch Class → 원하는 이름을 지정하고 "SecondViewController"로 이름을 지정합니다.

이것이 뷰 컨트롤러에 대한 클래스 파일을 만드는 방법입니다. 이제 "main.storyboard"로 돌아가서 두 번째 뷰 컨트롤러를 클릭하고 Identity Inspector를 확인합니다.

지금은 클래스 필드가 비어 있어야하므로 해당 필드를 클릭하고 마지막 단계에서 추가 한 클래스 이름을 입력하십시오. 나타나면 Enter를 클릭하십시오.

이제 다중 뷰 컨트롤러를 만들고 해당 뷰에 대한 컨트롤러 클래스 파일을 추가했습니다. 그러나 응용 프로그램을 실행하면 두 번째보기가 여전히 표시되지 않습니다. 왜?

기능을 추가하지 않았기 때문에 해당 뷰로 이동합니다. 요컨대, 우리는 아직 우리의 애플리케이션에 네비게이션을 추가하지 않았습니다. 걱정 하지마; 다음 섹션에서 다룰 것입니다.

응용 프로그램에 탐색 추가

한보기에서 다른보기로 전환하는 과정을 Segueing즉, 두보기 사이에 segue를 생성하여 수행됩니다. 이렇게하려면 첫 번째 뷰 컨트롤러에 버튼을 추가하고 두 번째 뷰로 드래그를 제어합니다. 버튼을 놓으면 아래 스크린 샷과 같이 몇 가지 옵션이 표시됩니다.

Action Segue에서 Show 옵션을 선택합니다. 이제 응용 프로그램을 실행하면 단추를 클릭하면 두 번째보기가 나타납니다 (두 번째보기에 더 명확하게 추가하여 식별 할 수 있음).

그러나 이제는 첫 번째보기로 돌아갈 수 없습니다. 이를 위해 우리는Navigation controllers.

내비게이션 컨트롤러 추가

첫 번째보기 컨트롤러를 선택하고 상단 표시 줄에서 Editor → Embed in → Navigation controller.

이제 애플리케이션은 다음 스크린 샷과 같아야합니다.

뷰 위에 약간 밝은 회색 줄이 있음을 확인해야합니다. 이제 애플리케이션을 실행하면보기 상단에 탐색 모음이 있음을 알 수 있습니다. 버튼을 클릭하면 두 번째보기로 이동하여 해당 탐색 모음에 뒤로 버튼이 표시됩니다. 이것을 클릭하면 초기보기로 돌아갑니다.

탐색 표시 줄에 제목 및 뒤로 버튼 추가

탐색 모음에 제목을 추가하려면 탐색 모음을 클릭하고 해당 속성 검사기를 확인합니다. 우리는 볼 것입니다-

  • Title − 이것은 중앙에 나타나는 내비게이션 바의 제목입니다.

  • Prompt -제목 표시 줄 상단 중앙에 나타납니다.

  • Back Button − 여기에서 뒤로 버튼에 나타나는 텍스트를 수정할 수 있습니다.

현재 뷰를 통과하는 버튼은 뷰에 있으며, 화면에 다른 것을 표시하려는 경우 적합하지 않을 수 있습니다. 따라서 탐색 모음에 Bar Button 항목을 추가하여 두 번째보기로 이동합니다. 그러나이를 위해 먼저 추가 한 마지막 버튼을 삭제해야합니다.

바 버튼 항목 추가

개체 라이브러리에서 막대 단추 항목을 검색하고 탐색 막대의 오른쪽으로 끌어다 놓습니다. 이름을 "Next>"로 지정하고 두 번째보기로 드래그를 제어하고 마지막으로 추가 한 버튼과 마찬가지로 표시를 선택합니다.

이제 응용 프로그램을 실행하면 더 깨끗하고 좋아 보입니다. 이것이 바로 지금 내비게이션으로 할 모든 것입니다. 다음 장에서는 필요한 경우 Swift Code를 사용하여 탐색 모음을 수정합니다.

테이블보기

테이블은 여러 행을 포함하는 단일 열 목록으로 데이터를 표시하며이를 섹션으로 더 나눌 수 있습니다. 데이터를 깨끗하고 효율적인 방식으로 표현하려면 테이블을 사용해야합니다.

이 섹션에서는 테이블보기 추가, 프로토 타입 셀 추가, 테이블보기에 대한 데이터 소스 및 대리자 추가, 테이블 속성 변경 및 테이블보기 셀에 대한 동적 데이터 설정 방법을 이해합니다.

테이블보기 추가

테이블 뷰를 추가하려면 먼저 새 프로젝트를 만들고 이름을 "tableView"로 지정합니다. 그런 다음 개체 라이브러리로 이동하여 테이블보기를 검색하면 테이블보기, 테이블보기 컨트롤러 및 기타 여러 옵션이 표시됩니다. 그러나 테이블 뷰를 선택하고 끌어서 기본 뷰 컨트롤러에 추가해야합니다.

프로토 타입 셀 추가

테이블보기가 강조 표시되는 동안 전체보기를 포함하도록 테이블보기를 늘립니다. 속성 검사기를 확인하면 현재 0 인 Prototype 셀이라는 필드가 있습니다. 값을 1로 변경해야합니다. 이제보기는 다음과 같이 보일 것입니다.

셀 식별자 변경

이제보기 내에서 프로토 타입 셀을 클릭합니다 (조금 까다 롭습니다). 따라서 문서 개요에서보기 컨트롤러 →보기 → 테이블보기 → 테이블보기 셀을 클릭합니다. 이제 속성 관리자에 식별자라는 열이 있습니다.이를 클릭하고 이름을 "셀"로 지정합니다. 위의 단계를 이해하려면 다음 스크린 샷을 참조하십시오.

대리인 및 데이터 소스 추가

테이블 뷰를 동적으로 만들려면 동적 데이터를로드해야합니다. 따라서이를위한 델리게이트와 데이터 소스가 필요합니다. 테이블의 델리게이트 및 데이터 소스를 만들려면 아래 스크린 샷과 같이 테이블 뷰에서 뷰 컨트롤러 또는 뷰 컨트롤러 상단의 노란색 버튼으로 드래그를 제어합니다.

커서를 놓으면 dataSource와 delegate의 두 가지 옵션이 표시되고 하나씩 선택합니다 (하나의 옵션을 선택하면 팝업이 숨겨지고 두 번째 옵션을 추가하려면 위 단계를 반복해야합니다). . 이제 다음과 같이 보일 것입니다.

지금 당장 UI / Main.Storyboard로 할 모든 것입니다. 이제 "ViewController.swift"파일로 전환합니다. 더하다UITableViewDelegate, UITableViewDataSource, 아래에 표시된 것처럼 viewController.swift에-

그러나 이제 Xcode는이 줄에 오류를 표시합니다.

이것은 우리가 사용해야 할 몇 가지 방법이 있기 때문입니다 UITableView

이러한 메서드를 보려면 Command + UITableViewDataSouce를 클릭하고 "numberOfRowsInSection", "cellForRowAtIndex"인수가있는 처음 두 메서드를 복사하여 viewDidLoad () 앞에 ViewController.swift에 붙여 넣습니다.

이 줄 제거 @available(iOS 2.0, *), 두 메서드에서 열고 닫는 중괄호 "{}"를 추가합니다. 이제보기는 다음과 같이 보일 것입니다.

Xcode는 두 기능 모두에서 오류를 표시해야합니다. 그러나 이러한 함수의 반환 유형을 추가하지 않았으므로 걱정하지 마십시오.

numberOfRowsInSection−이 함수는 섹션에 포함될 행 수를 정의합니다. 이제이 줄을 방법에 추가하십시오.

return 1 //This will return only one row.

cellForRowAt −이 메서드는 모든 셀의 내용을 반환합니다. indexPath모든 셀의 인덱스를 포함합니다. 셀을 만든 다음 해당 셀에 값을 할당하고 마지막으로 셀을 반환합니다.

이제 함수는 다음과 같이 보일 것입니다.

internal func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 
   return 1; 
} 
internal func tableView(_ tableView: UITableView, 
   cellForRowAt indexPath: IndexPath) -> UITableViewCell { 
   let cell = UITableViewCell(style: 
   UITableViewCellStyle.default, reuseIdentifier: "Cell") 
   cell.textLabel?.text = "First Row" 
   return cell 
}

첫 번째 줄에서는 기본 스타일로 셀을 만들고 reuseIdentifier 우리가 만든 프로토 타입 셀의 이름입니다.

Cell.textLable?.text − 이것은 해당 셀의 제목으로 표시되어야하는 텍스트를 정의합니다.

마지막으로 거기에서 셀을 반환합니다. 지금 애플리케이션을 실행 해보십시오. 다음과 같이 보일 것입니다.

시간표 신청

이 응용 프로그램에서는 마지막 프로젝트를 계속하고 2 (2… 10…. 20)의 표를 인쇄하는 응용 프로그램을 만들 것입니다.

따라서이 애플리케이션을 만들려면 프로젝트의 뷰 컨트롤러 파일을 변경하면됩니다.

아래와 같이 기능을 변경하십시오-

internal func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 
   return 10; 
} 
internal func tableView(_ tableView: UITableView, 
   cellForRowAt indexPath: IndexPath) -> UITableViewCell { 
   let cell = UITableViewCell(style: UITableViewCellStyle.default, reuseIdentifier: "Cell") 
}

이제 애플리케이션을 실행하십시오. 아래와 같이 보일 것입니다.

이제 테이블 뷰를 완성하고 응용 프로그램을 만들었으므로 해결해야 할 빠른 과제가 있습니다.

도전

사용자가 입력 한 숫자의 계수 표를 인쇄하는 응용 프로그램을 만듭니다.

Hint− 입력을 받고 버튼을 추가합니다. 버튼을 누르면 해당 숫자를 세는 테이블이로드됩니다. 여기에서 테이블 데이터를 다시로드하는 다음 함수도 필요합니다.

tableView.reloadData()

이 응용 프로그램에 대한 모든 주제를 다루었으므로이 문제에 대한 해결책은 제공하지 않습니다.

계란 타이머 응용 프로그램

이 응용 프로그램에서 우리는 Timer()Class Constructor, 시간을 관리합니다. 개념과 코딩을 제공합니다. 이전 장에서 모든 UI 요소를 이미 여러 번 논의 했으므로 UI를 직접 만들어야합니다. (아주 새로워 보이는 모든 것에 대한 힌트를 제공하지만).

최종 앱 레이아웃은 다음과 같아야합니다.

이 응용 프로그램에서 어떤 일이 발생합니까?

  • 제목 레이블의 시작 값은 210입니다.

  • 재생 버튼을 클릭하면 1 초에 1 씩 값이 감소합니다.

  • 일시 중지를 클릭하면 값이 여기에서만 중지됩니다.

  • -10을 클릭하면 값이 10 씩 감소하고 감소가 계속됩니다.

  • +10을 클릭하면 값이 10 씩 증가하고 감소가 계속됩니다.

  • 재설정을 클릭하면 값이 210이됩니다.

  • 값은 0보다 낮아서는 안됩니다.

개념

  • Timer () → var timer = Timer () 클래스의 변수를 사용합니다.

  • 방금 만든이 타이머 변수에 값을 설정합니다.

    • timer = Timer.scheduledTimer (timeInterval : 1, target : self, selector : #selector (ViewController.processTimer), userInfo : nil, repeats : true)

    • timeInterval-> 사용하려는 시간 간격입니다.

    • target-> 영향을 받아야하는 뷰 컨트롤러입니다.

    • 선택기->는이 타이머를 사용할 함수 이름입니다.

    • userInfo-> null 및 repeats, yes 우리는 반복하고 싶으므로 true입니다.

타이머 무효화

프로그래밍을 통해 타이머를 중지하려면 다음을 추가합니다. timer.invalidate() 함수.

Elements we have used

Navigation bar − 내비게이션 바에 세 가지 항목을 추가했습니다.

  • 바 버튼 항목, 왼쪽에 하나, 오른쪽에 하나.
  • 제목은 "Our Egg Timer"입니다.

Toolbar − 툴바는 앱 화면 하단에 나타나며 현재보기 또는 그 안의 콘텐츠와 관련된 작업을 수행하기위한 버튼을 포함합니다.

도구 모음은 반투명하며 배경 색조가있을 수 있습니다. 사람들이 필요하지 않을 때 종종 숨어 있습니다.

UI 하단에 5 개의 항목이있는 툴바를 추가했습니다.

  • -10, 재설정 및 +10이라는 세 개의 막대 단추 항목.
  • 두 개의 유연한 공간 : 바 버튼 항목 사이의 유연한 공간-

바 버튼 항목에 아이콘을 추가하는 방법은 무엇입니까?

바 버튼 항목을 선택하십시오. 막대 버튼 항목을 클릭하고 속성 검사기로 이동 한 다음 항목 선택을 클릭하고 나타나는 드롭 다운에서 항목을 선택합니다.

마찬가지로 다른 모든 버튼에 대한 항목을 선택하고 위에 주어진 UI를 만듭니다. View 중앙에 라벨을 추가하고 콘센트로 연결하고 이름을 −timeLeftLabel.

시작 타이머 작업

다음은 시작 타이머 프로그램입니다.

@IBAction func startTimerButton(_ sender: Any) { 
   if !timerActive { 
      timerActive = true 
      eggTimer = Timer.scheduledTimer(timeInterval: 1, target: self, selector: 
      #selector(ViewController.processTimer), userInfo: nil, repeats: true) 
   } 
}

다음 함수를 만듭니다-

func stopTimer() { 
   timerActive = false 
   eggTimer.invalidate() 
}

정지 기능에 대한 조치

다음은 정지 기능을위한 프로그램입니다.

@IBAction func pauseTimerButton(_ sender: Any) { 
   stopTimer() 
}

시간 빼기 동작

다음은 시간을 빼는 프로그램입니다.

@IBAction func subtractTime(_ sender: Any) { 
   if timeLeft > 10 { 
      timeLeft = timeLeft - 10 
      timeLeftLabel.text = String(timeLeft) 
   } 
}

시간 재설정을위한 조치

다음은 시간 재설정 프로그램입니다.

@IBAction func resetTimer(_ sender: Any) { 
   timeLeft = 210 
   timeLeftLabel.text = String(timeLeft) 
}

addTime에 대한 조치

다음은 시간 추가 프로그램입니다.

@IBAction func addTime(_ sender: Any) { 
   timeLeft = timeLeft + 10 
   timeLeftLabel.text = String(timeLeft) 
}

이제 viewController.swift는 다음과 같아야합니다.

import UIKit 
class ViewController: UIViewController { 
   @IBOutlet weak var timeLeftLabel: UILabel! 
   var eggTimer = Timer()  // Initialize the Timer class. 
   var timerActive = false // Prevents multiple timers from firing. 
   var timeLeft = 210  
   func stopTimer() { 
      timerActive = false 
      eggTimer.invalidate() 
   } 
     
   func processTimer() { 
      if timeLeft <= 0 { 
         stopTimer() 
         return 
      }     
      timeLeft = timeLeft - 1; 
      timeLeftLabel.text = String(timeLeft) 
   } 
    
   @IBAction func startTimerButton(_ sender: Any) { 
      if !timerActive {
         timerActive = true 
         eggTimer = Timer.scheduledTimer(timeInterval: 1, target: self, selector: 
         #selector(ViewController.processTimer), userInfo: nil, repeats: true) 
      } 
   } 
     
   @IBAction func pauseTimerButton(_ sender: Any) { 
      stopTimer() 
   } 
    
   @IBAction func subtractTime(_ sender: Any) { 
      if timeLeft > 10 { 
         timeLeft = timeLeft - 10 
         timeLeftLabel.text = String(timeLeft) 
      } 
   } 
     
   @IBAction func resetTimer(_ sender: Any) { 
      timeLeft = 210 
      timeLeftLabel.text = String(timeLeft) 
   } 
     
   @IBAction func addTime(_ sender: Any) { 
      timeLeft = timeLeft + 10 
      timeLeftLabel.text = String(timeLeft) 
   } 
     
   override func viewDidLoad() { 
      super.viewDidLoad() 
      // Do any additional setup after loading the view, typically from a nib. 
   }  
   override func didReceiveMemoryWarning() { 
      super.didReceiveMemoryWarning() 
      // Dispose of any resources that can be recreated
   } 
}

이것이 우리가 응용 프로그램에서 할 모든 것입니다. 응용 프로그램을 실행하려고 시도하면 제대로 실행됩니다.

로컬 저장소에 데이터 저장

로컬 저장소에 데이터를 저장하는 것은 로컬 장치의 저장소를 사용하여 장치에 응용 프로그램과 관련된 데이터를 저장하는 것을 의미합니다. 로컬 저장소에 데이터를 저장하는 두 가지 방법이 있습니다.NSUserDefaultCoreData.

자세히 이해합시다.

NSUserDefaults

NSUserDefaults는 기본 설정, 설정 또는 개별 값과 같은 작은 데이터 조각을 저장하기위한 것입니다. 응용 프로그램에서 UserDefaults를 사용하려면 아래와 같이 코드를 통해 nsuserDefaults에 대한 참조를 생성하기 만하면됩니다.

let defaultValues = NSUserDefaults.standardUserDefaults()

UserDefaults의 데이터에 값을 설정하려면 다음 코드를 사용할 수 있습니다.

defaultValues.setObject("Simplified iOS", forKey: "nameKey")  
func setDouble(value: Double, forKey defaultName: String) 
func setBool(value: Bool, forKey defaultName: String) 
func setObject(value: AnyObject?, forKey defaultName: String) 
func setURL(url: NSURL?, forKey defaultName: String) 
func setInteger(value: Int, forKey defaultName: String) 
func setFloat(value: Float, forKey defaultName: String)

NSUserDefaults에서 값을 가져 오기 위해 다음 코드를 사용할 수 있습니다.

func boolForKey(defaultName: String) -> Bool 
func integerForKey(defaultName: String) -> Int 
func floatForKey(defaultName: String) -> Float 
func doubleForKey(defaultName: String) -> Double 
func objectForKey(defaultName: String) -> AnyObject? 
func URLForKey(defaultName: String) -> NSURL?

CoreData

CoreData는 대규모 데이터 트랜잭션을 지원하는 영구 프레임 워크입니다. CoreData를 사용하면 사용자 데이터를 저장하기위한 관계형 엔티티 속성 모델을 구축 할 수 있습니다. CoreData는 프레임 워크이며 SQLite, 바이너리 형식을 사용하여 데이터를 저장할 수 있습니다.

응용 프로그램에서 CoreData를 사용하려면 새 프로젝트로 시작하고 프로젝트를 만드는 동안 "Use Core Data"를 선택해야합니다.

Login Using core Data − 새 프로젝트를 생성하고 다음 스크린 샷과 같이 CoreData 사용을 선택합니다.

프로젝트가 열릴 때까지 계속하면 프로젝트에 이전 프로젝트보다 더 많은 파일이 있음을 알 수 있습니다.

이 파일 CoreData_demo.xcdatamodeld 사용자 테이블을 만들고 데이터를 저장할 데이터베이스입니다.

Concept − CoreData의 경우 앱을 닫고 몇 달 후에 열더라도 저장 한 데이터는 그대로 유지되며 다음 애플리케이션에서 볼 수 있습니다.

이제 핵심 데이터를 추가하고 핵심 데이터를 검색하는 방법을 살펴 보겠습니다.

Adding Core Data− CoreData를 추가하려면 CoreData_demo.xcdatamodeld 파일을 클릭하면 엔티티가 비어 있음을 알 수 있습니다. 엔티티 추가 버튼을 클릭하면 엔티티가 추가됩니다. 이제 엔티티 이름을 두 번 클릭하고 원하는 이름으로 바꿉니다.

이제 엔티티를 클릭하면 속성 필드가 비어 있음을 알 수 있습니다. 더하기 기호를 클릭하고 엔티티 이름을 바꿉니다. 다음 필드에서 엔티티 유형을 선택하십시오.

엔티티와 하나의 속성을 추가했습니다. 이제 우리가AppDelegate.swift에서 CoreData를 선택했기 때문에 두 가지 새로운 기능이 추가 된 것을 볼 수 있습니다. 추가 된 두 가지 기능은 다음과 같습니다.

Note − 계속하기 전에 파일에서 CoreData를 가져옵니다.

Saving data to Core Data − CoreData에 일부 데이터를 저장하려면 AppDelegate Class의 객체를 만들어야합니다.

let appDelegate = UIApplication.shared.delegate as! AppDelegate

그리고 컨텍스트 객체

let context = appDelegate.persistentContainer.viewContext

그런 다음 엔티티라고 부르는 엔티티 객체를 만들어야합니다.

let newValue = NSEntityDescription.insertNewObject(forEntityName: "Users", into: context)

이제 생성 한 속성의 값을 설정합니다.

newValue.setValue(textField.text, forKey: "name")

우리는 사용하여 데이터를 저장합니다

context.save();

Fetching from core data− 가져 오는 동안 위의 두 단계 (appDelegate 및 컨텍스트 생성)는 동일합니다. 그런 다음 가져 오기 요청을 생성합니다.

let request = NSFetchRequest<NSFetchRequestResult>(entityName: "Users")

결과를 저장할 객체를 생성합니다.

let results = try context.fetch(request)

그런 다음 요구 사항에 따라 결과를 살펴볼 것입니다. 우리가 만드는 다음 애플리케이션에서 더 많은 CoreData를 보게 될 것입니다.

Challenge− 사용자가 이름을 입력 한 다음 로그인을 클릭하고 응용 프로그램을 닫는 응용 프로그램을 만들어보십시오. 다음에 사용자가 응용 프로그램을 열 때 그는 여전히 로그인되어 있어야합니다. 그런 다음 버튼을 추가합니다. 로그 아웃하고 그가이를 클릭하면 응용 프로그램에서 사용자 이름을 다시 묻습니다.

CoreData를 사용한 로그인 / 로그 아웃

'Login'이라는 단일보기 프로젝트를 만들고 CoreData 사용을 선택합니다. CoreData_demo.xcdatamodeld를 클릭하고 'Users'라는 엔티티를 추가하십시오. 그 안에 'name'이라는 속성을 추가하십시오.

main.storyboard로 이동하여 텍스트 필드와 로그인 버튼을 추가하십시오. 그 아래에 레이블을 추가하고 두 번 클릭하여 내용을 제거하십시오. 그런 다음 로그 아웃 버튼을 추가하고 속성 검사기로 이동하여 'alpha'를 0으로 만듭니다. 이제 뷰는 다음과 같이 표시됩니다.

이제 뷰 컨트롤러 파일로 이동하여 어시스턴트 편집기를 열고 UI 요소와 컨트롤러 파일 간의 연결을 만듭니다.

Note− 또한 두 버튼의 모양을 수정해야하므로 두 버튼에 대한 콘센트도 만들 것입니다. 예 : 사용자가 로그인 할 때 로그인 버튼을 숨기고, 사용자가 로그인하지 않은 경우 로그인을 표시하고 로그 아웃 버튼을 숨 깁니다.

CoreData에서 데이터 추가 및 가져 오기에 대해 이미 논의했듯이 여기에 코드를 넣을 것입니다.

Try-Catch− 코드에서 try-catch 블록을 여러 번 사용했음을 알 수 있습니다. try-catch 블록을 사용하지 않고 프로그램에 예외 나 오류가 있으면 실행이 중지되기 때문입니다. 반면 try catch 블록을 사용 중이고 오류가 발생하면 catch 블록이 오류를 처리합니다. Swift Tutorial 에서 자세히 알아보세요.

로그인 / 로그 아웃 애플리케이션 용 코드

로그인 / 로그 아웃 애플리케이션에 사용되는 다양한 구성 요소와 코드를 이해하겠습니다.

Login Button Action − 다음 코드는 로그인 버튼 동작을 추가하는 방법을 설명합니다.

var isLoggedIn = false 
@IBAction func logIn(_ sender: AnyObject) { 
   let appDelegate = UIApplication.shared.delegate as! AppDelegate
   let context = appDelegate.persistentContainer.viewContext 
   if isLoggedIn { 
      let request = NSFetchRequest<NSFetchRequestResult>(entityName: "Users") 
      do { 
         let results = try context.fetch(request) 
         if results.count > 0 { 
            for result in results as! [NSManagedObject] { 
               result.setValue(textField.text, forKey: "name") 
               do { 
                  try context.save() 
               } 
               catch { 
                  print("Update username failed") 
               } 
            } 
            label.text = "Hi " + textField.text! + "!" 
         } 
      } 
      catch { 
         print("Update failed") 
      } 
   } else { 
      let newValue = NSEntityDescription.insertNewObject(forEntityName: "Users", into: context) 
      newValue.setValue(textField.text, forKey: "name") 
      do { 
         try context.save() 
         logInButton.setTitle("Update username", for: []) 
         label.alpha = 1 
         label.text = "Hi " + textField.text! + "!" 
         isLoggedIn = true 
         logOutButton.alpha = 1 
      }  
      catch { 
         print("Failed to save") 
      }     
   } 
}

Logout Button Action − 다음 코드는 로그 아웃 버튼 동작을 추가하는 방법을 설명합니다.

@IBAction func logOut(_ sender: AnyObject) { 
   let appDelegate = UIApplication.shared.delegate as! AppDelegate 
   let context = appDelegate.persistentContainer.viewContext 
   let request = NSFetchRequest<NSFetchRequestResult>(entityName: "Users") 
   do { 
      let results = try context.fetch(request) 
      if results.count > 0 { 
         for result in results as! [NSManagedObject] { 
            context.delete(result) 
            do { 
               try context.save() 
            } catch { 
               print("Individual delete failed") 
            } 
         } 
         label.alpha = 0 
         logOutButton.alpha = 0 
         logInButton.setTitle("Login", for: []) 
         isLoggedIn = false 
         textField.alpha = 1 
      } 
   } catch { 
      print("Delete failed") 
   } 
}

ViewDidLoad() − 다음 코드는 ViewDidLoad () 함수 사용 방법을 설명합니다.

override func viewDidLoad() { 
   super.viewDidLoad() 
   // Do any additional setup after loading the view, typically from a nib.
   let appDelegate = UIApplication.shared.delegate as! AppDelegate 
   let context = appDelegate.persistentContainer.viewContext 
   let request = NSFetchRequest<NSFetchRequestResult>(entityName: "Users") 
   request.returnsObjectsAsFaults = false 
   do { 
      let results = try context.fetch(request) 
      for result in results as! [NSManagedObject] { 
         if let username = result.value(forKey: "name") as? String { 
            logInButton.setTitle("Update username", for: []) 
            logOutButton.alpha = 1 
            label.alpha = 1 
            label.text = "Hi there " + username + "!" 
         }     
      } 
             
   } catch { 
      print("Request failed") 
   } 
}

두 버튼 모두에 대해 콘센트와 작업을 만들어야했습니다.

이제 응용 프로그램을 저장하고 실행하십시오. 로그인하고 응용 프로그램을 닫은 다음 다시 실행하십시오. 다음과 같이 보일 것입니다.

이것이 CoreData로 할 모든 것입니다. 동일한 개념을 사용하여 많은 CoreData 애플리케이션을 구축 할 수 있습니다.

키보드 제어

이 섹션에서는 키보드 동작을 제어하는 ​​방법을 배웁니다. 예 : 텍스트를 입력 한 후 텍스트 필드 외부를 클릭하면 키보드가 닫히지 않습니다. 여기에서는 키보드를 제어하는 ​​방법을 이해합니다.

입력 필드 외부를 클릭하면 키보드가 사라져야합니다.

이것은 간단한 작업으로, 중괄호를 닫기 전에 다음 코드를 viewController 파일에 붙여 넣습니다.

override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) { 
   self.view.endEditing(true)  
}

이렇게하면 입력 필드 외부를 클릭하면 키보드가 사라집니다.

리턴 키 탭시 키보드가 사라져야합니다.

키보드를 사라지게하려면 뷰 컨트롤러에 새로운 유형을 추가해야합니다. 또한 텍스트 필드를 추가하고 textField라는 콘센트를 만듭니다. 마지막으로UITextFieldDelegate.

우리는 또한 control + drag 입력 필드에서 뷰 컨트롤러로 이동하고 나타나는 옵션에서 델리게이트를 선택합니다.

그런 다음 다음 기능을 추가합니다.

func textFieldShouldReturn(_ textField: UITextField) -> Bool { 
   textField.resignFirstResponder()  
   return true 
}

최종 뷰 컨트롤러 파일은 다음과 같아야합니다.

import UIKit 
class ViewController: UIViewController, UITextFieldDelegate { 
   override func viewDidLoad() { 
      super.viewDidLoad() 
      // Do any additional setup after loading the view, typically from a nib. 
   }  
   override func didReceiveMemoryWarning() { 
      super.didReceiveMemoryWarning() 
      // Dispose of any resources that can be recreated. 
   } 
   override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) { 
      self.view.endEditing(true) 
   }
   func textFieldShouldReturn(_ textField: UITextField) -> Bool { 
      textField.resignFirstResponder() 
      return true 
   } 
}

웹 콘텐츠 다운로드-Facebook / Google 열기

이 섹션에서는 각 버튼을 각각 눌렀을 때 Facebook과 Google을 여는 애플리케이션을 만드는 방법에 대해 알아 봅니다. 또한 웹보기 및 앱 전송 계층 보안의 개념에 대해서도 알아 봅니다. 그 후 자신 만의 브라우저를 만들 수 있습니다.

Note −이 응용 프로그램에는 인터넷 연결이 필요합니다.

웹 애플리케이션 만들기

새로운 단일보기 애플리케이션 인 iOS 프로젝트를 만들 것입니다. 개체 라이브러리의 검색 표시 줄에서 웹보기를 검색하고 끌어서 main.Storyboard의보기 컨트롤러에 추가합니다.

웹보기를 추가 한 후 모든 모서리로 늘립니다. 응용 프로그램 UI는 다음과 같아야합니다.

어시스턴트 에디터를 클릭하여 main.storyboard를 열고 컨트롤러를 볼 것입니다. webView를위한 아웃렛과 두 버튼에 대한 액션을 생성 할 것입니다. 로드시 애플리케이션은 webView에서 yahoo를로드합니다. Google을 클릭하면 Google이로드되고 Facebook 버튼을 클릭하면 Facebook 페이지가로드됩니다.

최종보기는 다음과 같아야합니다.

다음 스크린 샷은 애플리케이션의 다양한 화면이 어떻게 보이는지 보여줍니다. https가 아닌 웹 서비스를 열려고하면 오류가 표시되며 앱 전송 계층 보안 예외를info.plist 파일.

지도는 모든 사람의 일상 생활의 일부가되었습니다. 그들은 우리가 장소를 여행하거나 어떤 장소를 검색 할 때 매우 유용하게되었습니다.

지도 통합 및 India Gate 찾기

애플리케이션에서지도를 만들어 중앙에 인디아 게이트를 보여줍니다. 프로젝트에서 구현하여지도를 배웁니다. 따라서 단일보기 iOS 애플리케이션을 만들고 원하는 이름을 지정합니다.

지도 키트보기 추가

개체 라이브러리로 이동하여 맵 키트보기를 검색하고 드래그를 클릭하여보기로 가져 와서 전체보기를 채우도록 늘립니다.

제약 추가

controller.swift 파일을보기 위해 control + drag로 mapViewKit에 대한 콘센트를 만듭니다. 지금은 오류가 표시 될 수 있지만 처리하겠습니다. 파일 상단의 import UIKIT 아래에 import MapKit을 추가하면 오류가 제거됩니다.

그 후, ViewController : UIViewController 클래스 뒤에 MKMapViewDelegate를 추가합니다. 이제 파일은 다음과 같이 보일 것입니다.

이제지도에 대한 위도 및 경도, 델타, 스팬, 위치 및 지역을 생성합니다. 그 전에 장소의 위도와 경도를 얻는 방법을 알려 드리겠습니다.

maps.google.com으로 이동하여 위치를 검색합니다. 상단에는 URL에서 위도와 경도가 표시됩니다. 예 : India Gate를 검색해 보겠습니다.

위도 및 경도 설정

위도와 경도를 얻은 후 변수를 만들 것입니다.

let latitude: CLLocationDegrees = 28.610 
let longitude: CLLocationDegrees = 77.230

위도 및 경도에 대한 델타 설정

위도와 경도를 추가 한 후 위도와 경도를 확인할 수있는 값인 델타를 추가합니다. 더 정확한 위치에 대해서는 최소로 유지해야합니다.

let latDelta: CLLocationDegrees = 0.04 
let lonDelta: CLLocationDegrees = 0.04

지도의 범위, 위치 및 지역 설정

그런 다음 맵에 대한 Span, Location 및 Region을 생성합니다.

let span: MKCoordinateSpan = MKCoordinateSpan(latitudeDelta: latDelta,
longitudeDelta: lonDelta)  
let location: CLLocationCoordinate2D = CLLocationCoordinate2D(latitude:
latitude, longitude: longitude)  
let region: MKCoordinateRegion = MKCoordinateRegion(center: location, span: span)

지도 설정

다음 명령으로지도를 설정합니다.

mapView.setRegion(region, animated: true)

최종 애플리케이션은 아래에 표시된 스크린 샷과 같아야합니다.

위치 세트가 애플리케이션의 중심에 정확히 있는지 확인해야합니다. 이것이 바로 지금 우리가지도로 할 전부입니다.

iOS 애플리케이션을 만들고 해당 애플리케이션에 UI 요소를 추가하면 하나의 장치에서 완벽하게 보일 수 있습니다. 그럼에도 불구하고 이제 다른 장치에서 동일한 응용 프로그램을 시도해야합니다. 우리는 확실히 UI에서 급격한 변화를 보게 될 것이며 일부 요소는 잘 나타나지 않을 수도 있습니다.

자동 레이아웃은이 문제를 해결하는 데 사용할 기술입니다. 이 장에서는 응용 프로그램이 모든 장치에서 완벽하고 최상으로 보이도록 자동 레이아웃, 제약 조건 적용 및 스택보기를 만드는 방법을 이해합니다.

새로운 단일보기 애플리케이션을 만드는 것으로 시작합니다.

요소 추가

아래 그림과 같이 뷰의 상단 중앙에 레이블을 추가하고 뷰의 오른쪽 하단에 레이블을 추가하십시오.

이제 방향을 변경하면 오른쪽 하단이 나타나지 않고 Center는 중앙에 있지 않습니다.

(Tip − 레이아웃을보기 위해 시뮬레이터를 실행할 필요가 없습니다. 다음 스크린 샷과 같이 화면 하단에있는 View as − iPhone x를 클릭하기 만하면됩니다.)

iPhone 버전과 방향을 선택하십시오. UI 요소가 제대로 정렬되지 않은 것을 볼 수 있습니다. 따라서 방향, 장치 또는 둘 다를 변경하면 오른쪽 하단 레이블이 사라지고 가운데가 중앙에 있지 않습니다.

이것은 요소에 대한 고정 위치를 지정하지 않았기 때문에 발생합니다. 이를 해결하기 위해 Constraints를 사용합니다.

UI 요소에 제약 적용

가운데 레이블을 클릭하고 Ctrl 키를 누른 다음 뷰 내부 아무 곳으로나 드래그 한 다음 놓습니다. 지금 당신은보고 있어야합니다-

고르다 Center Horizontally in Container. 다시 위의 단계를 반복하고 상단 레이아웃 가이드에 수직 간격을 선택합니다.

이제 Add new constraint 버튼을 클릭하고 높이와 너비를 선택한 다음 Add 2 Constraints를 클릭합니다.

오른쪽 하단 레이블을 클릭하고 레이블에서 뷰 내부로 드래그를 제어하고 "Trailing space to container Margin"을 선택합니다. 마찬가지로 하단 레이아웃 가이드에 수직 간격을 선택합니다.

(Tip− 한 번에 여러 옵션을 선택하려면 Shift 키를 누르고 옵션을 선택합니다. 모든 것을 선택할 때까지 Shift를 놓지 마십시오.)

모든 제약 조건을 적용한 후보기는 다음과 같이 보일 것입니다.

스택보기

스택보기는 요소를 스택으로 배열하여 작동합니다. 정렬 후 제약 조건을 한 번만 정의하면 모든 요소가 그에 따라 정렬됩니다. 스택보기로 시작하려면 다음보기를 만드십시오. 다른 장치에서는보기 좋지 않습니다. 그러나이 섹션에서는 다른 장치에 적합하도록 만들 것입니다.

이제 상단의 두 버튼을 선택합니다. 하나의 버튼을 선택하고 command를 누른 다음 두 번째 버튼을 선택합니다. 스택보기에 임베드하려면 편집기 → 임베드 → 스택보기로 이동하십시오.

OR

오른쪽 하단 모서리

에이 옵션을 선택하는 옵션이 있습니다. 그러면 뷰가 스택 뷰에 포함됩니다.

수평 스택보기

수평 스택 뷰는 다음 스크린 샷과 같이 보입니다.

이 스택보기를 선택한 상태에서 속성 관리자로 이동합니다. 분포를 동일하게 채우고 간격을 10으로 변경합니다.

이제이 스택보기와 하단 버튼을 선택하고 다시 스택보기에 포함합니다. 이번에는 스택 뷰 축이 수직이고 이전 스택 뷰에서는 수평입니다.

수직 스택보기

이제보기는 다음과 같습니다.

이 스택보기가 선택되어있는 동안 속성 검사기로 이동하여 아래 스크린 샷과 일치하는지 확인하십시오.

이제보기는 다음과 같이 보일 것입니다.

마지막 단계는이 스택 뷰에 대한 제약을 만드는 것입니다.

스택보기를 선택하고 → 새 제약 조건 추가 버튼을 클릭합니다.

그러면 다음 스크린 샷에 표시된 단계를 따라야하는 새 창이 열립니다.

스택 뷰에 제약 조건 추가

다음 스크린 샷은 스택 뷰에 제약 조건을 추가하는 방법을 설명합니다.

이것이 우리가 자동 레이아웃으로 할 전부입니다. 다음 장에서는 애니메이션에 대해 논의 할 것입니다.

이것이 우리가 자동 레이아웃으로 할 전부입니다. 다음 장에서는 애니메이션에 대해 논의 할 것입니다.

애니메이션은 응용 프로그램에 사용자의 관심을 끌기 때문에 응용 프로그램의 중요한 부분입니다. 애니메이션은 빠른 속도로 반복되는 이미지 모음 일뿐입니다. 또한 응용 프로그램이 다른 응용 프로그램과 차별화됩니다.

애니메이션 프로젝트 만들기 − 키티 애니메이션

이것은 버튼을 클릭하면 애니메이션을 실행하는 간단한 프로젝트입니다. 여러 이미지를 사용하여 GIF를 만들 것이므로 GIF를 다운로드하여 이미지로 변환하면 해당 GIF의 여러 프레임이 제공됩니다.

이 섹션에서는 다음 이미지를 사용합니다.

이러한 이미지를 함께 재생하면 애니메이션이 만들어집니다. 따라서 우리는 단일보기 응용 프로그램을 만들 것입니다. 그런 다음 이미지보기 옵션, 레이블 및 기본보기 컨트롤러 내부의 버튼을 드래그합니다. 이 작업이 완료되면 이미지보기와 버튼을 빠른 파일에 연결합니다.

(이러한 이미지를 사용하지 않으려면 gif를 검색하고 일부 gif to image 변환기를 사용하여 온라인에서 이미지로 변환하십시오.)

버튼 액션 안에 버튼을 눌렀을 때 이미지를 표시하기 위해 다음 명령을 삽입합니다.

imageView.image = UIImage(named: "frame_0_delay-0.1s.gif") 
// frame_0_delay-0.1s.gif, is the name of image

이것이 우리가 프로그래밍 방식으로 이미지를 이미지 뷰에 할당하는 방법입니다. 이제보기는 다음과 같이 보일 것입니다.

첫 번째보기는 애플리케이션을 실행할 때 나타납니다. Animate 버튼을 클릭하면 이미지가 나타납니다.

이것은 애니메이션이 아니라 이미지입니다. 이제 애니메이션을 만들 것입니다.

이미지 출력 아래에 변수를 추가합니다. var counter = 1.

우리의 이미지에는 공통된 이름이 있고 한 문자 만 다릅니다. 애니메이션 버튼의 코드를 아래와 같이 변경하십시오.

@IBAction func animatePressed(_ sender: Any) { 
   imageView.image = UIImage(named: "frame_\(counter)_delay-0.1s.gif") 
   counter += 1 
   if counter == 9 { 
      counter = 0 
   } 
}

이제 animate버튼을 누르면 이미지가 매번 변경됩니다. 다음 단계는 다음을 만드는 것입니다.

  • 변수 만들기- isAnimating False를 할당하십시오.

  • 타이머 변수를 만들고 Timer() 기능.

위의 두 단계가 완료되면 애니메이션 함수를 만들고 다음 코드를 붙여 넣습니다.

func animate() { 
   imageView.image = UIImage(named: "frame_\(counter)_delay-s.gif") 
   counter += 1 
   if counter == 9 { 
      counter = 0 
   } 
}

여기서 counter는 이전 파일에서 만든 카운터 변수입니다. 이제 애니메이션 버튼 기능 안에 다음 코드를 추가하십시오.

if isAnimating { 
   timer.invalidate() 
   isAnimating = false 
} else { 
   timer = Timer.scheduledTimer(timeInterval: 0.1, target: self, selector: 
   #selector(ViewController.animate), userInfo: nil, repeats: true) 
   isAnimating = true 
}

응용 프로그램을 실행하면 장치에서 애니메이션이 실행되는 것을 볼 수 있습니다.

Challenge − 애니메이션을 중지하는 중지 버튼을 추가합니다.

애플리케이션에서 API에 연결하고 해당 API에서 데이터를 검색하고 애플리케이션에서 사용해야 할 수 있습니다.

첫째, 데이터를 제공 할 URL이 필요합니다.

api.openweathermap.org/data/2.5/forecast?id=524901&APPID=1111111111

그런 다음 서비스가 https가 아닌 경우 애플리케이션이 웹 서비스와 통신 할 수 있도록 전송 계층 보안 예외를 추가해야합니다. 우리는info.plist 파일.

마지막으로 네트워크 요청을 생성하는 URLSession을 생성합니다.

let urlString = URL(string: "your URL")  // Making the URL  
if let url = urlString {   
   let task = URLSession.shared.dataTask(with: url) { 
      (data, response, error) in // Creating the URL Session. 
      if error != nil {  
         // Checking if error exist. 
         print(error) 
      } else { 
         if let usableData = data { 
            // Checking if data exist. 
            print(usableData)   
            // printing Data. 
         } 
      } 
   }
}	
task.resume()

이것은 URL 세션을 사용하여 애플리케이션에서 웹 서비스를 사용하는 방법입니다.

Alamofire

Alamofire는 swift로 작성된 HTTP 네트워킹 라이브러리입니다. URL 요청, 데이터 게시, 데이터 수신, 파일 업로드, 데이터, 인증, 유효성 검사 등에 사용할 수 있습니다.

Aalmofire를 설치하려면 GitHub 에서 공식적으로 Alamofire로 이동하여 설치 가이드를 읽을 수 있습니다.

Alamofire에서 요청하기

Alamofire에서 요청하려면 다음 명령을 사용해야합니다.

Import Alamofire 
Alamofire.request("url");

응답 처리

다음 명령은 응답 처리에 사용됩니다.

Alamofire.request("url").responseJSON {  
   response in      
   print(response.request)   
   // original URL request     
   print(response.response)  
   // HTTP URL response      
   print(response.data)      
   // server data      
   print(response.result)    
   // result of response serialization       
   if let JSON = response.result.value {          
      print("JSON: \(JSON)")   
   } 
}

응답 검증

다음 명령은 응답 처리에 사용됩니다.

Alamofire.request("https://httpbin.org/get").validate().responseJSON {  
   response in      
   switch response.result {      
      case .success:         
      print("Validation Successful")      
      case .failure(let error):      
      print(error)      
   } 
}

URL 세션 및 Alamofire를 사용하여 URL 요청을 만드는 기본 사항입니다. 고급 Alamofire에 대한 자세한 내용은 Alamofire 문서 를 참조하십시오 .

동시성은 동시에 둘 이상의 것을 실행하는 방법입니다. 애플리케이션에서 동시성은 동시에 / 동시에 실행되는 여러 작업을 의미합니다.

동시성은 애플리케이션을 더 빠르고 깔끔하게 만들고 사용자에게 더 나은 경험을 제공 할 수 있습니다. 멀티 스레딩을 사용하는 것은 많은 개발자에게 어렵게 보이지만 API는NSOperationDispatch Queues 응용 프로그램에서 동시성 및 다중 스레딩을 쉽게 사용할 수 있습니다.

그랜드 센트럴 파견

GCD는 동시 코드를 관리하고 시스템 수준에서 비동기 적으로 작업을 실행하는 데 가장 일반적으로 사용되는 API입니다. GCD는 작업 대기열을 제공하고 사용합니다. 이러한 대기열은 FIFO 용어를 사용하는 데이터 구조입니다. 즉, 대기열의 첫 번째 작업이 먼저 실행되고 대기열의 마지막 작업이 마지막에 실행됩니다.

예를 들어, 영화 티켓 예약 라인을 가정 해 보겠습니다. 마지막 사람이면 마지막에 티켓을 받게되고, 누군가 뒤 따르면 티켓을 받게됩니다.

디스패치 대기열

디스패치 큐는 애플리케이션에서 작업을 비동기식으로 동시에 수행하는 쉬운 방법입니다. 두 가지 유형의 대기열이 있습니다.

  • Serial Queues − 일련의 작업을 저장하고 한 번에 하나의 작업을 실행합니다.

  • Concurrent Queues − 일련의 작업을 저장하고 한 번에 하나의 작업을 실행합니다.

큐를 생성하거나 가져 오는 데 사용되는 일부 기능은 다음과 같습니다.

dispatch_queue_create       
// create a serial or concurrent queue 
dispatch_queue_get_label     
// get the label of a given queue 
dispatch_get_main_queue   
// get the one and only main queue 
dispatch_get_global_queue    
// get one of the global concurrent queues

대기열에 작업 추가

대기열에 작업을 추가하는 데 도움이되는 두 가지 유형의 함수가 있습니다. 그들은-

Synchronous Functions

  • dispatch_once − 신청 기간이 지나면 과제를 제출합니다.

  • dispatch_sync − 작업을 대기열에 제출하고 작업이 완료된 경우에만 반환합니다.

Asynchronous Functions

  • Dispatch_async − 작업을 제출하고 반환합니다.

  • Dispatch_after − 즉시 반환되지만 특정 시간 동안 지연됩니다.

  • Dispatch_async − 즉시 반환되지만 작업이 여러 번 제출됩니다.

예제 코드

다음은 대기열에 작업을 추가하는 예제 코드입니다.

dispatch_async(dispatch_get_main_queue(), update_block);  
// add update_block to main queue  

dispatch_apply(i, some_queue, work_block)  
// add work_block to some_queue i times  

dispatch_sync(background_queue, blocking_block)  
// add blocking block to background queue and wait for completion

대기열 사용의 일반적인 예

다음 코드는 큐를 사용하는 예입니다.

dispatch_async(background_queue, ^ { 
   // Perform code that takes long time, here. 
   Dispatch_async(dispatch_get_main_queue(), ^ { 
      //Some other task, generally UI. 
   }); 
});

이것은 중급 iOS 개발자가 될 때까지 충분한 정보이므로 동시성 제어로 우리가 할 전부입니다.

배운 개념을 계속 연습하고 요구 사항에 따라 수정하고 통합하십시오.