Pengembangan iOS dengan Swift 2 - Panduan Cepat

Untuk mengembangkan aplikasi iOS, Anda harus memiliki perangkat Apple seperti MacBook Pro, Mac Mini, atau perangkat Apple apa pun dengan sistem operasi OS X, dan berikut ini -

  • Xcode - Dapat diunduh dari https://developer.apple.com/downloads/ Anda memerlukan akun pengembang Apple, yang gratis.

  • Simulator - Ini adalah iPhone / iPad virtual (Perangkat iOS) Anda, yang diinstal di Komputer Anda, jadi Anda tidak perlu menginstalnya secara terpisah.

Tentang Xcode

Xcodeadalah IDE default (Integrated Development Environment) yang disediakan oleh apple untuk Pengembangan Aplikasi iOS / OS X. Ini adalah IDE yang mencakup semua yang Anda butuhkan untuk mengembangkan iOS, OS X, Watch OS, Aplikasi TV OS, dll.

Untuk Menjalankan Xcode, Anda harus memiliki -

  • Perangkat Mac yang Menjalankan OS X, yaitu Sistem Operasi resmi Apple.
  • ID Apple (Gratis): Untuk mengunduh IDE.

Instalasi

Untuk menginstal Xcode di perangkat Anda, ikuti langkah-langkah selanjutnya. Lewati jika Anda sudah menginstal.

  • Buka App Store, Login jika Anda belum melakukannya, cari Xcode. Klik Dapatkan dan Instal.

  • Setelah Diunduh, buka Aplikasi atau Launchpad dan Jalankan aplikasi Anda.

  • Pada Proses Pertama, mungkin meminta beberapa Unduhan tambahan, biarkan mengunduh semuanya, masukkan kata sandi jika diminta.

  • Setelah semua ini selesai, Layar Selamat Datang akan muncul seperti gambar di bawah ini.

Dalam tutorial ini, kita akan mempelajari beberapa konsep dasar pengembangan iOS kita, yang meliputi -

  • Membuat Proyek Baru
  • Fitur IDE kami
  • Menavigasi melalui IDE
  • Menambahkan Label ke Tampilan Anda
  • Menjalankan aplikasi
  • Menyesuaikan simulator sesuai kenyamanan Anda

Jika Anda seorang pemula, maka tutorial ini akan sangat membantu.

Membuat Proyek Xcode Baru

Untuk membuat Proyek Xcode baru, kita harus mengikuti langkah-langkah yang diberikan di bawah ini.

Step 1 - Klik ikon Xcode di Launchpad Anda, lalu pilih Create a new Xcode project.

Step 2 - Pilih iOS dan kemudian pilih Aplikasi Tampilan Tunggal, klik Berikutnya.

Step 3- Layar berikutnya yang muncul akan memiliki beberapa bidang untuk diisi. Poin-poin berikut menjelaskan cara mengisi masing-masing bidang ini.

  • Masukkan Nama Proyek - ini bisa berupa nama yang menyerupai proyek Anda.

  • Bidang Tim dapat dikosongkan untuk saat ini. Ini digunakan saat kita membuat aplikasi di tim.

  • Nama organisasi adalah nama organisasi Anda atau jika itu adalah proyek pribadi Anda, Anda dapat menamainya apa saja. Tidak masalah sampai Anda ingin mempublikasikan aplikasi Anda di App Store.

  • Pengenal umumnya merupakan pengenal unik untuk aplikasi Anda, yang tidak boleh cocok dengan aplikasi lain di app store (hanya jika Anda memilih untuk mengunggah aplikasi Anda di App Store).

  • Bahasa akan Swift, perangkat akan universal, dan semua opsi lain tidak akan dicentang untuk saat ini.

Setelah semua detail terisi, klik tombol Next.

Step 4- Pilih lokasi tempat Anda ingin menyimpan proyek. Biarkan kotak centang "Buat Repositori Git" tidak dicentang untuk saat ini, karena kita tidak membutuhkannya sekarang. Klik Buat.

Selamat! Proyek Anda telah dibuat.

Navigasi melalui Lingkungan Xcode

Klik pada Main.storyboardopsi di dalam panel navigator Anda. Ini akan memunculkan tampilan utama, yang akan muncul saat aplikasi berjalan.

Menambahkan Label

Di pojok kanan bawah layar Anda ada bilah pencarian. Ketik label di bilah pencarian itu dan tekan kembali.

  • Setelah mencari Label, seret dan lepas Label ke tampilan utama Anda. Klik dua kali pada teks label dan Ketik "Hello World".

  • Seret label ke tengah tampilan, saat label berada tepat di tengah, dua garis berpotongan di tengah akan muncul.

Sekarang tampilan Anda akan terlihat seperti tangkapan layar berikut.

Menjalankan Aplikasi

Pilih perangkat Anda, klik tombol Putar di sudut kanan atas.

Ini adalah aplikasi terakhir kami, berjalan pada simulator iPhone 7.

Menyesuaikan Properti Simulator

Saat kami menjalankan aplikasi untuk pertama kali, layar simulator Anda mungkin tidak cocok untuk layar desktop atau laptop Anda. Jadi, saat simulator Anda berjalan di latar depan, klik Window → Scale, dan pilih persentase ukuran Layar Simulator yang sesuai dengan tampilan Anda.

Kami akan terus membahas tentang fitur simulator, seperti dan kapan kami menggunakannya dalam tutorial ini.

Bagus sekali, ini adalah Aplikasi Pertama, yang Anda selesaikan dengan sukses. Bersulang!

Pada bab ini, kami akan memperkenalkan beberapa hal baru dan fitur UI yang disediakan iOS untuk interaksi dengan pengguna. Kami akan menambahkan -

  • Bidang Teks
  • Labels
  • Tombol dan tindakannya

Selain itu, kami akan menulis kode dengan cepat untuk Label Dinamis, yang akan menampilkan hasil kalkulasi dari input yang dimasukkan oleh pengguna.

Yang kami maksud dengan judul "Membuat aplikasi kita interaktif" adalah membuat aplikasi kita berinteraksi dengan pengguna. Oleh karena itu, di sini kami memberi pengguna kekuatan untuk berinteraksi dan mengontrol aplikasi.

Menambahkan Bidang Teks

Di sini, kami akan kembali membuat proyek baru. Ini harus mudah dikelola, karena kita telah membahas cara membuat proyek baru di Xcode.

Oke, jadi sekarang kita akan membuat Proyek Baru bernama "My Dog's Age". Setelah membuat proyek ini, kita akan mengklik File "Main.storyboard" dan mengikuti langkah-langkah yang diberikan di bawah ini.

  • Di bilah Pencarian Panel utilitas (terletak di sudut kanan bawah Xcode), cari Label. Klik dan Seret Label itu ke main.storyboard / (View) Anda. Kemudian, klik dua kali pada label dan ubah namanya menjadi - "My Dog's Age".

  • Telusuri "bidang teks", klik dan seret bidang teks itu ke Tampilan Anda. Saat bidang teks ini dipilih, buka inspektur atribut dan ubah jenis keyboard ke Papan angka, sehingga hanya angka yang dapat dimasukkan seperti yang ditunjukkan pada gambar di bawah.

Menambahkan Tombol ke Tampilan kami

Sekarang cari Tombol di bilah pencarian. Tarik itu ke tampilan Anda, klik dua kali padanya dan ganti namanya menjadi "Hitung".

Menambahkan Label ke Tampilan

Cari label dan tambahkan di bawah tombol, untuk menampilkan keluaran usia. Klik dua kali dan buat label kosong dan regangkan sedikit, sehingga keluaran lengkap terlihat.

