web-dev-qa-db-ja.com

UIActionSheet with swift

アクションシートを作成しましたが、デリゲートメソッドが呼び出されないという問題があります

 myActionSheet = UIActionSheet()
        myActionSheet.addButtonWithTitle("Add event")
        myActionSheet.addButtonWithTitle("close")
        myActionSheet.cancelButtonIndex = 1
        myActionSheet.showInView(self.view)

/// UIActionSheetDelegate

func actionSheet(myActionSheet: UIActionSheet!, clickedButtonAtIndex buttonIndex: Int){
        if(myActionSheet.tag == 1){

            if (buttonIndex == 0){
                println("the index is 0")
            }
        }
}

IOS 8ではうまく機能したが、iOS7では機能しなかった別の方法を使用しました。

var ActionSheet =  UIAlertController(title: "Add View", message: "", preferredStyle: UIAlertControllerStyle.ActionSheet)

ActionSheet.addAction(UIAlertAction(title: "Add event", style: UIAlertActionStyle.Default, handler:nil))

self.presentViewController(ActionSheet, animated: true, completion: nil)

問題を解決するためのアイデアはありますか?

10
moteb

アクションシートのデリゲートを設定することはありません。

myActionSheet = UIActionSheet()
myActionSheet.delegate = self
8
Ian Henry

Swift言語のUIActionSheet:-

CancelButtonとdestructiveButtonを含むアクションシート

uIActionSheetDelegateを設定します。

        let actionSheet = UIActionSheet(title: "ActionSheet", delegate: self, cancelButtonTitle: "Cancel", destructiveButtonTitle: "Done")
        actionSheet.showInView(self.view)

CancelButton、destructiveButton、otherButtonを含むアクションシート

        let actionSheet = UIActionSheet(title: "ActionSheet", delegate: self, cancelButtonTitle: "Cancel", destructiveButtonTitle: "Done", otherButtonTitles: "Yes", "No")
        actionSheet.showInView(self.view)

アクションシート機能を作成する

func actionSheet(actionSheet: UIActionSheet!, clickedButtonAtIndex buttonIndex: Int)
{
    switch buttonIndex{

    case 0:
        NSLog("Done");
        break;
    case 1:
        NSLog("Cancel");
        break;
    case 2:
        NSLog("Yes");
        break;
    case 3:
        NSLog("No");
        break;
    default:
        NSLog("Default");
        break;
        //Some code here..

 }
20
Anit Kumar

UIActionSheetはiOS8以降非推奨です。以下のバージョンをサポートする必要がない場合は、UIAlertControllerを使用することをお勧めします。

private func presentSettingsActionSheet() {
  let settingsActionSheet: UIAlertController = UIAlertController(title:nil, message:nil, preferredStyle:UIAlertControllerStyle.ActionSheet)
  settingsActionSheet.addAction(UIAlertAction(title:"Send Feedback", style:UIAlertActionStyle.Default, handler:{ action in
    self.presentFeedbackForm()
  }))
  settingsActionSheet.addAction(UIAlertAction(title:"Tell Me a Joke!", style:UIAlertActionStyle.Default, handler:{ action in
    self.presentRandomJoke()
  }))
  settingsActionSheet.addAction(UIAlertAction(title:"Cancel", style:UIAlertActionStyle.Cancel, handler:nil))
  presentViewController(settingsActionSheet, animated:true, completion:nil)
}

表示される内容は次のとおりです。

AlertViewController in Swift

14
Zorayr

Swift 3:

ボタンクリックでUIActionSheetを表示/開く場合は、yourViewControllerの単純で更新されたコードの下で使用されます:

//メソッドの定義:

func showPaymentModeActionSheet()  {

    // 1
    let optionMenu = UIAlertController(title: nil, message: "Choose Payment Mode", preferredStyle: .actionSheet)

    // 2
    let fullAction = UIAlertAction(title: "FULL", style: .default, handler: {
        (alert: UIAlertAction!) -> Void in
        self.mPaymentModeTextField.text = "FULL"

    })
    let addvanceAction = UIAlertAction(title: "ADVANCE", style: .default, handler: {
        (alert: UIAlertAction!) -> Void in
        self.mPaymentModeTextField.text = "ADVANCE"
    })

    //
    let cancelAction = UIAlertAction(title: "Cancel", style: .cancel, handler: {
        (alert: UIAlertAction!) -> Void in
    })


    // 4
    optionMenu.addAction(fullAction)
    optionMenu.addAction(addvanceAction)
    optionMenu.addAction(cancelAction)

    // 5
    self.present(optionMenu, animated: true, completion: nil)
}

//メソッド呼び出し:

@IBAction func actionOnPaymentModeButton(_ sender: Any) {
    // open action sheet
    showPaymentModeActionSheet()
}
0
Kiran jadhav