LoginSignup
11
1

More than 5 years have passed since last update.

【Swift】パラパラ漫画風アプリを作ってみた

Posted at

Swiftの勉強を始めました!何か作りながら学びたいと思い、簡単なアプリを作成しました。

【Swift】パラパラ漫画風アプリを作ろう!

目標

storyboardとviewControllerを扱うことで画像を配置した画面遷移を行うことができるアプリの作成!

工程

  1. プロジェクトの作成
  2. storyboardでレイアウト作成
  3. 画像ファイルの配置
  4. UIPageViewControllerの作成
  5. viewControllerの生成
  6. imageViewに画像を設定
  7. ページ遷移の操作
  8. 完成!

1.プロジェクトの作成

  • まずはプロジェクトを作成します。Single ViewAppを選択してください。 image.png

  • project_name名を設定します。好きな名前を付けてください。
    image.png

  • 今回は横向きにパラパラさせたいので、横画面指定にします。
    Device Orientationでportraitを外してください。
    image.png

2.storyboardでレイアウト作成

  • まずはレイアウトを作成します。Main.storyboardというファイルを開いてください。
    初期設定では縦になっているので、横配置設定に変更します。
    image.png

  • 画像を表示したい場所にImage Viewを設定します。
    右下に表示されるImage Viewをドラッグアンドドロップしてください。 image.png

  • Image Viewを画面の中央に配置します。
    右下のマークをクリックして水平と垂直の値を0に設定してください。
    image.png

  • Image Viewを画面いっぱいに配置したいので制約を追加します。
    上下左右の幅の値を0にしてください。 image.png

3.画像ファイルの配置

  • パラパラする画像を設定します。
    Assets.xcassetsというフォルダを開いて画像をセットしてください。
    image.png

  • storyboard上で指定した設定とviewController.swiftを紐付けます。
    まず画面右上にあるマークをクリックしてください。画面が二つに分かれます。
    次にstoryboard上のImage Viewで右クリックをします。
    New Referencing Outlet の横にある丸をコード上写真の位置までドラッグしてください。
    Nameを「imageView」としConnectボタンを押下すると以下のコードが追加されます。
    image.png
ViewController.swift
@IBOutlet weak var imageView: UIImageView!

4.UIPageViewControllerの作成

  • パラパラさせるためにstoryboard上にpageViewContorllerを配置します。
    pageViewContorllerはviewControllerを司っていてまとめるイメージです。
    詳しくは後述しますがめくりたい画像の分だけviewControllerを生成します。
    image.png

  • UIPageViewControllerのサブクラスであるPageViewControllerクラスを作成します。
    新しいファイルを作成してサブクラスを選択しクラス名を指定してください。
    image.png

  • 作成したstoryboard上のpageViewControllerとPageViewControllerクラスを紐付けます。
    右上のマークをクリックしてクラスにPageViewControllerを選択してください。
    image.png

5.viewControllerの生成

  • PageViewController.swifに後で使用する変数を定義します。
PageViewController.swift
import UIKit

class PageViewController: UIPageViewController {

//ページ番号
var viewControllerIndex : Int = 0  

//画像の名前を格納
let imageNames: [String] = ["kronosくん1", "kronosくん2", "kronosくん3", "kronosくん4","kronosくん5","kronosくん6"]  

//viewControllerを格納
var targetViewControllers : [UIViewController] = []
  • 続いてstoryboardのviewControllerをインスタンス化します。
PageViewController.swift
override func viewDidLoad() {
  super.viewDidLoad()

  // 表示用ViewControllerを生成(ここで画像分のviewControllerを生成)
  for i in 0..<imageNames.count {
    let viewController = UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "vc") as! ViewController

  //viewControllerを追加
    targetViewControllers.append(viewController)
  }
  // Do any additional setup after loading the view.
  self.setViewControllers([targetViewControllers[0]], direction: .forward, animated: true, completion: nil)

  //自身を格納
  self.dataSource = self

  }

6.imageViewに画像を設定

  • viewControllerの初期表示を設定します。
ViewController.swift

import UIKit

class ViewController: UIViewController {

@IBOutlet weak var imageView: UIImageView!

private var imageName: String?

override func viewDidLoad() {
    super.viewDidLoad()
    imageView.image = UIImage(named:"kronosくん1")
    guard let imageName = imageName else {
        return
    }
    imageView.image = UIImage(named: imageName)
}
  • 画像名を引数にして、画像を設定するメソッドを作成します。
ViewController.swift
//画像を設定する処理
func setImageName(_ imageName: String) {
    self.imageName = imageName
    if let _ = imageView {
      imageView.image = UIImage(named: imageName)
    }
  }
  • PageViewController.swiftでviewControllerを生成している箇所に画像を設定するメソッドを追加します。
PageViewController.swift
for i in 0..<imageNames.count {

        let viewController =  UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "vc") as! ViewController
        // ここで画像を設定    
        viewController.setImageName(imageNames[i])
        targetViewController.append(viewController)

        }

7.ページ遷移の操作

  • 最後にUIPageViewControllerDataSourceをextensionし、遷移後の処理を追加していきます。
PageViewController.swift
extension PageViewController : UIPageViewControllerDataSource {

    func pageViewController(_ pageViewController: UIPageViewController, viewControllerAfter viewController: UIViewController) -> UIViewController? {

        //左にスワイプ
        if viewControllerIndex == targetViewControllers.count - 1 {
            return nil
        } else {
            viewControllerIndex = viewControllerIndex + 1
        }

        return targetViewControllers[viewControllerIndex]
    }

    func pageViewController(_ pageViewController: UIPageViewController, viewControllerBefore viewController: UIViewController) -> UIViewController? {

        //右にスワイプ
        if viewControllerIndex == 0 {
            return nil
        } else {
            viewControllerIndex = viewControllerIndex - 1
        }

        return targetViewControllers[viewControllerIndex]
    }
}

8.完成!

行程は以上で終了です!実行してみると・・。
表情が変化するパラパラ漫画風アプリが完成しました!!
demo.gif

11
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
11
1