Tip - Jika Anda tidak dapat mengganti nama dengan mengklik dua kali, pilih item dan di panel utilitas - Attribute inspector, ada judul item itu, modifikasi di sana dan tekan Return seperti yang ditunjukkan pada gambar berikut.

Sekarang, Main.storyboard Anda akan terlihat seperti tangkapan layar berikut.

Kita tidak berhenti sampai disini, sekarang kita akan membahas bagaimana cara menambahkan gambar ke main.storyboard.

Menambahkan Gambar ke Tampilan Kami

Untuk memulainya, pertama-tama kita harus mencari gambar, yang ingin kita tambahkan dalam proyek. Anda dapat mengunduh gambar yang diberikan di bawah ini -

Salin gambar ini ke proyek Anda, atau seret gambar ini ke proyek Anda, maka Anda akan melihat jendela berikut.

Pastikan Anda memilih, menyalin item jika perlu dan membuat grup. Klik pada tombol Selesai.

Sekarang, buka Panel Utilitas → Perpustakaan Objek dan cari tampilan Gambar. Tarik tampilan gambar ke tampilan Anda. Sekarang tampilan Anda akan terlihat seperti gambar di bawah ini.

Sekarang, klik pada Tampilan Gambar ini, Anda cukup menyeret tampilan Anda dan kemudian Anda akan melihat bahwa di area utilitas ada opsi bernama "Gambar" untuk memilih gambar. Klik panah itu dan Anda akan melihat semua gambar yang tersedia. Pastikan Anda telah memilih tampilan gambar yang baru ditambahkan ini.

Sekarang Anda telah memilih gambar untuk tampilan gambar Anda, tampilan akhir Anda akan terlihat seperti tangkapan layar berikut. Ini adalah satu-satunya hal yang akan kami lakukan dengan main.storyboard kami, untuk aplikasi ini.

Ini adalah tampilan kami sekarang setelah menambahkan semua elemen UI.

Setelah ini, kami memiliki implementasi logis dari kode kami yang akan kami lanjutkan jika Anda telah menyelesaikan hingga langkah ini.

Sekarang, pilih pengontrol tampilan Anda dan buka asisten editor dengan mengklik tombol asisten editor di sudut kanan atas (seperti yang ditunjukkan pada gambar di bawah).

Sekarang, tampilan kita akan terlihat seperti screenshot berikut.

Menambahkan Fungsi ke Aplikasi Kami

Sampai saat ini, aplikasi kita hanyalah Aplikasi Statis, yang tidak merespon apapun dan tidak berubah pada interaksi pengguna.

Sekarang sampai pada bagian utama menghubungkan Elemen UI kami ke Kode kami dan UI akan berubah sesuai dengan Input pengguna. Itu“ViewController.swift” file adalah file utama kami di mana kami akan menulis kode untuk tampilan kami saat ini.

Note- Saat ini kami sedang mengerjakan single views, nanti ketika kami membahas tentang multiple views. Kami akan membahas bagaimana file yang berbeda mengontrol Tampilan yang berbeda.

Klik pada bidang teks, tekan kontrol dan seret kursor Anda ke bagian kedua dari layar, yaitu file viewcontroller.swift. Anda akan melihat garis biru menghubungkan view kami dan file swift. Saat Anda melepaskan mouse, Anda akan melihat munculan, meminta masukan.

TIP- Isi bidang Nama dengan Nama apa pun yang mirip dengan bidang Input Anda. Satu hal yang penting adalah bahwa nama tidak boleh memiliki spasi, sehingga Anda dapat menuliskannya seperti yang ditunjukkan pada gambar sebelumnya, yaitu jika nama memiliki banyak kata, maka kata pertama harus ditulis dalam huruf kecil, kemudian alfabet pertama setiap kata berikutnya kata akan menjadi modal.

Ikuti prosedur yang sama dan hubungkan Elemen lainnya. Ingatlah bahwa untuk bidang teks dan label, jenisnya adalah Outlet. Namun, saat menambahkan tombol, jenisnya harus berupa tindakan seperti yang ditunjukkan pada gambar di bawah.

Pada tahap ini, viewcontroller.swift kita akan terlihat seperti -

Sekarang, di dalam tindakan tombol Anda, tambahkan baris berikut -

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

Tip- Kita tidak perlu menambahkan titik koma untuk mengakhiri baris dengan cepat, tetapi bahkan jika kita meletakkan titik koma, kompilator tidak akan melaporkan kesalahan apa pun .

Pada kode di atas, baris pertama mendeklarasikan variabel 'usia', yang akan kita bahas di bab selanjutnya. Kemudian kami menetapkan nilai yang dimasukkan oleh pengguna, dengan mengubahnya menjadi Integer, dan mengalikannya dengan 8.

Di baris kedua, kami menetapkan nilai 'usia' ke label keluaran kami. Pada tahap ini, pengontrol tampilan kita akan terlihat sebagai berikut -

Sekarang, kita akan menjalankan aplikasi kita dan begitulah tampilannya.

Tip- Jika keyboard Anda tidak muncul saat pertama kali dijalankan, buka simulator Anda, klik pada perangkat keras, buka keyboard dan klik Toggle Software Keyboard.

Pada bab selanjutnya, kita akan membahas tentang alat baru yang disebut Playground. Kami juga akan mempelajari beberapa konsep cepat seperti Variabel, Kamus, Array Loop, Kelas dan objek.

Dalam bab ini, kami akan memperkenalkan lingkungan baru tempat kami dapat menulis dan menjalankan kode swift. Kami juga akan membahas aspek-aspek berikut dari taman bermain cepat -

  • Variables
  • Dictionaries
  • Arrays
  • Loops
  • Kelas & Objek

Note- Kami hanya akan melihat melalui konsep dasar tersebut, yang akan kami gunakan dalam tutorial ini, jika Anda ingin belajar cepat secara mendalam, Anda dapat memeriksa Tutorial Swift kami .

Playground adalah alat yang disediakan dengan Xcode untuk menjalankan kode swift. Kami akan mulai dengan membuat taman bermain baru.

Memulai Swift Playground

Untuk membuat taman bermain yang cepat, klik ikon Xcode, dan pilih opsi pertama, mulailah dengan taman bermain yang cepat.

Beri nama taman bermain Anda dan pilih Platform sebagai iOS. Mari kita beri nama taman bermain kita sebagai Demo Playground. Klik Berikutnya.

Ini adalah satu-satunya langkah yang perlu Anda ikuti untuk membuat Playground. Tangkapan layar berikut menunjukkan Playground.

Sr Tidak Konsep & Deskripsi Dasar
1 Variabel

Variabel adalah memori / penyimpanan yang dapat digunakan program kita untuk menyimpan dan memanipulasi data. Setiap variabel memiliki tipe data tertentu, yang menentukan ukuran variabel yang akan menempati memori.

2 Kamus

Kamus adalah kumpulan yang menyimpan nilai dalam pasangan nilai kunci, yaitu data yang disimpan dalam kamus disimpan dalam metode di mana setiap nilai terkait dengan kunci. Di sini, setiap kunci unik dan tidak dapat muncul dua kali dalam kamus yang sama.

3 Array

Array adalah tipe data yang menyimpan tipe data yang sama dalam daftar berurutan. Nilai yang sama dapat muncul di beberapa indeks / Tempat dalam satu larik.

4 Loop (Aliran Kontrol)

