LoginSignup
100
100

More than 5 years have passed since last update.

iOSのUIライブラリ「PagingMenuController」の使い方

Last updated at Posted at 2015-11-24

結論 → xcodeにデフォルトで搭載されているsegmentedcontrolを使うより簡単じゃん!

Gunosy、SmartNewsの様なページ上部のタブをスワイプで切り替えることが出来るタブバーを簡単に導入することの出来るUIライブラリのPagingMenuControllerの使い方を紹介したいと思います。

Untitled.gif

PagingMenuControllerを導入する

ソースコードはGitHubに公開されています。
https://github.com/kitasuke/PagingMenuController

こちらからソースコードをダウンロードするかCocoaPodsからxcodeプロジェクトに追加してください。

source 'https://github.com/CocoaPods/Specs.git'
platform :ios, '8.0'
use_frameworks!

pod 'PagingMenuController'

swiftファイルでPagingMenuControllerを使う

import PagingMenuController

ViewControllerを作る

storyboardでViewControllerを3つ追加します。
プロジェクトに最初からあるViewController.swiftと同じ階層にPagingMenuController_1.swift、PagingMenuController_2.swift、PagingMenuController_3.swiftというファイルを作ります。

スクリーンショット 2015-11-24 23.50.27.png

次にstoryboardで作ったViewControllerそれぞれのCustom ClassとStoryboard IDPagingMenuController_1、PagingMenuController_2、PagingMenuController_3に変更します。

スクリーンショット 2015-11-25 0.49.00.png

スクリーンショット 2015-11-24 23.58.34.png

ViewController.swiftを編集する

ViewController.swift
import UIKit
import PagingMenuController

class ViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view, typically from a nib.


        //1ページ目で表示させるコントローラーを指定する
        let page_1 = self.storyboard?.instantiateViewControllerWithIdentifier("PagingMenuController_1") as! PagingMenuController_1
        page_1.title = "1ページ目"

        //2ページ目で表示させるコントローラーを指定する
        let page_2 = self.storyboard?.instantiateViewControllerWithIdentifier("PagingMenuController_2") as! PagingMenuController_2
        page_2.title = "2ページ目"

        //3ページ目で表示させるコントローラーを指定する
        let page_3 = self.storyboard?.instantiateViewControllerWithIdentifier("PagingMenuController_3") as! PagingMenuController_3
        page_3.title = "3ページ目"
        let viewControllers = [page_1, page_2, page_3]


        //表示オプション
        let options = PagingMenuOptions()   //オプションをインスタンス化

        //最初に表示させるページ番号
        options.defaultPage = 0

        //スワイプでページ間を移動させるか
        options.scrollEnabled = true

        //メニューバーの背景色
        options.backgroundColor = UIColor.whiteColor()

        //選択中のメニューバーの背景色
        options.selectedBackgroundColor = UIColor.whiteColor()

        //メニューのフォントサイズ
        options.font = UIFont.systemFontOfSize(14)

        //選択中のメニューのフォントサイズ
        options.selectedFont = UIFont.systemFontOfSize(14)

        //メニューの位置
        options.menuPosition = .Top

        //メニューの高さ
        options.menuHeight = 44

        //メニューのマージン
        options.menuItemMargin = 5

        //ページ移動をするときのアニメーションスピード
        options.animationDuration = 0.3

        //選択中のメニューの下線の色
        options.menuItemMode = .Underline(height: 3, color: UIColor.blackColor(), horizontalPadding: 0, verticalPadding: 0)

        //メニューの表示のされ方
        options.menuDisplayMode = .SegmentedControl


        let pagingMenuController = PagingMenuController(viewControllers: viewControllers, options: options)
        pagingMenuController.view.frame.origin.y += 20
        pagingMenuController.view.frame.size.height -= 20

        self.addChildViewController(pagingMenuController)
        self.view.addSubview(pagingMenuController.view)
        pagingMenuController.didMoveToParentViewController(self)
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }


}

表示オプションでメニューの背景色、フォントサイズ、位置を変更することが出来ます。

PagingMenuController_1.swift
class PagingMenuController_1: UIViewController {

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


}

PagingMenuController_1.swiftは何も書く必要がなければそのままでOKです。

Untitled.gif

出来上がりはこんな感じになります。
ぜひ使ってみてください!
この記事の内容に間違いや質問があればコメントをしていただけたらと思います!

100
100
3

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