質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.47%

  • Swift

    7496questions

    Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

  • Swift 2

    1334questions

    Swift 2は、Apple社が独自に開発を行っている言語「Swift」のアップグレード版です。iOSやOS X、さらにLinuxにも対応可能です。また、throws-catchベースのエラーハンドリングが追加されています。

Swiftでアクションシート表示後のシートをタップしても動作しない

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 3,151

eizi

score 5

ViewController.swiftに記載のボタンアクションで、別ファイル(ShareManager.swift)に記載したクラスからアクションシートを表示させ、シートをタップするとFacebook、Twitterをシェアするためのダイアログを表示させようとしているのですが、それが表示されません。

アクションシートを表示さるところまではうまく行ってます。

// ViewController.swift

import UIKit
import Social

class ViewController: UIViewController {
    @IBAction func btnShowAction(sender: AnyObject) {
        let showAction = shareManager().showActionSheet()
        presentViewController(showAction as! UIViewController, animated: true, completion: nil)
    }

    func showSNS(i: Int) {
        let dialog = shareManager().setSNS(i)
        // print(dialog)は返ってきてる
        presentViewController(dialog as! UIViewController, animated: true, completion: nil)
    }
    override func viewDidLoad() {
        super.viewDidLoad()
    }
}
// ShareManager.swift

import UIKit
import Social

class shareManager {
    func showActionSheet() -> AnyObject {
        let actionSheet = UIAlertController()
        actionSheet.addAction(
            UIAlertAction(title: "Facebook", style: .Default, handler: {(action) -> Void in
                ViewController().showSNS(0)
            })
        )
        actionSheet.addAction(
            UIAlertAction(title: "Twitter", style: .Default, handler: {(action) -> Void in
                ViewController().showSNS(1)
            })
        )
        actionSheet.addAction(
            UIAlertAction(title: "キャンセル", style: .Cancel, handler: nil)
        )
        return actionSheet
    }

    func setSNS(i: Int) -> AnyObject {
        var dialog = SLComposeViewController()
        switch i {
        case 0:
            dialog = SLComposeViewController(forServiceType: SLServiceTypeFacebook)
        case 1:
            dialog = SLComposeViewController(forServiceType: SLServiceTypeTwitter)
        default:
            break
        }
        dialog.setInitialText("共有するテキスト")
        return dialog
    }
}

下記のWarningが出てたのでネットで検索して

Warning: Attempt to present <SLComposeViewController: 0x1769f2f0> on <test.ViewController: 0x176dc240> whose view is not in the window hierarchy!

表示させるタイミングなのかと思って遅延処理を入れてみたのですが、それでもダメでした。

// ViewController.swift
        let delayTime = dispatch_time(DISPATCH_TIME_NOW, Int64(1 * Double(NSEC_PER_SEC)))
        dispatch_after(delayTime, dispatch_get_main_queue()) {
            self.presentViewController(dialog as! UIViewController, animated: true, completion: nil)
        }

環境
Xcode 7.3
Swift 2.2

まだまだ理解できていないこともありますが、よろしくお願いいたします。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

0

問題は
ViewController().showSNS(0)
です。
これはViewController()で新しいインスタンスのViewControllerを生成し、
その新しいViewControllerのshowSNS()を呼び出しています。
現在表示中でない新しいViewControllerを使って画面遷移しようとしているので、
「whose view is not in the window hierarchy!」
というエラーになっています。
現在表示中のViewControllerは、これとは別のViewControllerです。
その現在表示中のViewControllerを使って画面遷移する必要があります。

とりあえずshowActionSheet()showActionSheet(vc:ViewController)のように変更してViewControllerをパラメータで受け取れるようにした上で、ViewController().showSNS(0)vc.showSNS(0)とし、
let showAction = shareManager().showActionSheet(self)という形で呼び出せば、たぶんうまく表示できると思います。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/04/14 08:33

    なるほど、別のViewControllerを生成していたというわけですね。
    やはり理解できていなかったのですが、お陰様で頭の中がスッキリしました。

    教えて頂いた内容で無事に表示させることができました
    ありがとうございました!!

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.47%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • Swift

    7496questions

    Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

  • Swift 2

    1334questions

    Swift 2は、Apple社が独自に開発を行っている言語「Swift」のアップグレード版です。iOSやOS X、さらにLinuxにも対応可能です。また、throws-catchベースのエラーハンドリングが追加されています。