Swift menyediakan berbagai Pernyataan Arus Kontrol. Pengulangan umumnya digunakan untuk mengulang suatu kondisi atau pernyataan beberapa kali, sampai kebutuhan Condition / Programmer dari loop tersebut terpenuhi.

5 Kelas dan Objek

Kelas adalah konstruksi fleksibel untuk tujuan umum yang merupakan blok bangunan kode program Anda.

Objek adalah istilah yang umumnya digunakan untuk merujuk pada turunan kelas, jadi kita bisa menyebutnya sebagai turunan daripada objek.

Di bab ini, kita akan membuat dua Aplikasi baru menggunakan Swift.

Aplikasi Pertama - "Tebak Angka"

Pada bagian ini, kita akan membuat Aplikasi bernama "Tebak nomornya". Untuk membuat aplikasi ini, buat Aplikasi iOS Single View baru dan beri nama apa pun yang Anda inginkan.

Klik pada main.storyboard dan pilih tampilan utama Anda.

  • Tambahkan label teks → Ubah teks menjadi “Tebak angkanya”. Ubah warna, properti ukuran dan buat sesuai kebutuhan Anda.

  • Tambahkan bidang Input, rentangkan ke tampilan penuh.

  • Tambahkan tombol dan beri nama “Tebak.

  • Tambahkan satu label lagi, rentangkan, dan kosongkan kotak teks.

Ini adalah cara Anda view akan terlihat seperti setelah menambahkan semua elemen.

Sekarang Beralih ke asisten editor dan Klik seret dari elemen UI Anda untuk melihat file pengontrol, lalu hubungkan bidang teks sebagai outlet dan beri nama userInput. Demikian pula,

  • Hubungkan label kosong sebagai outlet dan beri nama resultLabel.
  • Hubungkan tombol Guess sebagai aksi dan beri nama guessButtonPressed.

Apa logikanya?

Logikanya sederhana, kita akan menghasilkan angka acak antara 0-9 dan melihat apakah itu sama dengan angka yang dimasukkan pengguna, atau tidak. Jika itu sama, kami akan menunjukkan "kamu benar", kalau tidak kami akan menunjukkan "kamu salah!".

Menerapkan logika

Untuk menghasilkan angka acak antara 0-9, kita akan menggunakan perintah berikut.

let rollIt = String(arc4random_uniform(10))

Kemudian kami akan menggunakan logika berikut untuk memeriksa apakah itu sama dengan input pengguna atau tidak.

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

Beginilah logika terakhir Anda dalam fungsi aksi tombol akan terlihat.

@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 + "." 
   } 
}

Aplikasi terakhir Anda akan terlihat seperti ini sekarang.

Mari kita sekarang menjalankan Aplikasi kita dan memeriksanya output. Layar pembuka akan terlihat sebagai berikut -

Selanjutnya, beri makan nomor di input daerah.

Mari beri makan nomor lain dan periksa hasilnya -

Kami telah menyelesaikan satu Aplikasi lagi. Coba jalankan aplikasi ini, dan masukkan input yang berbeda.

Aplikasi Kedua - "Is It Prime"

Dalam aplikasi ini, kami akan mengambil input dari pengguna dan kami akan memeriksa apakah bilangan itu prima atau tidak -

  • Layout - Mirip dengan aplikasi sebelumnya, kita membutuhkan input, tombol dan label output.

  • Challenges- Buat UI dan hubungkan elemen ke kode. Selain itu, cobalah jika Anda dapat membuat sendiri proyek lengkapnya. Jika Anda berhasil membuatnya sendiri, maka itu hebat dan Anda melakukannya dengan sangat baik dengan Pengembangan iOS.

Jika Anda tidak bisa mengelola, jangan khawatir. Lihatlah gambar berikut dan coba lakukan hal yang sama.

Cobalah untuk membuat tampilan seperti ini, jika Anda belum dapat melakukannya, silakan baca bagian sebelumnya di mana kami telah mengembangkan Game Tebak.

Apa Logika itu?

Bilangan prima adalah bilangan yang tidak dapat dibagi dengan bilangan lain kecuali 1 dan bilangan itu sendiri.

Example - 7 adalah bilangan prima karena bilangan lain selain 1 dan 7 tidak dapat membaginya.

Bagaimana Menerapkannya?

Cobalah untuk menulis kode untuk memeriksa bilangan prima. Kemudian ambil input pengguna dan lihat apakah itu bilangan prima atau tidak. Jika ya, maka tunjukkan prima; jika tidak, tunjukkan tidak prima di label hasil Anda.

Berikut adalah kode untuk memeriksa apakah nomor yang diberikan adalah "prima" atau tidak -

@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"                 
      } 
   } 
}

Seperti inilah tampilan tombol Anda. Berikut adalah gambar dari kode terakhir dan tampilan -

Seperti inilah tampilan aplikasi Anda yang sedang berjalan jika Anda mengikuti prosedur.

Sekarang, mari kita uji Aplikasi kita dengan memberikan nilai input -

Dalam bab ini, kita akan membahas beberapa fitur lanjutan seperti Membuat Beberapa Tampilan pada Aplikasi kita, Menambahkan Bilah Navigasi, Menambahkan Tampilan Tabel, Menyimpan Data dalam Aplikasi, Membuat Aplikasi Web, dll.

Silakan telusuri setiap bagian dengan hati-hati, karena bab ini berisi sebagian besar hal, yang kami butuhkan saat mengembangkan aplikasi.

Pengontrol Tampilan Ganda

Dalam aplikasi kami sebelumnya, kami hanya memberikan satu view / view controller. Namun, kami dapat memiliki beberapa tampilan dalam aplikasi kami dan kami dapat melakukannya secara independen.

Oleh karena itu, kami akan mulai dengan membuat proyek baru; nama proyek ini memiliki banyak tampilan. Seperti proyek lainnya, proyek ini juga memiliki Pengontrol Tampilan dan File Swift untuk pengontrol tersebut. (Ini dapat Anda lihat dengan memilih view & melihat propertinya di Identity Inspector.)

Tangkapan layar berikut menunjukkan bagaimana tampilan kami saat ini terlihat -

Di sisi kanan (Inspektur identitas), kita dapat melihat kelas yang terkait dengan pengontrol tampilan kita. Panah di sebelah kiri ini adalah titik masuk. Ini adalah tampilan pertama aplikasi kita yang akan ditampilkan setelah aplikasi mulai berjalan.

Menambahkan Pengontrol Tampilan Ganda Kedua

Untuk menambahkan pengontrol tampilan lain ke aplikasi kami, kami akan mencari pengontrol tampilan di perpustakaan objek kami. Setelah kami menemukannya, kami akan menyeret pengontrol tampilan ke main.stroryboard kami, tepat di luar tampilan lainnya.

Seperti inilah tampilan aplikasi Anda. Sekarang, kami telah menambahkan pengontrol tampilan, tetapi sekarang kami juga perlu membuat kelas pengontrol tampilan untuk tampilan yang baru kami tambahkan.

Right click on your project → new File → cocoa Touch Class → Beri nama apa pun yang Anda inginkan, kami akan menamainya "SecondViewController".

Ini adalah cara Anda membuat file kelas untuk pengontrol tampilan Anda. Sekarang, kembali ke "main.storyboard" Anda, klik pada pengontrol tampilan kedua Anda dan lihat Identity Inspector.

Bidang kelas harus kosong sekarang, jadi klik pada bidang itu dan mulailah mengetik nama kelas Anda yang Anda tambahkan pada langkah terakhir. Jika sudah muncul, klik enter.

Kami sekarang telah membuat pengontrol tampilan ganda dan menambahkan file kelas pengontrol untuk Tampilan itu. Namun, jika Anda menjalankan aplikasi, itu tidak akan menunjukkan tampilan kedua Anda. Mengapa?

Karena kami belum menambahkan fungsi, yang akan membawa kami ke tampilan tersebut. Singkatnya, kami belum menambahkan Navigasi ke Aplikasi kami. Jangan khawatir; kami akan membahasnya di bagian berikut.

Menambahkan Navigasi ke Aplikasi

Proses transisi dari satu tampilan ke tampilan lainnya disebut Segueing, yaitu dilakukan dengan membuat segue di antara dua tampilan. Untuk melakukan ini, tambahkan tombol di pengontrol tampilan pertama, dan kontrol seret dari itu ke tampilan kedua Anda. Saat Anda melepaskan tombol, Anda akan melihat beberapa opsi seperti yang ditunjukkan pada gambar di bawah.

Pilih opsi Show dari Action Segue. Sekarang jalankan aplikasi Anda, Anda akan melihat bahwa dengan mengklik tombol, Anda akan melihat tampilan kedua (Untuk melihat lebih jelas, tambahkan sesuatu dalam tampilan kedua Anda, sehingga Anda dapat mengidentifikasi).

Namun, sekarang Anda tidak dapat kembali ke tampilan pertama Anda. Untuk itu, kami punyaNavigation controllers.

Menambahkan Pengontrol Navigasi

Pilih pengontrol tampilan pertama Anda dan di bilah atas, klik Editor → Embed in → Navigation controller.

Sekarang, aplikasi kita akan terlihat seperti tangkapan layar berikut.

Kita harus memastikan bahwa, ada baris abu-abu terang di atas tampilan. Sekarang, ketika kita menjalankan aplikasi, kita dapat melihat bahwa ada bilah navigasi di atas tampilan. Ketika kita mengklik tombol tersebut, kita akan pergi ke tampilan kedua, di mana kita akan melihat tombol kembali di bilah navigasi itu. Klik ini dan kita akan kembali ke Tampilan Awal.

Menambahkan Judul & Tombol Kembali ke Bilah Navigasi

Untuk menambahkan judul ke bilah navigasi Anda, klik pada bilah navigasi, dan lihat inspektur atributnya. Di sana kita akan melihat -

  • Title - Ini akan menjadi judul bilah Navigasi, yang muncul di tengah.

  • Prompt - Ini muncul di atas bilah judul, di tengah.

  • Back Button - Di sini Anda dapat mengubah Teks yang muncul di tombol kembali.

Saat ini tombol yang melewati tampilan terletak di tampilan kita, yang mungkin tidak sesuai jika kita ingin sesuatu yang lain muncul di layar. Oleh karena itu, kami akan menambahkan item Tombol Bar di bilah navigasi, yang akan membawa kami ke tampilan kedua kami. Namun, untuk ini pertama-tama kita harus menghapus tombol terakhir yang kita tambahkan.

Menambahkan Item Tombol Bar

Cari item tombol bar di pustaka objek dan drag drop ke sisi kanan dari bar navigasi. Beri nama sebagai - “Next>”, kontrol drag dari itu ke tampilan kedua, pilih Show seperti yang kita lakukan dengan tombol terakhir yang kita tambahkan.

Sekarang jalankan aplikasinya, maka akan terlihat lebih bersih dan lebih baik. Ini semua yang akan kita lakukan dengan Navigasi sekarang. Di bab-bab selanjutnya, kami akan memodifikasi bilah navigasi menggunakan Kode Swift, jika diperlukan.

Tampilan Tabel

Tabel menyajikan data sebagai daftar kolom tunggal yang berisi beberapa baris, yang selanjutnya dapat dibagi menjadi beberapa bagian. Tabel harus digunakan untuk menyajikan data dengan cara yang bersih dan efisien.

Di bagian ini, kita akan memahami cara menambahkan tampilan tabel, menambahkan sel prototipe, menambahkan sumber data dan delegasi untuk tampilan tabel, mengubah properti tabel, dan mengatur data dinamis untuk sel tampilan tabel.

Menambahkan Tampilan Tabel

Untuk menambahkan tampilan tabel, pertama kita akan membuat proyek baru dan menamainya sebagai - "tableView". Lalu, pergi ke perpustakaan objek dan cari Tampilan Tabel, kita akan melihat tampilan tabel, pengontrol tampilan tabel dan banyak opsi lainnya. Namun, kita harus memilih tampilan tabel, menyeretnya dan menambahkan ke tampilan default Controller.

Menambahkan Sel Prototipe

Rentangkan tampilan tabel sehingga mencakup tampilan lengkap, sementara tampilan tabel Anda disorot. Periksa inspektur atributnya, ada bidang yang disebut sel Prototipe, yang saat ini 0. Kita harus mengubah nilainya menjadi 1, sekarang tampilan Anda akan terlihat seperti berikut -

Mengubah Pengenal Sel

Sekarang, di dalam tampilan Anda, klik sel prototipe Anda (yang sedikit rumit). Jadi, dalam outline dokumen Anda, klik pada View controller → View → Table View → Table View Cell, dan sekarang dalam atribut inspector ada kolom bernama Identifier, klik itu dan beri nama “Cell”. Lihat screenshot berikut untuk memahami langkah-langkah di atas.

Menambahkan Delegasi & Sumber Data

Untuk membuat tampilan tabel kita dinamis, kita membutuhkannya untuk memuat data dinamis. Oleh karena itu, dibutuhkan delegasi dan sumber data untuk itu. Untuk membuat delegasi dan sumber data tabel Anda, kontrol seret dari tampilan tabel ke pengontrol tampilan Anda atau tombol kuning di atas pengontrol tampilan seperti yang ditunjukkan pada gambar di bawah.

Saat kita melepaskan kursor, kita akan melihat dua opsi di sana, dataSource dan delegate, pilih satu per satu (saat Anda memilih salah satu opsi, pop up akan bersembunyi, Anda perlu mengulangi langkah di atas untuk menambahkan opsi kedua) . Sekarang akan terlihat seperti -

Ini semua yang akan kita lakukan dengan UI / Main.Storyboard kita, sekarang. Sekarang beralih ke file "ViewController.swift". MenambahkanUITableViewDelegate, UITableViewDataSource, ke viewController.swift Anda seperti yang ditunjukkan di bawah ini -

Namun, sekarang Xcode akan menampilkan kesalahan di baris ini.

Ini karena ada beberapa metode yang perlu kita gunakan UITableView

Untuk melihat metode ini, Command + klik pada UITableViewDataSouce, dan salin dua metode pertama, yang memiliki Argumen “numberOfRowsInSection”, “cellForRowAtIndex” dan tempelkan di ViewController.swift, sebelum viewDidLoad () kita.

Hapus baris ini @available(iOS 2.0, *), dari kedua metode dan tambahkan kurung kurawal buka dan tutup "{}". Sekarang, tampilan akan terlihat seperti berikut -

Xcode harus menunjukkan kesalahan di kedua fungsi. Namun, jangan khawatir karena kami belum menambahkan tipe kembalian dari fungsi tersebut.

numberOfRowsInSection- Fungsi ini menentukan jumlah baris yang akan dikandung bagian kita. Jadi sekarang tambahkan baris ini ke metode Anda.

return 1 //This will return only one row.

cellForRowAt - Metode ini mengembalikan konten untuk setiap sel, indexPathberisi indeks setiap sel. Kami akan membuat sel dan kemudian kami akan menetapkan beberapa Nilai ke Sel itu dan akhirnya mengembalikan sel.

Sekarang, fungsi Anda akan terlihat seperti berikut -

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 
}

Di baris pertama, kami membuat sel dengan gaya default, dan reuseIdentifier adalah nama sel prototipe yang kami buat.

Cell.textLable?.text - Ini mendefinisikan teks yang harus muncul sebagai judul sel itu.

Akhirnya, kami mengembalikan sel dari sana. Coba jalankan Aplikasi Anda sekarang, akan terlihat seperti berikut -

Aplikasi Tabel Waktu

Dalam aplikasi ini, kami akan melanjutkan proyek terakhir kami, dan kami akan membuat aplikasi di mana kami mencetak tabel 2 (2… 10…. 20).

Jadi, untuk membuat aplikasi ini, cukup ubah file pengontrol tampilan proyek.

Ubah fungsi seperti yang ditunjukkan di bawah ini -

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") 
}

Sekarang, jalankan aplikasi Anda. Ini akan terlihat seperti yang ditunjukkan di bawah ini.

Sekarang, karena kita telah menyelesaikan tampilan tabel dan membuat aplikasi, jadi inilah tantangan singkat yang harus kita selesaikan.

Tantangan

Buatlah aplikasi, di mana kami mencetak tabel hitung nomor mana saja yang dimasukkan pengguna.

Hint- Ambil masukan, tambahkan tombol, yang bila ditekan akan memuat tabel dengan penghitungan angka tersebut. Di sini kita juga membutuhkan fungsi berikut, yang akan memuat ulang data tabel.

tableView.reloadData()

Ini adalah tantangan bagi Anda karena kami telah membahas semua topik tentang aplikasi ini, jadi kami tidak akan memberikan solusi untuk ini.

Aplikasi Timer Telur

Dalam aplikasi ini, Kami akan menggunakan konsep Timer() dan Class Constructor, yang mengatur waktu. Kami akan memberikan Anda konsep dan pengkodean. Anda harus membuat UI sendiri karena kami telah membahas setiap Elemen UI berkali-kali di bab-bab sebelumnya. (Meskipun kami akan memberikan petunjuk untuk segala sesuatu yang terlihat cukup baru).

Tata letak aplikasi terakhir Anda akan terlihat seperti ini -

Apa yang terjadi di aplikasi ini?

  • Label judul memiliki nilai awal 210.

  • Pada klik tombol putar, nilai harus berkurang satu setiap detik.

  • Pada klik jeda, nilai harus berhenti di situ saja.

  • Pada klik -10, nilai harus dikurangi 10, dan penurunan harus dilanjutkan.

  • Pada klik +10, nilai harus dinaikkan 10, dan penurunan harus dilanjutkan.

  • Saat mengklik Reset, nilainya menjadi 210.

  • Nilai tidak boleh di bawah 0.

Konsep

  • Kita akan menggunakan variabel kelas Timer () → var timer = Timer ().

  • Kami akan menetapkan nilai ke variabel timer yang baru saja kami buat.

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

    • timeInterval -> adalah interval waktu yang ingin kita gunakan,

    • target -> adalah pengontrol tampilan yang harus diterapkan,

    • selector -> adalah nama fungsi yang akan menggunakan timer ini,

    • userInfo -> null and repeats, yes we want to repeat so Itu benar.

Pewaktu Tidak Valid

Untuk menghentikan timer melalui pemrograman, kami akan menambahkan timer.invalidate() fungsi.

Elements we have used -

Navigation bar - Di bilah navigasi, kami telah menambahkan tiga item.

  • Item Tombol Bar, satu di kiri dan satu di kanan.
  • Judul bernama - “Our Egg Timer”.

Toolbar - Bilah alat muncul di bagian bawah layar aplikasi dan berisi tombol untuk melakukan tindakan yang relevan dengan tampilan atau konten saat ini di dalamnya.

Bilah alat tembus cahaya dan mungkin memiliki warna latar belakang. Mereka sering bersembunyi ketika orang tidak mungkin membutuhkannya.

Kami telah menambahkan toolbar di bagian bawah UI kami, yang memiliki 5 item.

  • Tiga item tombol Bar, bernama -10, Reset dan +10.
  • Dua Ruang fleksibel: Ruang fleksibel antara item tombol bar -

Bagaimana cara menambahkan ikon ke item tombol bar?

Pilih item tombol bar Anda. Klik pada item tombol bar Anda, pergi ke inspektur atribut, klik Pilih Item dan pilih item dari Dropdown yang muncul.

Demikian pula, pilih item untuk semua tombol lainnya dan buat UI seperti yang diberikan di atas. Tambahkan label ke tengah View dan hubungkan sebagai outlet, beri nama -timeLeftLabel.

Tindakan untuk Timer Mulai

Berikut adalah program untuk pengatur waktu mulai.

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

Buat fungsi berikut -

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

Tindakan untuk Fungsi Berhenti

Berikut adalah program untuk fungsi stop.

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

Tindakan untuk Mengurangi Waktu

Berikut program pengurangan waktu.

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

Tindakan untuk Mengatur Ulang Waktu

Berikut adalah program untuk mengatur ulang waktu.

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

Tindakan untuk addTime

Berikut program penambahan waktu.

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

Sekarang, viewController.swift akan terlihat seperti -

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
   } 
}

Ini semua yang akan kita lakukan dalam aplikasi kita, coba jalankan aplikasi, seharusnya berjalan dengan baik.

Menyimpan Data di Penyimpanan Lokal

Menyimpan data di penyimpanan lokal berarti menggunakan penyimpanan perangkat lokal untuk menyimpan data yang terkait dengan aplikasi di perangkat. Kami memiliki dua cara untuk menyimpan data di penyimpanan lokal yaituNSUserDefault dan CoreData.

Mari kita pahami secara detail.

NSUserDefaults

NSUserDefaults dimaksudkan untuk menyimpan potongan kecil data seperti preferensi, pengaturan, atau nilai individual. Untuk menggunakan UserDefaults di aplikasi kita, kita hanya perlu membuat referensi ke nsuserDefaults melalui kode kita seperti yang ditunjukkan di bawah ini.

let defaultValues = NSUserDefaults.standardUserDefaults()

Untuk mengatur nilai ke data di UserDefaults kita dapat menggunakan kode berikut -

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)

Untuk mendapatkan nilai dari NSUserDefaults, kita dapat menggunakan kode berikut.

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 adalah kerangka kerja persisten, yang mendukung transaksi data besar. CoreData memungkinkan Anda membangun model entitas-atribut relasional untuk menyimpan data pengguna. CoreData adalah kerangka kerja dan dapat menggunakan SQLite, format biner untuk menyimpan data.

Untuk menggunakan CoreData dalam aplikasi kita, kita akan mulai dengan proyek baru dan memastikan Anda mencentang "Gunakan Data Inti", saat membuat proyek.

Login Using core Data - Buat proyek baru, pilih gunakan CoreData seperti yang ditunjukkan pada tangkapan layar berikut.

Lanjutkan hingga proyek terbuka, sekarang kami melihat bahwa proyek memiliki lebih banyak file daripada proyek kami sebelumnya.

File ini CoreData_demo.xcdatamodeld adalah database kami di mana kami akan membuat tabel pengguna dan menyimpan data.

Concept - Hal tentang CoreData adalah, meskipun kita menutup aplikasi, dan membukanya setelah berbulan-bulan, data yang kita simpan akan tetap ada, yang akan kita lihat di aplikasi berikutnya yang kita buat.

Sekarang kita akan melihat bagaimana menambahkan data inti dan mengambil data inti.

Adding Core Data- Untuk menambahkan CoreData, klik file CoreData_demo.xcdatamodeld dan kemudian kita akan melihat bahwa entitas kosong. Klik tombol add Entity, itu akan menambahkan entitas, sekarang klik dua kali pada nama entitas dan ganti namanya sesuka Anda.

Sekarang klik pada entitas dan kita dapat melihat bahwa bidang atribut kosong. Klik pada simbol plus dan ganti nama entitas. Pilih jenis entitas dari bidang berikutnya.

Kami telah menambahkan Entitas dan satu Atribut di dalamnya. Sekarang, jika kita pergi keAppDelegate.swift, kita dapat melihat bahwa dua fungsi baru telah ditambahkan karena kita memilih CoreData. Dua fungsi yang ditambahkan adalah -

Note - Impor CoreData di file Anda sebelum melanjutkan.

Saving data to Core Data - Untuk menyimpan beberapa data di CoreData, kita perlu membuat objek AppDelegate Class.

let appDelegate = UIApplication.shared.delegate as! AppDelegate

Dan, objek konteks

let context = appDelegate.persistentContainer.viewContext

Kemudian, kita perlu membuat objek entitas, yang akan memanggil entitas kita -

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

Kami sekarang akan menetapkan nilai atribut yang kami buat.

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

Kami akan menyimpan data menggunakan

context.save();

Fetching from core data- Saat mengambil, dua langkah di atas (membuat appDelegate dan konteks) akan sama. Kemudian, kami akan membuat permintaan pengambilan.

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

Kami akan membuat objek untuk menyimpan hasilnya.

let results = try context.fetch(request)

Kemudian kami akan memeriksa hasil sesuai kebutuhan kami. Kita akan melihat lebih banyak CoreData dengan aplikasi berikutnya yang kita buat.

Challenge- Coba buat aplikasi, di mana pengguna memasukkan nama, lalu klik login dan tutup aplikasi. Saat pengguna membuka aplikasi di lain waktu, ia harus tetap masuk. Kemudian tambahkan tombol - logout, dan jika ia mengkliknya, aplikasi akan meminta nama pengguna lagi.

Masuk / Keluar menggunakan CoreData

Buat proyek tampilan tunggal yang disebut 'Login', pilih penggunaan CoreData. Klik CoreData_demo.xcdatamodeld dan tambahkan entitas bernama 'Pengguna'. Di dalamnya, tambahkan atribut bernama 'name'.

Buka main.storyboard, Tambahkan kolom teks dan tombol login. Di bawahnya, tambahkan label, klik dua kali di atasnya dan hapus isinya. Kemudian, tambahkan tombol logout, buka inspektur atributnya dan buat 'alpha' sama dengan 0. Sekarang, tampilan kita akan terlihat seperti berikut -

Sekarang, buka file pengontrol tampilan Anda, buka asisten editor dan buat koneksi antara Elemen UI dan file pengontrol Anda.

Note- Kami juga akan membuat outlet untuk kedua tombol tersebut, karena kami perlu mengubah tampilan tombol tersebut. Misalnya - Saat pengguna masuk, kami akan menyembunyikan tombol masuk, jika pengguna tidak masuk kami akan menampilkan login dan menyembunyikan tombol logout.

Karena kita telah membahas tentang menambahkan dan mengambil data dari CoreData, kita akan meletakkan kodenya di sini.

Try-Catch- Anda akan melihat bahwa kami telah menggunakan blok try-catch berkali-kali dalam kode. Karena jika kita tidak menggunakan blok try-catch dan ada beberapa pengecualian atau kesalahan dalam program kita, maka eksekusi akan terhenti. Sedangkan jika kita menggunakan blok try catch dan jika terjadi error, maka blok catch menangani error tersebut. Baca lebih lanjut tentang itu di Tutorial Swift kami

Kode untuk Aplikasi Login / Logout

Mari kita pahami berbagai komponen dan kode yang digunakan untuk aplikasi login / logout.

Login Button Action - Kode berikut menjelaskan cara menambahkan aksi tombol login.

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 - Kode berikut menjelaskan cara menambahkan aksi tombol logout.

@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() - Kode berikut menjelaskan cara menggunakan fungsi 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") 
   } 
}

Ingat Anda harus membuat jalan keluar dan tindakan, untuk kedua tombol.

Sekarang, simpan dan jalankan aplikasi. Masuk, tutup aplikasi dan jalankan lagi. Ini akan terlihat sebagai berikut.

Hanya itu yang akan kita lakukan dengan CoreData. Dengan menggunakan konsep yang sama, kita dapat membangun banyak aplikasi CoreData.

Mengontrol Keyboard

Di bagian ini, kita akan belajar mengontrol perilaku keyboard. Misalnya - Saat kita mengklik di luar bidang teks setelah memasukkan beberapa teks, keyboard tidak menutup. Di sini, kami akan memahami cara mengontrol keyboard.

Keyboard akan menghilang saat mengklik di luar kolom input

Ini adalah tugas sederhana, untuk melakukannya cukup tempel kode berikut ke file viewController Anda, sebelum menutup tanda kurung kurawal.

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

Dengan melakukan ini, ini akan membuat keyboard menghilang saat mengklik di luar kolom input.

Keyboard akan hilang saat tombol kembali diketuk

Untuk menghilangkan keyboard, kita harus menambahkan Type baru untuk View Controller kita. Kami juga akan menambahkan bidang teks dan membuat outletnya yang disebut bidang teks. Terakhir, kami akan menambahkanUITextFieldDelegate.

Kami juga akan melakukannya control + drag dari bidang masukan kami ke pengontrol tampilan dan pilih delegasi dari opsi yang muncul.

Kemudian, kami akan menambahkan fungsi berikut.

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

File View Controller terakhir akan terlihat sebagai berikut -

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 
   } 
}

Mendownload Konten Web - Membuka Facebook / Google

Pada bagian ini, kita akan belajar tentang membuat aplikasi yang akan membuka Facebook dan Google ketika masing-masing tombol ditekan. Kita juga akan mempelajari konsep Tampilan Web dan Keamanan lapisan transportasi Aplikasi. Setelah ini, Anda akan dapat membuat browser Anda sendiri.

Note - Kami membutuhkan Koneksi Internet dalam aplikasi ini.

Membuat Aplikasi Web

Kami akan membuat aplikasi tampilan tunggal baru, proyek iOS. Di bilah Pencarian pustaka objek, kami akan mencari tampilan web, menyeretnya dan menambahkannya ke pengontrol Tampilan kami di main.Storyboard.

Setelah menambahkan tampilan web, kami akan merentangkannya ke semua sudut. UI Aplikasi akan terlihat seperti berikut -

Kami akan membuka main.storyboard dan melihat pengontrol dengan mengklik asisten editor. Kami akan membuat outlet untuk webView kami dan tindakan untuk kedua tombol. Saat dimuat, aplikasi akan memuat yahoo di webView. Saat mengklik google, Google akan dimuat, dan saat mengklik tombol Facebook, halaman Facebook akan dimuat.

Tampilan akhir akan terlihat sebagai berikut -

Tangkapan layar berikut menunjukkan bagaimana tampilan layar yang berbeda dari aplikasi kita seharusnya. Jika Anda mencoba membuka layanan web yang bukan https, itu akan menunjukkan kesalahan dan kami harus menambahkan pengecualian Keamanan Lapisan Transportasi Aplikasi di Andainfo.plist mengajukan.

Peta telah menjadi bagian dari kehidupan sehari-hari setiap orang. Mereka menjadi sangat berguna ketika kita bepergian ke suatu tempat atau mencari suatu tempat.

Mengintegrasikan Peta dan Menemukan Gerbang India

Kami akan membuat peta di aplikasi kami, yang akan menunjukkan kepada kami Gerbang India di tengah. Kami akan mempelajari peta dengan menerapkan dalam sebuah proyek. Jadi, buat aplikasi iOS tampilan tunggal dan beri nama apa pun yang Anda inginkan.

Menambahkan Tampilan Map Kit

Pergi ke perpustakaan objek dan cari tampilan kit peta, klik seret dan bawa ke tampilan Anda, rentangkan sehingga memenuhi tampilan lengkap.

Menambahkan Batasan

Buat outlet untuk mapViewKit dengan control + drag untuk melihat file controller.swift. Ini mungkin menunjukkan kesalahan sekarang, tetapi kami akan menanganinya. Di atas file, di bawah UIKIT impor, tambahkan impor MapKit, ini akan menghapus kesalahan.

Setelah itu, tambahkan MKMapViewDelegate setelah kelas ViewController: UIViewController. Sekarang, file tersebut akan terlihat seperti berikut -

Sekarang, kita akan membuat Garis Lintang dan Bujur, Delta, Span, Lokasi dan Wilayah untuk Peta kita. Sebelumnya kami akan memberi tahu Anda cara mendapatkan latitude dan longitude suatu tempat.

Buka maps.google.com dan cari beberapa lokasi. Di atas, kita akan melihat garis lintang dan bujurnya di URL. Contoh: Mari kita cari India Gate.

Mengatur Latitude dan Longitude

Setelah mendapatkan garis lintang dan bujur, kita akan membuat variabel untuk mereka.

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

Menetapkan Delta untuk Lintang dan Bujur

Setelah menambahkan garis lintang dan bujur, kami akan menambahkan delta untuk mereka, yang merupakan nilai yang dapat memverifikasi garis lintang dan bujur kami. Mereka harus dijaga seminimal mungkin untuk lebih banyak lokasi yang tepat.

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

Setting Span, Location dan Region untuk Map

Kemudian kita akan membuat Span, Location dan Region untuk peta kita.

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

Mengatur Peta

Kami akan mengatur peta dengan perintah berikut.

mapView.setRegion(region, animated: true)

Aplikasi terakhir kita akan terlihat seperti gambar yang ditunjukkan di bawah ini.

Kita harus berhati-hati bahwa set lokasi kita tepat di tengah aplikasi kita. Ini semua yang akan kita lakukan dengan peta sekarang.

Ketika kami membuat aplikasi iOS dan kami menambahkan Elemen UI di aplikasi itu, mereka mungkin tampak sempurna di satu perangkat. Namun demikian, sekarang kita harus mencoba aplikasi yang sama di beberapa perangkat lain. Kami pasti akan melihat perubahan drastis di UI dan beberapa elemen mungkin tidak muncul juga.

Tata letak otomatis adalah teknik yang akan kami gunakan untuk mengatasi masalah ini. Dalam bab ini, kita akan memahami cara membuat Tata Letak Otomatis, Menerapkan Batasan, dan Tampilan Tumpukan untuk membuat aplikasi Anda terlihat sempurna dan terbaik di setiap Perangkat.

Kita akan mulai dengan membuat aplikasi single view baru.

Menambahkan Elemen

Tambahkan label di tengah atas tampilan dan satu di kanan bawah tampilan seperti yang ditunjukkan di bawah ini -

Sekarang, coba ubah orientasi dan kita akan melihat bahwa kanan bawah tidak muncul, sedangkan Center tidak berada di tengah.

(Tip - Anda tidak perlu menjalankan simulator untuk melihat tata letak, cukup klik Lihat sebagai - iPhone x, di bagian bawah layar seperti yang ditunjukkan pada tangkapan layar berikut.)

Pilih versi iPhone dan orientasinya. Kita akan melihat bahwa elemen UI tidak tersusun dengan baik. Oleh karena itu, ketika kita mengubah orientasi, perangkat, atau keduanya, label kanan bawah akan hilang dan pusat tidak akan berada di tengah.

Ini terjadi karena kami belum menentukan posisi tetap untuk elemen. Untuk mengatasi ini, kami akan menggunakan Kendala.

Menerapkan Batasan ke Elemen UI

Klik pada Label Tengah, tekan kontrol dan seret ke mana saja di dalam tampilan, lepaskan. Sekarang Anda harus melihat -

Pilih Center Horizontally in Container. Sekali lagi, ulangi langkah di atas dan pilih, Vertical Spacing to Top Layout Guide.

Sekarang, klik pada tombol Add new constraint dan pilih tinggi dan lebar, dan klik Add 2 Constraints.

Klik di kanan bawah label, kontrol drag dari label ke mana saja di dalam tampilan, dan pilih "Trailing space to container Margin". Demikian pula pilih, Vertical spacing to Bottom layout Guide.

(Tip- Untuk memilih beberapa opsi sekaligus, tekan shift dan pilih opsi. Pastikan Anda tidak melepaskan shift sampai Anda memilih semuanya.)

Setelah menerapkan semua batasan, tampilan akan terlihat seperti berikut -

Tampilan Stack

Tampilan tumpukan bekerja dengan mengatur elemen dalam tumpukan. Setelah mengatur, kami mendefinisikan batasan hanya sekali, dan semua elemen diatur sesuai. Untuk memulai dengan tampilan tumpukan, buat tampilan berikut, yang tidak akan terlihat lebih baik di perangkat lain. Namun, kami akan membuatnya sesuai untuk perangkat lain di bagian ini.

Sekarang, pilih dua tombol teratas - pilih satu tombol, tekan perintah lalu pilih yang kedua. Untuk menyematkannya dalam tampilan tumpukan, buka editor → embed In → stack view.

OR

Di sudut kanan bawah, ada opsi

Pilih opsi ini dan ini akan menyematkan tampilan ke tampilan tumpukan.

Tampilan Tumpukan Horizontal

Tampilan Tumpukan Horizontal akan terlihat seperti yang ditunjukkan pada tangkapan layar berikut.

Saat tampilan tumpukan ini dipilih, buka inspektur atribut. Ubah Distribusi menjadi Isi Sama dan Spasi menjadi 10.

Sekarang, pilih tampilan tumpukan ini dan tombol bawah dan sematkan lagi ke tampilan tumpukan. Kali ini sumbu tampilan tumpukan akan vertikal, sedangkan pada tampilan tumpukan sebelumnya, adalah horizontal.

Tampilan Tumpukan Vertikal

Sekarang tampilan Anda akan terlihat seperti -

Saat tampilan tumpukan ini dipilih, buka inspektur atributnya dan pastikan cocok dengan tangkapan layar di bawah.

Sekarang, tampilan Anda akan terlihat sebagai berikut -

Langkah terakhir adalah membuat batasan untuk tampilan tumpukan ini.

Pilih tampilan tumpukan → Klik tombol tambahkan batasan baru.

Ini akan membuka jendela baru di mana kita harus mengikuti langkah-langkah yang ditunjukkan pada tangkapan layar berikutnya.

Menambahkan Batasan ke Stack View

Tangkapan layar berikut akan menjelaskan cara menambahkan batasan ke tampilan tumpukan.

Itu saja yang akan kami lakukan dengan tata letak otomatis. Pada bab selanjutnya, kita akan membahas tentang Animasi.

Itu saja yang akan kami lakukan dengan tata letak otomatis. Pada bab selanjutnya, kita akan membahas tentang Animasi.

Animasi adalah bagian penting dari Aplikasi apa pun karena menarik perhatian pengguna ke aplikasi. Animasi hanyalah kumpulan gambar yang berulang dengan kecepatan tinggi. Itu juga membuat aplikasi Anda berdiri berbeda dari yang lain.

Membuat Proyek Animasi - Animasi Kitty

Ini akan menjadi proyek sederhana, di mana kita akan menjalankan animasi saat tombol diklik. Kami akan menggunakan banyak gambar untuk membuat GIF, jadi unduh GIF apa pun dan konversikan menjadi gambar, yang akan memberi Anda banyak bingkai GIF itu.

Di bagian ini, kami akan menggunakan gambar berikut.

Gambar-gambar ini, saat diputar bersama, membuat animasi. Oleh karena itu, kami akan membuat aplikasi single view. Kami kemudian akan menyeret opsi tampilan gambar, label dan tombol di dalam pengontrol tampilan utama. Setelah ini selesai, kami akan menghubungkan tampilan gambar dan tombol ke file swift kami.

(Jika Anda tidak ingin menggunakan gambar-gambar ini, cari gif apa pun dan konversikan menjadi gambar online dengan menggunakan konverter gif ke gambar.)

Di dalam aksi tombol, kami akan memasukkan perintah berikut untuk menampilkan gambar saat tombol ditekan.

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

Ini adalah cara kami menetapkan gambar secara terprogram ke Tampilan Gambar. Tampilannya sekarang akan terlihat sebagai berikut -

Tampilan pertama akan muncul saat kita menjalankan aplikasi. Saat kita klik tombol Animate, gambar akan muncul.

Ini bukan animasi, tapi hanya gambar. Kami akan membuat animasi sekarang -

Tambahkan variabel di bawah outlet gambar: var counter = 1.

Lihat bahwa gambar kami memiliki nama yang sama dan hanya satu karakter yang berbeda. Ubah kode tombol animasi Anda seperti yang ditunjukkan di bawah ini -

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

Sekarang, saat Anda menekan animatetombol, gambar berubah setiap saat. Langkah selanjutnya adalah membuat yang berikut -

  • Buat variabel - isAnimating dan tetapkan False untuk itu.

  • Buat variabel timer dan tetapkan a Timer() berfungsi untuk itu.

Setelah dua langkah di atas selesai, buat fungsi animate dan paste kode berikut.

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

Dimana, counter adalah variabel counter yang kita buat di file sebelumnya. Sekarang, di dalam fungsi tombol animasi, tambahkan kode berikut -

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 
}

Coba jalankan aplikasi dan kita akan melihat bahwa animasi sedang dijalankan di perangkat Anda.

Challenge - Tambahkan tombol stop yang akan menghentikan animasi.

Dalam aplikasi kita, kita mungkin perlu terhubung ke API dan mengambil data dari API itu dan digunakan dalam aplikasi kita.

Pertama, kami membutuhkan URL, yang akan memberi kami data.

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

Setelah itu, kita perlu menambahkan pengecualian keamanan lapisan transport untuk memungkinkan aplikasi kita berkomunikasi ke layanan web, jika layanan tersebut bukan https. Kami akan membuat perubahan ini diinfo.plist mengajukan.

Terakhir, kami akan membuat URLSession untuk membuat permintaan jaringan.

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()

Ini adalah bagaimana Anda dapat Menggunakan layanan Web dalam aplikasi Anda menggunakan sesi URL.

Alamofire

Alamofire adalah pustaka jaringan HTTP yang ditulis dengan cepat. Ini dapat digunakan untuk membuat Permintaan URL, Memposting Data, Menerima Data, Mengunggah File, Data, Otentikasi, Validasi, dll.

Untuk menginstal Aalmofire, Anda dapat mengunjungi Alamofire secara resmi di GitHub , dan membaca panduan instalasi mereka

Membuat Permintaan di Alamofire

Untuk membuat permintaan di Alamofire, kita harus menggunakan perintah berikut.

Import Alamofire 
Alamofire.request("url");

Penanganan Respon

Perintah berikut digunakan untuk penanganan respons.

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)")   
   } 
}

Validasi Respon

Perintah berikut digunakan untuk penanganan respons.

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

Ini adalah dasar-dasar membuat permintaan URL, menggunakan Sesi URL dan Alamofire. Untuk Alamofire yang lebih maju, silakan kunjungi Dokumentasi Alamofire , dan Anda dapat membacanya secara detail.

Concurrency adalah cara untuk mengeksekusi lebih dari satu hal pada saat yang bersamaan. Dalam aplikasi, Concurrency mengacu pada beberapa tugas yang berjalan pada waktu yang sama / bersamaan.

Konkurensi dapat membuat aplikasi Anda lebih cepat, lebih bersih, dan memberikan pengalaman yang lebih baik kepada pengguna. Penggunaan multithreading tampaknya sulit bagi banyak pengembang, tetapi API seperti ituNSOperation dan Dispatch Queues memudahkan penggunaan konkurensi dan multi-threading dalam aplikasi.

Grand Central Dispatch

GCD adalah API yang paling umum digunakan untuk mengelola kode serentak dan menjalankan operasi secara asinkron di tingkat sistem. GCD menyediakan dan menggunakan antrian tugas. Antrian ini adalah struktur data yang menggunakan terminologi FIFO, yaitu tugas di tempat pertama dalam antrian akan dijalankan pertama kali dan tugas terakhir dari antrian akan dijalankan pada akhirnya.

Misalnya - Misalkan sebuah baris pemesanan tiket film, jika Anda adalah orang terakhir, Anda akan mendapatkan tiket terakhir, dan jika seseorang datang setelah Anda, dia akan mendapatkan tiket setelah Anda.

Antrian Pengiriman

Antrean pengiriman adalah cara mudah untuk melakukan tugas secara tidak bersamaan dan bersamaan dalam aplikasi Anda. Ada dua jenis antrian -

  • Serial Queues - Mereka menyimpan tugas secara seri dan menjalankan satu tugas dalam satu waktu.

  • Concurrent Queues - Mereka menyimpan tugas secara seri dan menjalankan satu tugas dalam satu waktu.

Beberapa fungsi yang digunakan untuk membuat atau mendapatkan antrian adalah -

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

Menambahkan Tugas ke Antrean

Ada dua jenis fungsi yang membantu dalam menambahkan tugas ke antrian. Mereka adalah -

Synchronous Functions -

  • dispatch_once - akan mengirimkan tugas hanya setelah selesai masa aplikasi.

  • dispatch_sync - akan mengirimkan tugas ke antrian dan kembali hanya setelah tugas selesai.

Asynchronous Functions -

  • Dispatch_async - akan menyerahkan tugas dan kembali.

  • Dispatch_after - segera kembali tetapi tertunda untuk waktu tertentu.

  • Dispatch_async - segera kembali tetapi tugas dikirim beberapa kali.

Kode Contoh

Berikut adalah contoh kode untuk menambahkan tugas ke antrian.

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

Contoh Umum menggunakan Antrian

Kode berikut adalah contoh penggunaan antrian.

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

Ini semua akan kami lakukan dengan kontrol konkurensi, karena ini adalah informasi yang cukup sampai Anda menjadi Pengembang iOS perantara.

Teruslah berlatih konsep-konsep yang telah Anda pelajari dan cobalah untuk memodifikasi dan mengintegrasikannya sesuai dengan kebutuhan Anda.